您的位置: OpenADSP社区论坛 -> Blackfin专区 -> 新手上路 -> BF53x技术支持专区 -> BF533/BF531处理器应用设计3-中断设计
本帖共有765个阅读者
发表帖子 发表投票 回复主题
BF533/BF531处理器应用设计3-中断设计
尊贵身份标志
OpenADSP(管理员)
OpenADSP
头衔:社区公民
帮派:无帮无派
帖数:5195
金钱:34806
积分:6378
注册时间:2011/6/7
楼主信息 | 留言 | Email | 主页 | 编辑 | 管理 | 离线
BF533/BF531处理器应用设计3-中断设计

视频讲解

http://www.macromedia.com/shockwave/download/index.cgi?P1_Prod_Version=ShockwaveFlash' type='application/x-shockwave-flash' width='500' height='400'>$2

硬件实现原理

ADSP-EDU-BF53x 开发板上的中断资源连接到了CPLD,并通过CPLD 将中断信号连接到PF0 触发,通过CPLD映射的寄存器读取中断源数据。
中断功能映射到 CPLD 寄存器中的DEVICE_OE 和INTERRUPT_DAT 两个寄存器,其映射内容如下:

DEVICE_OE 寄存器(读/写):
DEVICE_OE 寄存器地址:0x20320000
DEVICE_OE 寄存器设置硬件设备上一些控制管脚的电平状态。
DEVICE_OE 寄存器位功能:

上传的图片
  20127309454183.jpg [ 23.44 KB 838×73 ] (缩略时请点击查看原图)

 



我是OP...
等级:管理员 参考IP地址:*.*.*.*
2012/7/30 9:45:49
尊贵身份标志
OpenADSP(管理员)
OpenADSP
头衔:社区公民
帮派:无帮无派
帖数:5195
金钱:34806
积分:6378
注册时间:2011/6/7
1信息 | 留言 | Email | 主页 | 编辑 | 管理 | 离线

PF0_SET:PF0 模拟IIC 总线 SCL 接口或PF0 中断功能使能
1:关闭I2C_SCL 输入信号, 使能PF0 中断信号
0:使能I2C_SCL 输入信号,关闭PF0 中断信号
使用中断时,将 I2C_SCL 位设置为1。

INTERRUPT_DAT 寄存器(读唯一):
INTERRUPT_DAT 寄存器地址:0x20360000
INTERRUPT_DAT 寄存器是板卡上所有中断资源的中断源数据寄存器,可以通过该寄存器数据判断出当前中断是哪一个设备产生的。

INTERRUPT_DAT 寄存器位功能:

上传的图片
  2012730947883.jpg [ 23.00 KB 842×73 ] (缩略时请点击查看原图)

 

当中断未触发时,读取的Bit 位值为1,当中断触发时,读取的Bit 位值为0,根据Bit 位数据,获取中断设备。SD_INF 为SD 卡插入查询位,该bit 位不会触发中断,只能通过读取该寄存器来查询SD 卡否插入。

硬件连接示意图

上传的图片
  20127309501283.jpg [ 31.05 KB 523×179 ] (缩略时请点击查看原图)

 

代码实现功能

代码实现了利用板卡的中断机制,当有中断触发时,PF0 脚产生中断,然后进入中断函数,通过INTERRUPT_DAT寄存器查询触发中断的中断源,并打印中断源信息。

测试实验步骤

1. 将仿真器(ICE)与ADSP-EDU-BF53x 开发板和计算机连接好。
2. 先给仿真器(ICE)上电再为ADSP-EDU-BF53x 开发板上电。
3. 运行 VisualDSP++ 5.0 软件,选择合适的BF533 的session 将仿真器与软件连接。
4. 加载 VisualDSP++ 5.0 工程文件BF53x_INTERRUPT.dpj,编译并全速运行。
5. 点击触摸屏或者按按键测试中断触发。

测试结果

点击触摸屏或者按按键测试中断触发,代码打印出触发中断的中断源。

上传的图片
  20127309523683.jpg [ 36.07 KB 542×245 ] (缩略时请点击查看原图)

 

未插入 SD 卡和插入SD 卡中断信息比较。



我是OP...
等级:管理员 参考IP地址:*.*.*.*
2012/7/30 9:53:03
Powered by OpenADSP Copyright © 2010 www.Openadsp.com. All rights reserved.159916 Call, 1 Queries, Processed in 0.015625 second(s),