




已阅读5页,还剩9页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1 / 14dps 实验三实验报告 实验三:DSP 的定时器和外中断定时器:一实验目的1通过实验熟悉 VC5509A 的定时器;2掌握 VC5509A 定时器的控制方法;3掌握 VC5509A 的中断结构和对中断的处理流程;4学会 C 语言中断程序设计,以及运用中断程序控制程序流程。二实验设备计算机,ICETEK-VC5509-A 实验箱。三实验原理1通用定时器介绍及其控制方法:TMS320VC5509A 内部有两个 20 位通用定时器:* 每个通用定时器包括:- 一个 16 位的减计数的计数器 TIM;- 一个 16 位的定时器周期寄存器 PRD;- 一个 16 位的定时器控制寄存器 TCR;- 一个 16 位的定时器预定标寄存器 PSCR;2 / 14* PSCR 寄存器说明:15 10 9 6 5 4 3 0Reserved PSC Reserved TDDRPSC: 4 位的预定标值, 与 TIM 共同组成 20 位的定时计数器.TDDR: 预定标周期寄存器TCR 寄存器说明2中断响应过程:外设事件要引起 CPU 中断,必须保证:IER 中相应使能位被使能,IFR 相应中断也被 使能。在软件中,当设置好相应中断标志后,开中断,进入等待中断发生的状态;外设中断发生时,首先跳转到相应中断高级的服务程序中,程序在进行服务操作之后,应将本外设的中断标志位清除以便能继续中断,然后返 回。3中断程序设计:- 程序中应包含中断向量表,VC5509A 默认向量表从程序区 0 地址开始存放,根据 IPVD 和 IPVH 的值确定向量表的实际地址。- 注意观察程序中 INTR_init 函数的定义部分,其中 IPVD 和 IPVH 的值都为 0x0d0;同时 观察配置文件ICETEK 中的 VECT 段描述中 o=0x0d000。- 向量表中每项为 8 个字,存放一个跳转指令,3 / 14跳转指令中的地址为相应服务程序入口地址。 第一个向量表的首项为复位向量,即 CPU 复位操作完成后自动进入执行的程序入口。 - 服务程序在服务操作完成后,清除相应中断标志,返回,完成一次中断服务5实验程序分析:本实验设计的程序是在上实验 基础上修改得来,由于实验 控制指示灯闪烁的延时控制是用循环计算方法得到的,延时不精确也不均匀,采用中断方式可以实现指示灯的定 时闪烁,时间更加准确。实验程序的工程中包含了两种源代码,主程序采用 C 语言编制利于控制,中断向量表在 汇编语言文件中,利于直观地控制存储区分配。在工程中只需将它们添加进来 即可,编译系统会自动识别分别处理完成整合工作。实验程序的 C 语言主程序中包含了内嵌汇编语句,提供一种在需要更直接控制 DSP 状态时 的方法,同样的方法也能提高 C 语言部分程序的计算效率四实验步骤1实验准备:连接实验设备:请参看本书第三部分、第一章、二。4 / 14关闭实验箱上扩展模块和信号源电源开关。2设置 Code Composer Studio 在硬件仿真方式下运行:请参看本书第三部分、第一章、四、2。3启动 Code Composer Studio :请参看本书第三部分、第一章、五、2。选择菜单 DebugReset CPU。4打开工程文件:打开菜单“Project” 的“Open”项;选择C:ICETEKVC5509AeVC5509AeLab0303-Timer 目录中的“” 。在项目浏览器中,双击,激活 文件,浏览该文件的内容,理解各语句作用。 打开 ICETEK,对照 源程序学习中断向量表的写法。5编译、下载程序。6运行程序,观察结果。7改变 TIMER_init 函数里*prd0 = 0x0ffff 为 “=0x0fff ”;重复步骤 5,6 观察实验现象。五实验代码#include / 定义指示灯寄存器地址和寄存器类型#define LBDS 0x400001)5 / 14void INTR_init;void TIMER_init;int nCount;mainnCount=0;PLL_Init;SDRAM_init;LBDS=0;INTR_init;TIMER_init;while void interrupt TimernCount+; nCount%=16;if LBDS1;void INTR_init6 / 14IVPD=0xd0;IVPH=0xd0;IER0=0x10;DBIER0 =0x10;IFR0=0xffff;asm;void TIMER_initioport unsigned int *tim0;ioport unsigned int *prd0;ioport unsigned int *tcr0;ioport unsigned int *prsc0;tim0 = 0x1000;prd0 = 0x1001;tcr0 = 0x1002;prsc0 = 0x1003;*tcr0 = 0x04f0;*tim0 = 0;*prd0 = 0x0ffff;*prsc0 = 2;7 / 14*tcr0 = 0x00e0;六实验结果- 指示灯在定时器的定时中断中按照设计定时闪烁。- 使用定时器和中断服务程序可以完成许多需要定时完成的任务,比如 DSP 定时启动 A/D 转换,日常生活中的计时器计数、空调的定时启动和关闭等。- 在调试程序时,有时需要指示程序工作的状态,可以利用指示灯的闪烁来达到,指示灯灵活的闪烁方式可表达多种状态信息。外部中断:一实验目的1通过实验熟悉 VC5509A 的中断响应过程。2学会 C 语言中断程序设计,以及运用中断程序控制程序流程。二实验设备计算机,ICETEK-VC5509-A 实验箱。三实验原理1中断及中断处理过程:中断简介:8 / 14中断是一种由硬件或软件驱动的信号,DSP 在接到此信号时,将当前程序悬挂起来, 转去执行另外一个任务,这个任务我们称为中断服务程序。TMS320C55 DSP 可支持 32 个 ISR,可由硬件或软件触发。所有的 C55x 中断,可以分成可屏蔽中断和不可屏蔽中断两种,软件中断是不可屏蔽的。 DSP 处理中断的步骤:接收中断请求。请求由软件或硬件发出。响应中断请求。对于可屏蔽中断,需要满足若干条件,才发生响应;而对于不可屏蔽中 断,则立即响应。准备执行中断服务程序。- 完成当前正在执行的指令;将进入流水线但还未解码的指令清除。- 自动保存若干寄存器的值到数据堆栈和系统堆栈。- 取得用户定义的中断向量表中当前中断向量,中断向量指向中断服务程序入口。执行中断服务程序。中断服务程序包含中断返回指令,这样返回时可以出栈以前保存的 关键寄存器数据,从而恢复中断服务程序执行前的现场。中断向量表:9 / 14中断向量表的构成请参见 TI 的文档 之。中断向量表的地址可以由用户指定。外中断:TMS320C5509 可以响应 INT0-INT4 五个外中断。2ICETEK-CTR 板的键盘接口:显示/控制模块 ICETEK-CTR 通过接口 P8 连接小键盘,接收小键盘传送的扫描码,并在每个扫描码结束后保存,同时向 DSP 的INT2 发送中断信号;当 DSP 读键盘时将扫描码 送到数据总线上。小键盘上每次按下一个键将产生 2 个扫描码、2 次中断。3程序编制:由一个不含中断处理程序的工程通过改写加入中断处理程序部分大致需要如下操作: 编制中断服务程序:可以用 C 语言程序实现,编写单独的一个函数 XINT, 此函数使用 interrupt 修饰,没有参数和返回值。 构造中断向量表:可以用汇编语言构造,编写一个汇编语言模块程序,在程序 头上声明段名为“.vectors”;定义外部标号_XINT,由于汇编语言要使用 C 语言程序中定义10 / 14的标号 XINT,需要在这个标号前加底线;在中断向量表该中断对应位置写汇编语言语 句跳转语句。 修改连接命令文件:在 MEMORY 小节中开辟单独的地址段用以存放中断向量表;在 SECTIONS 小节中指定.vectors 段到前步开设的内存段中。 主程序中进行初始化设置:定位中断向量表,使能中断,清中断等。四实验步骤1实验准备: 连接实验设备:请参看本书第三部分、第一章、二。 连接实验箱附带的键盘的 PS2 插头到ICETEK-CTR 的“键盘接口”P8。 将 ICETEK-CTR 板的供电电源开关拨动到“开”的位置。开关位置请参见第二部分、第 一章、三、“扩展模块电源开关及其指示灯” 。2设置 Code Composer Studio 在硬件仿真方式下运行:请参看本书第三部分、第一章、四、2。3启动 Code Composer Studio :请参看本书第三部分、第一章、五、2:选择菜单 DebugReset CPU。11 / 144打开工程文件:工程目录:C:ICETEKVC5509AES60VC5509AELab0304-XINTv60。 浏览 文件的内容,理解各语句作用。打开 ICETEK,对照 源程序学习中断向量表的写法。5编译、下载程序。6运行程序,观察结果:运行程序,按一下小键盘上任意一个键,注意观察 ICETEK-CTR 板上指示灯闪烁的情况。7观察中断函数的执行:选择“Debug” 菜单中“Halt”暂停运行程序,在 XINT 程序中的语句上加软件断点,重新 运行程序,观察何时程序停留在断点上。五实验代码#include #include #include void InitMcBSP;void INTR_init;void TIME_init;int nCount;12 / 14mainnCount=0;nCount=*0x10000;asm;PLL_Init;SDRAM_init;INTR_init;InitMcBSP;InitCTR;CTRLR=0xc8; / 使能 IO/CTRCLKEY=0;while void InitMcBSP/ IOPin: S15/_=0,=1,=1,=0/1SPCR2_1PCR1|=0x2800;13 / 14void interrupt XINTnCount+; nCount%=2;if LBDS1;/CTRCL
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年今日高考历史试卷及答案
- 大二数据库模拟试题及答案
- 公共常识基础题库及答案
- 浙江2025自考智能分子工程英语二模拟题及答案
- 海南2025自考医疗器械与装备马克思概论模拟题及答案
- 湖北2025自考汉语言文学外国文学史选择题专练
- 西藏2025自考生物育种技术种子生物学易错题专练
- 迷惑脑力测试题及答案
- 水性涂料建设项目施工方案
- 云南2025自考环境设计设计色彩主观题专练
- 2025年湖南大学事业编制管理辅助岗位招聘58人笔试备考试题及答案解析
- GB 18664-2025呼吸防护装备的选择、使用和维护
- 水库枢纽工程运行维护管理方案
- 中国电信集团有限公司2026年度秋季校园招聘考试参考题库及答案解析
- 信息安全全员培训课件
- 2025-2026学年大象版(2024)小学科学三年级上册(全册)教学设计(附目录P208)
- 湿陷性黄土湿陷量计算表
- 在课堂教学中寻找发展学生科学思维的生长点课件
- 因离婚给孩子申请改姓协议书
- 大众蔚揽保养手册
- 中共一大会址
评论
0/150
提交评论