一种保护mcu工作程序的方法及系统的制作方法

文档序号:9597699阅读:454来源:国知局
一种保护mcu工作程序的方法及系统的制作方法
【技术领域】
[0001]本发明涉及芯片工作程序控制领域,尤其涉及一种保护MCU工作程序的方法及系统。
【背景技术】
[0002]MCU: Microcontroller Unit,微控制单元。
[0003]内存:运行内存,是指MCU运行程序时的内存,也叫RAM (简称运存)。
[0004]FLASH:闪存,闪存的英文名称是"Flash Memory",一般简称为〃Flash〃,它属于内存器件的一种,是一种不挥发性内存。
[0005]目前一些电子产品因特殊需求设有自动销毁程序,在发生紧急情况触发销毁程序后,工作程序就会被删除,想要再次使用该设备时就需要重新烧录程序,为使用带来不便。

【发明内容】

[0006]为了解决上述技术问题,本发明的目的是提供一种可方便工作程序升级,使用方便,同时减少占用MCU总线资源的保护MCU工作程序方法。
[0007]为了解决上述技术问题,本发明的另一个目的是提供一种可方便工作程序升级,使用方便,同时减少占用MCU总线资源的保护MCU工作程序系统。
[0008]本发明所采用的技术方案是:
一种保护MCU工作程序的方法,其包括步骤:S1,运行下载程序;S2,由下载程序判断是应该运行工作程序还是应该升级工作程序,如果是运行工作程序则进入步骤S3,如需要升级工作程序则进入步骤S4 ;S3,下载程序则从外部存储模块中搬移工作程序代码到内存中对应地址,完成搬移后MCU运行工作程序;S4,MCU接收来自上位机的工作程序,由下载程序把工作程序写到外部存储模块中的对应位置,然后复位重复步骤S1和S2。
[0009]优选的,所述下载程序和工作程序存储在同一外部存储模块的不同存储扇区中。
[0010]优选的,所述外部存储模块为一个FLASH存储器。
[0011]优选的,所述保护MCU工作程序的方法还包括步骤:S01,先从外部存储模块中搬移BOOT代码到内存中,然后运行BOOT代码;S02,BOOT代码执行动作:从外部存储模块中搬移下载程序和/或工作程序到内存中对应的地址,搬移完成后执行步骤S1。
[0012]一种保护MCU工作程序的系统,所述系统用于实施保护MCU工作程序的方法,所述系统包括:MCU,分别与外部存储模块和内存连接,用于运行下载程序、工作程序;外部存储模块,所述外部存储模块包括第一存储扇区和第二存储扇区,所述第一存储扇区用于存储下载程序,所述第二存储扇区用于存储工作程序;内存,用于根据MCU的命令存储下载程序和/或工作程序。
[0013]优选的,所述第一存储扇区存储有BOOT代码,所述BOOT代码用于引导MCU搬移和运行下载程序和/或工作程序。
[0014]优选的,所述外部存储模块为一个FLASH存储器。
[0015]本发明的有益效果是:
本发明首先通过在MCU的FLASH中先烧录进去下载程序,MCU上电后运行下载程序,然后由下载程序来升级工作程序或者负责把工作程序运行起来,实现当工作程序被删除后依然可以方便的实现升级并运行;其次,通过利用外部存储模块的一部分扇区存储下载程序,另一部分扇区存储工作程序,节省了 MCU接口总线资源,从而节省成本;再次,本发明安全性高,使用方便,运行稳定可靠,具有良好的经济和社会效益。
[0016]本发明可广泛应用于各种MCU工作程序管理系统。
【附图说明】
[0017]下面结合附图对本发明的【具体实施方式】作进一步说明:
图1是本发明保护MCU工作程序的系统一种实施例的结构示意图。
【具体实施方式】
[0018]需要说明的是,在不冲突的情况下,本申请中的实施例及实施例中的特征可以相互组合。
[0019]为了【背景技术】中提出的问题,可以如下方式实现,在MCU的FLASH存储器中先烧录进去下载程序,MCU上电后运行下载程序,然后由下载程序来升级工作程序或者负责把工作程序运行起来,这样当工作程序被删除后依然可以方便的实现升级并运行。实施上述方法,可以通过外接两片FLASH存储器实现,一片存储下载程序,一片存储工作程序。下载程序运行起来后从另一片FLASH存储器中搬移工作程序到内存中然后运行工作程序。也可以采用一片FLASH存储器实现。当MCU外接芯片较多时会出现接口资源紧张的情况,这时一片FLASH的优势就体现出来了。在一片FLASH的情况下,FLASH的一部分扇区存储下载程序,另一部分扇区存储工作程序,当MCU上电后,先从存储下载程序的FLASH的地址搬移下载程序到内存中运行,运行起来后根据情况再决定是需要升级工作程序或者是从存储工作程序的FLASH的地址搬移工作程序到内存中运行。当工作程序被删除后,可以方便的实现升级,保护了工作程序的安全性。具体方案如下:
如图1所示,一种保护MCU工作程序的系统,所述系统用于实施保护MCU工作程序的方法,所述系统包括:
MCU,分别与外部存储模块和内存连接,用于运行下载程序、工作程序,还有实现BOOT代码从FLASH存储器到内存的搬移。
[0020]外部存储模块,本实施例采用一 FLASH存储器,FLASH存储器包括第一存储扇区和第二存储扇区,所述第一存储扇区用于存储下载程序,所述第二存储扇区用于存储工作程序,所述第一存储扇区还存储有BOOT代码,所述BOOT代码用于引导MCU搬移和运行下载程序和/或工作程序,所述BOOT代码存储在第一存储扇区的起始位置。
[0021]内存,用于根据MCU的命令存储下载程序和/或工作程序,也是存储程序本身、运行程序的空间。
[0022]—种保护MCU工作程序的方法,其包括步骤:S1,运行下载程序;S2,由下载程序判断是应该运行工作程序还是应该升级工作程序,如果是运行工作程序则进入步骤
当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1