在这里我只说在项目中常用的一种添加NVRAM方式。
(1)在Nvram_user_defs.h中定义LID NVRAM_EF_EDUCATION_LID
NVRAM 中的数据是在 fs 文件系统的管理中操作的,而文 件操作需要识别数据项和管理数据项,都是通过这个 LID 来操作的。
(2)在Nvram_user_defs.h中定义size和total,
NVRAM_EDUCATION_DATA_SIZE 4:相当于一个内存块的大小
NVRAM_EDUCATION_DATA_TOTAL 1:一共有几个内存快
(3)定义NVRAM项Version 在Custom_nvram_editor_data_item.h中定义 #define NVRAM_EF_EDUCATION_LID_VERNO "001"
文件系统是怎么知道 它所管理的这些 NV 数据已经改变了呢?就是通过这个版本号来识别的,比如你修改了某个 NV 数据但没有更该它的版本号,文件 系统是不会对原始数据更改的;只有在更改了 NV 值并且修改了版本号,这时文件系统才识别到已经更改,并进行相应的数据更新 。
(4)定义NVRAM默认值使用默认的可以不用定义
(5)
在Nvram_user_config.c中使用
{
NVRAM_EF_EDUCATION_LID ,
NVRAM_EDUCATION_DATA_SIZE,
NVRAM_EDUCATION_DATA_TOTAL,
NVRAM_NORMAL(NVRAM_EF_ZERO_DEFAULT),这里就使用系统内的默认值
NVRAM_ATTR_MULTIREC_READ,
NVRAM_CATEGORY_USER,
"CT05",这里要注意这个序号,跟着上面那个来,上面那个如果是CT04这里就写CT05,这可不要认为是自己随便写
VER(NVRAM_EF_EDUCATION_LID),
"Education\0",这个可以随便写
NVRAM_RESERVED_VALUE
}
最主要说的就是我们使用的读写方法,有两个WriteValue/ReadValue或是WriteRecord/ReadRecord。但是这里只能使用WriteRecord/ReadRecord,如果使用WriteValue/ReadValue就会出现复位现象。而且要注意在使用的时候这里的大小不能使用DS_BYTE /DS_SHORT/DS_DOUBLE,要用我们上面定义的 NVRAM_EDUCATION_DATA_SIZE。
ReadRecord(
NVRAM_EF_EDUCATION_LID ,
1,//表示你使用到那一块内存
(&read_buff,
NVRAM_EDUCATION_DATA_SIZE,//注意这里不能使用DS_BYTE /DS_SHORT/DS_DOUBLE这三个 。
&pError);
WriteRecord使用方法一样。
要想使用WriteValue/ReadValue可以,修改两个文件custom_mmi_default_value.h和Common_mmi_cache_config.c中
在custom_mmi_default_value.h中定义LID NVRAM_MY_EDUCATION_UN, 注意在这个文件中有有三个枚举变量,分别是BYTEDATA,SHORTDATA,DOUBLEDATA,每一个枚举变量都对应在Mmi_frm_nvram_gprot.h中的
typedef enum
{
/* Corresponding to NVRAM_EF_CACHE_BYTE_LID. */
DS_BYTE = 1,
/* Corresponding to NVRAM_EF_CACHE_SHORT_LID. */
DS_SHORT = 2,
/* Corresponding to NVRAM_EF_CACHE_DOUBLE_LID. */
DS_DOUBLE = 8
} DATASIZE;
在 Common_mmi_cache_config.c文件中定义
SHORT_ENTRY(NVRAM_MY_EDUCATION_UN ,
NVRAM_APP_PHNSET,
NVRAM_CACHE_ID_RESERVED,
#ifdef _SETTING
NVRAM_COMMON_AVERAGE |NVRAM_COMMON_FACTORY_RESTORE|NVRAM_COMMON_USER_RESTORE ,
#else
KAL_TRUE,
#endif
"EDUCATIONLID",
0xFF,0xFF),
注意在这个文件中有三个数组,分别是common_mmi_cache_byte[],common_mmi_cache_short[] ,common_mmi_cache_double[]和上面LID定义中的BYTEDATA,SHORTDATA,DOUBLEDATA想对应起来
所以这里别忘了放错地方了。
定义好之后就可以使用WriteValue/ReadValue函数了,而且第三个参数可以相应的是DS_BYTE ,DS_SHORT ,DS_DOUBLE ,这里要注意之前LID定义在哪里就要相应的使用哪个,不要说在custom_mmi_default_value.h文件中定义的LID是在这个SHORTDATA枚举类型中的,那么在使用WriteValue/ReadValue函数时第三个参数就要使用DS_SHORT,不然会出现复位现象。