前面的中断学习中我们学了按键,GPIO,Timer,是时候把它们整合到一起了。今天我们混合使用PS/PL部分的资源,建立一个比较大的系统。
板子:zc702。
实现功能如下:
1.通过串口打印信息询问你要按SW5还是SW7;
2.当正确的按键被按下,定时器启动,关闭led DS23;
3.当定时器溢出后触发中断,开启DS23,系统回到1。
我们用一个AXI GPIO连接到SW5,EMIO连接SW7,MIO连接DS23(固定连接),定时器也使用PL的AXI Timer。
AXI Timer的主要特性:
硬件系统
1.添加zynq核,AXI GPIO,AXI Timer
2.打开zynq核的配置,使能UART 1,使能GPIO MIO,添加1 bit的EMIO GPIO,使能PL-PS中断IRQ_F2P
3.AXI GPIO宽度设为1
4.点击自动连接,所有都可以自动连接
5.将zynq的IRQ_F2P[0:0] 连接到AXI Timer的interrupt,点击zynq的GPIO_0 右键Make External ,点击输出的引脚可以修改信号名称
生成顶层文件:
添加约束
连接到两个按键,AXI GPIO连接到SW5,EMIO 连接到SW7
set_property PACKAGE_PIN G19 [get_ports {gpio_sw_tri_i[0]}]
set_property IOSTANDARD LVCMOS25 [get_ports {gpio_sw_tri_i[0]}]
set_property PACKAGE_PIN F19 [get_ports {gpio_0_tri_io[0]}]
set_property IOSTANDARD LVCMOS25 [get_ports {gpio_0_tri_io[0]}]
另外,LED DS 23连接在MIO 10: