本篇文章主要介绍外设(PL)产生的中断请求,在PS端进行处理。
在PL端通过按键产生中断,PS接受到之后点亮相应的LED.

本文所使用的开发板是Miz702 PC 开发环境版本:Vivado 2015.4 Xilinx SDK 2015.4

13.0本章难度系数★★☆☆☆☆☆

13.1 ZYNQ 中断介绍

13.1.1 ZYNQ中断框图

可以看到本例子中PL到PS部分的中断经过ICD控制器分发后后同时进入CPU1 和CPU0。从下面的表格中可以看到中断向量的具体值。PL到PS部分一共有20个中断可以使用。其中4个是快速中断。剩余的16个是本章中涉及了,可以任意定义。如下表所示。

13.1.2 ZYNQ CPU软件中断 (SGI)

ZYNQ 2个CPU 都具备各自16个软件中断。

13.1.3 ZYNQ CPU 私有端口中断

这些中断都是固定死的,不能修改。这里有2个PL到CPU的快速中断nFIQ


11.1.4 ZYNQ PS和PL共享中断


13.2 搭建硬件工程

Step1:新建一个名为为Miz702_sys的工程

Step2:选择RTL Project 勾选Do not specify source at this time

Step3:由于Miz702兼容zedboard 因此选择zedboard开发包

Step4:单击Finish

13.3使用IP Integrator创建硬件系统

Step1:单击Create Block Design

Step2:输入system

Step3:单击下图中添加IP按钮

Step4:搜素单词z选择ZYNQ7 Processing System,然后双击

Step5:添加进来了ZYNQ CPU IP,然后单击Run Block Automation

Step6:直接单击OK

Step7:在你点击了OK后,你会发现DDR以及FICED_IO自劢的延伸出来。

Step8:连线的作用就是把PS的时钟可以接入PL部分,当然这里我们暂时用不到PL部分的资源。在Block文件中,我们迚行连线,将鼠标放在引脚处,鼠标变成铅笔后迚行拖拽,连线如下图所示:

Step9:双击 ZYNQ,打开Re-customize IP对话框,使能IRQ_F2P

Step10:使能UART1点击Run Connection Automation,按照如图所示配置后单击OK

Step11:添加一个GPIO IP,添加5个输入,按照如图所示配置,使能中断

Step12:再添加一个GPIO IP,添加8个输出按照如图所示配置,点击OK

Step13:单击Run Connection Automation,将2个GPIO进行自动连线

Step14:把axi_gpio_0的ip2intc_irpt和ZYNQ PS的 IRQ_F2P[0:0]连在一起,并且修改GPIO的名字如图所示:搭建好的硬件系统连接,如图所示

Step15: 右击 system.bd, 单击Generate Output Products

Step16:支部操作会产生执行、仿真、综合的文件

Step17:右击system.bd 选择 Create HDL Wrapper 这步的作用是产生顶层的HDL文件

Step18:选择Leave Let Vivado manager wrapper and auto-update 然后单击OK

Step19:添加xdc约束文件

set_property IOSTANDARD LVCMOS33 [get_ports {btns_5bits_tri_i[4]}]

set_property IOSTANDARD LVCMOS33 [get_ports {btns_5bits_tri_i[3]}]

set_property IOSTANDARD LVCMOS33 [get_ports {btns_5bits_tri_i[2]}]

set_property IOSTANDARD LVCMOS33 [get_ports {btns_5bits_tri_i[1]}]

set_property IOSTANDARD LVCMOS33 [get_ports {btns_5bits_tri_i[0]}]

set_property IOSTANDARD LVCMOS33 [get_ports {leds_8bits_tri_o[0]}]

set_property IOSTANDARD LVCMOS33 [get_ports {leds_8bits_tri_o[1]}]

set_property IOSTANDARD LVCMOS33 [get_ports {leds_8bits_tri_o[2]}]

set_property IOSTANDARD LVCMOS33 [get_ports {leds_8bits_tri_o[3]}]

set_property IOSTANDARD LVCMOS33 [get_ports {leds_8bits_tri_o[4]}]

set_property IOSTANDARD LVCMOS33 [get_ports {leds_8bits_tri_o[5]}]

set_property IOSTANDARD LVCMOS33 [get_ports {leds_8bits_tri_o[6]}]

set_property IOSTANDARD LVCMOS33 [get_ports {leds_8bits_tri_o[7]}]

set_property PACKAGE_PIN T18 [get_ports {btns_5bits_tri_i[0]}]

set_property PACKAGE_PIN R18 [get_ports {btns_5bits_tri_i[1]}]

set_property PACKAGE_PIN R16 [get_ports {btns_5bits_tri_i[2]}]

set_property PACKAGE_PIN P16 [get_ports {btns_5bits_tri_i[3]}]

set_property PACKAGE_PIN N15 [get_ports {btns_5bits_tri_i[4]}]

set_property PACKAGE_PIN T22 [get_ports {leds_8bits_tri_o[0]}]

set_property PACKAGE_PIN T21 [get_ports {leds_8bits_tri_o[1]}]

set_property PACKAGE_PIN U22 [get_ports {leds_8bits_tri_o[2]}]

set_property PACKAGE_PIN U21 [get_ports {leds_8bits_tri_o[3]}]

set_property PACKAGE_PIN V22 [get_ports {leds_8bits_tri_o[4]}]

set_property PACKAGE_PIN W22 [get_ports {leds_8bits_tri_o[5]}]

set_property PACKAGE_PIN U19 [get_ports {leds_8bits_tri_o[6]}]

set_property PACKAGE_PIN U14 [get_ports {leds_8bits_tri_o[7]}]

Step19:执行->产生bit文件

13.4导出SOC硬件到SDK

Step1:File->Export->Export Hardware

Step2:勾选Include bitstream 直接单击OK

Step3:File->Launch SDK加载到SDK

Step4:单击OK

13.5软件工程

新建一个PL_PS_INTC空的工程,并且添加main.c把以下代码添加进去

#include "xparameters.h"

#include "xscugic.h"

#include "xil_exception.h"

#include "xgpio.h"

// Parameter definitions

#define INTC_DEVICE_ID      XPAR_PS7_SCUGIC_0_DEVICE_ID

#define LED_DEVICE_ID       XPAR_AXI_GPIO_1_DEVICE_ID

#define BTNS_DEVICE_ID      XPAR_AXI_GPIO_0_DEVICE_ID

#define INTC_GPIO_INTERRUPT_ID XPAR_FABRIC_AXI_GPIO_0_IP2INTC_IRPT_INTR

#define BTN_INT             XGPIO_IR_CH1_MASK // This is the interrupt mask for channel one

#define DELAY 100000000

XGpio   LED;

XGpio   BTNInst;

XScuGic INTCInst;

static u8 btn_value;

//----------------------------------------------------

// PROTOTYPE FUNCTIONS

//----------------------------------------------------

static void BTN_Intr_Handler(void *baseaddr_p);

static int InterruptSystemSetup(XScuGic *XScuGicInstancePtr);

static int IntcInitFunction(u16 DeviceId, XGpio *GpioInstancePtr);

//----------------------------------------------------

//  INTERRUPT SERVICE ROUTINE(ISR)

//also know as : INTERRUPT HANDLER FUNCTION

// - called by the buttons interrupt, performs push buttons read

//----------------------------------------------------

void BTN_Intr_Handler(void *InstancePtr)

{

unsigned char led_val = 0;

// Ignore additional button presses

if ((XGpio_InterruptGetStatus(&BTNInst) & BTN_INT) !=

            BTN_INT) {

return;

// Disable GPIO interrupts

    XGpio_InterruptDisable(&BTNInst, BTN_INT);

             }

    btn_value = ~XGpio_DiscreteRead(&BTNInst, 1)&0x1f;

switch (btn_value){

case 0x01: led_val = 0x01; break;

case 0x02: led_val = 0x02; break;

case 0x04: led_val = 0x04; break;

case 0x08: led_val = 0x08; break;

case 0x10: led_val = 0x10; break;

default:break;  }

    XGpio_DiscreteWrite(&LED,1,led_val);

// Acknowledge GPIO interrupts

    (void)XGpio_InterruptClear(&BTNInst, BTN_INT);

// Enable GPIO interrupts

    XGpio_InterruptEnable(&BTNInst, BTN_INT);

}

//----------------------------------------------------

// MAIN FUNCTION

//----------------------------------------------------

int main (void)

{

int status;

// 初始化按键

  status = XGpio_Initialize(&BTNInst, BTNS_DEVICE_ID);

if(status != XST_SUCCESS) return XST_FAILURE;

//初始化LED

  status = XGpio_Initialize(&LED, LED_DEVICE_ID);

if(status != XST_SUCCESS) return XST_FAILURE;

// 设置按键IO的方向为输入

  XGpio_SetDataDirection(&BTNInst, 1, 0xFF);

//设置LED IO的方向为输出

  XGpio_SetDataDirection(&LED, 1, 0x00);

// 初始化中断控制器

  status = IntcInitFunction(INTC_DEVICE_ID, &BTNInst);

if(status != XST_SUCCESS) return XST_FAILURE;

while(1){

  }

return (0);

}

//----------------------------------------------------

// INTERRUPT SETUP FUNCTIONS

//----------------------------------------------------

int IntcInitFunction(u16 DeviceId, XGpio *GpioInstancePtr)

{

XScuGic_Config *IntcConfig;

int status;

// Interrupt controller initialization

    IntcConfig = XScuGic_LookupConfig(DeviceId);

    status = XScuGic_CfgInitialize(&INTCInst, IntcConfig, IntcConfig->CpuBaseAddress);

if(status != XST_SUCCESS) return XST_FAILURE;

// Call interrupt setup function

    status = InterruptSystemSetup(&INTCInst);

if(status != XST_SUCCESS) return XST_FAILURE;

// Register GPIO interrupt handler

    status = XScuGic_Connect(&INTCInst,

                             INTC_GPIO_INTERRUPT_ID,

                             (Xil_ExceptionHandler)BTN_Intr_Handler,

                             (void *)GpioInstancePtr);

if(status != XST_SUCCESS) return XST_FAILURE;

// Enable GPIO interrupts

    XGpio_InterruptEnable(GpioInstancePtr, 1);

    XGpio_InterruptGlobalEnable(GpioInstancePtr);

// Enable GPIO interrupts in the controller

    XScuGic_Enable(&INTCInst, INTC_GPIO_INTERRUPT_ID);

return XST_SUCCESS;

}

int InterruptSystemSetup(XScuGic *XScuGicInstancePtr)

{

// Register GIC interrupt handler

    Xil_ExceptionRegisterHandler(XIL_EXCEPTION_ID_INT,

                                 (Xil_ExceptionHandler)XScuGic_InterruptHandler,

                                 XScuGicInstancePtr);

    Xil_ExceptionEnable();

return XST_SUCCESS;

}

13.6结果

下载好之后,按键按下可以看到相应的LED被点亮

13.7 本章小结

本章学习了外部中断,通过PL传递开发板按键的中断,然后在PS接受处理中断。

淘宝店铺:https://osrc.taobao.com

官网论坛:www.osrc.cn

视频链接:http://www.osrc.cn/forum.php?mod=viewthread&tid=1103

源码链接:http://pan.baidu.com/s/1jHCdRds 密码:zvtu

第十三章 ZYNQ-MIZ702 PL中断请求的更多相关文章

  1. S02_CH07_ ZYNQ PL中断请求

    S02_CH07_ ZYNQ PL中断请求 7.1 ZYNQ 中断介绍 7.1.1 ZYNQ中断框图 可以看到本例子中PL到PS部分的中断经过ICD控制器分发器后同时进入CPU1 和CPU0.从下面的 ...

  2. PRML读书会第十三章 Sequential Data(Hidden Markov Models,HMM)

    主讲人 张巍 (新浪微博: @张巍_ISCAS) 软件所-张巍<zh3f@qq.com> 19:01:27 我们开始吧,十三章是关于序列数据,现实中很多数据是有前后关系的,例如语音或者DN ...

  3. <构建之法>第十三章到十七章有感以及这个项目读后感

    <构建之法>第十三章到十七章有感 第13章:软件测试方法有哪些? 主要讲了软件测试方法:要说有什么问题就是哪种效率最高? 第14章:质量保障 软件的质量指标是什么?怎么样能够提升软件的质量 ...

  4. 《Linux命令行与shell脚本编程大全》 第二十三章 学习笔记

    第二十三章:使用数据库 MySQL数据库 MySQL客户端界面 mysql命令行参数 参数 描述 -A 禁用自动重新生成哈希表 -b 禁用 出错后的beep声 -B 不使用历史文件 -C 压缩客户端和 ...

  5. 《Android群英传》读书笔记 (5) 第十一章 搭建云端服务器 + 第十二章 Android 5.X新特性详解 + 第十三章 Android实例提高

    第十一章 搭建云端服务器 该章主要介绍了移动后端服务的概念以及Bmob的使用,比较简单,所以略过不总结. 第十三章 Android实例提高 该章主要介绍了拼图游戏和2048的小项目实例,主要是代码,所 ...

  6. Gradle 1.12 翻译——第十三章 编写构建脚本

    有关其它已翻译的章节请关注Github上的项目:https://github.com/msdx/gradledoc/tree/1.12,或訪问:http://gradledoc.qiniudn.com ...

  7. [汇编学习笔记][第十三章int指令]

    第十三章int指令 13.1 int指令 格式: int n, n 为中断类型码 可以用int指令调用任何一个中断的中断处理程序(简称中断例程). 13.4 BIOS和DOS 所提供的中断例程 BIO ...

  8. perl5 第十三章 Perl的面向对象编程

    第十三章 Perl的面向对象编程 by flamephoenix 一.模块简介二.Perl中的类三.创建类四.构造函数 实例变量 五.方法六.方法的输出七.方法的调用八.重载九.析构函数十.继承十一. ...

  9. 第十三章——表和索引分区(1)——使用Range Left进行表分区

    原文:第十三章--表和索引分区(1)--使用Range Left进行表分区 前言: 如果数据表的数据持续增长,并且表中的数据量已经达到数十亿甚至更多,数据的查询和操作将非常困难,面对非常庞大的表,几时 ...

  10. CSS3秘笈复习:十三章&十四章&十五章&十六章&十七章

    第十三章 1.在使用浮动时,源代码的顺序非常重要.浮动元素的HTML必须处在要包围它的元素的HTML之前. 2.清楚浮动: (1).在外围div的底部添加一个清除元素:clear属性可以防止元素包围浮 ...

随机推荐

  1. abd shell pm list packages

    abd shell pm list packages ####查看当前连接设备或者虚拟机的所有包 adb shell pm list packages -d #####只输出禁用的包. adb she ...

  2. spring配置hibernate在使用oracle驱动时报错Cannot load JDBC driver class 'oracle.jdbc.driver.OracleDriver '

    在看到这个错误的时候就感觉有点不对劲了,在错误的结尾和引号之间还有空间,如果敏锐的点应该察觉到可能是空格问题.由于本人的粗心导致这个问题一直困扰了我接近一个上午. 在排查这个问题的时候首先想到的就是关 ...

  3. 002-多线程-JUC集合-List-CopyOnWriteArrayList

    一.概述 CopyOnWriteArrayList是Java并发包中提供的一个并发容器,它是个线程安全且读操作无锁的ArrayList,写操作则通过创建底层数组的新副本来实现,是一种读写分离的并发策略 ...

  4. Oracle查询表和字段

    查看表字段.类型.注释 SELECT A.COLUMN_NAME,B.comments,A.DATA_TYPE FROM USER_TAB_COLUMNS A LEFT JOIN user_col_c ...

  5. Java8 根据对象某个属性值去重

    list中的对象某个属性存在重复时将重复的对象去重 //根据skuAttrValueName值去重 List<SkuValue> uniqueSkuValues = skuValues.s ...

  6. 灵活配置tomcat根目录网站

    <Host name="localhost" appBase="webapps" unpackWARs="true" autoDepl ...

  7. 总是访问到tomcat首页解决

    部署代码后总是访问到tomcat首页解决 没有把路径写全 访问:养成带上绝对路径的习惯,否则总是访问到tomcat的首页 http://114.116.65.232:8085/ssoserver/

  8. VMware虚拟机下CentOS 6.5配置网络

    使用NAT模式 虚拟机网络连接使用NAT模式,物理机网络连接使用Vmnet8. 虚拟机设置里面——网络适配器,网络连接选择自定义:Vmnet8 (NAT模式) 虚拟机菜单栏—编辑—虚拟网络编辑器,选择 ...

  9. iOS-同步下载与异步下载

    一.同步下载(交互不好,容易出现卡死现象,一般下载数据较小或有特定需求才使用). 发送同步请求后,程序将停止用户交互,直到服务器返回数据完成后,才进行下一步的操作. //第一步:创建URL NSURL ...

  10. JS遍历数组,实现数组去重(重复的元素只保留一个)

    1.遍历数组法 它是最简单的数组去重方法(indexOf方法) 实现思路:新建一个数组,遍历去要重的数组,当值不在新数组的时候(indexOf为-1)就加入该新数组中: var arr=[2,8,5, ...