位置:51电子网 » 技术资料 » 单 片 机

单片机系统多串行口设计技术

发布时间:2008/9/2 0:00:00 访问次数:576

  1  引言

  在以单片机为核心的测控系统中.微控制器往往需要两个或两个以上的串行口与其他主机或外设进行通讯,如何使系统具备多个串行接口,是一个具有普遍性的问题。尤其在航空航天领域,由于gps、大气数据系统、数字罗盘、无线电高度表、甚至陀螺等航空电子设备普遍采用串行通讯方式,单片计算机系统就更需要有多个串行口以满足与外界信息交换的需要。

  2 常用的多串行口设计方法

  ①选用多串行口单片机

  直接选用多串行口单片机作为系统的cpu,显然是最直接有效的方法。现在有许多新型cpu配备两个或两个以上串行口,如w77e58、ds80c320、msp430f149、c8051f020单片机和数字信号处理器tms320c30有两个串行口,而cygnal的c8051f系列单片机有4-5个全双工的异步串行口。

  ②用cpu的i/o模拟串行口

  当串行口的波特率设为9600波特时,传送一个bit需要100us左右,对于一般的单片机而言,软件定时器完全有能力按异步串行通讯协议模拟出串行口的时序。所以,用cpu的两个i/o口和一个软件定时器,就可以纯粹用软件模拟出一个串行口来。文献介绍了一种具体的实现方法,发送时,只需按时序一位一位输出数据即可,接收时,首先利用外部中断检测到i/o接收口上的起始电平,然后利用定时器按半个bit的时间长度延时接收第一个bit的数据,再按一个bit的时间长度延时依此读取其他位的信号。

  ③基于高速输入输出的软件串行口

  80c196系列单片机配备了高速输入hsi和高速输出hso接口.可以利用hsi和hso来模拟串行口。数据的输出利用hso,只要在hso的定时器里写入与波特率对应的延迟时间,hso每中断一次,输出一个数据位,直到停止位输出完毕。接收时,利用hsi自身的信号跳变检测功能检测起始位,并产生中断通知cpu开始接收数据,后续的数据位由软件定时器按波特率定时读取。文献详细介绍了实现方法,并给出了完整的程序代码;本方法在80c196mc/md单片机中。则表现为事件处理阵列epa和外设事物服务器pts的应用,其优点是epa的每个模块与cpu的指定引脚对应,减少了软件开销和程序设计的复杂度。

  ④16c550系列可编程通讯控制器

  利用并行口扩展串行口的接口芯片种类较多,其中16c550系列通讯控制器普遍应用于计算机控制系统和通讯设备,以实现cpu与串行口和modem的通讯。16c550配备一个串行口,16c552配备两个串行口,而16c554配备四个串行口。16c550系列器件的实质是实现串行口与cpu并行口的转换,其自身有较强的数字逻辑功能。16c550系列器件的串行口工作方式均可编程,有的还带有开关量输入输出接口,可以作为cpu的开关量扩展接口用。

  ⑤用分立器件将并行口转换为串行口

  文献提供了一种利用555定时器、d触发器和移位寄存器等分立元件实现串、并口互相转换的电路。该电路用定时器产生与波特率一直的同步时钟信号,把接收到的数据移位寄存到并口供cpu读取,或把并行口的数据移位发出,其实质是用若干个分立元件模拟16c550的功能。

  ⑥串行口扩展芯片

  现在有一种专门的sp系列串行口扩展芯片,可以将一路高速的全双工串行口扩展为多路的低速全双工串行口,串口的波特率通过晶振统一确定。如sp2328和sp2338可以将一路母串口扩展为三路子串口,sp2538可以将一路母串口扩展为五路子串口。该系列芯片有输入地址线和输出地址线,在通过母串口向子串口发送数据时要给输出地址线上加选择电平,确定从哪一路子串口输出,在通过母串口从子串口读取数据时要检测输入地址线的电平,以确定是哪一路子串口的信号。该系列芯片应该是采用分时机制,通过内部的逻辑电路将一路数据分解为多路或将多路数据合成为一路。如sp2328母串口的波特率是子串口波特率的四倍,sp2538母串口的波特率是子串口波特率的六倍。

  ⑦用多路复用器扩展串行口

  文献提供了一种利用多路复用器max353将一路串行口扩展为两路的方法。在发送信号的时候,cpu先给出max353的端口选择地址,串行信号经多路复用器的切换,从指定通道发送出去。在接受信号的时候,将多路复用器默认为第一通道,第二路串行口的rxd2同时接到(2pu的外部中断引脚上。如果第一通道有数据,则直接接收。如果第二通道有数据.rxd2的起始位将产生一个外部中断,cpu进入中断响应程序,将复用器切换到第二通道,接受rxd2的数据。一个字节接收完毕后,将复用器切换回第一通道。

  文献的方法占用了一个外部中断,且只能将一路串口扩展为两路。基于同样的思路,可以

  1  引言

  在以单片机为核心的测控系统中.微控制器往往需要两个或两个以上的串行口与其他主机或外设进行通讯,如何使系统具备多个串行接口,是一个具有普遍性的问题。尤其在航空航天领域,由于gps、大气数据系统、数字罗盘、无线电高度表、甚至陀螺等航空电子设备普遍采用串行通讯方式,单片计算机系统就更需要有多个串行口以满足与外界信息交换的需要。

  2 常用的多串行口设计方法

  ①选用多串行口单片机

  直接选用多串行口单片机作为系统的cpu,显然是最直接有效的方法。现在有许多新型cpu配备两个或两个以上串行口,如w77e58、ds80c320、msp430f149、c8051f020单片机和数字信号处理器tms320c30有两个串行口,而cygnal的c8051f系列单片机有4-5个全双工的异步串行口。

  ②用cpu的i/o模拟串行口

  当串行口的波特率设为9600波特时,传送一个bit需要100us左右,对于一般的单片机而言,软件定时器完全有能力按异步串行通讯协议模拟出串行口的时序。所以,用cpu的两个i/o口和一个软件定时器,就可以纯粹用软件模拟出一个串行口来。文献介绍了一种具体的实现方法,发送时,只需按时序一位一位输出数据即可,接收时,首先利用外部中断检测到i/o接收口上的起始电平,然后利用定时器按半个bit的时间长度延时接收第一个bit的数据,再按一个bit的时间长度延时依此读取其他位的信号。

  ③基于高速输入输出的软件串行口

  80c196系列单片机配备了高速输入hsi和高速输出hso接口.可以利用hsi和hso来模拟串行口。数据的输出利用hso,只要在hso的定时器里写入与波特率对应的延迟时间,hso每中断一次,输出一个数据位,直到停止位输出完毕。接收时,利用hsi自身的信号跳变检测功能检测起始位,并产生中断通知cpu开始接收数据,后续的数据位由软件定时器按波特率定时读取。文献详细介绍了实现方法,并给出了完整的程序代码;本方法在80c196mc/md单片机中。则表现为事件处理阵列epa和外设事物服务器pts的应用,其优点是epa的每个模块与cpu的指定引脚对应,减少了软件开销和程序设计的复杂度。

  ④16c550系列可编程通讯控制器

  利用并行口扩展串行口的接口芯片种类较多,其中16c550系列通讯控制器普遍应用于计算机控制系统和通讯设备,以实现cpu与串行口和modem的通讯。16c550配备一个串行口,16c552配备两个串行口,而16c554配备四个串行口。16c550系列器件的实质是实现串行口与cpu并行口的转换,其自身有较强的数字逻辑功能。16c550系列器件的串行口工作方式均可编程,有的还带有开关量输入输出接口,可以作为cpu的开关量扩展接口用。

  ⑤用分立器件将并行口转换为串行口

  文献提供了一种利用555定时器、d触发器和移位寄存器等分立元件实现串、并口互相转换的电路。该电路用定时器产生与波特率一直的同步时钟信号,把接收到的数据移位寄存到并口供cpu读取,或把并行口的数据移位发出,其实质是用若干个分立元件模拟16c550的功能。

  ⑥串行口扩展芯片

  现在有一种专门的sp系列串行口扩展芯片,可以将一路高速的全双工串行口扩展为多路的低速全双工串行口,串口的波特率通过晶振统一确定。如sp2328和sp2338可以将一路母串口扩展为三路子串口,sp2538可以将一路母串口扩展为五路子串口。该系列芯片有输入地址线和输出地址线,在通过母串口向子串口发送数据时要给输出地址线上加选择电平,确定从哪一路子串口输出,在通过母串口从子串口读取数据时要检测输入地址线的电平,以确定是哪一路子串口的信号。该系列芯片应该是采用分时机制,通过内部的逻辑电路将一路数据分解为多路或将多路数据合成为一路。如sp2328母串口的波特率是子串口波特率的四倍,sp2538母串口的波特率是子串口波特率的六倍。

  ⑦用多路复用器扩展串行口

  文献提供了一种利用多路复用器max353将一路串行口扩展为两路的方法。在发送信号的时候,cpu先给出max353的端口选择地址,串行信号经多路复用器的切换,从指定通道发送出去。在接受信号的时候,将多路复用器默认为第一通道,第二路串行口的rxd2同时接到(2pu的外部中断引脚上。如果第一通道有数据,则直接接收。如果第二通道有数据.rxd2的起始位将产生一个外部中断,cpu进入中断响应程序,将复用器切换到第二通道,接受rxd2的数据。一个字节接收完毕后,将复用器切换回第一通道。

  文献的方法占用了一个外部中断,且只能将一路串口扩展为两路。基于同样的思路,可以

相关IC型号

热门点击

 

推荐技术资料

硬盘式MP3播放器终级改
    一次偶然的机会我结识了NE0 2511,那是一个远方的... [详细]
版权所有:51dzw.COM
深圳服务热线:13692101218  13751165337
粤ICP备09112631号-6(miitbeian.gov.cn)
公网安备44030402000607
深圳市碧威特网络技术有限公司
付款方式


 复制成功!