【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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/312426.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

requestAnimationFrame 解析

文章目录 什么是 requestAnimationFrame为什么 setInterval 实现动画会有一些抖动感使用 requestAnimationFramerequestAnimationFrame 对比 setInterval 本文将给大家介绍一个使用 js 实现动画的利器&#xff0c;requestAnimationFrame&#xff0c;我们一般情况下&#xff0c;…

2013年AMC8数学竞赛中英文真题典型考题、考点分析和答案解析

“一元复始&#xff0c;万象更新。行而不辍&#xff0c;未来可期。” 努力学习和奋斗的时光总是过得飞快&#xff0c;不知不觉&#xff0c;2024年已经悄然而至&#xff0c;今天是2024年1月1日&#xff0c;六分成长祝所有的读者朋友和孩子们新年快乐&#xff01;学习进步&#…

【模拟电路】基础理论与实际应用

一、毫安时和毫瓦时 二、开关电路 三、继电器 四、半导体 五、二极管 六、三极管 七、三极管应用案例 一、毫安时和毫瓦时 毫安时&#xff08;mAh&#xff09;和毫瓦时&#xff08;mWh&#xff09;是两个不同的物理量&#xff0c;它们分别表示电量和能量的度量单位。下面的图…

LVS那点事

LVS 原理 IPVS LVS 的 IP 负载均衡技术是通过 IPVS 模块来实现的&#xff0c;IPVS 是 LVS 集群系统的核心软件&#xff0c;它的主要作用是&#xff1a;安装在 Director Server 上&#xff0c;同时在 Director Server 上虚拟出一个 IP 地址&#xff0c;用户必须通过这个虚拟的…

大华主动注册协议介绍

一、大华主动注册协议介绍 前面写了一篇文章&#xff0c;介绍一些设备通过大华主动注册协议接入到AS-V1000的文章&#xff0c;很多问我关于大华主动注册协议的相关知识。 由于大华主动注册协议是一种私有协议&#xff0c;通常不对外公开详细的协议规范和技术细节。因此…

[Angular] 笔记 25:指令

组件指令 (chatgpt 回答) 在 Angular 中&#xff0c;组件本身可以被视为指令&#xff0c;这种指令被称为组件指令。组件是 Angular 应用的构建块之一&#xff0c;它封装了一段具有特定功能和特性的用户界面&#xff0c;并且可以在应用中重复使用。 组件指令具有以下特征&…

学习SpringCloud微服务

SpringCloud 微服务单体框架微服务框架SpringCloud微服务拆分微服务差分原则拆分商品服务拆分购物车服务拆分用户服务拆分交易服务拆分支付服务服务调用RestTemplate远程调用 微服务拆分总结 服务治理注册中心Nacos注册中心服务注册服务发现 OpenFeign实现远程调用快速入门引入…

TiDB SQL调优案例TiFlash

背景 早上收到某系统的告警tidb节点挂掉无法访问&#xff0c;情况十万火急。登录中控机查了一下display信息&#xff0c;4个TiDB、Prometheus、Grafana全挂了&#xff0c;某台机器hang死无法连接&#xff0c;经过快速重启后集群恢复&#xff0c;经排查后是昨天上线的某个SQL导…

python安装MongoDB与运算符优先级

python安装MongoDB MongoDB 是目前最流行的 NoSQL 数据库之一&#xff0c;使用的数据类型 BSON&#xff08;类似 JSON&#xff09;。 PyMongo Python 要连接 MongoDB 需要 MongoDB 驱动&#xff0c;这里我们使用 PyMongo 驱动来连接。 pip 安装 pip 是一个通用的 Python 包…

HTTP小记2

目录 HTTP/1.1优化 QUIC协议 路由器 RTT&#xff08;Round-Trip Time&#xff09; 计算机网络体系结构 体系结构各层在整个过程中的作用 HTTP/1.1优化 1.通过缓存技术来避免/减少发送HTTP请求 2.减少HTTP请求的次数 将原本由客户端处理的重定向请求&#xff0c;交给代理…

面向对象基础-类与对象-封装

1、类与对象 1.1 概念 类&#xff1a;类是一个抽象的概念&#xff0c;用于描述一类对象的特点。 对象&#xff1a;根据类的概念所创造的实体。 【思考】一个对象可以没有对应的类嘛&#xff1f; 不可以&#xff0c;因为必须现有类才能创建对象。 1.2 类的内容 类中最基础的内容…

git(安装,常用命令,分支操作,gitee,IDEA集成git,IDEA集成gitee,IDEA集成github,远程仓库操作)

文章目录 1. Git概述1.1 何为版本控制1.2 为什么需要版本控制1.3 版本控制工具1.4 Git简史1.5 Git工作机制1.6 Git和代码托管中心 2. Git安装3. Git常用命令3.1 设置用户签名3.1.1 说明3.1.2 语法3.1.3 案例实操 3.2 初始化本地库3.2.1 基本语法3.2.2 案例实操3.2.3 结果查看 3…