- 1、本文档共10页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
DSP实验设计报告
外设控制实验—发光二极管阵列显示
前言
面对当今飞速发展的电子产品市场,设计师需要更加实用、快捷的DSP工具,使用统一的集成化设计环境,改变传统设计思路,将精力集中到设计构思、方案比较和寻找优化设计等方面,需要以最快的速度,开发出性能优良、质量一流的电子产品,对DSP技术提出了更高的要求。未来的DSP技术将在仿真、时序分析、集成电路自动测试、高速印刷电路板设计及开发操作平台的扩展等方面取得新的突破,向着功能强大、简单易学、使用方便的方向发展。
在实际学习中我们应该从应用的角度看待这门课程,初步掌握基本设计工具和设计方法,在课程实践中应锻炼自己的实际设计思想、创新思维和创造能力,力求提高自己的工程实践能力和自主创新能力。
一、实验目的
通过实验学习使用2812A DSP的扩展端口控制外围设备的方法,了解发光二极管阵列控制编程方法。
二、实验设备
计算机, ICETEK-F2812-EDU.
三、实验原理
1、EMIF接口
TMS320F2812DSP的扩展存储器接口(EMIF)用来与大多数外围设备进行连接,典型应用如连接片外扩展存储器等。这一接口提供地址连线、数据连线和一组控制线。ICETEK-F2812-A将这些扩展线引到了板上的扩展插座上供扩展使用。
2、发光二极管显示阵列的显示是由扩展端口控制,扩展在EMIF接口的两个寄存器提供具体控制。原理图如下:
3、显示原理
DSP须将显示的图形按列的顺序存储起来(8*8点阵,8个字节,高位在下方,地位在上方),然后定时刷新控制显示。具体方法是,将以下控制字按先后顺序、每两个为一组发送到端口0X602802,发送完毕后,隔不太长的时间(以人眼观察不闪烁的时间间隔)在发送一遍,由于位值为“0”时点亮,所以需要将显示的数据取反。
0X01,第8列数据取反,0 X02,第7列数据取反,
0X04,第6列数据取反,0X08,第5 列数据取反,
0X10,第4列数据取反,0X20,第3列数据取反,
0X40,第2列数据取反,0X80,第1列数据取反,
4、程序流程图:
开始
初始化:DSP时钟
初始化CETEK-CTR
选通发光二极管显示阵列
有A到B的循环计数
选相应点阵刷新显示
四、实验步骤
1、实验准备
(1)连接实验设备
(2)连接试验箱附带的键盘的PS2插头到ICETEK-CTR的“键盘接口”P8.
(3)将ICETEK-CTR板的供电电源开关拨动到“开”的位置。
2、设置Code Composer Studio 2.21在硬件仿真方式下运行。
3、启动Code Composer Studio 2.21 选择菜单Debug→Reg CPU.
4、打开工程文件。
5、编译并下载程序。
6、运行程序观察结果。
7、结束程序运行退出,退出CCS。
五、实验结果与分析
实验结果:可以观察到发光二极管阵列显示图案。
分析:本程序使用循环延时的方法,如果想实现较为精确的定时,可使用通用计时器,在通用计时器中断中取得延时,改变显示内容。另外本程序中 DSP 一直在做刷新显示的工作,如果使用通用计时器定时刷新显示,将能减少DSP 用于显示的操作。适当更新显示可取得动画效果。
参考程序:
#include DSP281x_Device.h // DSP281x Headerfile Include File
#include DSP281x_Examples.h // DSP281x Examples Include File
#include f2812a.h
#define LEDS *(int *)0xc0000
#define CTRGR *(int *)0x108000
#define CTRLCDCMDR *(int *)0x108001
#define CTRKEY *(int *)0x108001
#define CTRLCDCR *(int *)0x108002
#define CTRCLKEY *(int *)0x108002
#define CTRLCDLCR *(int *)0x108003
#define CTRLCDRCR *(int *)0x108004
#define CTRLA *(int *)0x108005
#define CTRLR *(int *)0x108007
void Delay(unsigned int nTime); // 延时子程序
void RefreshLEDArray(); // 刷新显示
void SetLEDArray(int nNumber); /
文档评论(0)