《DSP与PC机串口通信设计报告.docx》由会员分享,可在线阅读,更多相关《DSP与PC机串口通信设计报告.docx(9页珍藏版)》请在第一文库网上搜索。
1、1序言:本次设计题目主要是进一步掌握同步串口McBSP的结构及工作原理,学习DSP实现RS232串口通讯的程序设计,学习MAX3111与DSP的接口设计。近年来,DSP在电子、通信和控制领域得到了非常广泛的应用,在DSP应用系统设计中与上位机和下位机的通信必不可少。串口通信作为重要的通信方式之优点就是接口需要的引脚少,结构简单易于实现。本文介绍了TMS320C5416多通道缓冲口,并通过具体的实例介绍说明利用串口进行DSP通信的具体实现。2 MCBSP的接口信号及工作过程McBSP由一个数据通道和一个控制通道组成,如图1所示。不同的接受和发送引脚实现和外部器件之间的通信。MCBSP的接收操作采
2、用三级缓冲方式,发送操作采用两级缓冲方式。数据发送引脚(DX)负责数据的发送,数据接受引脚负责数据的接受,另外五个引脚(C1KS,C1KX,C1KR,FSX和FSR)提供了控制信号(时钟和帧同步)接口。C5416CPU通过片内的外设总线访问串口的32位控制寄存器,从而实现与McBSP间的通信与控制。接受的数据到达DR引脚后移位到RSR,一旦整个数据单元接受完毕,如果RBR寄存器未满,则RSR被复制到RBR中。如果DRR中的数据已经被CPU/DMA控制器读取,则RSR被将被复制到DRR中。发送数据首先由CPU或DMA控制器写入DXR中。如果XSR寄存器为空,则DXR中的值被复制到XSR并准备移位
3、输出,否则,DXR会等待XSR中旧数据的最后一位被移位输出到DX引脚后,才将数据复制到XSR中。3 MCBSP与SP1设备的接口SPI(SeriesProtoco1InterfaCe)是一个利用4根信号线的串行接口协议,包括主从两种模式。4个接口信号分别是:串行数据输入(M1S0,设备输入,从设备输出)、串行数据输出(MOS1主设备输出,从设备输出),移位时钟(SCK)、低电平有效的从设备使能信号(SS)。SPI的最大特点是由主设备时钟信号的出现与否来确定主从设备间的通信。一旦检测到主设备时钟信号,数据开始传送,时钟信号无效后,传输结束。在这期间,要求从设备必须被使能(SS信号保持有效McBS
4、P为SPI主设备的接口当McBSP为SPI的主设备时,由McBSP内部的采样发生器产生时钟C1KX和从设备使能信号FSXo当McBSP作为SPI从设备时,由外部的主设备产生所需要的主控时钟信号和从设备使能信号。4 .McBSP为主设备时的串口通信电路设计MAX3111是MAX3100的改进类型,它包括一个振荡器和一个可编程波特率发生器;具有一个可屏蔽的中断源;另具有一个8字节的接收FIFO(先入先出)缓冲器。其应用SPI/MICROWIRE接口技术直接与控制器之间进行通信,通信速率可达230kbps,还包括两个RS-232电平转换器,这样无需再接入电平转换器,而使应用一个芯片即可实现具有SPI
5、/MI-CROWIRE接口的微控器与PC或是其他设备进行异步数据传输。DSP的发送时钟信号(C1KX)作为MAX31U的串行时钟输入,发送帧同步脉冲信号(FSX)作为MAX3111的片选信号(CS)。DX与D1N连接作为发送数据线,DR与DOUT连接为接收数据线。MAX3111的DX与DIN连接,DX与DOUT连接,从而利用其片内的转换器实现UART到RS-232电平的转换。由于SP1模式下的MCBSP并不能产生接受中断,因此MAX3111的中断信号(IRQ)与DSP的外部中断相连。5软件流程图(附程序)6软件硬件联调把程序烧录到DSP芯片内,然后运行机房电脑里的串口调试工具,设置好端口和参数
6、。运行程序结果:(1)按下键2,PC机向DSP处理器发送数据(2)按下键1,DSP处理器向PC机发送数据,连续递增加1显示经分析:实验结果与我们理论设计结果相同,本实验圆满完成。7总结与展望课程设计是培养学生综合运用所学知识,发现,提出,分析和解决实际问题,锻炼实践能力的重要环节,是对学生实际工作能力的具体训练和考察过程.回顾起此次DSP原理及应用的课程设计,至今我仍感慨颇多,从理论到实践,在整个实验的过程中,可以说得是苦多于甜,但是可以学到很多很多的的东西,同时不仅可以巩固了以前所学过的知识,而且学到了很多在书本上所没有学到过的知识。通过这次课程设计使我懂得了理论与实际相结合是很重要的,只有
7、理论知识是远远不够的,只有把所学的理论知识与实践相结合起来,从理论中得出结论,才能真正为社会服务,从而提高自己的实际动手能力和独立思考的能力。在设计的过程中遇到问题,可以说得是困难重重,这毕竟是第一次综合应用DSP技术来做设计,难免会遇到过各种各样的问题,同时在设计的过程中发现了自己的不足之处,对以前所学过的知识理解得不够深刻,掌握得不够牢固通过这次毕业设计之后,可以把以前所学过的知识重新温故。这次毕业设计终于顺利完成了,在设计中遇到了很多问题,最后在老师的辛勤指导下,同学的帮助下终于迎刃而解。在此我表示感谢!8参考文献川DSP原理及应用IM,邹彦:电子工业出版社.12张雄伟,曹铁男.DSP芯
8、片的原理与开发应用(第2版)M.北京:电子工业出版社,2000.张毅刚,赵光权,孙宁,.TMS3201F2812DSPIgS,开发与应用M.哈尔滨:哈尔滨工业大学出版社,2006.4郑红,吴冠.TMS320F2812DSP应用系统的设计M.北京:北京航天航空大学出版社,2002.5刘和平等,TMS3201F240xDSPC语言开发应用北京航空航天大学出版社,2003年1月.6尹勇等,DSP集成开发环境CCS开发指南,北京航空航天大学出版社,2002年5月.8李法春单片机原理及接口技术案例教程&nbs.9陈伟,陈建,汪书宁等译,DSP算法、应用与设计,机械工业出版社、中信出版社,2003年7月.
9、9附程序:#pragmaCODESECTION(VeCtjVeCt”)unsignedint*pmem=0;#defineIMR*(Pmem+0x0000)#defineIFR*(pmem+0x0001)#definePMST*(pmem+0x001d)#defineSWCR*(pmem+0x002b)#defineSWWSR*(pmem+0x0028)#defineC1KMD*(pmem+0x0058)#definePRDO*(pmem+0x0025)/timerperiodregister#defineTCRO*(pmem+0x0026)/timercontro1register*mcbs
10、p1*/#defineSPSA1*(pmem+0x0048)子地址寄存器#defineSPSD1*(pmem+0x0049)/#defineDRR11*(pmem+0x0041)接收数据寄存器1#defineDRR21*(pmem+0x0040)接收数据寄存器2#defineDXR11*(pmem+0x0043)发送数据寄存器1#defineDXR21*(pmem+0x0042)发送数据寄存器2*mcbsp1subadress*/#defineSPCRi1OxOOOO串行口控制寄存器1#defineSPCR21OxOOOI串行口控制寄存器2#defineRCR110x0002接收控制寄存器I#
11、defineRCR210x0003接收控制寄存器2#defineXCRI10x0004发送控制寄存器1#defineXCR210x0005发送控制寄存器2#defineSRGR10x0006采样率发生寄存器1#defineSRGR20x0007/采样率发生寄存器1#definePCR1OxOOOe引脚控制寄存器ioportunsignedportcOOO;/数码管地址ioportunsignedportc001;/键盘地址ioportunsignedportc002;/发光二极管地址intnum=0;intn=0;staticintTmcounter;staticconstchartab1e1
12、0=1234567890);staticintweima8J=(OxO1OO/*1*/,0x0200*2*/,0x0400*3*0x0800*4*/,0x1000*5*/,0x2000*6*/,0x4000*7*/,Ox8OOO*8*/);staticintduanma1!6J=0x003f7*0*/,0x0006*1*/,0x005b*2*0x004f*3*/,0x0066M*0x006d*5*/,0x007d*6*/,0x0007*7*/,OXoO7B*8*/,0x006f*9*/,OxOO77*a*0x007c*b*0x0039*c*/,0x005e*d*/,0x0079*e*/,0x0
13、071*f*);voidde1ay()/WAIT(asm(,STM#0008h,ARO,);asm(RPT*AR0);asm(NOP);)voidde1ay10ms()(inti,j,k;for(i=0ii2ji)for(j=0J2)for(k=0;k2;k+);)voidde1ay100ms()(inti,j,k;for(i=0;i14;i+)for(j=0ij12j+)for(k=0;k20;k+);)voidcpujnit()/初始化DSP(asm(ssbxintm);asm(,ssbxxf,);PMST=0xe8;SWWSR=0x7fff;SWCR=0x0000;C1KMD=0x100
14、0;TCRO=0x0a59;PRDO=0xf9f;IMR=OxOcOc;/开放mcbsp1发送中断、mcbsp1接收中断、外部中断2、定时器0中断IFR=Oxffff;asm(rsbxintm);asm(,rsbxxf);)voidmcbsp_init()spsai=spcriI;/Seria1PortContro1Register1SPSDI=0x1800;SPSA1=SPCR21;/1800/Seria1PortContro1Register2SPSDI=OxOOOO;Spsai=RCRII;SPSDI=0X40;SPSAI=RCR21;Spsdi=OxOi;/0000/ReceiveCo
15、ntro1Register1/0040/ReceiveContro1Register2/OOO1SPSAI=XCR11;/TransmitContro1Register1SPSDI=0x40;SPSAI=XCR21;SPSDI=0x01;/0040/TransmitContro1Register2/O1SPSAI=SRGR1;Spsdi=OxOOOO;SPSA1=SRGR2;SPSDI=0x2000;SPSAI=PCR1;SPSDI=0x0a08;DXR11=0x000;spsai=spcrii;/Samp1eRateGeneratorRegisterI/0000/Samp1eRateGeneratorRegister2/