CN115374035A - 基于单片机的串口扩展方法、串口扩展设备和清洁机器人 - Google Patents

基于单片机的串口扩展方法、串口扩展设备和清洁机器人 Download PDF

Info

Publication number
CN115374035A
CN115374035A CN202210843904.5A CN202210843904A CN115374035A CN 115374035 A CN115374035 A CN 115374035A CN 202210843904 A CN202210843904 A CN 202210843904A CN 115374035 A CN115374035 A CN 115374035A
Authority
CN
China
Prior art keywords
serial port
data
chip microcomputer
single chip
port expansion
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.)
Pending
Application number
CN202210843904.5A
Other languages
English (en)
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.)
Guangzhou Coayu Robot Co Ltd
Original Assignee
Guangzhou Coayu Robot 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 Guangzhou Coayu Robot Co Ltd filed Critical Guangzhou Coayu Robot Co Ltd
Priority to CN202210843904.5A priority Critical patent/CN115374035A/zh
Publication of CN115374035A publication Critical patent/CN115374035A/zh
Pending legal-status Critical Current

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/40Bus structure
    • G06F13/4063Device-to-bus coupling
    • G06F13/4068Electrical coupling
    • G06F13/4072Drivers or receivers
    • 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/14Handling requests for interconnection or transfer
    • G06F13/16Handling requests for interconnection or transfer for access to memory bus
    • G06F13/1668Details of memory controller
    • G06F13/1673Details of memory controller using buffers
    • 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/14Handling requests for interconnection or transfer
    • G06F13/20Handling requests for interconnection or transfer for access to input/output bus
    • G06F13/24Handling requests for interconnection or transfer for access to input/output bus using interrupt
    • 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/382Information transfer, e.g. on bus using universal interface adapter
    • G06F13/387Information transfer, e.g. on bus using universal interface adapter for adaptation of different data processing systems to different peripheral devices, e.g. protocol converters for incompatible systems, open system
    • 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

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Hardware Design (AREA)
  • Information Transfer Systems (AREA)

Abstract

本发明公开了一种基于单片机的串口扩展方法、串口扩展设备和清洁机器人。该方法包括:在I2C接口接收到主处理器发送的数据时,实时地将接收到的数据存储至存储模块中,将存储模块中的数据从串口收发器发送至外部串口设备;在串口收发器接收到外部串口设备发送的数据时,将接收到的数据存储至存储模块中,生成中断信号并将中断信号发送至主处理器,中断信号用于提醒主处理器通过I2C接口读取存储模块中的数据,使得单片机自带的I2C接口和串口收发器进行通信,同时通过存储模块的缓冲作用实现通信速率匹配,这样在串口不足时,可以有效地利用主处理器的I2C接口来连接更多的串口设备,实现串口扩展,同时单片机价格便宜,降低了设备成本。

Description

基于单片机的串口扩展方法、串口扩展设备和清洁机器人
技术领域
本发明属于电子技术领域,具体地讲,涉及一种基于单片机的串口扩展方法、串口扩展设备和清洁机器人。
背景技术
随着社会的进步,人工智能技术的快速发展,大数据的快速整合与应用,家用扫地机器人的应用越来越普及。家用扫地机器人集成的功能越来越多,使用的传感器、通信模组也越来越多。由于扫地机器人使用的很多功能部件、传感器、通信模组都是采用串口进行通信,造成扫地机器人的主处理器对外的串口数量不够使用。同时主处理器对外的接口中,却往往会剩余有I2C接口未使用,故可以把此I2C接口利用起来,通过协议转换成串口,即可解决串口资源不足的问题。并且由于I2C接口本身的特点,其一根总线上可以挂载多个设备,这对于扩展更多的设备是非常有利的。目前市面上有I2C转串口的专用芯片销售,但这些专用芯片的价格较高,会显著增加家用扫地机器人的制造成本。
发明内容
本发明解决的技术问题是:如何在实现I2C接口与串口通信协议转换的前提下,降低设备成本。
本申请公开了一种基于单片机的串口扩展方法,所述单片机具有I2C接口、串口收发器和存储模块,所述串口扩展方法包括:
在所述I2C接口接收到主处理器发送的数据时,实时地将接收到的数据存储至所述存储模块中,将所述存储模块中的数据从所述串口收发器发送至外部串口设备;
在所述串口收发器接收到外部串口设备发送的数据时,将接收到的数据存储至所述存储模块中,生成中断信号并将所述中断信号发送至主处理器,所述中断信号用于提醒所述主处理器通过所述I2C接口读取所述存储模块中的数据。
优选地,所述实时地将接收到的数据存储至所述存储模块中,将所述存储模块中的数据从所述串口收发器发送至外部串口设备的方法包括:
在所述存储模块中设置地址连续的存储空间,所述存储空间具有起始地址和终止地址;
将接收到的数据按照从所述起始地址至所述终止地址的顺序写入到所述存储空间的各个存储单元;
按照所述起始地址至所述终止地址的顺序从各个存储单元中读取数据并通过所述串口收发器发送至外部串口设备。
优选地,当接收到的数据的容量大于所述存储空间的容量时,所述串口扩展方法还包括:
当在所述终止地址对应的存储单元写入数据之后,继续按照从所述起始地址至所述终止地址的顺序在各个存储单元中写入数据。
优选地,所述串口扩展方法还包括:
当在所述终止地址对应的存储单元的数据被读取和被发送之后,继续按照从所述起始地址至所述终止地址的顺序从各个存储单元中读取数据并通过所述串口收发器发送至外部串口设备。
优选地,在所述起始地址对应的存储单元中写入数据的同时,生成中断信号并将所述中断信号发送至主处理器。
优选地,所述串口扩展方法还包括:将生成的中断信号保持直至从存储模块中读取的数据量等于向存储模块中写入的数据量。
优选地,所述单片机的型号为STC8G1K08。
优选地,所述存储空间的容量为128字节。
本申请还公开了一种基于单片机的串口扩展设备,所述串口扩展设备包括计算机可读存储介质、处理器和存储在所述计算机可读存储介质中的基于单片机的串口扩展程序,所述基于单片机的串口扩展程序被处理器执行时实现任一种上述的基于单片机的串口扩展方法。
本申请还公开了一种清洁机器人,所述清洁机器人包括上述的基于单片机的串口扩展设备。
本发明公开的一种基于单片机的串口扩展方法、串口扩展设备和清洁机器人,具有如下技术效果:
利用软件程序方法,使得单片机自带的I2C接口和串口收发器进行通信,同时通过存储模块的缓冲作用实现通信速率匹配,这样在串口不足时,可以有效地利用主处理器的I2C接口来连接更多的串口设备,实现串口扩展,同时单片机价格便宜,降低了设备成本。
附图说明
图1为本发明的实施例一的基于单片机的串口扩展方法的原理示意图;
图2为本发明的实施例一的单片机中数据传输过程示意图;
图3为本发明的实施例二的基于单片机的串口扩展设备示意图。
具体实施方式
为了使本发明的目的、技术方案及优点更加清楚明白,以下结合附图及实施例,对本发明进一步详细说明。应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
在详细描述本申请的各个实施例之前,首先简单描述本申请的技术构思:现有技术中为了实现I2C接口与串口的通信协议转换,通常采用专用芯片,价格较高,增加了设备成本。为此,本申请提供了一种基于单片机的串口扩展方法,利用单片机自带的I2C接口、串口收发器和存储模块,通过设定相应的控制程序来实现数据在I2C接口和串口收发器之间的传输,实现I2C接口和串口的通信协议转换,以使得主处理器可与更多的外部串口设备进行通信,达到串口扩展目的,同时由于单片机的成本较低,从而可以降低设备的整体成本。
如图1和图2所示,本实施例一的单片机100具有I2C接口10、串口收发器20和存储模块30,其中I2C接口10和串口收发器20的数量均设置为多个,具体数量以及存储模块30的存储容量取决于相应型号的单片机,从成本上来看,串口数量和存储容量越大,单片机价格越高。示例性地,在资源满足功能需求的前提下,本实施例一优先采用SO-8封装、MCS-51内核的国产型号为STC8G1K08的单片机,此型号的单片机成本大约为市场上主流的I2C接口与串口转接专用芯片的十分之一,极大地降低了成本。
具体来说,本实施例一的基于单片机的串口扩展方法包括发送方法和接收方法。发送方法为:在I2C接口10接收到主处理器200发送的数据时,实时地将接收到的数据存储至存储模块30中,将存储模块30中的数据从串口收发器20发送至外部串口设备300。接收方法为:在串口收发器20接收到外部串口设备300发送的数据时,将接收到的数据存储至存储模块30中,生成中断信号并将中断信号发送至主处理器200,中断信号用于使主处理器200实时地通过I2C接口10读取存储模块30中的数据。在发送和接收过程中,I2C接口10作为从机,主处理器200作为I2C主机,I2C接口10可从主处理器200中接收数据,但是不能直接向主处理器200发送数据,因此需要发送中断信号提醒主处理器200从I2C接口10中读取数据。外部串口设备300可以为通信模组、传感器等。
进一步地,在存储模块30内设置两个存储空间,分别用于在发送和接收数据过程中进行数据缓冲,由于I2C接口10通信速率和串口收发器20的通信速率不相同,通过存储空间的缓冲作用来匹配双方的通信速率。为了便于描述,将两个存储空间分别命名为第一存储空间和第二存储空间。其中两个存储空间的地址均连续,即具有从起始地址指向终止地址的连续多个存储单元,每个存储单元为一个字节,示例性地,本实施例一的存储空间的容量大小优选为128字节。在I2C接口10接收到主处理器200发送的数据时,将接收到的数据按照从起始地址至终止地址的顺序写入到第一存储空间的各个存储单元,接着按照起始地址至终止地址的顺序从各个存储单元中读取数据并通过串口收发器20发送至外部串口设备300,即按照先进先出的顺序来发送数据。示例性地,可设置写指针和读指针来表示读写过程。写指针指向当前要写入的地址,写入完成后写指针地址自动增加。初始状态下,写指针指向起始地址,当写指针指向终止地址时,完成写入后自动指向起始地址。类似地,读指针指向当前要读出的地址,读出完成后读指针地址自动增加。初始状态下,读指针指向起始地址,当读指针指向终止地址时,完成读出后自动指向起始地址。其中,读指针可以追上写指针,追上后读指针等于写指针,代表存储空间中的数据全部被读出,没有数据了。写指针不可以追上读指针,追上代表数据覆盖。写指针往后,到读指针之间的存储单元数量,就是已经存放的数据数量。
进一步地,当接收到的数据的容量大于存储空间的容量时,即当写指针指向终止地址时,继续收到需要存储的数据,当在终止地址对应的存储单元写入数据之后,继续按照从起始地址至终止地址的顺序在各个存储单元中写入数据,即写指针重新指向起始地址。类似地,当在终止地址对应的存储单元的数据被读取和被发送之后,继续按照从起始地址至终止地址的顺序从各个存储单元中读取数据并通过串口收发器发送至外部串口设备,即当读指针指向终止地址时,需要继续发送存储的数据时,将读指针重新指向起始地址。
进一步地,在起始地址对应的存储单元中写入数据的同时,生成中断信号并将中断信号发送至主处理器。一方面由于单片机100中的I2C接口10为从机,无法直接向主处理器200发送数据,需要通过中断信号提示主处理器200开始读取数据;另一方面,由于主处理器200存在一定延时,需要第一时间通知主处理器200,尽量减少数据在存储模块中的“停留”时间,避免先存入的数据未及时读出而被后写入的数据覆盖,导致数据丢失。示例性地,可通过将单片机的一个引脚电平由低电平变为高电平,高电平作为中断信号。
进一步地,将生成的中断信号保持直至从存储模块中读取的数据量等于向存储模块中写入的数据量。当读指针还未追上写指针,说明还有数据未被读出,需要提醒主处理器200继续读取数据,当读指针等于写指针,代表存储空间中的数据全部被读出,没有数据可读取了,此时撤销中断信号。
本实施例一公开的基于单片机的串口扩展方法,利用软件程序方法,使得单片机自带的I2C接口和串口收发器进行通信,同时通过存储模块的缓冲作用实现速率匹配,这样在串口不足时,可以有效地利用主处理器的I2C接口来连接更多的串口设备,同时单片机价格便宜,降低了设备成本。
本实施例二还公开了一种基于单片机的串口扩展设备,在硬件层面,如图3所示,该计算机设备包括处理器12、内部总线13、网络接口14、计算机可读存储介质11。处理器12从计算机可读存储介质11中读取对应的计算机程序然后运行,在逻辑层面上形成请求处理装置。当然,除了软件实现方式之外,本说明书一个或多个实施例并不排除其他实现方式,比如逻辑器件抑或软硬件结合的方式等等,也就是说以下处理流程的执行主体并不限定于各个逻辑单元,也可以是硬件或逻辑器件。计算机可读存储介质11上存储有基于单片机的串口扩展程序,所述基于单片机的串口扩展程序被处理器执行时实现实施例一中的基于单片机的串口扩展方法。
计算机可读存储介质包括永久性和非永久性、可移动和非可移动媒体可以由任何方法或技术来实现信息存储。信息可以是计算机可读指令、数据结构、程序的模块或其他数据。计算机可读存储介质的例子包括,但不限于相变内存(PRAM)、静态随机存取存储器(SRAM)、动态随机存取存储器(DRAM)、其他类型的随机存取存储器(RAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、快闪记忆体或其他内存技术、只读光盘只读存储器(CD-ROM)、数字多功能光盘(DVD)或其他光学存储、磁盒式磁带、磁盘存储、量子存储器、基于石墨烯的存储介质或其他磁性存储设备或任何其他非传输介质,可用于存储可以被计算设备访问的信息。
进一步地,本实施例三还公开了一种清洁机器人,该清洁机器人具有实施例二中的基于单片机的串口扩展设备。
上面对本发明的具体实施方式进行了详细描述,虽然已表示和描述了一些实施例,但本领域技术人员应该理解,在不脱离由权利要求及其等同物限定其范围的本发明的原理和精神的情况下,可以对这些实施例进行修改和完善,这些修改和完善也应在本发明的保护范围内。

Claims (10)

1.一种基于单片机的串口扩展方法,其特征在于,所述单片机具有I2C接口、串口收发器和存储模块,所述串口扩展方法包括:
在所述I2C接口接收到主处理器发送的数据时,实时地将接收到的数据存储至所述存储模块中,将所述存储模块中的数据从所述串口收发器发送至外部串口设备;
在所述串口收发器接收到外部串口设备发送的数据时,将接收到的数据存储至所述存储模块中,生成中断信号并将所述中断信号发送至主处理器,所述中断信号用于提醒所述主处理器通过所述I2C接口读取所述存储模块中的数据。
2.根据权利要求1所述的基于单片机的串口扩展方法,其特征在于,所述实时地将接收到的数据存储至所述存储模块中,将所述存储模块中的数据从所述串口收发器发送至外部串口设备的方法包括:
在所述存储模块中设置地址连续的存储空间,所述存储空间具有起始地址和终止地址;
将接收到的数据按照从所述起始地址至所述终止地址的顺序写入到所述存储空间的各个存储单元;
按照所述起始地址至所述终止地址的顺序从各个存储单元中读取数据并通过所述串口收发器发送至外部串口设备。
3.根据权利要求2所述的基于单片机的串口扩展方法,其特征在于,当接收到的数据的容量大于所述存储空间的容量时,所述串口扩展方法还包括:
当在所述终止地址对应的存储单元写入数据之后,继续按照从所述起始地址至所述终止地址的顺序在各个存储单元中写入数据。
4.根据权利要求3所述的基于单片机的串口扩展方法,其特征在于,所述串口扩展方法还包括:
当在所述终止地址对应的存储单元的数据被读取和被发送之后,继续按照从所述起始地址至所述终止地址的顺序从各个存储单元中读取数据并通过所述串口收发器发送至外部串口设备。
5.根据权利要求1所述的基于单片机的串口扩展方法,其特征在于,所述存储模块中设置有地址连续的存储空间,所述存储空间具有起始地址和终止地址,在所述起始地址对应的存储单元中写入数据的同时,生成中断信号并将所述中断信号发送至主处理器。
6.根据权利要求5所述的基于单片机的串口扩展方法,其特征在于,所述串口扩展方法还包括:将生成的中断信号保持直至从存储模块中读取的数据量等于向存储模块中写入的数据量。
7.根据权利要求1所述的基于单片机的串口扩展方法,其特征在于,所述单片机的型号为STC8G1K08。
8.根据权利要求2所述的基于单片机的串口扩展方法,其特征在于,所述存储空间的容量为128字节。
9.一种基于单片机的串口扩展设备,其特征在于,所述串口扩展设备包括计算机可读存储介质、处理器和存储在所述计算机可读存储介质中的基于单片机的串口扩展程序,所述基于单片机的串口扩展程序被处理器执行时实现权利要求1至8任一项所述的基于单片机的串口扩展方法。
10.一种清洁机器人,其特征在于,所述清洁机器人包括如权利要求9所述的基于单片机的串口扩展设备。
CN202210843904.5A 2022-07-18 2022-07-18 基于单片机的串口扩展方法、串口扩展设备和清洁机器人 Pending CN115374035A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202210843904.5A CN115374035A (zh) 2022-07-18 2022-07-18 基于单片机的串口扩展方法、串口扩展设备和清洁机器人

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202210843904.5A CN115374035A (zh) 2022-07-18 2022-07-18 基于单片机的串口扩展方法、串口扩展设备和清洁机器人

Publications (1)

Publication Number Publication Date
CN115374035A true CN115374035A (zh) 2022-11-22

Family

ID=84060983

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202210843904.5A Pending CN115374035A (zh) 2022-07-18 2022-07-18 基于单片机的串口扩展方法、串口扩展设备和清洁机器人

Country Status (1)

Country Link
CN (1) CN115374035A (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN117312216A (zh) * 2023-11-30 2023-12-29 国家海洋环境监测中心 串口扩展电路装置及测试方法

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN117312216A (zh) * 2023-11-30 2023-12-29 国家海洋环境监测中心 串口扩展电路装置及测试方法
CN117312216B (zh) * 2023-11-30 2024-02-02 国家海洋环境监测中心 串口扩展电路装置及测试方法

Similar Documents

Publication Publication Date Title
CN100334564C (zh) 具有内部行高速缓存的内存集线器及访问方法
CN105335326A (zh) 一种基于fpga的pcie转sata接口阵列的装置
CN107783727B (zh) 一种内存设备的访问方法、装置和系统
CN102314400B (zh) 一种分散聚合式dma方法及装置
CN103034616B (zh) 一种多个操作系统访问存储介质的方法、计算机
US11500541B2 (en) Memory system and controlling method
CN114416630B (zh) 基于pcie的通信方法、装置、计算机设备和可读存储介质
CN115374035A (zh) 基于单片机的串口扩展方法、串口扩展设备和清洁机器人
WO2024179298A1 (zh) 跨机柜服务器内存池化方法、装置、设备、服务器及介质
CN110347621A (zh) 与psram存储器连接的fpga及存储系统
CN107451075B (zh) 数据处理芯片和系统、数据存储转发和读取处理方法
US20240021239A1 (en) Hardware Acceleration System for Data Processing, and Chip
CN107329929A (zh) 一种基于SoC FPGA的数据传输系统及数据传输方法
WO2022141250A1 (zh) 数据传输方法和相关装置
CN204291206U (zh) 一种基于闪存阵列的高清视频数据记录仪
CN114185830A (zh) 基于mailbox的多处理器通信方法、设备、系统和存储介质
CN108897696B (zh) 一种基于DDRx存储器的大容量FIFO控制器
CN115794705A (zh) 一种用于芯片原型快速功能验证的chi总线存储器
CN111190840A (zh) 基于现场可编程门阵列控制的多方中央处理器通信架构
CN107643991B (zh) 数据处理芯片和系统、数据存储转发处理方法
CN114691382A (zh) 基于rdma的通信方法、节点、系统及介质
CN107577625B (zh) 数据处理芯片和系统、数据存储转发处理方法
CN114242131A (zh) 芯片与相关的芯片系统
TWI421874B (zh) 遠端協助測試記憶體的方法
TW202020674A (zh) 數據處理系統

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