【AMD Xilinx】ZUBoard(2):通过AXI GPIO控制PL端的管脚输出

2023-12-31 12:12

本文主要是介绍【AMD Xilinx】ZUBoard(2):通过AXI GPIO控制PL端的管脚输出,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【AMD Xilinx】ZUBoard(2):通过AXI GPIO控制PL端的管脚输出

  • 一、基本功能和流程
  • 二、Vivado工程
    • 1. 总体框图
    • 2. AXI GPIO相关部分
    • 3. 配置AXI GPIO
    • 4. 绑定管脚
      • 4.1 根据原理图查找对应管脚
        • 4.1.1 LED0
        • 4.1.2 LED1
      • 4.2 I/O Planning
    • 5. XDC
  • 三、ARM代码
    • 1. 地址空间
    • 2. 函数说明
    • 3. 实际的C代码实现
    • 4. 测试结果

一、基本功能和流程

前文导航
【AMD Xilinx】Avnet高性价比MPSoC评估板-ZUBoard(1):基本资料和开发流程

这篇讲解如何实现一个PL+PS结合的工程。虽然只是一个很简单的例子,但是涉及到arm裸机程序编写、调试、fpga开发、ip核配置、管脚分配、时序约束。能独立走完这个流程,就算是对MPSoC入门了。

要实现的功能大致如下:

  • ARM程序通过AXI总线给PL发送数据
  • AXI GPIO控制对应IO输出高低电平
  • 6个IO连接到两颗RGB三色LED,每3个IO一组,控制LED的R、G、B三种颜色的开关

二、Vivado工程

1. 总体框图

这个工程基于上一章介绍的zub1cg_sbc_base工程,整体框图如下。图片太大,分辨率问题看不太清,这里仅供参考。实际操作请打开Vivado查看。这次的例程我们只需要关注axi-gpio部分

在这里插入图片描述

2. AXI GPIO相关部分

在这里插入图片描述

3. 配置AXI GPIO

双击打开配置,设置为output,3根io输出则位宽设置为3位,初始值低电平,灯不亮。
注意下面有个GPIO2,后面在编程时会用到channel值,指的就是选择GPIO还是GPIO2
在这里插入图片描述

如果对于一个新ip如果不熟悉它的用法,点左上角的Documentation -> Product Guide就可以跳转到对应的文档
在这里插入图片描述

4. 绑定管脚

4.1 根据原理图查找对应管脚

4.1.1 LED0

根据原理图,D4对应的3个控制管脚分别是A7(Red) 、B6(Green)、 B5(Blue)
在这里插入图片描述

在这里插入图片描述

4.1.2 LED1

根据原理图,D5对应的3个控制管脚分别是B4(Red) 、A2(Green)、 F4(Blue)
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4.2 I/O Planning

在Layout-> I/O Planning

在这里插入图片描述

在这里插入图片描述

5. XDC

set_property IOSTANDARD LVCMOS18 [get_ports {rgb_led*}]set_property PACKAGE_PIN A7 [get_ports {rgb_led_0_tri_o[0]}]; # HD_GPIO_RGB1_R 
set_property PACKAGE_PIN B6 [get_ports {rgb_led_0_tri_o[1]}]; # HD_GPIO_RGB1_G 
set_property PACKAGE_PIN B5 [get_ports {rgb_led_0_tri_o[2]}]; # HD_GPIO_RGB1_B set_property PACKAGE_PIN B4 [get_ports {rgb_led_1_tri_o[0]}]; # HP_GPIO_RGB2_R 
set_property PACKAGE_PIN A2 [get_ports {rgb_led_1_tri_o[1]}]; # HP_GPIO_RGB2_G 
set_property PACKAGE_PIN F4 [get_ports {rgb_led_1_tri_o[2]}]; # HP_GPIO_RGB2_B 

三、ARM代码

1. 地址空间

对于ARM来说,PL端的AXI GPIO就是一段地址空间,通过读写这段地址来实现对PL管脚的控制
在这里插入图片描述
我们配置的rgb_led0和rgb_led1分别对应地址axi_gpio_0和axi_gpio_1

对应的C代码的宏定义在xparameters.h里面
在这里插入图片描述

2. 函数说明

初始化gpio
int XGpio_Initialize(XGpio * InstancePtr, u16 DeviceId)

设置IO输入还是输出
void XGpio_SetDataDirection(XGpio *InstancePtr, unsigned Channel,
u32 DirectionMask)
设置为高
void XGpio_DiscreteWrite(XGpio * InstancePtr, unsigned Channel, u32 Mask)

设置为低
void XGpio_DiscreteClear(XGpio * InstancePtr, unsigned Channel, u32 Mask)

在bsp页面,点击对应外设后面的Documentation Link,就可以跳转到对应的API说明文档
在这里插入图片描述

3. 实际的C代码实现

先用hello world模板创建一个新工程,把下面的代码复制进去

#include <stdio.h>
#include "platform.h"
#include "xil_printf.h"#include "sleep.h"
#include "xgpio.h"//RGB三色灯的颜色值,有红绿黄3种单色,还有紫色、黄色、青色、白色4种组合色。总共可以显示7种颜色
#define LED 0x07
#define LED_RED 0x01
#define LED_GREEN 0x02
#define LED_BLUE 0x04#define LED_PURPLE (LED_RED | LED_BLUE)
#define LED_YELLOW (LED_RED | LED_GREEN)
#define LED_CYAN   (LED_GREEN | LED_BLUE)
#define LED_WHITE  (LED_RED | LED_GREEN | LED_BLUE)//Gpio信息
XGpio Gpio[2];//两路LED对应的设置ID
int Gpio_led_rgb_device_id[2] = {XPAR_GPIO_0_DEVICE_ID,XPAR_GPIO_1_DEVICE_ID
};//两路LED对应的通道ID,前面有提过,单通道填1,如果是GPIO2则填2
int led_rgb_channel[2] = {1, 1};void delay_ms(int ms)
{usleep(ms * 1000L);
}int main()
{int Status;int led_out;int i;int j;int count;init_platform();for(i = 0; i < 2; i++){//初始化GPIOStatus = XGpio_Initialize(&Gpio[i], Gpio_led_rgb_device_id[i]);if (Status != XST_SUCCESS) {xil_printf("Gpio Initialization Failed\r\n");return XST_FAILURE;}//bit 0为输出,1为输入。这里把除LED外的其他IO设置为输入XGpio_SetDataDirection(&Gpio[i], led_rgb_channel[i], ~LED);}count = 0;while (1) {//两个3色LED灯,每个灯有3种颜色,每种颜色点亮一次。灯1红绿蓝,灯2红绿蓝,共6次for(i = 0; i < 2; i++) {led_out = 1;for(j = 0; j < 3; j++) {xil_printf("count=%d  LED%d led=0x%.2X\n\r", ++count, i, led_out);//打印日志,用来判断是否在运行XGpio_DiscreteWrite(&Gpio[i], led_rgb_channel[i], led_out);//点亮delay_ms(500);XGpio_DiscreteClear(&Gpio[i], led_rgb_channel[i], led_out);//熄灭delay_ms(500);led_out <<= 1;}}}//实际并不会执行到这里print("Successfully ran Hello World application");cleanup_platform();return 0;
}

然后debug运行即可

4. 测试结果

运行结果如视频所示,灯1红绿蓝依次亮500ms,然后是灯2红绿蓝,总共6秒一个循环。
这样就实现了一个用arm端的C代码控制fpga端gpio的案例

axi_gpio_led_rgb_test

这篇关于【AMD Xilinx】ZUBoard(2):通过AXI GPIO控制PL端的管脚输出的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/555999

相关文章

浅析如何使用Swagger生成带权限控制的API文档

《浅析如何使用Swagger生成带权限控制的API文档》当涉及到权限控制时,如何生成既安全又详细的API文档就成了一个关键问题,所以这篇文章小编就来和大家好好聊聊如何用Swagger来生成带有... 目录准备工作配置 Swagger权限控制给 API 加上权限注解查看文档注意事项在咱们的开发工作里,API

Spring IOC控制反转的实现解析

《SpringIOC控制反转的实现解析》:本文主要介绍SpringIOC控制反转的实现,IOC是Spring的核心思想之一,它通过将对象的创建、依赖注入和生命周期管理交给容器来实现解耦,使开发者... 目录1. IOC的基本概念1.1 什么是IOC1.2 IOC与DI的关系2. IOC的设计目标3. IOC

使用TomCat,service输出台出现乱码的解决

《使用TomCat,service输出台出现乱码的解决》本文介绍了解决Tomcat服务输出台中文乱码问题的两种方法,第一种方法是修改`logging.properties`文件中的`prefix`和`... 目录使用TomCat,service输出台出现乱码问题1解决方案问题2解决方案总结使用TomCat,

C++中实现调试日志输出

《C++中实现调试日志输出》在C++编程中,调试日志对于定位问题和优化代码至关重要,本文将介绍几种常用的调试日志输出方法,并教你如何在日志中添加时间戳,希望对大家有所帮助... 目录1. 使用 #ifdef _DEBUG 宏2. 加入时间戳:精确到毫秒3.Windows 和 MFC 中的调试日志方法MFC

Python使用Colorama库美化终端输出的操作示例

《Python使用Colorama库美化终端输出的操作示例》在开发命令行工具或调试程序时,我们可能会希望通过颜色来区分重要信息,比如警告、错误、提示等,而Colorama是一个简单易用的Python库... 目录python Colorama 库详解:终端输出美化的神器1. Colorama 是什么?2.

Python实现局域网远程控制电脑

《Python实现局域网远程控制电脑》这篇文章主要为大家详细介绍了如何利用Python编写一个工具,可以实现远程控制局域网电脑关机,重启,注销等功能,感兴趣的小伙伴可以参考一下... 目录1.简介2. 运行效果3. 1.0版本相关源码服务端server.py客户端client.py4. 2.0版本相关源码1

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

顺序表之创建,判满,插入,输出

文章目录 🍊自我介绍🍊创建一个空的顺序表,为结构体在堆区分配空间🍊插入数据🍊输出数据🍊判断顺序表是否满了,满了返回值1,否则返回0🍊main函数 你的点赞评论就是对博主最大的鼓励 当然喜欢的小伙伴可以:点赞+关注+评论+收藏(一键四连)哦~ 🍊自我介绍   Hello,大家好,我是小珑也要变强(也是小珑),我是易编程·终身成长社群的一名“创始团队·嘉宾”

AI(文生语音)-TTS 技术线路探索学习:从拼接式参数化方法到Tacotron端到端输出

AI(文生语音)-TTS 技术线路探索学习:从拼接式参数化方法到Tacotron端到端输出 在数字化时代,文本到语音(Text-to-Speech, TTS)技术已成为人机交互的关键桥梁,无论是为视障人士提供辅助阅读,还是为智能助手注入声音的灵魂,TTS 技术都扮演着至关重要的角色。从最初的拼接式方法到参数化技术,再到现今的深度学习解决方案,TTS 技术经历了一段长足的进步。这篇文章将带您穿越时

控制反转 的种类

之前对控制反转的定义和解释都不是很清晰。最近翻书发现在《Pro Spring 5》(免费电子版在文章最后)有一段非常不错的解释。记录一下,有道翻译贴出来方便查看。如有请直接跳过中文,看后面的原文。 控制反转的类型 控制反转的类型您可能想知道为什么有两种类型的IoC,以及为什么这些类型被进一步划分为不同的实现。这个问题似乎没有明确的答案;当然,不同的类型提供了一定程度的灵活性,但