




免费预览已结束,剩余1页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
利用TL16C750实现DSP与PC机的高速串行通信摘要:TL16C750是TI公司生产的异步通信芯片,在通信系统的实时性要求较高时,可通过扩展异步通信芯片TL16C750来实现系统的高速串行通信,从而增强系统的通信接口控制能力。文中介绍了TL16C750的性能及与通信有关的寄存器,给出了TL16C750在TMS320C50与PC机通信系统中的硬件应用电路及TMS320C50初始化TL16C750的软件编程。 关键词:数字信号处理 通信接口 扩展 异步通信 TL16C750 通用数字信号处理器(DSP)以其很强的数据处理能力使其在高速数字信号处理方面得到广泛的应用,但是它的通信接口控制能力比较弱。如TMS320C50,它有两个串口,其中一个是TDM(Time Division Mulitipl),另外一个串口常被语音接口占用。当TMS320C50独立构成一个处理单元时,往往需要与外设交换一些数据,通信能力弱就会影响 DSP的应用。在研制语音信号频谱分析仪时,笔者以TMS320C50作为信号处理单元进行快速傅立叶变换(FFT),然后将转换的结果通过串口传送到 PC机显示或作进一步处理。由于系统的实时性要求较高,如何实现TMS320C50与PC机高速和可靠的通信问题就显得更加重要。1 异步通信芯片TL16C750 对TI(德州仪器)的TMS320系列的数字信号处理器来说,设计串口的方法一般有两种:第一种是利用通用的I/O口线XF和BIO来构成串口,由软件来设定波特率,在DSP不繁忙的情况下,往往采用这种方法;但是当这两种I/O线被占用或通信的实时性要求较高时,DSP应该通过扩展异步通信芯片来实现高速串行通信。 TL16C750是TI公司的异步通信芯片,其主要特点如下: 管脚与TL16C550B/C兼容; 可由软件设定16字节或64字节的FIFO以减少CPU中断; 最高可达1M的波特率,其波特率发生器可编程; 具有可编程的串行数据发送格式: 数据位长度为5、6、7、8; 具有偶校验、奇校验或无校验模式; 停止位长度为1、1.5、2; 采用44引脚PLCC(Plastic Leaded Chip Carrier)封装。1.1 TL16C750的引脚功能 TL16C750的引脚图如图1所示,各主要引脚的功能说明如下: A0A2:片内寄存器的选择信号; D0D7:双向8位数据线; CS0、CS1、CS2:输入片选信号,当CS0=CS1=1且CS2=0时,TL16C750被选中; ADS:是地址选通信号,该脚有效时,可将CS0、CS1、CS2及A0、A1、A2锁存在TL16C750内部; XIN、XOUT:外部时钟端,该两脚可接晶振或外部时钟信号; RXRDY是接收准备好信号,当TL16C750已经从串行输入端接收了一个字符时,该信号失效,在中断方式时可作为中断请求信号; TXRDY是发送准备好信号,当TL16C750允许发送且发送缓冲区为空时,该信号有效,在中断方式时可作为中断请求信号。1.2 TL16C750的片内寄存器 TL16C750内部共有11个寄存器,这些寄存器分别用于实现通信参数的设置、对线路及MODEN的状态访问、数据的发送和接收以及中断管理等功能。编程人员可由A0、A1、A2三条片内寄存器选择线和线路控制寄存器的除法数锁存器访问位DLAB一起通过多路复用进行访问或控制TL16C750的任何一个寄存器。表1给出了访问这些寄存器时DLAB和A0、A1、A2的状态。因为接收/发送缓冲寄存器的DLAB、A0、A1、A2各位都相同,因此还必须通过读/写信号来加以区分:鸡使用IN指令时,接收缓冲寄存器被访问,鸡使用OUT指令时,发送缓冲寄存器被访问。 下面对与TMS320C50和PC机通信有关的寄存器做一简单介绍。表1 TL16C750的片内寄存器DLABA2A1A0寄存器0LLL接收/发送缓冲寄存器0LLH中断允许寄存器XLHL中断识别寄存器XLHLFIFO控制寄存器XLHH线路控制寄存器XHLLMODEN控制寄存器XHLH线路状态寄存器XHHLMODEN状态寄存器XHHH高速暂存寄存器1LLL波特率因子寄存器低位1LLH波特率因子寄存器高位 线路控制寄存器(LCR)用来存放串口传送的二进制位串行数据格式,LCR是一个8位寄存器,各位的定义如下:d0d1是字长选择位,若d0d1=00,传送的字长为5位;d0d1=01时字长为6;d0d1=10时字长为7;d0d1=11时字长为8。d2位是停止位选择,d2=0时停止位为1位; d2=1时停止位为1.5位。d3位是校验有效位,d3=0时校验有效;d3=1时校验无效。d4是校验类型位,d4=0时进行奇校验;d4=1时进行偶校验。d7位(DLAB)是锁定特率发生器位,d7=1时访问波特率因子寄存器;d7=0时访问其它寄存器。 线路状态寄存器(LSR)用于记录串行数据发送和接收过程的状态信息,CPU可在集体时候读取这些信息。该寄存器的状态位如表2所列。表2 TL16C750寄存器的状态位LSR的各位10d0接收完成标成接收完毕读后复位d1接收重叠标志发生重叠读后复位d2奇偶校验错标志奇偶校验错读后复位d3格式错标志接收有错接收无误d4间断标志连续收到0未间断d5发缓冲器空标志THR已空写THR复位d6发移位寄存器空标志已空未空d7接收器FIFO出错FIFO有错FIFO无错 两个8位波特率因子寄存器可构成一个16位的波特率因子寄存器。TL16C750的内部波特率发生器可产生发送数据的时钟信号。波特率因子可以通过下列算式求出: 波特率因子=基准时钟频率/(16波特率) 这个波特率发生器可以利用比较通用的三种不同频率产生标准的波特率。这三种不同的频率为1.8432MHz、3.072MHz和8MHz。可以任意选择写入波特率因子的高字节和低字节的顺序,但写入前必须置线路控制寄存器(LCR)的d7(DLAB)位为1。写入波特率因子后应将线路控制寄存器的d7恢复为0,以便访问其他寄存器。在外接晶振为1.8432MHz时,几种常用的波特率所对应的波特率因子寄存器的值如表3所列。表3 波特率因子对应的波特率因子寄存器的值波特率波特率因子寄存器的值3600324800249600121920063840032 TMS320C50与PC机串行通信的硬件电路 TMS320C50与PC机通信的硬件电路如图2所示。图中,TL16C750的CS0和CS1都接高电平,而CS2接TMS320C50的IS。IS是TMS320C50的外部I/O空间选择线,它和PS(程序空间选择)、DS(数据空间选择)一起来确定CPU所访问的空间。当TMS320C50使用IN、OUT指令对TL16C750的内部寄存器进行访问时,IS信号有效,TL16C750被选中。 当XIN、XOUT端外接1.8432MHz晶振时,TMS320C50以28400的波特率与PC机通信,所以波特率因子寄存器的低位的值应为02H,高位值为00H. TL16C750的数据线D0D7直接与TMS320C50的D0D7数据线相连;TL16C750的片内寄存器选择线接TMS320C50的A0A2。 由于TL16C750的读信号和写信号保持时间的典型值均为40ns,因此可以将TMS320C50的WR和RD直接连到TL16C750的WR1和 RD1,为了避免与其它I/O端口发生冲突,在硬件电路设计中,将TMS320C50的RD信号线与两条高位地址线A15、A14及IS经一个与非门后再接到TL16C750的RD1端。实践证明:这样的设计在解决地址冲突的基础上对写信号性能也有一定的改善作用。TMS320C50的读信号也作了类似的处理。具体的电路如图3所示。 由于RS-232-C电路电平与CMOS电平不同,因此RS232驱动器与CMOS电平连接时必须经过电平转换。本系统采用MAX3232完成这一功能, MAX3232具有一个专有的低压降发送器输出级,在其以双电荷泵3.05.5V供电时,可获得真正的RS-232性能。该器件只需4个0.1F小型外接电容,可在维持RS-232输出电平的情况下确保运行于120kb/s数据率,因此十分适合高速串行数据通信的场合。TL16C750的串行输入线(SIN)和串行输出线(SOUT)分别接MAX3232的R1OUT和T1IN,经电平转换后由MAX3232的T1OUT和R1IN连接到PC机的串口。 TL16C750与TMS320C50虽然可以通过查询的方式工作,但这样会降低系统的性能。笔者在本系统中利用RXRDY和TXRDY来引入外部中断,从而使系统工作在中断方式,这样就保证了TMS320C50和PC机的高速通信。由图2可知,RXRDY将产生外部0中断(INT0),而TXRDY将产生外部1中断(INT1)。3 软件设计 该系统软件设计包括PC机、TMS320C50及TL16C750的初始化和通信协议等。下面将结合本系统的硬件给出TMS320C50初始化 TL16C750的程序。初始化的主要任务是设置操作所需要的参数,这些参数包括串行通信时数据串的数据位数、停止位数、奇偶校验等。另外,还需要设置发送和接收的波特率及中断方式。 在本系统中,TL16C750的线路控制寄存器(LCR)的地址为8003H(A15=1,A14=0)。波特率设置为38400,波特率因子寄存器的高位是00H,低位为03H。通信格式为8位数据位,2位停止位,奇校验,线路控制寄存器的值(LCR)为07H。系统工作在中断方式,应允许接收就绪中断和发送缓冲区空中断,相应地,中断允许寄存器的值亦设置为03H.具体程序如下: TEM-BUF EQU 80H AORG 40H INIT-TL16C750 ROVM LACK 80H;DLAB=1,设置波特率 SACL TEM-BUF OUT TEM-BUF,8003H LACK 00H;波特率为38400, SACL TEM-BUF;16位波特率因子寄存器的值为0003 OUT TEM-BUT,8001H LACK 03H SACL TEM-BUF OUT
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年保健课考试流程及答案
- 2025年安全职责考试及答案
- 2025年兽药员工考试题目及答案
- 2025年suki考试及答案
- 2025年机械设计考试题库及答案
- 举办活动方案范本
- 2025办公室租赁合同模板标准版
- 曲靖市第二人民医院招聘考试真题2024
- 安徽小体量民宿施工方案
- 2025金属材料购销合同书范本
- 2026中国电建集团成都勘测设计研究院有限公司招聘笔试备考试题及答案解析
- 2025广西崇左凭祥市委宣传部招聘编外工作人员1人考试参考题库及答案解析
- 2025江西赣州南康赣商村镇银行招聘4人考试参考题库及答案解析
- 社保协议书模板6篇
- 企业安全生产责任书范本大全
- 工艺设备变更风险评估报告模板
- 红星照耀中国考试真题及答案
- 2025离婚起诉状民事诉状(离婚案件用)
- 前端Vue3项目实战教程
- 智算中心高性能计算系统设计方案
- 中央八项规定精神应知应会测试题有答案【夺分金卷】附答案详解
评论
0/150
提交评论