ZYNQ+Vivado2015.2系列(十五)AXI Timer 用户定时器中断控制LED

本文介绍了如何在ZYNQ+Vivado2015.2环境下,结合PS/PL资源创建一个系统,该系统通过AXI Timer进行中断控制,实现按键启动定时器关闭LED,定时器溢出后触发中断重新开启LED。文中详细阐述了硬件配置,包括添加Zynq核、AXI GPIO和AXI Timer,以及设置中断连接。软件部分涉及AXI GPIO和AXI Timer的初始化,中断处理函数的定义,并通过用户输入选择按键触发定时器中断。
摘要由CSDN通过智能技术生成

前面的中断学习中我们学了按键,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:

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值