CN107239411B - 一种车载控制器内存管理方法及系统 - Google Patents

一种车载控制器内存管理方法及系统 Download PDF

Info

Publication number
CN107239411B
CN107239411B CN201710425029.8A CN201710425029A CN107239411B CN 107239411 B CN107239411 B CN 107239411B CN 201710425029 A CN201710425029 A CN 201710425029A CN 107239411 B CN107239411 B CN 107239411B
Authority
CN
China
Prior art keywords
data
memory
initialization
writing
loss
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
CN201710425029.8A
Other languages
English (en)
Other versions
CN107239411A (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.)
SAIC General Motors Corp Ltd
Pan Asia Technical Automotive Center Co Ltd
Original Assignee
SAIC General Motors Corp Ltd
Pan Asia Technical Automotive Center 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 SAIC General Motors Corp Ltd, Pan Asia Technical Automotive Center Co Ltd filed Critical SAIC General Motors Corp Ltd
Priority to CN201710425029.8A priority Critical patent/CN107239411B/zh
Publication of CN107239411A publication Critical patent/CN107239411A/zh
Application granted granted Critical
Publication of CN107239411B publication Critical patent/CN107239411B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/0223User address space allocation, e.g. contiguous or non contiguous base addressing
    • G06F12/023Free address space management
    • G06F12/0238Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory
    • G06F12/0246Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory in block erasable memory, e.g. flash memory
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/16Protection against loss of memory contents

Abstract

本发明公开一种车载控制器内存管理方法及系统,方法包括:响应于对车载控制器的非易失性随机访问存储器数据读取请求,从物理内存中获取非易失性随机访问存储器数据读取请求所指定的读取数据,物理内存内的数据为掉电数据不丢失存储器的镜像,掉电数据不丢失存储器对车载控制器模拟为电可擦可编程只读存储器;响应于对车载控制器的非易失性随机访问存储器数据写入请求,向物理内存写入非易失性随机访问存储器数据写入请求所指定的写入数据,向掉电数据不丢失存储器写入所述写入数据。本发明通过物理内存作为掉电数据不丢失存储器的镜像,由于物理内存的响应速度快,从而解决了实时性不高的问题,同时也避免数据掉电丢失。

Description

一种车载控制器内存管理方法及系统
技术领域
本发明涉及汽车相关技术领域,特别是一种车载控制器内存管理方法及系统。
背景技术
通常车载控制器大都集成如下几种内存:数据闪存(DFLASH),用于存储常数等标定数据信息;代码闪存(CODEFLASH),用于存储代码和常数;随机存储器(RAM),用于存储控制器实时运行的数据;复位不丢失存储器(KAM),用于存储复位(非掉电)情况下的实时运行数据;电可擦可编程只读存储器(EEPROM),用于存储运行实时数据,但掉电后期望不丢失的数据。其中闪存(FLASH)较EEPROM价格便宜,写入速度快,但写入前需要先擦除原有数据。
随着汽车行业的蓬勃发展,车载电脑(车载控制器)所使用的内存,由于可靠性和低廉性的原因,逐步淘汰了EEPROM,转而在物理DFLASH内存的基础上,使用系统模拟的方式实现EEPROM内存一样的效果。这大大降低了控制器MCU的成本,然而,其缺点是带来了系统成本和系统复杂度升高,同时造成了读写模拟EEPROM实时性降低的问题。
目前,应对DFLASH模拟EEPROM(简称FEE)的系统策略有很多,各个MCU芯片厂商都有各自的算法推荐,但参差不齐。当今,最流行,应用也最广的FEE方法是AUTOSAR机构定义的FEE策略。FEE策略使用后,对控制器最直接的影响是,初始化时间和写入时间加长。因为FEE的初始化时间和写入速度都达不到系统的要求,造成控制器从休眠到唤醒后全速运行时间间隔拉长,这直接造成控制器实时性变差,往往造成功能异常和网络异常等问题。造成上述问题的原因是DFLASH的写入速度远远慢于EEPROM,在功能应用程序请求存储重要控制信息时,不能及时的响应。这对实时性要求极高的车载控制器来说,是不能接受的。
目前,还有一种应对数据存储实时性能的方法,就是使用复位不丢失随机存储器(KAM)来存储重要控制器信息,该方法避免了FEE的一些缺点,但由于KAM掉电丢失且易受干扰等问题,使得该方法不能解决车载控制器的内存存储问题。
发明内容
基于此,有必要针对现有技术在车载控制器内存上实时性不高的技术问题,提供一种车载控制器内存管理方法及系统。
本发明提供一种车载控制器内存管理方法,包括:
模拟步骤,包括:将掉电数据不丢失存储器模拟为电可擦可编程只读存储器;
数据读取步骤,包括:响应于对车载控制器的非易失性随机访问存储器数据读取请求,从物理内存中获取所述非易失性随机访问存储器数据读取请求所指定的读取数据,所述物理内存内的数据为掉电数据不丢失存储器的镜像;
数据写入步骤,包括:响应于对车载控制器的非易失性随机访问存储器数据写入请求,向所述物理内存写入所述非易失性随机访问存储器数据写入请求所指定的写入数据,向所述掉电数据不丢失存储器写入所述写入数据。
本发明提供一种车载控制器内存管理系统,包括:
模拟模块,用于:将掉电数据不丢失存储器模拟为电可擦可编程只读存储器;
数据读取模块,用于:响应于对车载控制器的非易失性随机访问存储器数据读取请求,从物理内存中获取所述非易失性随机访问存储器数据读取请求所指定的读取数据,所述物理内存内的数据为掉电数据不丢失存储器的镜像;
数据写入模块,用于:响应于对车载控制器的非易失性随机访问存储器数据写入请求,向所述物理内存写入所述非易失性随机访问存储器数据写入请求所指定的写入数据,向所述掉电数据不丢失存储器写入所述写入数据。
本发明通过掉电数据不丢失存储器模拟电可擦可编程只读存储器,以保证数据掉电后不丢失,同时,通过物理内存作为掉电数据不丢失存储器的镜像,由于物理内存的响应速度快,从而解决了实时性不高的问题,同时也避免数据掉电丢失。
附图说明
图1为本发明一种车载控制器内存管理方法的工作流程图;
图2为本发明最佳实施例的车载控制器内存管理框图;
图3为根据本发明最佳实施例的车载控制器内存管理方法的内存读取时序示意图;
图4为根据本发明最佳实施例的车载控制器内存管理方法的内存写入时序示意图;
图5为根据本发明最佳实施例的车载控制器内存管理方法在控制器系统中的启动时KAM自恢复流程示意图;
图6为本发明最佳实施例的车载控制器内存管理方法从DFLASH 9中恢复数据流程示意图;
图7为本发明一种车载控制器内存管理系统的结构模块图。
具体实施方式
下面结合附图和具体实施例对本发明做进一步详细的说明。
如图1所示为本发明一种车载控制器内存管理方法的工作流程图,包括:
步骤S101,包括:将掉电数据不丢失存储器模拟为电可擦可编程只读存储器;
步骤S102,包括:响应于对车载控制器的非易失性随机访问存储器数据读取请求,从物理内存中获取所述非易失性随机访问存储器数据读取请求所指定的读取数据,所述物理内存内的数据为掉电数据不丢失存储器的镜像;
步骤S103,包括:响应于对车载控制器的非易失性随机访问存储器数据写入请求,向所述物理内存写入所述非易失性随机访问存储器数据写入请求所指定的写入数据,向所述掉电数据不丢失存储器写入所述写入数据。
其中,在步骤S101中,可以采用现有AUTOSAR机构定义的FEE策略将掉电数据不丢失存储器模拟为电可擦可编程只读存储器。
在步骤S102中,非易失性随机访问存储器(Non-Volatile Random AccessMemory,NVRAM)数据读取请求,是要获取断电后仍能保持数据的内存中的数据,因此,该数据请求是要获取存储在电可擦可编程只读存储器或者模拟电可擦可编程只读存储器中的数据。本发明由于采用了物理内存镜像掉电数据不丢失存储器的数据,而掉电数据不丢失存储器则模拟为电可擦可编程只读存储器,因此,对于NVRAM的数据读取请求,则从物理内存中获取。
同样地,当在步骤S103中执行NVRAM数据写入请求时,是要向电可擦可编程只读存储器或者模拟电可擦可编程只读存储器中写入数据,由于本发明是采用掉电数据不丢失存储器去模拟电可擦可编程只读存储器,因此,该写入数据将写入掉电数据不丢失存储器,同时由于物理内存镜像掉电数据不丢失存储器,因此,该写入数据也同时写入物理内存。
本发明对车载控制器将掉电数据不丢失存储器模拟为电可擦可编程只读存储器,并通过物理内存镜像掉电数据不丢失存储器,执行步骤S102进行数据读取时,其数据来自于物理内存,从而提供访问速度。将掉电数据不丢失存储器模拟为电可擦可编程只读存储器可以采用现有AUTOSAR机构定义的FEE策略进行模拟。
如图2所示为本发明最佳实施例的车载控制器内存管理框图。其中应用程序1和应用程序2为内存的使用者,通过实时环境RTE 3向内存管理单元4请求读和写,应用程序1、2提供读写内存块的标号。读时,内存管理单元4执行步骤S101将要读的内存值放入应用程序1、2提供的地址内;写时,内存管理单元4执行步骤S102,将要写的值从应用程序1、2提供的地址内取出,并写入物理内存5和掉电数据不丢失存储器9。物理内存5用于镜像存储实时的非易失数据,掉电数据不丢失存储器9通过AUTOSAR机构定义的FEE策略,由标准AUTOSAR模块NVM 6、标准AUTOSAR模块FEE 7、标准AUTOSAR模块FLS 8模拟为电可擦可编程只读存储器。
需要指出的是,上述仅为本发明的最佳实施例,在实际使用中,所述内存管理单元4之上的应用程序可以是多个,也可以是单个。作为内存管理单元4的使用模块不限于处在内存管理单元之上,也可以在其同层或之下。所述实时环境RTE 3是基于AUTOSAR的系统思想所示意,本发明实例不限于AUTOSAR系统思想,及应用程序和内存管理单元之间可以选的使用实时环境RTE 3。可选的,所述标准AUTOSAR模块NVM 6、标准AUTOSAR模块FEE 7和标准AUTOSAR模块FLS 8也可以使用自定义的模拟EEPROM的系统思想实现的非易失性随机访问存储器。
本发明通过掉电数据不丢失存储器模拟电可擦可编程只读存储器,以保证数据掉电后不丢失,同时,通过物理内存作为掉电数据不丢失存储器的镜像,由于物理内存的响应速度快,从而解决了实时性不高的问题,同时也避免数据掉电丢失。
在其中一个实施例中,所述物理内存包括:第一内存区域、第二内存区域和第三内存区域;
所述向所述物理内存写入所述非易失性随机访问存储器数据写入请求所指定的写入数据,具体包括:向所述第一内存区域写入所述非易失性随机访问存储器数据写入请求所指定的写入数据,向所述第二内存区域写入所述写入数据,向所述第三内存区域写入所述写入数据的反码。
本实施例的物理内存采用三个内存区域,采用第一内存区域=第二内存区域=~第三内存区域的算法,即当第一内存区域写入1时,第二内存区域写入1,第三内存区域写入0。本实施例解决车载控制器在强干扰环境下,物理内存受到电磁干扰出现的一致性内存错误。同时,采用本实施例的方式,可以不再使用循环冗余码校验算法(Cyclic RedundancyCode,CRC),以提高读写性能。
在其中一个实施例中,还包括初始化步骤,所述初始化步骤,包括:
车载控制器初始化开始时,从所述第一内存区域读取第一初始化读取数据,从所述第二内存区域读取第二初始化读取数据,从所述第三内存区域读取第三初始化读取数据;
如果所述第一初始化读取数据与所述第三初始化读取数据的反码相等,则将所述第一初始化读取数据复制到所述第二内存区域,结束初始化步骤;
如果所述第二初始化读取数据与所述第三初始化读取数据的反码相等,则将所述第二初始化读取数据复制到所述第一内存区域,结束初始化步骤;
如果所述第一初始化读取数据与所述第二初始化读取数据相等,则将所述第一初始化读取数据的反码复制到所述第三内存区域,结束初始化步骤;
如果所述第一初始化读取数据与所述第三初始化读取数据的反码不相等,且所述第二初始化读取数据与所述第三初始化读取数据的反码不相等,且所述第一初始化读取数据与所述第二初始化读取数据不相等,则标记物理内存数据不可靠,结束初始化步骤。
本实施例中物理内存通过对三个内存区域进行比较以实现自动恢复功能。
在其中一个实施例中,还包括复位步骤,所述复位步骤,具体包括:
如果接收到复位请求,或者所述物理内存中用于表征数据恢复成功的幻码值不合法,或者如果标记物理内存数据不可靠,则清除所述幻码值;
从所述掉电数据不丢失存储器中按照数据块号读取每个数据块号对应的待恢复数据;
检查所述待恢复数据的有效性,如果所述待恢复数据有效,则将所述待恢复数据写入到所述第一内存区域和所述第二内存区域,将所述待恢复数据的反码写入到所述第三内存区域,如果所述待恢复数据无效,则将预设的默认值写入到所述第一内存区域和所述第二内存区域,将所述默认值的反码写入到所述第三内存区域;
当所有的数据块号遍历完后,在所述物理内存中设置所述幻码值。
幻码值MagicCode是一个预设的特殊数值,通过设置和清除幻码值,可以标识是否恢复完成。
由于物理内存的数据掉电丢失且易受干扰,因此,本实施例通过掉电数据不丢失存储器对物理内存进行恢复,以达到物理内存在掉电或数据受到干扰时,能从掉电数据不丢失存储器准确地恢复数据。
在其中一个实施例中,采用标准AUTOSAR模块NVM 6、标准AUTOSAR模块FEE 7和标准AUTOSAR模块FLS 8从掉电数据不丢失存储器9获取数据,完成与物理内存5的交互。在另一个实施例中,采用自定义的模拟EEPROM系统方法从掉电数据不丢失存储器9获取数据,完成与物理内存5的交互。
在其中一个实施例中,所述向所述掉电数据不丢失存储器写入所述写入数据,具体包括:
读取所述车载控制器的工作电压,如果所述工作电压在预设工作电压范围内,则向所述掉电数据不丢失存储器写入所述写入数据,否则不向所述掉电数据不丢失存储器写入所述写入数据。
其中,预设工作电压范围优选为大于掉电数据不丢失存储器的标定电压。标定电压指的是,在该电压下掉电数据不丢失存储器擦写不保证成功,该标定电压一般由芯片手册提供。
本实施例对车载控制器的工作电压进行检测,从而保证在预设工作电压范围外不对掉电数据不丢失存储器进行操作,避免在工作电压范围外操作掉电数据不丢失存储器造成损坏。对车载控制器的工作电压进行检测,可以通过车载控制器的电压管理模块实现。
在其中一个实施例中,所述物理内存为复位不丢失随机存储器或者随机存储器,所述掉电数据不丢失存储器为闪存。
作为本发明最佳实施例,采用如图2所示的车载控制器内存管理框图。物理内存采用复位不丢失存储器KAM,物理内存分为三个内存分区以实现备份、互相检查(checksum)及自恢复功能。本发明并不限定分区的个数,可以是1个、2个或者更多,当只有一个KAM分区时可以使用CRC校验等其他方法来实现数据完整性的校验,但没有备份和自恢复功能。本发明并不限定KAM内存区域的个数,可选的,可根据实现车载控制器的KAM内存大小而定。
图3是根据本发明最佳实施例的车载控制器内存管理方法的内存读取时序示意图。
步骤S301,应用程序1在需要读取非易失性随机访问存储器数据时,向内存管理单元4请求读。实际通过调用内存管理单元4提供的读接口来实现,接口参数提供内存块号和数据指针,内存块号用来表征应用程序1要读取的内存块的索引地址,数据指针用来提供给内存管理单元4,供其将数据拷贝到该数据指针所在的地方。
步骤S302,内存管理单元4拿到请求后,操作KAM物理内存5,例如物理内存的第一内存区域51,从第一内存区域51将数据拷贝到应用程序1提供的地址所指向的位置。可选的,所述物理内存如对内存读写有保护或者字节要求,在对内存操作时选择合适的寄存器操作。在成功拷贝数据后,返回正确响应给应用程序1。可选的,在发生读或拷贝失败时,返回错误响应码给应用程序1。其中三个模块的交互,为同步模式。
图4是根据本发明最佳实施例用于车载控制器的内存管理系统应用在控制器系统中的内存写入的时序示意图。实例时序图中包含:应用程序1、内存管理单元4、KAM物理内存5、电源管理模块10,标准AUTOSAR NVM模块6。所述应用程序1指代有非易失性随机访问存储器内存需求的应用程序模块,这里都是泛指,不指定特定的功能。
步骤S401,应用程序1在需要写非易失性随机访问存储器数据时,向内存管理单元4请求写。实际通过调用内存管理单元4提供的写接口来实现,接口参数提供内存块号和数据指针,内存块号用来表征应用程序1要读取的内存块的索引地址,数据指针用来提供给内存管理单元4,供其将数据从该数据指针所指的地方拷贝到物理内存。
步骤S402,内存管理单元4拿到请求后,先操作物理内存5,将当前物理内存5里的第一内存区域的数据读出,内存管理单元4将读出的数据与应用程序请求写的数据,进行比较。根据比较结果,选择写动作是否发生。当比较相等时,取消写动作,当比较不等时,继续执行写请求。该方法可以避免由于应用程序1频繁出现调用写接口,而写入数据不变,造成的CPU负载增高,内存损坏等故障。
步骤S403,当内存管理模块4发现请求数据和当前KAM物理内存5的数据一致时,直接返回正确响应,通知应用程序1,并结束该次内存写请求。作为另外一个分支,当内存管理模块发现请求数据和当前KAM物理内存的数据不等,即数据有更新,内存管理单元4将应用程序1请求的数据分别写入KAM物理内存5的第一内存区域和第二内存区域,并将请求的数据的反码写入KAM物理内存5的第三内存区域
步骤S404,在写入KAM物理内存5之后,内存管理单元4调用电压管理模块10的接口来获取当前车载控制器的系统电压,将系统当前电压和标定电压比较,当大于标定电压时,内存管理单元4调用NVM 6的写接口,请求将数据写入到DFLASH 9中。当小于标定电压时,不再调用NVM 6接口,即不再向DFLASH 9中写入数据。此时向应用程序1返回错误响应码,标示由于电压过低DFLASH 9更新数据失败。该方法目的是保证在低压情况下不对物理DFLASH 9操作,避免低压下操作物理DFLASH 9造成的物理区间的损坏。所述标定电压,指在该电压下DFLASH 9物理内存擦写不保证成功(一般由芯片手册提供)。
步骤S405,在内存管理单元4将数据写入KAM第一内存区域51、第二内存区域52和第三内存区域53 7和将数据向NVM 6请求写入后,将正确响应返回给应用程序1.时序图中五个模块的交互,为同步模式。内存管理单元4向AUTOSAR标准模块NVM 6请求数据写入时为同步操作,但NVM 6再次调用FEE 7、FLS 8模块为异步操作,异步主进程由后台任务完成。
图5是根据本发明最佳实施例的车载控制器内存管理方法在控制器系统中的启动时KAM自恢复流程示意图。所述启动时,指在车载控制器上电和复位后,执行初始化阶段。该流程图只是本发明的一个具体实例的示意图,具体实现时并不局限于该流程。
车载控制器初始化开始时,执行步骤S501;
步骤S501,将KAM物理内存5中的第一内存区域、第二内存区域和第三内存区域中的值读出,在发生读或拷贝失败时,记录故障状态;
步骤S502,将第一内存区域51的数据与第三内存区域53的数据的反码比较,当第一内存区域51的数据与第三内存区域53的数据的反码相等时,不再比较,并且执行第二内存区域52的数据=第一内存区域51的数据,即恢复第二内存区域52与第一内存区域51一致,然后结束该流程;
步骤S503,当第一内存区域51的数据与第三内存区域53的数据的反码不相等时,将第二内存区域52的数据与第三内存区域53的数据的反码比较,当第二内存区域52的数据与第三内存区域53的数据的反码相等时,不再比较,并且执行第一内存区域51的数据=第二内存区域52的数据,即恢复第一内存区域51与第二内存区域52一致,然后结束该流程;
步骤S504,当第二内存区域52的数据与第三内存区域53的数据的反码不相等时,将第一内存区域51的数据与第二内存区域52的数据比较,当第一内存区域51的数据与第二内存区域52的数据相等时,不再比较,并且执行第三内存区域53的数据=第一内存区域51的数据的反码,即恢复第三内存区域53与第一内存区域51的反码一样,然后结束该流程;
步骤S505,当第一内存区域51的数据与第二内存区域52的数据不相等时,即表示第一内存区域51/第二内存区域53/~第三内存区域53之间两两不等,表示从KAM物理内存5恢复数据失败,记录标记。所述标记,用于表征三者均不等发生,KAM物理内存5的数据不可靠。
图6是本发明最佳实施例的车载控制器内存管理方法从DFLASH 9中恢复数据流程示意图。该流程图只是本发明的一个具体实例的示意图,具体实现时并不局限于该流程。流程中所述获取复位信息,指代从MCU驱动模块中获取的复位信息,其中上电、低压复位两个复位源是该案例需要的信息。所述MagicCode,指代一组存储在物理KAM里的数据,该数据表征所有非易失性随机访问存储器数据是否已经成功从DFLASH 9恢复到物理内存5内。MagicCode由6字节组成。每次开始从DFLASH 9恢复时,清MagicCode=0x00,从DFLASH 9成功恢复到KAM物理内存5后,置MagicCode=0x77A75A766C5A76A5。MagicCode不合法表示MagicCode不等于0x77A75A766C5A76A5。该MagicCode用于保护数据从DFLASH 9的恢复的可靠性,从DFLASH 9恢复时,采用同步操作,较耗时,如若中途退出,将造成数据不可用。
从DFLASH恢复流程开始后,执行步骤S601。
步骤S601,首先从MCU驱动模块读取复位源,执行步骤S602;
步骤S602,当复位源是上电复位,流程跳转到步骤S606,如果复位源不是上电,执行步骤S603;
步骤S603,判断复位源是否为低压复位,当复位源是低压复位,流程跳转到步骤S606,如果既不是上电复位也不是低压复位时,执行步骤S604;
步骤S604,流程判断MagicCode是否合法,如不合法,流程跳转到步骤S606,否则,执行步骤S605;
步骤S605,判断KAM物理内存的两两不等标记位是否有效,如有效,流程跳转到步骤S605,否则,所有条件不满足从DFLASH恢复数据,流程结束;
步骤S606,首先清除MagicCode,表征MagicCode不再合法;
步骤S607,内存管理单元4开始调用AUTOSAR标准模块NVM/FEE/FLS的接口,按照数据块号遍历,将对应块号的非易失性随机访问存储器数据从DFLASH中恢复出来,当所有的数据块号遍历完后,执行步骤S611;
步骤S608,如果恢复出的数据有效,则执行步骤S609,否则执行步骤S610;
步骤S609,将数据写入到KAM物理内存5,然后执行步骤S607;
步骤S610,将默认值写入到KAM物理内存5,然后执行步骤S607;
步骤S611,置MagicCode,表征MagicCode合法,流程结束。
如图7所示为本发明一种车载控制器内存管理系统的结构模块图,包括:
模拟模块701,用于:将掉电数据不丢失存储器模拟为电可擦可编程只读存储器;
数据读取模块702,用于:响应于对车载控制器的非易失性随机访问存储器数据读取请求,从物理内存中获取所述非易失性随机访问存储器数据读取请求所指定的读取数据,所述物理内存内的数据为掉电数据不丢失存储器的镜像;
数据写入模块703,用于:响应于对车载控制器的非易失性随机访问存储器数据写入请求,向所述物理内存写入所述非易失性随机访问存储器数据写入请求所指定的写入数据,向所述掉电数据不丢失存储器写入所述写入数据。
在其中一个实施例中,所述物理内存包括:第一内存区域、第二内存区域和第三内存区域;
所述向所述物理内存写入所述非易失性随机访问存储器数据写入请求所指定的写入数据,具体包括:向所述第一内存区域写入所述非易失性随机访问存储器数据写入请求所指定的写入数据,向所述第二内存区域写入所述写入数据,向所述第三内存区域写入所述写入数据的反码。
在其中一个实施例中,还包括初始化模块,所述初始化模块,用于:
车载控制器初始化开始时,从所述第一内存区域读取第一初始化读取数据,从所述第二内存区域读取第二初始化读取数据,从所述第三内存区域读取第三初始化读取数据;
如果所述第一初始化读取数据与所述第三初始化读取数据的反码相等,则将所述第一初始化读取数据复制到所述第二内存区域,结束初始化模块;
如果所述第二初始化读取数据与所述第三初始化读取数据的反码相等,则将所述第二初始化读取数据复制到所述第一内存区域,结束初始化模块;
如果所述第一初始化读取数据与所述第二初始化读取数据相等,则将所述第一初始化读取数据的反码复制到所述第三内存区域,结束初始化模块;
如果所述第一初始化读取数据与所述第三初始化读取数据的反码不相等,且所述第二初始化读取数据与所述第三初始化读取数据的反码不相等,且所述第一初始化读取数据与所述第二初始化读取数据不相等,则标记物理内存数据不可靠,结束初始化模块。
在其中一个实施例中,还包括复位模块,所述复位模块,具体用于:
如果接收到复位请求,或者所述物理内存中用于表征数据恢复成功的幻码值不合法,或者如果标记物理内存数据不可靠,则清除所述幻码值;
从所述掉电数据不丢失存储器中按照数据块号读取每个数据块号对应的待恢复数据;
检查所述待恢复数据的有效性,如果所述待恢复数据有效,则将所述待恢复数据写入到所述第一内存区域和所述第二内存区域,将所述待恢复数据的反码写入到所述第三内存区域,如果所述待恢复数据无效,则将预设的默认值写入到所述第一内存区域和所述第二内存区域,将所述默认值的反码写入到所述第三内存区域;
当所有的数据块号遍历完后,在所述物理内存中设置所述幻码值。
在其中一个实施例中,所述向所述掉电数据不丢失存储器写入所述写入数据,具体包括:
读取所述车载控制器的工作电压,如果所述工作电压在预设工作电压范围内,则向所述掉电数据不丢失存储器写入所述写入数据,否则不向所述掉电数据不丢失存储器写入所述写入数据。
在其中一个实施例中,所述物理内存为复位不丢失随机存储器或者随机存储器,所述掉电数据不丢失存储器为闪存。
以上所述实施例仅表达了本发明的几种实施方式,其描述较为具体和详细,但并不能因此而理解为对本发明专利范围的限制。应当指出的是,对于本领域的普通技术人员来说,在不脱离本发明构思的前提下,还可以做出若干变形和改进,这些都属于本发明的保护范围。因此,本发明专利的保护范围应以所附权利要求为准。

Claims (12)

1.一种车载控制器内存管理方法,其特征在于,包括:
模拟步骤,包括:将掉电数据不丢失存储器模拟为电可擦可编程只读存储器;
数据读取步骤,包括:响应于对车载控制器的非易失性随机访问存储器数据读取请求,从物理内存中获取所述非易失性随机访问存储器数据读取请求所指定的读取数据,所述物理内存内的数据为掉电数据不丢失存储器的镜像;
数据写入步骤,包括:响应于对车载控制器的非易失性随机访问存储器数据写入请求,向所述物理内存写入所述非易失性随机访问存储器数据写入请求所指定的写入数据,同时向所述掉电数据不丢失存储器写入所述写入数据。
2.根据权利要求1所述的车载控制器内存管理方法,其特征在于,所述物理内存包括:第一内存区域、第二内存区域和第三内存区域;
所述向所述物理内存写入所述非易失性随机访问存储器数据写入请求所指定的写入数据,具体包括:向所述第一内存区域写入所述非易失性随机访问存储器数据写入请求所指定的写入数据,向所述第二内存区域写入所述写入数据,向所述第三内存区域写入所述写入数据的反码。
3.根据权利要求2所述的车载控制器内存管理方法,其特征在于,还包括初始化步骤,所述初始化步骤,包括:
车载控制器初始化开始时,从所述第一内存区域读取第一初始化读取数据,从所述第二内存区域读取第二初始化读取数据,从所述第三内存区域读取第三初始化读取数据;
如果所述第一初始化读取数据与所述第三初始化读取数据的反码相等,则将所述第一初始化读取数据复制到所述第二内存区域,结束初始化步骤;
如果所述第二初始化读取数据与所述第三初始化读取数据的反码相等,则将所述第二初始化读取数据复制到所述第一内存区域,结束初始化步骤;
如果所述第一初始化读取数据与所述第二初始化读取数据相等,则将所述第一初始化读取数据的反码复制到所述第三内存区域,结束初始化步骤;
如果所述第一初始化读取数据与所述第三初始化读取数据的反码不相等,且所述第二初始化读取数据与所述第三初始化读取数据的反码不相等,且所述第一初始化读取数据与所述第二初始化读取数据不相等,则标记物理内存数据不可靠,结束初始化步骤。
4.根据权利要求3所述的车载控制器内存管理方法,其特征在于,还包括复位步骤,所述复位步骤,具体包括:
如果接收到复位请求,或者所述物理内存中用于表征数据恢复成功的幻码值不合法,或者如果标记物理内存数据不可靠,则清除所述幻码值;
从所述掉电数据不丢失存储器中按照数据块号读取每个数据块号对应的待恢复数据;
检查所述待恢复数据的有效性,如果所述待恢复数据有效,则将所述待恢复数据写入到所述第一内存区域和所述第二内存区域,将所述待恢复数据的反码写入到所述第三内存区域,如果所述待恢复数据无效,则将预设的默认值写入到所述第一内存区域和所述第二内存区域,将所述默认值的反码写入到所述第三内存区域;
当所有的数据块号遍历完后,在所述物理内存中设置所述幻码值。
5.根据权利要求1所述的车载控制器内存管理方法,其特征在于,所述向所述掉电数据不丢失存储器写入所述写入数据,具体包括:
读取所述车载控制器的工作电压,如果所述工作电压在预设工作电压范围内,则向所述掉电数据不丢失存储器写入所述写入数据,否则不向所述掉电数据不丢失存储器写入所述写入数据。
6.根据权利要求1~5任一项所述的车载控制器内存管理方法,其特征在于,所述物理内存为复位不丢失随机存储器或者随机存储器,所述掉电数据不丢失存储器为闪存。
7.一种车载控制器内存管理系统,其特征在于,包括:
模拟模块,用于:将掉电数据不丢失存储器模拟为电可擦可编程只读存储器;
数据读取模块,用于:响应于对车载控制器的非易失性随机访问存储器数据读取请求,从物理内存中获取所述非易失性随机访问存储器数据读取请求所指定的读取数据,所述物理内存内的数据为掉电数据不丢失存储器的镜像;
数据写入模块,用于:响应于对车载控制器的非易失性随机访问存储器数据写入请求,向所述物理内存写入所述非易失性随机访问存储器数据写入请求所指定的写入数据,同时向所述掉电数据不丢失存储器写入所述写入数据。
8.根据权利要求7所述的车载控制器内存管理系统,其特征在于,所述物理内存包括:第一内存区域、第二内存区域和第三内存区域;
所述向所述物理内存写入所述非易失性随机访问存储器数据写入请求所指定的写入数据,具体包括:向所述第一内存区域写入所述非易失性随机访问存储器数据写入请求所指定的写入数据,向所述第二内存区域写入所述写入数据,向所述第三内存区域写入所述写入数据的反码。
9.根据权利要求8所述的车载控制器内存管理系统,其特征在于,还包括初始化模块,所述初始化模块,用于:
车载控制器初始化开始时,从所述第一内存区域读取第一初始化读取数据,从所述第二内存区域读取第二初始化读取数据,从所述第三内存区域读取第三初始化读取数据;
如果所述第一初始化读取数据与所述第三初始化读取数据的反码相等,则将所述第一初始化读取数据复制到所述第二内存区域,结束初始化模块;
如果所述第二初始化读取数据与所述第三初始化读取数据的反码相等,则将所述第二初始化读取数据复制到所述第一内存区域,结束初始化模块;
如果所述第一初始化读取数据与所述第二初始化读取数据相等,则将所述第一初始化读取数据的反码复制到所述第三内存区域,结束初始化模块;
如果所述第一初始化读取数据与所述第三初始化读取数据的反码不相等,且所述第二初始化读取数据与所述第三初始化读取数据的反码不相等,且所述第一初始化读取数据与所述第二初始化读取数据不相等,则标记物理内存数据不可靠,结束初始化模块。
10.根据权利要求9所述的车载控制器内存管理系统,其特征在于,还包括复位模块,所述复位模块,具体用于:
如果接收到复位请求,或者所述物理内存中用于表征数据恢复成功的幻码值不合法,或者如果标记物理内存数据不可靠,则清除所述幻码值;
从所述掉电数据不丢失存储器中按照数据块号读取每个数据块号对应的待恢复数据;
检查所述待恢复数据的有效性,如果所述待恢复数据有效,则将所述待恢复数据写入到所述第一内存区域和所述第二内存区域,将所述待恢复数据的反码写入到所述第三内存区域,如果所述待恢复数据无效,则将预设的默认值写入到所述第一内存区域和所述第二内存区域,将所述默认值的反码写入到所述第三内存区域;
当所有的数据块号遍历完后,在所述物理内存中设置所述幻码值。
11.根据权利要求7所述的车载控制器内存管理系统,其特征在于,所述向所述掉电数据不丢失存储器写入所述写入数据,具体包括:
读取所述车载控制器的工作电压,如果所述工作电压在预设工作电压范围内,则向所述掉电数据不丢失存储器写入所述写入数据,否则不向所述掉电数据不丢失存储器写入所述写入数据。
12.根据权利要求7~11任一项所述的车载控制器内存管理系统,其特征在于,所述物理内存为复位不丢失随机存储器或者随机存储器,所述掉电数据不丢失存储器为闪存。
CN201710425029.8A 2017-06-06 2017-06-06 一种车载控制器内存管理方法及系统 Active CN107239411B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201710425029.8A CN107239411B (zh) 2017-06-06 2017-06-06 一种车载控制器内存管理方法及系统

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201710425029.8A CN107239411B (zh) 2017-06-06 2017-06-06 一种车载控制器内存管理方法及系统

Publications (2)

Publication Number Publication Date
CN107239411A CN107239411A (zh) 2017-10-10
CN107239411B true CN107239411B (zh) 2020-12-08

Family

ID=59987425

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201710425029.8A Active CN107239411B (zh) 2017-06-06 2017-06-06 一种车载控制器内存管理方法及系统

Country Status (1)

Country Link
CN (1) CN107239411B (zh)

Families Citing this family (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN108062259B (zh) * 2017-11-01 2021-03-30 联创汽车电子有限公司 Mcu内部数据存储ecc处理系统及其处理方法
CN108664355B (zh) * 2018-03-30 2022-03-08 斑马网络技术有限公司 备份系统及其备份方法
CN109640383A (zh) * 2019-01-30 2019-04-16 深圳高新兴物联科技有限公司 降低省电模式功耗的方法及装置、物联网设备及存储介质
CN110764486B (zh) * 2019-09-30 2020-09-29 华人运通(江苏)技术有限公司 车载控制器的运行方法、装置、车载控制器及存储介质
CN111158611A (zh) * 2020-03-26 2020-05-15 长春师范大学 一种新能源汽车控制器内存管理方法
CN113341924A (zh) * 2021-06-09 2021-09-03 中国第一汽车股份有限公司 一种ecu下电方法、装置、设备及存储介质
CN113778061B (zh) * 2021-09-16 2023-03-28 广州锦红源电子科技有限公司 电子控制器程序完整性的校验方法、装置、电子控制器

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102135891A (zh) * 2010-01-21 2011-07-27 杭州华三通信技术有限公司 可实现引导启动的系统及引导启动控制装置和方法
CN102662802A (zh) * 2012-05-08 2012-09-12 无锡云动科技发展有限公司 基于非易失性内存的全系统断电恢复方法及设备
WO2014055446A1 (en) * 2012-10-02 2014-04-10 Nextbit, Inc. Application state synchronization across multiple devices
CN103914393A (zh) * 2014-04-11 2014-07-09 四川华拓光通信股份有限公司 一种基于mcu的flash不丢失更新存储方法

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7152139B1 (en) * 2004-02-19 2006-12-19 Micron Technology, Inc. Techniques for generating serial presence detect contents
CN103268294A (zh) * 2013-04-19 2013-08-28 深圳创维数字技术股份有限公司 一种存取数据的操作方法和数据处理设备
US9684853B2 (en) * 2014-04-15 2017-06-20 Kyocera Document Solutions Inc. Image forming apparatus that writes data from volatile memory to non-volatile memory
CN105653345A (zh) * 2014-10-17 2016-06-08 伊姆西公司 用于支持对数据的非易失性随机访问的方法和设备

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102135891A (zh) * 2010-01-21 2011-07-27 杭州华三通信技术有限公司 可实现引导启动的系统及引导启动控制装置和方法
CN102662802A (zh) * 2012-05-08 2012-09-12 无锡云动科技发展有限公司 基于非易失性内存的全系统断电恢复方法及设备
WO2014055446A1 (en) * 2012-10-02 2014-04-10 Nextbit, Inc. Application state synchronization across multiple devices
CN103914393A (zh) * 2014-04-11 2014-07-09 四川华拓光通信股份有限公司 一种基于mcu的flash不丢失更新存储方法

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
Flash模拟EEPROM的方法;levi8508;《https://blog.csdn.net/levi8508/article/details/4274693》;20090616;正文第1页 *

Also Published As

Publication number Publication date
CN107239411A (zh) 2017-10-10

Similar Documents

Publication Publication Date Title
CN107239411B (zh) 一种车载控制器内存管理方法及系统
US7197613B2 (en) Nonvolatile memory
US8914702B2 (en) Bit error repair method and information processing apparatus
US8006030B2 (en) Memory controller for identifying the last valid page/segment in a physical block of a flash memory
US8271515B2 (en) System and method for providing copyback data integrity in a non-volatile memory system
US7774382B2 (en) Method and apparatus for configuring a control device, and corresponding control device
US20110029726A1 (en) Data updating method, memory system and memory device
CN102298545B (zh) 一种系统启动引导处理方法及装置
KR100316981B1 (ko) 플래시 메모리를 구비한 마이크로컴퓨터 및 플래시 메모리에 프로그램을 저장하는 방법
JP4227149B2 (ja) 電子制御装置の情報記憶方法
JP2002351685A (ja) 不揮発性メモリのデータ更新方法及び制御装置
CN109933340B (zh) 一种航天器eeprom基于页模式的在轨写入和自检方法
CN112015447B (zh) 电子设备的系统更新方法及装置、电子设备及存储介质
JP2004220068A (ja) メモリカード及びメモリへのデータ書き込み方法
US20070277028A1 (en) Method and system for recovery from reprogramming failures in nonvolatile memory
JP4661369B2 (ja) メモリコントローラ
US20180052635A1 (en) Electronic control apparatus and information storage method for the same
CN111506449B (zh) 一种空调参数存储方法及装置和存储介质
CN113434086B (zh) 数据存储方法、装置、非易失性存储器件和存储器
JPH10124403A (ja) ブロック消去型フラッシュメモリの書込み方法
CN114356653A (zh) 一种工控防火墙掉电保护方法及装置
JP4558393B2 (ja) 情報処理装置
US20220204008A1 (en) Arithmetic processing device, vehicle control device, and update method
US7849279B2 (en) Method for the secure updating data areas in non volatile memory, device to perform such a method
CN114138191B (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
GR01 Patent grant
GR01 Patent grant