一种异步串行通讯控制器件的制作方法

文档序号:6561048阅读:287来源:国知局
专利名称:一种异步串行通讯控制器件的制作方法
一种异步串行通讯控制器件所厲领域本发明涉及通讯领域,尤其涉及通讯领域中的串行通讯领域。 背荣技术目前许多电子系统中需要用到异步串行通讯方式来进行通讯,当同一个设备(或模块、系统)需要较 多的串行口时, 一般采用以下方法1. 使用本身就具有多个异步串行通讯接口的通用控制器件。这样的通用控制器件一般设计有2到3个异 步串行通讯接口。采用此法能够获得的串口数量还是有限。2. 使用软件方法利用通用控制器件的普通输入输出端口模拟异步串行端口的时序和通讯格式进行扩展。 采用此法能够扩展的串口数量和通讯速率有限。3. 使用异步收发串行扩展专用集成电路,代表性的芯片有TI公司16C55X系列芯片。釆用此方法技术 复杂,占用系统资源多,成本高。使用此方法不能实现与该类型器件连接的器件之间相互直接通讯。4. 使用串口扩展多串口器件,代表性的器件有GM812X系列和SP233X系列串口扩展芯片,使用此方 法因为要使用额外的IO 口作为多通道子串口的地址线,在接收到每一帧数据后都必须立即读取子串口 的地址线来判断数据的来源或决定数据的去向(否则就有可能丢失数据),导致器件本身的母串口数据 缓冲队列以及和母串口相连接的串口的数据缓冲队列失去应有的作用,处理时间增加,所以不能实现 高速数据传输。使用此方法不能实现与该类型器件连接的器件之间相互直接通讯。 当有多个系统需要使用异步串行口进行互连时,必须把一个系统当主控系统,其他系统把信息发送给主控系统,经过主控系统进行中转分发,增加了中间处理环节,降低了效率。

发明内容
本发明的目的在于提供一种可支持多个异步串行口均可以相互直接进行髙速通讯的控制器件,使用方 法简单。为了实现上述目的,本发明实现上述目的的技术方案是 一种异步串行通讯控制器件,它包括3个以 上(含3个)的异步串行控制器内部控制逻辑,以及与每个异步串行控制器对应的发送端口、接收端口、 发送目的寄存器和接收来源寄存器,主控制器。主控制器处理从各异步串行口接收过来的信息幀,并判断 信息帧的类型是指令帧还是数据帧进行相应的处理如果是指令帧,就根据指令帧的内容对相关的寄存器 进行操作,如果是数据帧就根据相关寄存器的内容把数据帧的内容从设定的串行口以设定的数据格式和速 率发送出去。本发明所包括的各串行接口都有编号0, 1, 2* n。本发明所包括的寄存器有串口0 串口n的发送目的寄存器存放从串口接收进来的数据楨将要发 往的串口的编号。串口0 串口n的接收来源寄存器存放从串口发送出去的数据帧的来源串口的编号。 发送目的寄存器可以是固定的,B卩从某个串口接收过来的数据只发往另外一个固定的串口。 接收来源寄存器可以是固定的,即某个串口只发送从另外一个固定的串口接收过来的数据。 本发明所述信息帧是指直接从各串口接收和发送的内容,本发明串行通讯控制器件把信息帧分为指令 帧和数据帧,指令帧是指用来对本发明串行通讯控制器件进行设置和控制的信息,数据帧指各串口发送到 其他串口和从其他串口接收的实际数据信息。指令帧和数据帧可以利用接收到到的信息帧里的某一位来进 行判断。比如如果串口 n使用的通讯格式为9位数据位加1位停止位,就可以把第9位数据位作为判断 标志第9位数据位是0作为数据帧,第9位数据位是1作为指令帧。或者反过来第9位数据位是1作为数据帧,第9位数据位是0作为指令帧。指令帧和数据帧也可以利用接收到的信息帧里的某几位来进行 判断,指令帧和数据帧还可以利用接收到到信息帧时的器件的10 口的状态来判断。本发明串行通讯控制器件处理信息帧的典型过程当从串口 l接收到一个指令帧,该指令帧要求发送数据到串口 2,主控制器处理到串口1的这个指令帧时就把串口1的发送目的寄存器设置为串口 2的编号。 主控制器会把接下来的从串口 1接收的数据通过串口 2发送出去,直到接收到新的指令改变串口 1的发送 目的寄存器值为止。主控制器在把从串口 l接收的数据通过串口2发送出去时会先检查串口2的接收来源
寄存器是否等于串口 1的编号,如果不等,主控制器会先通过串口2发送一个指令桢,告诉与串口2连接 的设备(模块或系统)接下来发送的数据来源是串口 1,同时把串口 2的接收来源寄存器设置为串口 1的 编号。如果相等,就直接通过串口2发送数据帧。本发明串行通讯控制器件包含的串行控制器以及与每个异步串行控制器对应的数据发送逻辑、数据接 收逻辑、发送端口、接收端口、发送目的寄存器和接收来源寄存器可以是基于硬件实现方式的。本发明串行通讯控制器件包含的串行控制器以及与每个异步串行控制器对应的数据发送逻辑、数据接 收逻辑、发送端口、接收端口、发送目的寄存器和接收来源寄存器也可以是基于软件模拟方式实现的。本发明串行通讯控制器件包含的串行控制器以及与每个异步串行控制器对应的数据发送逻辑、数据接 收逻辑、发送端口、接收端口、发送目的寄存器和接收来源寄存器是基于硬件方式和软件模拟方式两者混 合的方式实现的。本发明串行通讯控制器件还可以包括一组或多组缓冲。因为串口数量较多,传输的数据量也大,所以 使用缓冲存储未来得及处理的信息和已经处理的信息,比如某个串口的通讯速率很高,当此串口短时间内 突发收到多帧信息,主控制器来不及处理,就可以把收到的信息先放进一组缓冲,又比如某个串口的通讯 速率很低,当此串口短时间内需要发送多帧信息,也可以把要发送的信息放入一组缓冲。缓冲的设置还可 以实现高优先级的指令帧优先处理或发送当主控制器处理到高优先级的的指令帧时,可以把该指令帧插 入缓冲的头部,使该指令帧获得优先处理或发送。本发明串行通讯控制器件从各个串口接收数据的方式可以是中断方式,也可以是査询方式。 本发明串行通讯控制器件向各个串口发送数据的方式可以是中断方式,也可以是査询方式。本发明串行通讯控制器件还可以包括以下寄存器串口通讯格式寄存器存放串口的通讯格式设置参 数。串口通讯速率寄存器存放串口的通讯速率设置参数。串口错误寄存器存放处理与串口的相关的寄 存器和数据时的出错信息,比如缓冲器溢出信息等。实际使用中,用户可以选择使用硬件也可以选择使用软件方式来设置本发明串行通讯控制器件的寄存器。综上所述,本发明实现了与本发明串行通讯控制器件连接的多个异步串行接口均可以相互直接进行高 速通讯,不需使用额外的通讯控制线,使用简单。与同类产品相比,本发明串行通讯控制器件具有以下优 :1. 通用型强本发明串行通讯控制器件既可以作为单串口扩展多串口器件使用,也可以作为多系统 通过串口互连使用。多系统通过串口互连在不使用主控系统的情况下如果不使用本器件,如果霈要互连的系统是n个,那么每个系统必须要有(n—l)个串口,使用本发明串行通讯控制器每个 系统只需要l个串口就可以了,系统处理器的选型范围显著扩大,硬件成本显著降低,系统的硬 件和软件设计复杂度显著降低,能够显著降低成本。2. 控制简单,本发明串行通讯控制器件可以利用软件设置寄存器,没有额外的控制线。显著降低技 术复杂度。3. 应用灵活本发明串行通讯控制器件的各个串口通讯速率都可以单独设定,也可以统一设定。


附图是本发明所述的最佳实施例的示意图; 下面结合结合附图和实施例对本发明做进一步说明。
具体实施方式
最佳实施例参见附图,本发明由以下几个部分组成n个异步串行控制器内部控制逻辑,以及与每个异步串行控 制器对应的发送端口、接收端口、发送目的寄存器和接收来源寄存器,与每个异步串行控制器对应的发送 缓冲器,与每个异步串行控制器对应的接收缓冲器,主控制器,各个串口独立工作,接收到的数据进入接 收缓冲等待处理,主控制器循环处理各个串口接收缓冲的信息帧。如果是指令帧,就根据指令帧的内容对 相关的寄存器进行操作,如果是数据帧就根据相关寄存器的内容把数据帧的内容从设定的串行口以设定的 数据格式和速率发送出去。
权利要求
1. 一种异步串行通讯控制器件,其特征在于包括3个以上的异步串行控制器内部控制逻辑,以及与每 个异步串行控制器对应的发送端口、接收端口、发送目的寄存器和接收来源寄存器,主控制器。主控 制器处理从各异步串行口接收过来的信息帧,并判断信息帧的类型是指令帧还是数据帧进行相应的处 理如果是指令帧,就根据指令帧的内容对相关的寄存器进行操作,如果是数据帧就根据相关寄存器 的内容把数据帧的内容从设定的串行口以设定的数据格式和速率发送出去。
2. 根据权利要求1所述的异步串行通讯控制器件,其特征在于使用的通讯格式为9位数据位加l位停 止位,把第9位数据位作为判断标志第9位数据位是0作为数据帧,第9位数据位是1作为指令帧。
3. 根据权利要求1所述的异步串行通讯控制器件,其特征在于使用的通讯格式为9位数据位加1位停 止位,把第9位数据位作为判断标志第9位数据位是1作为数据帧,第9位数据位是0作为指令帧。
4. 根据权利要求1所述的异步串行通讯控制器件,其特征在于包括多组缓冲,用于存储未来得及处理 的信息和已经处理的信息。
5. 根据权利要求l所述的异步串口控制器件,其特征在于包括以下寄存器串口通讯格式寄存器存 放串口的通讯格式设置参数。串口通讯速率寄存器存放串口的通讯速率设置参数。串口错误寄存器: 存放处理与串口的相关的寄存器和数据时的出错信息。
全文摘要
本发明公开了一种异步串行通讯控制器件,它包括3个以上的异步串行控制器内部控制逻辑,以及与每个异步串行控制器对应的发送端口、接收端口、发送目的寄存器和接收来源寄存器,主控制器。主控制器处理从各异步串行口接收过来的信息帧,并判断信息帧的类型是指令帧还是数据帧进行相应的处理如果是指令帧,就根据指令帧的内容对相关的寄存器进行操作,如果是数据帧就根据相关寄存器的内容把数据帧的内容从设定的串行口以设定的数据格式和速率发送出去。本发明具有以下优点支持多个异步串行接口均可以相互直接进行高速通讯,提高了系统的效率,使用方法简单。
文档编号G06F13/42GK101122894SQ20061011526
公开日2008年2月13日 申请日期2006年8月13日 优先权日2006年8月13日
发明者朱金怀 申请人:朱金怀
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1