CN113377701B - 基于复杂可编程逻辑器件cpld的串口控制系统及其通信方法 - Google Patents

基于复杂可编程逻辑器件cpld的串口控制系统及其通信方法 Download PDF

Info

Publication number
CN113377701B
CN113377701B CN202110694686.9A CN202110694686A CN113377701B CN 113377701 B CN113377701 B CN 113377701B CN 202110694686 A CN202110694686 A CN 202110694686A CN 113377701 B CN113377701 B CN 113377701B
Authority
CN
China
Prior art keywords
register
serial port
processor
controller
cpld
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
CN202110694686.9A
Other languages
English (en)
Other versions
CN113377701A (zh
Inventor
刘刚
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Dongguan Huabei Electronic Technology Co Ltd
Original Assignee
Dongguan Huabei Electronic Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Dongguan Huabei Electronic Technology Co Ltd filed Critical Dongguan Huabei Electronic Technology Co Ltd
Priority to CN202110694686.9A priority Critical patent/CN113377701B/zh
Publication of CN113377701A publication Critical patent/CN113377701A/zh
Priority to US18/569,727 priority patent/US12086093B2/en
Priority to PCT/CN2021/129522 priority patent/WO2022267303A1/zh
Application granted granted Critical
Publication of CN113377701B publication Critical patent/CN113377701B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/38Information transfer, e.g. on bus
    • G06F13/42Bus transfer protocol, e.g. handshake; Synchronisation
    • G06F13/4282Bus transfer protocol, e.g. handshake; Synchronisation on a serial bus, e.g. I2C bus, SPI bus
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2213/00Indexing scheme relating to interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F2213/0002Serial port, e.g. RS232C
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02PCLIMATE CHANGE MITIGATION TECHNOLOGIES IN THE PRODUCTION OR PROCESSING OF GOODS
    • Y02P90/00Enabling technologies with a potential contribution to greenhouse gas [GHG] emissions mitigation
    • Y02P90/02Total factory control, e.g. smart factories, flexible manufacturing systems [FMS] or integrated manufacturing systems [IMS]

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Information Transfer Systems (AREA)
  • Programmable Controllers (AREA)

Abstract

本发明公开了一种基于复杂可编程逻辑器件CPLD的串口控制系统及其通信方法,其中串口控制系统包括控制台、多个处理器以及设置在控制台与多个处理器之间的CPLD,CPLD包括控制器和寄存器;控制台被配置为发送指令至控制器,指令包括对应的处理器的串口的寄存器地址和寄存器内容;控制器被配置为解析指令以获取对应的寄存器地址和寄存器内容并写入寄存器;根据寄存器地址和寄存器内容,控制器与对应的处理器的串口进行通信。本发明利用CPLD的控制器和寄存器能够自动切换串口以与对应的处理器进行通信,进而提高效率。

Description

基于复杂可编程逻辑器件CPLD的串口控制系统及其通信方法
技术领域
本发明涉及交换机和服务器硬件设计技术领域,尤其涉及一种基于复杂可编程逻辑器件CPLD的串口控制系统及其通信方法。
背景技术
当前的服务器或交换机的系统设计中,一般包括多个处理器,例如X86处理器、BMC(Baseboard Management Controller,基板管理控制器)以及其他带有UART接口的器件,如CPLD(Complex Programmable Logic Device,复杂可编程逻辑器件)和FPGA(Field-Programmable Gate Array,现场可编程门阵列)等。目前这些端口与控制台(Console)连接方法主要采用Debug header,这种方法需要人工介入,例如需求关机后手动进行连接器Debug,并且针对不同的处理器,要进行多次切换Debug,较为复杂,切换效率较低。
发明内容
本发明的目的是为解决上述技术问题的不足而提供一种基于复杂可编程逻辑器件CPLD的串口控制系统及其通信方法,能够自动切换串口以与所需的处理器进行通信,进而提高效率。
为了实现上述目的,本发明公开了一种基于复杂可编程逻辑器件CPLD的串口控制系统,其包括控制台、多个处理器以及设置在所述控制台与所述多个处理器之间的CPLD,所述CPLD包括控制器和寄存器;
所述控制台被配置为发送指令至所述控制器,所述指令包括对应的所述处理器的串口的寄存器地址和寄存器内容;
所述控制器被配置为解析所述指令以获取对应的所述寄存器地址和所述寄存器内容并写入所述寄存器;
根据所述寄存器地址和所述寄存器内容,所述控制器与对应的所述处理器的串口进行通信。
可选地,所述控制器还被配置为根据所述处理器的串口模式参数修改所述CPLD的串口模式参数。
可选地,所述串口模式参数包括波特率和/或检验位。
可选地,所述控制台还被配置为读取所述寄存器的状态信息。
可选地,所述状态信息包括状态机和状态参数。
可选地,所述控制器根据所述寄存器的配置与所述处理器通讯以获取所述处理器返回的状态信息。
可选地,所述控制器以预设时间间隔获取所述处理器的状态信息。
可选地,所述寄存器通过所述控制台和/或所述处理器进行配置。
可选地,所述处理器中的一者发送出的信息通过所述CPLD的串口组发送至所述处理器中的另一者。
为了实现上述另一目的,本申请还提供一种如上所述的基于复杂可编程逻辑器件CPLD的串口控制系统的通信方法,其包括:
所述控制台发送指令至所述控制器;
所述控制器解析所述指令以获取对应的所述寄存器地址和所述寄存器内容并写入所述寄存器;
根据所述寄存器地址和所述寄存器内容,所述控制器与对应的所述处理器的串口进行通信。
本发明在CPLD内设置有控制器和寄存器,在使用时,控制台发送指令至控制器,接着控制器解析接收到的指令以获取对应的寄存器地址和寄存器内容并写入寄存器,最后根据寄存器地址和寄存器内容,控制器与对应的处理器通信。因此,本发明利用CPLD的控制器和寄存器能够自动切换串口以与对应的处理器进行通信,进而提高效率。
附图说明
图1为本发明实施例基于复杂可编程逻辑器件CPLD的串口控制系统的结构示意图。
图2为本发明另一实施例基于复杂可编程逻辑器件CPLD的串口控制系统的结构示意图。
图3是本发明实施例基于复杂可编程逻辑器件CPLD的串口控制系统的通信方法的流程示意图。
具体实施方式
为详细说明本发明的技术内容、结构特征、实现原理及所实现目的及效果,以下结合实施方式并配合附图详予说明。
请参阅图1,本发明实施例公开了一种基于复杂可编程逻辑器件CPLD的串口控制系统,其包括控制台1、多个处理器2以及设置在控制台1与多个处理器2之间的CPLD,CPLD包括控制器31和寄存器32。控制台1被配置为发送指令至控制器31,指令包括对应的处理器2的串口的寄存器地址和寄存器内容。控制器31被配置为解析指令以获取对应的寄存器地址和寄存器内容并写入寄存器32。根据寄存器地址和寄存器内容,控制器31与对应的处理器2的串口进行通信。
本发明在CPLD内设置有控制器31和寄存器32,在使用时,控制台1发送指令至控制器31,接着控制器31解析接收到的指令以获取对应的寄存器地址和寄存器内容并写入寄存器32,最后根据寄存器地址和寄存器内容,控制器31与对应的处理器2通信。因此,本发明利用CPLD的控制器31和寄存器32能够自动切换串口以与对应的处理器2进行通信,进而提高效率。
具体地,控制台1通过串口接口与CPLD连接,多个处理器2分别通过串口接口与CPLD连接。优选地,多个处理器2可包括X86处理器21、BMC 22及其他带有UART接口的各种器件,如CPLD/FPGA 23等。串口接口为UART接口,控制台1采用RS-232C标准的接口与CPLD进行连接,当然串口接口的具体形式也可以是其他形式,在此不作限制。
本发明的基于复杂可编程逻辑器件CPLD的串口控制系统在使用时,控制台1通过串口接口发送指令至CPLD的控制器31。接着控制器31解析该指令以获取该指令对应的串口的寄存器地址和寄存器内容并将其写入寄存器32,其中,寄存器地址指对应处理器2的串口地址,例如,X86处理器21、BMC 22的串口地址。而寄存器内容指与对应处理器2通信的内容,例如,需要执行的动作、功能及传输数据等。当然一个指令可以包括一个或一个以上寄存器地址以及一个或一个以上寄存器内容。最后,控制器31根据寄存器地址和寄存器内容,与对应的处理器2的串口进行通信。
在一些实施例中,控制器31还被配置为根据处理器2的串口模式参数修改CPLD的串口模式参数。
通过上述技术手段,有利于控制器31与具有不同串口模式参数的处理器2进行通信,提高系统的适用性。
具体地,处理器2的串口模式参数可能存在不同,控制器31先获取需要进行通信的处理器2的串口模式参数,接着控制器31根据获取的串口模式参数,修改CPLD的串口模式参数,使CPLD的串口模式参数与需要进行通信的处理器2的串口模式参数匹配。
进一步地,串口模式参数包括但不限于波特率和/或检验位。
具体地,串口模式参数可以只包括波特率,由于波特率是衡量数据传送速率的指标,同时串口彼此之间通信,必须使用相同的波特率进行操作,因此通过控制器31修改CPLD的波特率以与需要进行通信的处理器2的波特率相同,有利于控制器31与对应的处理器2的串口正常通信。另外串口模式参数也可以只包括检验位,通过辨别检验位可以校验数据传送的正确性。当然串口模式参数也可以同时包括波特率和检验位,在此不作限制。
上述设置无需修改系统的硬件即可与具有不同串口模式参数的处理器2进行正常通信。
在一些实施例中,控制台1还被配置为读取寄存器32的状态信息。通过上述方式,有利于及时获取CPLD的状态信息,便于清楚了解CPLD运作状况,方便监控和后期调试。
具体地,控制台1通过串口获取CPLD的寄存器32的状态信息。
进一步地,状态信息包括状态机和状态参数。状态机能够反馈CPLD的运行流程,状态参数指CPLD在运行时处于各状态的数据。
在一些实施例中,控制器31根据寄存器32的配置与处理器2通讯以获取处理器2返回的状态信息。
通过上述技术手段,有利于及时获取各处理器2的状态信息,便于监控和调试各处理器2。
进一步地,控制器31以预设时间间隔获取处理器2的状态信息。
具体地,控制器31可根据预设时间间隔与一个或多个处理器2通信,其中,预设时间间隔的具体数值可在CPLD上设定,本发明对此不作限定。在运行过程中,寄存器32配置有需要被监控的处理器2的信息,控制器31根据寄存器32的配置信息,通过CPLD的串口发送指令至需要被监控的处理器2,需要被监控的处理器2接收到指令后,返回该处理器2的状态信息于CPLD,有利于CPLD获取各处理器2的状态信息。上述过程无需控制台1的介入,同时需要被监控的处理器2无需花费额外的进程,进而减少处理器2的工作量。另外,当CPLD获取到对应处理器2的状态信息时,对获取到的状态信息进行分析,接着可作出相应的动作指令,例如关机,重启或者上报中断等。
在一些实施例中,寄存器32通过控制台1和/或处理器2进行配置。
采用多种方式配置寄存器32,能够提高系统的便捷性以及丰富其功能。
具体地,寄存器32可以只通过控制台1进行配置,如控制台1可通过串口发送指令的形式配置寄存器32。寄存器32也可以只通过处理器2配置,处理器2可通过I2C、LPC等方式配置寄存器32,该设置可以摆脱控制台1的介入。当然寄存器32可以由控制台1和处理器2同时配置,在此不作限定。
寄存器32的具体配置至少包括以下一种:
(1)配置工作模式。控制器31根据寄存器32配置的工作模式,切换对应的串口通信模式。
(2)配置串口模式参数。控制器31根据寄存器32配置的串口模式参数,修改CPLD的串口模式参数。
(3)配置读取寄存器32状态信息的功能,控制器31根据寄存器32配置的读取状态信息的功能,读取寄存器32的状态信息。
(4)获取处理器2状态信息的功能,控制器31根据寄存器32配置的获取处理器2状态信息的功能,获取处理器2的状态信息。
当然,寄存器32的配置并不限于上述具体形式。
请参阅图2,在一些实施例中,处理器2中的一者发送出的信息通过CPLD上的串口组发送至处理器2中的另一者。
通过上述技术手段,有利于处理器2之间信息传递,扩展了CPLD的功能应用,比如,可以通过接收信息的串口对发送信息的串口进行监控。
具体地,CPLD上的串口组由多个串口组成,多个处理器2分别通过串口与CPLD连接。处理器2先通过串口发送信息至CPLD,CPLD再将该信息通过对应串口发送到至另外的一个或多个处理器2。
请参阅图3,本申请还提供一种上述的基于复杂可编程逻辑器件CPLD的串口控制系统的通信方法,其包括以下步骤:
101、控制台1发送指令至控制器31;
102、控制器31解析指令以获取对应的寄存器地址和寄存器内容并写入寄存器32;
103、根据寄存器地址和寄存器内容,控制器31与对应的处理器2的串口进行通信。
通过上述方法能够自动切换串口以与对应的处理器2进行通信,进而提高效率。
以上所揭露的仅为本发明的较佳实例而已,当然不能以此来限定本发明之权利范围,因此依本发明申请专利范围所作的等同变化,仍属于本发明所涵盖的范围。

Claims (9)

1.一种基于复杂可编程逻辑器件CPLD的串口控制系统,其特征在于,包括控制台、多个处理器以及设置在所述控制台与所述多个处理器之间的CPLD,所述CPLD包括控制器和寄存器;
所述控制台被配置为发送指令至所述控制器,所述指令包括对应的所述处理器的串口的寄存器地址和寄存器内容;
所述控制器被配置为解析所述指令以获取对应的所述寄存器地址和所述寄存器内容并写入所述寄存器;
根据所述寄存器地址和所述寄存器内容,所述控制器与对应的所述处理器的串口进行通信;
所述寄存器配置有需要被监控的所述处理器的信息,所述控制器根据所述寄存器的配置信息,通过所述CPLD的串口发送指令至需要被监控的所述处理器,需要被监控的所述处理器接收到指令后,返回该处理器的状态信息于所述CPLD;
当所述CPLD获取到所述处理器的状态信息时,对获取到的状态信息进行分析并作出相应的动作指令。
2.如权利要求1所述的串口控制系统,其特征在于,
所述控制器还被配置为根据所述处理器的串口模式参数修改所述CPLD的串口模式参数。
3.如权利要求2所述的串口控制系统,其特征在于,所述串口模式参数包括波特率和/或检验位。
4.如权利要求1所述的串口控制系统,其特征在于,
所述控制台还被配置为读取所述寄存器的状态信息。
5.如权利要求4所述的串口控制系统,其特征在于,
所述状态信息包括状态机和状态参数。
6.如权利要求1所述的串口控制系统,其特征在于,
所述控制器以预设时间间隔获取所述处理器的状态信息。
7.如权利要求1所述的串口控制系统,其特征在于,
所述寄存器通过所述控制台和/或所述处理器进行配置。
8.如权利要求1所述的串口控制系统,其特征在于,
所述处理器中的一者发送出的信息通过所述CPLD的串口组发送至所述处理器中的另一者。
9.一种如权利要求1至8任一项所述的基于复杂可编程逻辑器件CPLD的串口控制系统的通信方法,其特征在于,包括:
所述控制台发送指令至所述控制器;
所述控制器解析所述指令以获取对应的所述寄存器地址和所述寄存器内容并写入所述寄存器;
根据所述寄存器地址和所述寄存器内容,所述控制器与对应的所述处理器的串口进行通信。
CN202110694686.9A 2021-06-22 2021-06-22 基于复杂可编程逻辑器件cpld的串口控制系统及其通信方法 Active CN113377701B (zh)

Priority Applications (3)

Application Number Priority Date Filing Date Title
CN202110694686.9A CN113377701B (zh) 2021-06-22 2021-06-22 基于复杂可编程逻辑器件cpld的串口控制系统及其通信方法
US18/569,727 US12086093B2 (en) 2021-06-22 2021-11-09 Serial port control system based on complex programmable logic device (CPLD) and communication method therefor
PCT/CN2021/129522 WO2022267303A1 (zh) 2021-06-22 2021-11-09 基于复杂可编程逻辑器件cpld的串口控制系统及其通信方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202110694686.9A CN113377701B (zh) 2021-06-22 2021-06-22 基于复杂可编程逻辑器件cpld的串口控制系统及其通信方法

Publications (2)

Publication Number Publication Date
CN113377701A CN113377701A (zh) 2021-09-10
CN113377701B true CN113377701B (zh) 2023-04-11

Family

ID=77578495

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202110694686.9A Active CN113377701B (zh) 2021-06-22 2021-06-22 基于复杂可编程逻辑器件cpld的串口控制系统及其通信方法

Country Status (2)

Country Link
CN (1) CN113377701B (zh)
WO (1) WO2022267303A1 (zh)

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113377701B (zh) * 2021-06-22 2023-04-11 东莞华贝电子科技有限公司 基于复杂可编程逻辑器件cpld的串口控制系统及其通信方法
CN117591449B (zh) * 2024-01-17 2024-04-23 苏州元脑智能科技有限公司 一种基板的可编程逻辑器件系统及其应用设备

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107908582A (zh) * 2017-11-06 2018-04-13 杭州宏杉科技股份有限公司 串口切换装置和存储设备

Family Cites Families (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105243039A (zh) * 2015-11-13 2016-01-13 上海斐讯数据通信技术有限公司 一种串口通信系统及方法
CN107145464A (zh) * 2017-05-25 2017-09-08 郑州云海信息技术有限公司 一种多串口调试方法、装置及系统
CN109558369A (zh) * 2018-11-29 2019-04-02 杭州迪普科技股份有限公司 多cpu单串口的控制方法、装置、设备及系统
CN109857685B (zh) * 2018-12-06 2021-04-09 积成电子股份有限公司 一种mpu与fpga扩展多串口的实现方法
CN112015602A (zh) * 2019-05-30 2020-12-01 鸿富锦精密电子(天津)有限公司 调试装置及具有所述调试装置的电子装置
CN113377701B (zh) * 2021-06-22 2023-04-11 东莞华贝电子科技有限公司 基于复杂可编程逻辑器件cpld的串口控制系统及其通信方法

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107908582A (zh) * 2017-11-06 2018-04-13 杭州宏杉科技股份有限公司 串口切换装置和存储设备

Also Published As

Publication number Publication date
WO2022267303A1 (zh) 2022-12-29
US20240273053A1 (en) 2024-08-15
CN113377701A (zh) 2021-09-10

Similar Documents

Publication Publication Date Title
CN113377701B (zh) 基于复杂可编程逻辑器件cpld的串口控制系统及其通信方法
CN107908582A (zh) 串口切换装置和存储设备
CN112055096B (zh) 自动设置设备通信地址的方法及装置
CN110865958B (zh) 一种基于lrm的综合交换管理模块的设计方法
MX2008003299A (es) Depuracion de sistemas integrados.
WO2024078223A1 (zh) 一种电子设备及其PCIe拓扑配置方法和装置
CN105183575A (zh) 处理器故障的诊断方法、装置及系统
CN105159851A (zh) 多控存储系统
CN102426548B (zh) 嵌入式系统的调试方法、调试器和调试系统
CN112118158A (zh) 一种交换机的测试方法、测试装置、测试设备及存储介质
CN115858221A (zh) 存储设备的管理方法、装置、存储介质及电子设备
CN104750057B (zh) 样本处理流水线控制系统
CN109558369A (zh) 多cpu单串口的控制方法、装置、设备及系统
CN116627861B (zh) 基于扩展器的数据处理方法、系统、电子设备及存储介质
CN107729035A (zh) 分布式电池管理系统程序下载及更新方法
DE3586925T2 (de) Netzsteuerungssystem fuer mehrere prozessormodule.
US12086093B2 (en) Serial port control system based on complex programmable logic device (CPLD) and communication method therefor
CN109270885B (zh) 监测plc系统的数据通信方法、装置、设备及存储介质
CN115599617B (zh) 总线检测方法、装置、服务器及电子设备
CN101267350A (zh) 调试方法和调试系统
CN116300780B (zh) 零部件配置方法、装置、电子设备及存储介质
CN115168141A (zh) 光口管理系统、方法、装置、可编程逻辑器件及存储介质
CN110417581B (zh) 一种基于以太网的RapidIO交换网络在线配置与升级方法
CN116719712B (zh) 处理器串口日志输出方法、装置、电子设备及存储介质
CN117687859B (zh) PCIe设备的异常检测设备、系统、服务器、方法

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant