CN109709837A - 一种适用于单片机芯片的数据处理方法 - Google Patents

一种适用于单片机芯片的数据处理方法 Download PDF

Info

Publication number
CN109709837A
CN109709837A CN201811410190.9A CN201811410190A CN109709837A CN 109709837 A CN109709837 A CN 109709837A CN 201811410190 A CN201811410190 A CN 201811410190A CN 109709837 A CN109709837 A CN 109709837A
Authority
CN
China
Prior art keywords
instruction
singlechip chip
processor
chip
data
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
CN201811410190.9A
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.)
Shanghai Smart Semiconductor Co Ltd
Original Assignee
Shanghai Smart Semiconductor 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 Shanghai Smart Semiconductor Co Ltd filed Critical Shanghai Smart Semiconductor Co Ltd
Priority to CN201811410190.9A priority Critical patent/CN109709837A/zh
Publication of CN109709837A publication Critical patent/CN109709837A/zh
Pending legal-status Critical Current

Links

Landscapes

  • Devices For Executing Special Programs (AREA)

Abstract

本发明公开了一种单片机的数据处理方法,先将需要存储的数据进行压缩,再保存在单片机的存储存空间内,再将解压缩后的指令提供给单片机的外理芯片进行处理,单片机对需要存储的数据进行分块压缩,处理芯片判断下一条需要执行的指令是否位于所述当前指令所关联的地址范围内,当处理芯片判断下一条需要执行的指令位于当前指令所关联的地址范围之外时,处理芯片根据压缩后的存储地址获取指令并进行解压缩,随后执行指令。本发明可以间接的扩大单片机的存储空间,并不需要添加外部存储期间,更不用跟换芯片,可以节省产品的成本,通过压缩算法压缩文件所需要的存储空间变小,但是并不改变文件信息的内容,这样在相同大小的存储空间中就可以存储更大的文件。

Description

一种适用于单片机芯片的数据处理方法
技术领域
本发明涉及及存储技术领域,尤其涉及一种适用于单片机芯片的数据处理方法。
背景技术
随着超大规模集成电路的迅速发展,芯片的处理速度和处理能力不断得到提高,单片机芯片凭借其体积小、质量轻、性价比高的优点在工业控制、网络通讯、航空航天等领域得到越来越广泛的应用。其中,微处理器是单片机芯片的中央处理单元(CentralProcessing Unit,简称“CPU”),主要用于完成数据的算术或逻辑运算,同时也对整个单片机芯片系统的操作进行协调和管理。
存储区用于存储数据和程序,其中数据存储区用于存放数据的中间结果,完成数据暂存以及数据缓冲等功能,单片机芯片的存储区通常分为片内存储区和片外存储区,其中片内存储区又可分为用于存储程序的只读存储器(Read Only Memory,简称“ROM”)和用于存储数据的随机访问存储器(Random Access Memory,简称“RAM”)。片外存储器是片内存储器的扩展,主要是为了弥补片内存储器存储空间较小的缺点,通常可以由可擦写的可编程只读存储器(Erasable Programmable Read Only Memory,简称“EPROM”)、可电擦写的可编程只读存储器(Electrically Erasable Programmable Read Only Memory,简称“EEPROM”)、闪存(Flash Memory,简称“Flash”)等来实现。
目前单片机的存储空间都是很小并且是有限的,所以在遇到单片机存储不够的情况下一般的选择是更换更大存储空间的单片机或者增加外部存储硬件,这样就增加的产品的成本,更换单片机的同时还会存在单片机不兼容的问题。
发明内容
针对所述技术的不足,本发明主要目的是在不扩展存储硬件的情况下,增加单片机芯片芯片的存储,本发明要解决的问题,提供一种适用于单片机芯片的数据处理方法。
为实现上述目的,本发明通过以下方案来实现。
一种适用于单片机的芯片数据处理方法,其中,所述单片机芯片在进行数据存储之前,先将需要存储的数据进行压缩,再保存在所述单片机芯片的存储空间内;
所述单片机芯片在执行所述存储空间内的指令之前,先对所述存储空间内的指令进行解压缩,再将解压缩后的指令提供给所述单片机芯片的处理器进行处理;
于所述单片机芯片内部执行对所述指令的解压缩,以及将解压缩后的指令进行处理的过程;
采用所述单片机芯片外部的编译器执行数据压缩,再保存在所述单片机芯片的所述存储空间内。
优选的,该一种数据处理方法,其中,所述编译器对需要存储的数据进行分块压缩,再保存在所述单片机芯片的所述存储空间内。
优选的,该一种数据处理方法,其中,当所述单片机芯片的所述处理器执行当前指令完毕后,所述处理器判断下一条需要执行的指令是否位于所述当前指令所关联的地址范围内;
若是,则所述处理器在所述当前指令的地址范围内继续执行下一条指令;
若否,则所述处理器重新从所述存储空间内提取对应的指令并进行解压缩,再执行解决缩后的指令。
优选的,该一种机数据处理方法,其中,压缩前的数据的存储地址与压缩后的数据的存储地址一一对应;
当所述处理器判断下一条需要执行的指令位于所述当前指令所关联的地址范围之外时,执行下述步骤:
所述处理器产生关联于下一条需要执行的指令的存储地址,并经过地址映射后得到压缩后的存储地址,所述处理器根据压缩后的存储地址获取指令并进行解压缩,随后执行指令。
一种适用于单片机芯片的数据处理系统,其中,于所述单片机芯片内设置有存储空间和处理器,所述处理器连接所述存储空间;
在进行数据存储之前,采用所述单片机芯片外部的编译器将需要存储的数据进行压缩,再保存在所述单片机芯片的存储空间内;
所述处理器在执行所述存付空间内的指令之前,先对所述存储空间内的指令进行解压缩,再将解压缩后的指令提供给所述单片机芯片的处理器进行处理。
优选的,该数据处理系统,其中,所述编译器对需要存储的数据进行分块压缩,再保存在所述单片机芯片的所述存储空间内。
优选的,该数据处理系统,其中,于所述单片机芯片内还设置有一连接所述处理器的判断单元,用于在所述单片机芯片的所述处理器执行当前指令完毕后,判断下一条需要执行的指令是否位于所述当前指令所关联的地址范围内,并输出相应的判断结果;
所述处理器根据所述判断结果:
当下一条需要执行的指令位于所述当前指令所关联的地址范围内时,在所述当前指令的地址范围内继续执行下一条指令;
当下一条需要执行的指令位于所述当前指令所关联的地址范围外时,重新从所述存储空间内提取对应的指令并进行解压缩,再执行解压缩后的指令。
优选的,该一种数据处理系统,其中,压缩前的数据的存储地址与压缩后的数据的存储地址一一对应;
当所述判断结果表示判断下一条需要执行的指令位于所述当前指令所关联的地址范围之外时,所述处理器产生关联于下一条需要执行的指令的存储地址,并经过地址映射后得到压缩后的存储地址,所述处理器根据压缩后的存储地址获取指令并进行解压缩,随后执行指令。
一种单片机芯片,其中,采用上述的适用于单片机芯片的数据处理方法。
一种单片机芯片,其中,应用上述的适用于单片机芯片的数据处理系统。本发明的优点在于:
本发明中,对指令数据在外部编译器中进行压缩,解压缩的功能集成在单片机芯片中,可以间接的扩大单片机芯片的存储空间,并不需要添加外部存储期间,更不用跟换芯片,使单片机芯片的存储空间扩大。这样可以节省产品的成本,也可以降低程序移植时代来的风险。通过压缩算法压缩文件使文件存储时所需要的存储空间变小,但是并不改变文件信息的内容;这样在相同大小的存储空间中就可以存储更大的文件。
附图说明
为了更清楚地说明本发明实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本发明的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。
图1是现有技术中,单片机芯片数据进行存储的示意图;
图2是本发明一种适用于单片机芯片的数据处理方法实施例中将可执行文件压缩后存放入单片机芯片示意图;
图3是本发明一种适用于单片机芯片的数据处理方法实施例中的流程示意图;
图4是本发明一种适用于单片机芯片的数据处理系统实施例中的系统示意图;
图5是本发明一种适用于单片机芯片的数据处理系统实施例中的单片机芯片逻辑结构示意图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动的前提下所获得的所有其他实施例,都属于本发明保护的范围。
需要说明的是,在不冲突的情况下,本发明中的实施例及实施例中的特征可以相互组合。
下面结合附图和具体实施例对本发明作进一步说明,但不作为本发明的限定。
具体地,如图1中所示,现有技术中,单片机芯片在进行数据保存时,通常不会事先对数据进行压缩,而直接进行存储,这样的保存方式会占用较大的存储容量,不适用于单片机芯片目前容量有限的存储空间。
而本发明较佳的实施例中,根据现有技术存在的问题,现提供一种适用于单片机芯片数据处理的方法,单片机芯片在进行数据存储之前,先将需要存储的数据进行压缩,再保存在单片机芯片的存储存空间内(其指令数据的保存过程如图2中所示);进一步地,单片机芯片需要对需要存储的数据进行分块压缩,再保存在单片机芯片的存储空间内。
具体地,单片机芯片在执行存储空间内的指令之前,先对存储空间内的指令进行解压缩,再将解压缩后的指令提供给单片机芯片的外理芯片进行处理。
上述数据处理方法单片机芯片中,对指令数据进行分块压缩的功能可以采用单片机芯片外部的编译器执行,并且可以通过单片机芯片内部的处理器执行解压缩的功能。
本发明较佳的实施例中,如图3中所示,当单片机芯片的处理器执行当前指令完毕后,处理器判断下一条需要执行的指令是否位于当前指令所关联的地址范围内;
若是,则处理器在当前指令的地址范围内继续执行下一条指令;
若否,则处理器重新从所述存储空间内提取对应的指令并进行解压缩,再执行解决缩后的指令。
本发明较佳的实施例中,压缩前的数据的存储地址与压缩后的数据的存储地址一一对应;
仍然如图3中所示,当处理器判断下一条需要执行的指令位于当前指令所关联的地址范围之外时,执行下述步骤:
处理器产生关联于下一条需要执行的指令的存储地址,并经过地址映射后得到压缩后的存储地址,处理器根据压缩后的存储地址获取指令并进行解压缩,随后执行指令。
具体地,当单片机芯片中得处理器要执行存储中的程序时,一般是直接读取存储区程序的指令,而在使用压缩后的程序后存储区的程序不能直接执行,要通过解压缩后才能正常的执行。
当处理器发送从单片机芯片的存储区出一条指令,取出的指令进行解压后处理器执行,当处理器执行指令期间出现要执行本块压缩指令外的指令,此时处理器发出的地址是没压缩前的地址,通过地址镜像映射找到压缩后的指令的实际位置,取出进行解压,然后处理器继续执行。
本发明的较佳的实施例中,基于上文中所述的适用于单片机芯片的数据处理方法,现提供一种适用于单片机芯片的数据处理系统,具体如图4中所示:
于单片机芯片内设置有存储空间1和处理器2,处理器2连接存储空间1,单片机芯片还连接一外部的编译器(图中未示出);
上述编译器处理器在进行数据存储之前,先将需要存储的数据进行压缩,再保存在单片机芯片的存储空间1内;
上述处理器2在执行存储空间1内的指令之前,先对存储空间1内的指令进行解压缩,再将解压缩后的指令提供给单片机芯片的处理器2进行处理。
本发明较佳的实施例中,处理器外部编译器对需要存储的数据进行分块压缩,再保存在单片机芯片的存储空间1内。
本发明较佳的实施例中,仍然如图4中所示,于单片机芯片内还设置有一连接处理器2的判断单元3,用于在单片机芯片的处理器2执行当前指令完毕后,判断下一条需要执行的指令是否位于当前指令所关联的地址范围内,并输出相应的判断结果;
处理器2根据判断结果:
当下一条需要执行的指令位于当前指令所关联的地址范围内时,在当前指令的地址范围内继续执行下一条指令;
当下一条需要执行的指令位于当前指令所关联的地址范围外时,重新从存储空间内提取对应的指令并进行解压缩,再执行解压缩后的指令。
本发明较佳的实施例中,压缩前的数据的存储地址与压缩后的数据的存储地址一一对应;
当判断结果表示判断下一条需要执行的指令位于当前指令所关联的地址范围之外时,处理器2产生关联于下一条需要执行的指令的存储地址,并经过地址映射后得到压缩后的存储地址,处理器2根据压缩后的存储地址获取指令并进行解压缩,随后执行指令。
本发明较佳的实施例中,提供一种单片机芯片,适用于单片机芯片的数据处理方法。
本发明较佳的实施例中,还提供一种单片机芯片,适用于单片机芯片的数据处理系统。
具体地,该单片机芯片如图5中所示,其中集成有片内存储器51(上文中所述的存储空间),该片内存储器51中保存有分块压缩后(经过单片机芯片外部的编译器进行分块压缩)的指令数据。同时该单片机芯片中还集成有解压缩的功能模块52,该功能模块52用于在单片机芯片的处理器(CPU)53需要执行指令时从片内存储器51中获取相应的指令数据并进行解压缩,随后将经过解压缩的指令数据发送至指令缓存空间(cache)54中,以供处理器53调取并执行。综上,所有的功能都集成于单片机芯片内部,在解决单片机芯片存储空间不够的问题的同时提高了单片机芯片的集成度。当然,如图5中所示,在该单片机芯片中还集成有外设功能模块以及电源等组件55,在此不再一一赘述。
本发明的有益效果在于:
本发明可以间接的扩大单片机芯片的存储空间,并不需要添加外部存储期间,更不用更换芯片,使单片机芯片的存储空间扩大。这样可以节省产品的成本,也可以降低程序移植时代来的风险。通过压缩算法压缩文件使文件存储时所需要的存储空间变小,但是并不改变文件信息的内容;这样在相同大小的存储空间中就可以存储更大的文件。
以上所述仅为本发明较佳的实施例,并非因此限制本发明的实施方式及保护范围,对于本领域技术人员而言,应当能够意识到凡运用本发明说明书及图示内容所作出的等同替换和显而易见的变化所得到的方案,均应当包含在本发明的保护范围内。

Claims (10)

1.一种适用于单片机芯片的数据处理方法,其特征在于,所述单片机芯片在进行数据存储之前,先将需要存储的数据进行压缩,再保存在所述单片机芯片的存储空间内;
所述单片机芯片在执行所述存储空间内的指令之前,先对所述存储空间内的指令进行解压缩,再将解压缩后的指令提供给所述单片机芯片的处理器进行处理;
于所述单片机芯片内部执行对所述指令的解压缩,以及将解压缩后的指令进行处理的过程;
采用所述单片机芯片外部的编译器执行数据压缩,再保存在所述单片机芯片的所述存储空间内。
2.根据权利要求1所述的一种数据处理方法,其特征在于,所述单片机芯片编译器对需要存储的数据进行分块压缩,再保存在所述单片机芯片的所述存储空间内。
3.根据权利要求1所述的一种数据处理方法,其特征在于,当所述单片机芯片的所述处理器执行当前指令完毕后,所述处理器判断下一条需要执行的指令是否位于所述当前指令所关联的地址范围内;
若是,则所述处理器在所述当前指令的地址范围内继续执行下一条指令;
若否,则所述处理器重新从所述存储空间内提取对应的指令并进行解压缩,再执行解决缩后的指令。
4.根据权利要求3所述的一种机数据处理方法,其特征在于,压缩前的数据的存储地址与压缩后的数据的存储地址一一对应;
当所述处理器判断下一条需要执行的指令位于所述当前指令所关联的地址范围之外时,执行下述步骤:
所述处理器产生关联于下一条需要执行的指令的存储地址,并经过地址映射后得到压缩后的存储地址,所述处理器根据压缩后的存储地址获取指令并进行解压缩,随后执行指令。
5.一种适用于单片机芯片的数据处理系统,其特征在于,于所述单片机芯片内设置有存储空间和处理器,所述处理器连接所述存储空间;
处理器在进行数据存储之前,采用所述单片机芯片外部的编译器将需要存储的数据进行压缩,再保存在所述单片机芯片的存储空间内;
所述处理器在执行所述存付空间内的指令之前,先对所述存储空间内的指令进行解压缩,再将解压缩后的指令提供给所述单片机芯片的处理器进行处理单片机芯片。
6.根据权利要求5所述的数据处理系统,其特征在于,所述处理器编译器对需要存储的数据进行分块压缩,再保存在所述单片机芯片的所述存储空间内。
7.根据权利要求5所述的数据处理系统,其特征在于,于所述单片机芯片内还设置有一连接所述处理器的判断单元,用于在所述单片机芯片的所述处理器执行当前指令完毕后,判断下一条需要执行的指令是否位于所述当前指令所关联的地址范围内,并输出相应的判断结果;
所述处理器根据所述判断结果:
当下一条需要执行的指令位于所述当前指令所关联的地址范围内时,在所述当前指令的地址范围内继续执行下一条指令;
当下一条需要执行的指令位于所述当前指令所关联的地址范围外时,重新从所述存储空间内提取对应的指令并进行解压缩,再执行解压缩后的指令。
8.根据权利要求7所述数据处理系统,其特征在于,压缩前的数据的存储地址与压缩后的数据的存储地址一一对应;
当所述判断结果表示判断下一条需要执行的指令位于所述当前指令所关联的地址范围之外时,所述处理器产生关联于下一条需要执行的指令的存储地址,并经过地址映射后得到压缩后的存储地址,所述处理器根据压缩后的存储地址获取指令并进行解压缩,随后执行指令。
9.一种单片机芯片,其特征在于,采用如权利要求1-4中任意一项所述的适用于单片机芯片的数据处理方法。
10.一种单片机芯片,其特征在于,应用如权利要求5-8中任意一项所述的适用于单片机芯片的数据处理系统。
CN201811410190.9A 2018-11-23 2018-11-23 一种适用于单片机芯片的数据处理方法 Pending CN109709837A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201811410190.9A CN109709837A (zh) 2018-11-23 2018-11-23 一种适用于单片机芯片的数据处理方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201811410190.9A CN109709837A (zh) 2018-11-23 2018-11-23 一种适用于单片机芯片的数据处理方法

Publications (1)

Publication Number Publication Date
CN109709837A true CN109709837A (zh) 2019-05-03

Family

ID=66255046

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201811410190.9A Pending CN109709837A (zh) 2018-11-23 2018-11-23 一种适用于单片机芯片的数据处理方法

Country Status (1)

Country Link
CN (1) CN109709837A (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN115407942A (zh) * 2022-08-29 2022-11-29 深圳市锦锐科技股份有限公司 一种适用于单片机芯片的数据处理方法

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20070226420A1 (en) * 2006-03-22 2007-09-27 Sung Chih-Ta S Compression method and apparatus for a CPU
CN101398752A (zh) * 2007-09-29 2009-04-01 国际商业机器公司 重叠指令存取单元和重叠指令存取方法
CN101452643A (zh) * 2007-11-30 2009-06-10 无锡华润矽科微电子有限公司 一种学习型红外遥控器
CN102087608A (zh) * 2009-12-04 2011-06-08 康佳集团股份有限公司 一种嵌入式程序压缩方法,解压缩方法和嵌入式系统
CN103399763A (zh) * 2013-07-23 2013-11-20 北京昆腾微电子有限公司 下载用于芯片的程序文件的方法和装置
CN103902467A (zh) * 2012-12-26 2014-07-02 华为技术有限公司 压缩内存访问控制方法、装置及系统

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20070226420A1 (en) * 2006-03-22 2007-09-27 Sung Chih-Ta S Compression method and apparatus for a CPU
CN101398752A (zh) * 2007-09-29 2009-04-01 国际商业机器公司 重叠指令存取单元和重叠指令存取方法
CN101452643A (zh) * 2007-11-30 2009-06-10 无锡华润矽科微电子有限公司 一种学习型红外遥控器
CN102087608A (zh) * 2009-12-04 2011-06-08 康佳集团股份有限公司 一种嵌入式程序压缩方法,解压缩方法和嵌入式系统
CN103902467A (zh) * 2012-12-26 2014-07-02 华为技术有限公司 压缩内存访问控制方法、装置及系统
CN103399763A (zh) * 2013-07-23 2013-11-20 北京昆腾微电子有限公司 下载用于芯片的程序文件的方法和装置

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN115407942A (zh) * 2022-08-29 2022-11-29 深圳市锦锐科技股份有限公司 一种适用于单片机芯片的数据处理方法

Similar Documents

Publication Publication Date Title
CN207458128U (zh) 一种基于fpga在视觉应用中的卷积神经网络加速器
CN109934339A (zh) 一种基于一维脉动阵列的通用卷积神经网络加速器
CN106484331B (zh) 一种数据处理方法、装置及闪存设备
CN109783004A (zh) 数据储存装置与存储器装置的数据处理方法
CN106802867A (zh) 固态储存装置及其数据编程方法
CN103544269B (zh) 目录的存储方法、查询方法及节点控制器
CN103309818B (zh) 存储数据的方法及装置
CN105930186A (zh) 多cpu的软件加载方法及基于多cpu的软件加载装置
CN109709837A (zh) 一种适用于单片机芯片的数据处理方法
CN109491587A (zh) 数据访问的方法及装置
CN107111461A (zh) 在基于中央处理单元(cpu)的系统中通过经压缩存储器控制器(cmc)使用背靠背读取操作来提供存储器带宽压缩
CN103365926B (zh) 在文件系统中用于保存快照的方法和装置
CN108139916A (zh) 可编程逻辑设备的多阶段引导映像加载和配置
CN105426322B (zh) 一种数据的预取方法及装置
CN107111575A (zh) 用于在计算机系统内部传输数据的方法和存储管理装置、存储系统和计算机系统
CN109101194A (zh) 一种刷写性能优化方法和存储系统
CN110647292B (zh) 一种服务器系统中扩充存储容量的方法及系统
CN106293736B (zh) 用于粗粒度多核计算系统的两级编程装置及其计算方法
CN103093446B (zh) 基于多处理器片上系统的多源图像融合装置和方法
CN104050189B (zh) 页面共享处理方法及装置
CN207611373U (zh) 一种基于主/从结构的控制系统
CN107305486A (zh) 一种神经网络maxout层计算装置
CN101385680B (zh) 监护仪及其配置管理方法
CN105404591B (zh) 处理器系统及其存储器控制方法
CN104731744B (zh) 一种基于SiP的可重构嵌入式计算机模块

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
RJ01 Rejection of invention patent application after publication

Application publication date: 20190503

RJ01 Rejection of invention patent application after publication