《DSP 的定时器和外中断实验报告》由会员分享,可在线阅读,更多相关《DSP 的定时器和外中断实验报告(7页珍藏版)》请在金锄头文库上搜索。
1、实验三:DSP 的定时器和外中断定时器:一实验目的1通过实验熟悉VC5509A 的定时器;2掌握VC5509A 定时器的控制方法;3掌握VC5509A 的中断结构和对中断的处理流程;4学会C 语言中断程序设计,以及运用中断程序控制程序流程。二实验设备计算机,ICETEK-VC5509-A 实验箱(或ICETEK 仿真器+ICETEKVC5509-A 系统板+相关连线及电源)。三实验原理1通用定时器介绍及其控制方法(详见spru595b.pdf):TMS320VC5509A 内部有两个20 位通用定时器(GP):* 每个通用定时器包括:- 一个16 位的减计数的计数器 TIM;- 一个16 位的
2、定时器周期寄存器 PRD;- 一个16 位的定时器控制寄存器 TCR;- 一个16 位的定时器预定标寄存器 PSCR;* PSCR 寄存器说明 :15 10 9 6 5 4 3 0Reserved PSC Reserved TDDRPSC: 4 位的预定标值,与TIM 共同组成20 位的定时计数器.TDDR: 预定标周期寄存器(在需要时重装入 PSC 的值)TCR 寄存器说明(详见spru595b.pdf)2中断响应过程(详见spru595b.pdf):外设事件要引起CPU 中断,必须保证:IER 中相应使能位被使能,IFR 相应中断也被使能。在软件中,当设置好相应中断标志后,开中断,进入等待
3、中断发生的状态;外设(如定时器)中断发生时,首先跳转到相应中断高级的服务程序中(如:定时器1 会引起TINT中断),程序在进行服务操作之后,应将本外设的中断标志位清除以便能继续中断,然后返回。3中断程序设计:- 程序中应包含中断向量表,VC5509A 默认向量表从程序区 0 地址开始存放,根据IPVD 和IPVH 的值确定向量表的实际地址。- 注意观察程序中INTR_init()函数的定义部分,其中IPVD 和IPVH 的值都为0x0d0;同时观察配置文件ICETEK VC5509-AE.cmd 中的VECT 段描述中 o=0x0d000。- 向量表中每项为8 个字,存放一个跳转指令,跳转指令
4、中的地址为相应服务程序入口地址。第一个向量表的首项为复位向量,即CPU 复位操作完成后自动进入执行的程序入口。- 服务程序在服务操作完成后,清除相应中断标志,返回,完成一次中断服务5实验程序分析:本实验设计的程序是在上实验3.1 基础上修改得来,由于实验3.1 控制指示灯闪烁的延时控制是用循环计算方法得到的,延时不精确也不均匀,采用中断方式可以实现指示灯的定时闪烁,时间更加准确。实验程序的工程中包含了两种源代码,主程序采用C 语言编制利于控制,中断向量表在vector.asm 汇编语言文件中,利于直观地控制存储区分配。在工程中只需将它们添加进来即可,编译系统会自动识别分别处理完成整合工作。实验
5、程序的C 语言主程序中包含了内嵌汇编语句,提供一种在需要更直接控制DSP 状态时的方法,同样的方法也能提高C 语言部分程序的计算效率四实验步骤1实验准备:连接实验设备:请参看本书第三部分、第一章、二。关闭实验箱上扩展模块和信号源电源开关。2设置Code Composer Studio 3.1 在硬件仿真(Emulator)方式下运行:请参看本书第三部分、第一章、四、2。3启动Code Composer Studio 3.1:请参看本书第三部分、第一章、五、2。选择菜单DebugReset CPU。4打开工程文件:打开菜单“Project”的“Open”项;选择C:ICETEKVC5509AeV
6、C5509AeLab0303-Timer目录中的“Timer.pjt ”。在项目浏览器中,双击main.c,激活main.c 文件,浏览该文件的内容,理解各语句作用。打开ICETEKVC5509-Ae.cmd,对照vector.asm 源程序学习中断向量表的写法。5编译、下载程序。6运行程序,观察结果。7改变TIMER_init()函数里*prd0 = 0x0ffff 为 “=0x0fff ”;重复步骤5,6 观察实验现象。五实验代码#include myapp.h/ 定义指示灯寄存器地址和寄存器类型#define LBDS (*(unsigned int *)0x400001)void IN
7、TR_init( void );void TIMER_init(void);int nCount;main()nCount=0;PLL_Init(40);SDRAM_init();LBDS=0;INTR_init();TIMER_init();while ( 1 )void interrupt Timer()nCount+; nCount%=16;if ( nCount=0 )LBDS=1;void INTR_init( void )IVPD=0xd0;IVPH=0xd0;IER0=0x10;DBIER0 =0x10;IFR0=0xffff;asm( BCLR INTM);void TIMER
8、_init(void)ioport unsigned int *tim0; ioport unsigned int *prd0; ioport unsigned int *tcr0; ioport unsigned int *prsc0; tim0 = (unsigned int *)0x1000;prd0 = (unsigned int *)0x1001;tcr0 = (unsigned int *)0x1002;prsc0 = (unsigned int *)0x1003;*tcr0 = 0x04f0;*tim0 = 0;*prd0 = 0x0ffff;*prsc0 = 2;*tcr0 =
9、 0x00e0;六实验结果- 指示灯在定时器的定时中断中按照设计定时闪烁。- 使用定时器和中断服务程序可以完成许多需要定时完成的任务,比如DSP 定时启动A/D 转换,日常生活中的计时器计数、空调的定时启动和关闭等。- 在调试程序时,有时需要指示程序工作的状态,可以利用指示灯的闪烁来达到,指示灯灵活的闪烁方式可表达多种状态信息。外部中断:一实验目的1通过实验熟悉VC5509A 的中断响应过程。2学会C 语言中断程序设计,以及运用中断程序控制程序流程。二实验设备计算机,ICETEK-VC5509-A 实验箱(或ICETEK 仿真器+ICETEKVC5509-A 系统板+相关连线及电源)。三实验原
10、理1中断及中断处理过程:中断简介:中断是一种由硬件或软件驱动的信号,DSP 在接到此信号时,将当前程序悬挂起来,转去执行另外一个任务,这个任务我们称为中断服务程序(ISR)。TMS320C55(C55 x) DSP可支持32 个ISR,可由硬件或软件触发。所有的C55x 中断,可以分成可屏蔽中断和不可屏蔽中断两种,软件中断是不可屏蔽的。DSP 处理中断的步骤:接收中断请求。请求由软件或硬件发出。响应中断请求。对于可屏蔽中断,需要满足若干条件,才发生响应;而对于不可屏蔽中断,则立即响应。准备执行中断服务程序。- 完成当前正在执行的指令;将进入流水线但还未解码的指令清除。- 自动保存若干寄存器的值
11、到数据堆栈和系统堆栈。- 取得用户定义的中断向量表中当前中断向量,中断向量指向中断服务程序入口。执行中断服务程序。中断服务程序包含中断返回指令,这样返回时可以出栈以前保存的关键寄存器数据,从而恢复中断服务程序执行前的现场。中断向量表:中断向量表的构成请参见TI 的文档sprs295d.pdf 之3.11。中断向量表的地址可以由用户指定。外中断:TMS320C5509 可以响应INT0-INT4 五个外中断。2ICETEK-CTR 板的键盘接口:显示/控制模块ICETEK-CTR 通过接口P8 连接小键盘,接收小键盘传送的扫描码,并在每个扫描码结束后保存,同时向DSP 的INT2 发送中断信号;
12、当DSP 读键盘时将扫描码送到数据总线上。小键盘上每次按下一个键将产生2 个扫描码、2 次中断。3程序编制:由一个不含中断处理程序的工程通过改写加入中断处理程序部分大致需要如下操作(假设使用INT2) : 编制中断服务程序:可以用C 语言程序实现(参见实验程序),编写单独的一个函数XINT,此函数使用interrupt 修饰,没有参数和返回值。 构造中断向量表:可以用汇编语言构造,编写一个汇编语言模块程序vector.asm,在程序头上声明段名为“.vectors”;定义外部标号_XINT,由于汇编语言要使用C 语言程序中定义的标号XINT,需要在这个标号前加底线;在中断向量表该中断对应位置(
13、int2)写汇编语言语句跳转语句。 修改连接命令文件:在MEMORY 小节中开辟单独的地址段用以存放中断向量表;在SECTIONS 小节中指定.vectors 段到前步开设的内存段中。 主程序中进行初始化设置:定位中断向量表,使能中断,清中断等。四实验步骤1实验准备: 连接实验设备:请参看本书第三部分、第一章、二。 连接实验箱附带的键盘的PS2 插头到ICETEK-CTR 的 “键盘接口”P8。 将ICETEK-CTR 板的供电电源开关拨动到“开”的位置。开关位置请参见第二部分、第一章、三、“扩展模块电源开关及其指示灯”。2设置Code Composer Studio 3.1 在硬件仿真(Em
14、ulator)方式下运行:请参看本书第三部分、第一章、四、2。3启动Code Composer Studio 3.1:请参看本书第三部分、第一章、五、2:选择菜单DebugReset CPU。4打开工程文件:工程目录:C:ICETEKVC5509AES60VC5509AELab0304-XINTv60XINT.pjt。浏览main.c 文件的内容,理解各语句作用。打开ICETEKVC5509-AE.cmd,对照vector.asm 源程序学习中断向量表的写法。5编译、下载程序。6运行程序,观察结果:运行程序,按一下小键盘上任意一个键,注意观察ICETEK-CTR 板上指示灯闪烁的情况。7观察中
15、断函数的执行:选择“Debug”菜单中“Halt”暂停运行程序,在XINT 程序中的语句上加软件断点,重新运行程序(选择“Debug ”菜单中 “Run”),观察何时程序停留在断点上。五实验代码#include myapp.h#include ICETEK-VC5509-EDU.h#include scancode.hvoid InitMcBSP();void INTR_init( void );void TIME_init(void);int nCount;main()nCount=0;nCount=*(int *)0x10000;asm( nop );PLL_Init(20);SDRAM_
16、init();INTR_init();InitMcBSP();InitCTR();CTRLR=0xc8; / 使能 IO/CTRCLKEY=0;while ( 1 )void InitMcBSP()/ IOPin: McBSP1.FSX S15 /SPCR2.XRST_=0,PCR.XIOEN=1,PCR.FSXM=1,PCR.FSXP=0/1SPCR2_1PCR1|=0x2800;void interrupt XINT()nCount+; nCount%=2;if ( nCount=0 )LBDS=1;/CTRCLKEY=0;void INTR_init( void )IVPD=0x80;IVPH=0x80;IER0=8;DBIER0=8;IFR0=0xffff;a