《DSP课程设计报告》.docxVIP

  • 63
  • 0
  • 约1.59万字
  • 约 32页
  • 2020-08-16 发布于天津
  • 举报
DSRM程设计报告 南京邮电大学 实验报告 实验名称 DSP课程设计 课程名称 DSP课程设计 班级学号 姓 名 开课时间20XX/20XX学年, 第1 学期 实验一、EMIF接口上的I/O接口扩展 实验目的 了解 ICETEK-VC5509-A 板在 TMS320VC5509DS外部扩 展存储空间上的扩展。 了解ICETEK-VC5509-A板上指示灯 扩展原理。学习在C语言中使用扩展的控制寄存器的方法。 实验原理 1 . TMS320VC5509DSP勺 EMIF 接口: 存储器扩展接口 (EMIF)是DSP扩展片外资源的主要接 口,它提供了一组控制信号和地址、 数据线,可以扩展各类存储器和寄存器映射的外设。 -ICETEK-VC5509-A评估板在 EMIF接口上除了扩展了 片外SDRAMS,还扩展了指示灯、 DIP开关和D/A设备。具体扩展地址如下: 爱心—用心—怛心 400800-400802h : D/A 转换控制寄存器 400000-400000h : 板上DIP开关控制寄存器 400001-400001h :板上指示灯控 制寄存器 -与ICETEK-VC5509-A评估板连接的 ICETEK-CTR显示 控制模块也使用扩展空间控制主要 设备: 602800-602800h : 读-键盘扫描值,写-液晶控制寄存 器 600801-600801h : 液晶辅助控制寄存器 602801-600802h : 液晶显示数据寄存器 602802-602802h : 发光二极管显示阵列控制寄存器 2.指示灯扩展原理 3.实验程序流程图: 部分程序代码 //定义指示灯寄存器地址和寄存器类型 #define LBDS (*((unsigned int *)0x400001)) // 子 程序接口 void Delay(unsigned int nDelay); // 延时子程序 int i; main { unsigned int uLED[4]={1,2,4,8}; // 控制字,逐位 置 1: 0001B 0010B 0100B 1000B CLK_init ; // 初始化DS阮行时字巾SDRAM_init ; // 初始化 EMIF接口 while ( 1 ) { for ( i=0;i=0;i-- ) ( LBDS=uLED[i]; // 反向顺序送控制字 Delay(32); //延时 【延时256-32】} } } 实验结果 映射在扩展存储器空间地址上的指示灯寄存器在设置 时是低4位有效的,数据的最低位对应指示灯 D1,次低位对 应 D2,...依次类推。LED指示灯 D1tD2tD3^DD3^D2 i D1循环依次点亮。 实验小结 通过本次实验,我们了解到了 ICETEK-VC5509-A板在 TMS320VC5509DS由卜部 扩展 存储空 间上的 扩展,了解了 ICETEK-VC5509-A板上指示灯扩展原理。实验过程中需要注 意或者说是需要重点了解的是控制字的写入,改变控制字就 可以控制不同灯的闪烁,例如要使 D1、D2灯同时闪烁,控 制字就可写为3,即0011B。 实验二、定时器的使用 实验目的 通过实验熟悉VC5509A的定时器;掌握VC5509A定时 器的控制方法; 掌握VC5509A的中断结构和对中断的处理流程; 学会C语言中断程序设计,以及运用中断程序控制程序 流程。 实验原理 1 .通用定时器介绍及其控制方法 TMS320VC5509A内部有两个 20位通用定时器:*每个 通用定时器包括: -一个16位的减计数的计数器 TIM;- 一个16位的定 时器周期寄存器PRD - 一个16位的定时器控制寄存器 TCR -一个16位的定时器预定标寄存器 PSCR *PSCR寄存器说 明: PSC: 4位的预定标值,与TIM共同组成20位的定时计 数器. TDDR:预定标周期寄存器(在需要时重装入 PSC的值)TCR寄存器说明2 .中断程序设计: -程序中应包含中断向虽表, VC5509A默认向虽表从程 序区0地址开始存放,根据IPVD和 IPVH的值确定向虽表的实际地址。 -注意观察程序中 INTR_init 函数的定义部分,其中 IPVD和IPVH的值都为0x0d0 ;同时观察配置文件 中的VECT 段描述中o=0x0d000。 -向虽表中每项为 8个字,存放一个跳转指令,跳转指 令中的地址为相应服务程序入口地址。 第一个向虽表的首项为复位向虽, 即CPU复位操作完成 后自动进入执行的程序入口。 -服务程序在服务操作完成 后,清除相应中断标志,返回,完成一次中断服务。 实验结果 LED指示灯D1在定时器的定时中断中按照设计定时闪 烁。将*prd0 = 0x0ffff 改为*prd0 = 0x0f

文档评论(0)

1亿VIP精品文档

相关文档