微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > MCU和DSP > DSP56311EVM的教学实验平台设计

DSP56311EVM的教学实验平台设计

时间:08-06 来源:互联网 点击:
C编译器g563c的命令格式为:     


  
在混合编程时,需要注意以下几点:

①C程序与汇编程序混合编程的特点是,汇编语句是在汇编语言环境中编写的;而使用_asm()指令在C语言程序中插入汇编指令的混合编程方式,汇编程序的编写要遵循C语言的规则。

②为了确保在汇编环境中编写的汇编子程序在C语言环境中可靠地被调用执行,汇编程序需要做出如下处理:引导部分,把程序返回地址保存到堆栈,接受程序入口参数的传递;保存汇编程序将要使用的寄存器的值;汇编程序的主体;恢复第二步所保存的寄存器的值,把保存到堆栈中的寄存器的值按顺序从堆栈中取出并赋给原来的寄存器,使这些寄存器恢复到本汇编子程序被调用前的状态;结尾部分,处理程序的返回值和返回地址,c语言子程序调用可以用return命令返回一个数值,混合编程的汇编程序也可以在C环境中被调用后返回一个值。在汇编源程序中,最后把需要返回的数值存放到累加器a中,然后用汇编指令tst把参数传递给c环境。

③C语言调用汇编源文件中的汇编子程序。首先在一个汇编源文件(如source,asm)中编写一个汇编子程序。一般在汇编环境中子程序的写法如下:  

若在C语言源文件(如proj.c)中调用汇编子程序Ftest,则可以在C语言中重新定义汇编子程序的标号。即在C语言文件头部(或调用该汇编子程序的C函数之前)定义:  
extern void ReName()__asm(“FTest”);
然后在C语言环境中调用ReName()子程序即可。

如果在编写汇编子程序时,在子程序的名称前加上一个大写的“F”,则在C环境中可以省略重新定义汇编子程序标号的步骤,这样C语言默认的汇编子程序的名称为去掉“F”以后的程序名。如上面的例子,在C环境中调用test()子程序,即调用source.asm中Ftest子程序。

④中断程序的C语言写法。编写C语言的中断程序,首先要修改crt0.asm中的中断向量表,即在中断向量表中找到某中断向量的位置,并在此处调用程序员所编写的中断响应程序。

如把增强型同步串口0(ESSI0)设定工作在中断方式,数据的接收、发送都采用中断来执行。程序员编写的增强串口数据接收中断服务子程序为Fssi_rx_isr。增强串口O数据接收的中断向量的地址为p:$30(p代表程序存储区),则对crt0.asm中的中断向量表修改如下:  



⑤C语言使用汇编源文件中定义的变量

因C语言定义的变量都是映射在内存的Y区的,故C语言可以读写的在汇编源程序中定义的变量也必须是定义在Y区的。例如,在汇编程序source.asm中定义内存:  

  
则C变量c_var与汇编变量test_var映射的是同一个内存物理地址。这是一种C语言与汇编语言之间数据的有效传递方式。

g563c的局限性在于,对于g563c编译规则不十分熟悉的使用者,会常常因为汇编语言与C语言程序使用DSP资源的冲突而发生异常的错误,导致C语言程序无法可靠运行。本课题的目的也在于减少使用者在C语言环境下大量使用汇编语言的需要,从而增强了系统的可靠性。
  
3 主要实验项目

本嵌入式系统目前主要是作为本科和研究生的实验平台,在设计上包括硬件基础实验和软件算法实验两部分。

硬件实验部分包括:

①串行通信实验。
②数据存储实验。编程控制A端口对外部SRAM存储器以及外围的Flash存储器特定区域进行存取操作。
③语音采集存储实验。设置适当采样率,编程实现语音信号的采集。
④语音录放实验。
⑤A/D实验(简易示渡)。
⑥D/A实验(函数信号发生器)。

软件实验部分包括:

①基本数学运算实验。
②FFT快速傅里叶变换。
③FIR有限冲激响应滤波器。

对给定时域信号进行操作,并与Matlab运算结果进行分析比较。

下面以串行通信实验为例简述实验:

实验内容DSP通过串行接口(RS232)与PC机进行双向通信。①把从键盘输入的字符通过串口发送给PC机,并且接收PC机发送的字符。LCD工作在文字显示模式;锁相环时钟分频器和串行通信控制器设定串行通信的波特率。②由PC机通过串口把一幅黑白图片传输给DSP并且通过LCD显示出来。LCD工作在图形显示模式。

实验原理 利用对56311的SCI(Serial Communica-tion Interface)编程,实现DSP与上位机进行多种波特率的串行通信。

实验使用的外部设备标准102键盘和LCD。

实验使用的DSP内部模块锁相环时钟分频器和串行通信接口(SCI)。实验内容:DSP通过串行接口(RS232)与PC机进行双向通信。DSP把从键盘输入的字符通过串口发送给PC机,并且可以接收PC机发送的字符。

实验结果图4为发送图片的LCD显示结果。    

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top