本文是Xilinx MicroBlaze系列教程的第1篇文章。
AXI_INTC简介
AXI_INTC中断控制器用于将多路中断信号按照优先级输出一路给处理器,支持AXI4-Lite总线,最多支持32个中断输入,中断输入可配置为边沿触发或电平触发,中断输出可配置为边沿或电平输出,支持级联模式。
本篇文章介绍如何基于AXI_INTC来实现GPIO中断触发。
常用函数
AXI_INTC的库函数适用于ISE和Vivado开发环境,都是一样的。
//级联模式下用于初始化从机
static void XIntc_InitializeSlaves(XIntc * InstancePtr)
int XIntc_Initialize(XIntc * InstancePtr, u16 DeviceId)
//启动中断控制器,并使能中断信号输出到处理器
int XIntc_Start(XIntc * InstancePtr, u8 Mode)
//禁止中断信号输出给处理器
void XIntc_Stop(XIntc * InstancePtr)
//连接中断源
int XIntc_Connect(XIntc * InstancePtr, u8 Id, XInterruptHandler Handler, void *CallBackRef)
//断开指定的中断源连接
void XIntc_Disco