ZYNQ系列学习GPIO实验
GPIO实验
一、实验原理
调用GPIO实现PS对引脚的控制
二、实验步骤
1、建立工程
这部分是ivado的操作内容,这里不做过多说明。
2、添加ZYNQ处理器IP
在左侧菜单栏中双击Create Block Design(bd为文件),在跳出的Diagram界面添加IP核processing_system7_0(点击中间的加号后输入zynq即可筛选出来)
3、配置IP核
勾选UART1用于调试,设置DDR用于下载,具体的配置方式根据相应的芯片做出设置。
4、添加两个GPIO与总线连接的IP核
AXI-GPIO核添加和内核添加类似,直接调用IP核的库就行。
5、设置输入与输出的GPIO-AXI核类型
输入:
输出:

6、自动连接和自动
在Diagram框内出现Run Block Automation 和 Run Connection Automation两个选项,先后再前,依次执行,得到的效果图·:

7、生成例化
在资源界面顶层文件右击》generate Productor,默认生成即可。再右击选择Create HDL wrapped即可得到自动例化的文件。
8、配置引脚
双击open elaborated design,打开引脚管理器IO ports(2019的默认在右下角),根据原理图选择管脚。注意使用开发板的管教电压。
9、综合映射生成bit文件
这里本来有三个个步骤,但是可以合在一起执行。直接点击左下角的generate Bitstream即可得到bit文件。这里需要比较长的时间,需要耐心等待。映射也是需要做的。
这里说明一下bit文件的作用。
生成好的bit文件可以在file》export中输出hardware,生成的hardware可以使用sdk或者vitis平台读取,形成自定义的硬件平台。换言之,截至到这一步,所有的硬件设备已经调用完成,不能再添加硬件设计了。下面的都是基于软件的设计,不能修改硬件。所以这里需要检查所有的硬件设计是否达标。由于这里设计简单,就不做仿真了,使用过的全是IP核,具有保障。
成功的标志是生成xsa文件。
这里总是出现licence不支持的情况,如果使用是下载的licence的话,到licence管理器中刷新后重启软件好像可以解决,不确定。
10、vitis读取硬件
在2019之前的版本使用的是SDK,可以自动调用,新出的vitis好像不行,需要自己引用文件。
11、新建application project
在file》new 》application project中新建一个文件。
需要更改的设置就是platform
这里的选择Create a new platform from hardware,使用添加(加号)选择vivado生成的xsa文件(默认位于工程目录下,在生成的时候可以自己设置)

还有就是在不熟悉软件的架构之前可以使用hello word 模板,可以有效缩短时间。
12、编写代码
找到主文件(工程名.c),写入代码。
由于这部分不做代码设计的实验,就先找了一份代码作为测试:
#include <stdio.h>
#include "platform.h"
#include "xparameters.h"
#include "xscugic.h"
#include "xil_exception.h"
#include "xgpio.h"
#include <unistd.h> // usleep()
#include <stdbool.h> // bool
#define LED_DEVICE_ID XPAR_AXI_GPIO_1_DEVICE_ID
#define KEY_DEVICE_ID XPAR_AXI_GPIO_0_DEVICE_ID
XGpio LEDInst;
XGpio KEYInst;
u8 key_value_pre=0;
u8 key_value_now=0;
int main()
{
init_platform();
int status;
status = XGpio_Initialize(&KEYInst, KEY_DEVICE_ID); // initial KEY
if(status != XST_SUCCESS) return XST_FAILURE;
status = XGpio_Initialize(&LEDInst, LED_DEVICE_ID); // initial LED
if(status != XST_SUCCESS)return XST_FAILURE;
XGpio_SetDataDirection(&KEYInst, 1, 1); // set KEY IO direction as in
XGpio_SetDataDirection(&LEDInst, 1, 0); // set LED IO direction as out
XGpio_DiscreteWrite(&LEDInst, 1, 0x0);// at initial, all LED turn off
printf(">>> Press PL KEY1 ~ KEY4 one by one, and check the PL LED1 ~ LED4\n");
while(1)
{
usleep(100000); // 0.1s sleep, to debounce, in common, the meta-state will sustain no more than 20ms
key_value_pre=key_value_now;
key_value_now= XGpio_DiscreteRead(&KEYInst, 1) & 0x0F;
XGpio_DiscreteWrite(&LEDInst, 1, key_value_now);
if(key_value_pre!=key_value_now) printf("key state_changed!\n");
}
cleanup_platform();
return 0;
}
注:以上代码源自小熊猫学堂
13、调试代码
首先要搭建该工程的调试环境,使用小锤子图标可以实现。
先debug编译,再运行。编译时选择板上编译。这两个操作就是对应调试虫和开始键,接触过的人就应该知道。由于这个设计中加入了串口,所以还要加入端口,端口设置就不用多说了,做过串口实验的就会。根据这个可以得到调试的结果。如果要下载的话则调用flash即可。
三、实验结果
串口显示结果:

开发板显示结果:
ZYNQ系列学习GPIO实验的更多相关文章
- S02_CH10_ User GPIO实验
S02_CH10_ User GPIO实验 在之前的第四章课程中,我们详细的讲解了如何在VIVADO软件下封装一个简单的流水灯程序.在ZYNQ开发过程中,有时候我们可能会需要与ARM硬核进行通信,在这 ...
- Cortex-M3学习日志(一)-- GPIO实验
因为项目所需,所以不得不开始研究M3,我用的是NXP公司的LPC1768这个芯片,它是具有三级流水线的哈佛结构,带独立的本地指令和数据总线以及用于外设的稍微低性能的第三条总线,还包含一个支持随机跳转的 ...
- S02_CH08_ ZYNQ 定时器中断实验
S02_CH08_ ZYNQ 定时器中断实验 上一章实现了PS接受来自PL的中断,本章将在ZYNQ的纯PS里实现私有定时器中断.每隔一秒中断一次,在中断函数里计数加1,通过串口打印输出. 8.1中断原 ...
- GPIO实验之c语言
上一章节进行实验使用的是汇编进行编程的,本次实验是使用c语言进行编写的. (1)点亮一个led灯 1)启动文件: crt.S .text .global _start _star ...
- Beaglebone Back学习四(GPIO实验)
GPIO Beaglebone Back开发板引出了92个引脚,其中只有65个GPIO口可通过配置使用,由于引脚具有“复用”的特性,大约每个引脚有8种工作模式(Beagle System Refere ...
- GPIO实验(二)
=============第三个实验============用c语言轮流点亮3个LED=================== 1.crt0.S.text.global _start_start: ...
- GPIO实验(一)
目标:点亮LED1.看原理图,找到对应的引脚和寄存器2.a.配置寄存器为输入/出引脚 GPFCON[9:8]=0b01 b.设置输出高/低电平 GPDAT[4]=0b0 1.预处理2.编 ...
- 02-JZ2440裸机学习之GPIO实验【转】
本文转载自:http://blog.csdn.net/fengyuwuzu0519/article/details/54910717 版权声明:本文为博主原创文章,转载请注明http://blog.c ...
- GPIO实验
一.目标:点亮led 1.看原理图:怎样点亮led 2.怎样GPF4输出0/1 a.配置功能 输出/输入/其他功能(中断或者其他) b.设置输出高电平/低电平 操作寄存器--->看芯片手册 A ...
- Vivado设计二:zynq的PS访问PL中的自带IP核(基于zybo)
1.建立工程 首先和Vivado设计一中一样,先建立工程(这部分就忽略了) 2.create block design 同样,Add IP 同样,也添加配置文件,这些都和设计一是一样的,没什么区别. ...
随机推荐
- java 注解结合 spring aop 实现日志traceId唯一标识
MDC 的必要性 日志框架 日志框架成熟的也比较多: slf4j log4j logback log4j2 我们没有必要重复造轮子,一般是建议和 slf4j 进行整合,便于后期替换为其他框架. 日志的 ...
- 【Unity3D】协同程序
1 简介 1)协程概念 协同程序(Coroutine)简称协程,是伴随主线程一起运行的程序片段,是一个能够暂停执行的函数,用于解决程序并行问题.协程是 C# 中的概念,由于 Unity3D 的 ...
- 【Unity3D】IK动画
1 IK简介 2D动画.人体模型及动画.人物跟随鼠标位置中介绍了 Aniamtion.Animator.人体模型.人体骨骼.人体动画等基础知识及人体动画的应用,本文将进一步介绍 IK 动画. ...
- Java集合框架学习(十) LinkedHashMap详解
LinkedHashMap介绍 1.Key和Value都允许null: 2.维护key的插入顺序: 3.非线程安全: 4.Key重复会覆盖.Value允许重复. 类定义 public class Li ...
- 在python中发送自定义消息
.py import win32api, win32con, win32gui import win32gui_struct import ctypes from ctypes import * GU ...
- TCP/IP的确认号,序列号和超时重传的学习笔记
一:确认应答和序列号 在tcp中,发送端的数据到达主机时,接收端会返回一个已收到的通知.这个消息叫做确认应答(ACK). 当发送端发送数据后,会等待对端的确认应答.如果有确认应答,说明数据已经成功到达 ...
- MyBaits查询MySQL日期类型结果相差8个小时
问题描述 在Java项目中使用MyBatis作为ORM框架,但是查询出的MySQL日期类型字段值总是比数据库表里的值多8个小时. 具体说明: MySQL数据库表字段类型为timestamp,映射的Ja ...
- 硬件开发笔记(七): 硬件开发基本流程,制作一个USB转RS232的模块(六):创建0603封装并关联原理图元器件
前言 有了原理图,可以设计硬件PCB,在设计PCB之间还有一个协同优先动作,就是映射封装,原理图库的元器件我们是自己设计的.为了更好的表述封装设计过程,本文描述了贴片电阻电容0603芯片封装,创建 ...
- 01、etcd基础介绍
互联网技术发展真的快,层出不穷的新技术.最近项目使用到了etcd,自己之前在部署k8s集群的时候玩过,但是并没有系统的学习.正好趁这个机会,系统性的学习下.文章中的内容有些是来自官方文档,有些是来自网 ...
- 隐私计算在释放万亿美元 SaaS 市场的重要作用
PrimiHub一款由密码学专家团队打造的开源隐私计算平台,专注于分享数据安全.密码学.联邦学习.同态加密等隐私计算领域的技术和内容. 过去十年间数字领域经历了一场颠覆性的转变.这一演变的前沿是软件即 ...