鴻蒙Hi3861 NV操作——如何保存數(shù)據(jù)到開發(fā)板,斷電不丟失
想了解更多內(nèi)容,請訪問:
51CTO和華為官方合作共建的鴻蒙技術(shù)社區(qū)
https://harmonyos.51cto.com/#zz
實際產(chǎn)品開發(fā)過程中,我們肯定需要保存一些數(shù)據(jù),并且掉電不丟失。例如很多人在使用我之前寫的一篇WiFi配網(wǎng)功能后,都會遇到一個問題:我配置了WiFi賬戶密碼,但是下次我又得重新配網(wǎng),能不能把WiFi賬戶密碼保存起來?
好,接下來我們來實現(xiàn)這個功能:保存數(shù)據(jù)到開發(fā)板,斷電不丟失。
有兩種方式:
1、使用KV系統(tǒng)——最簡單,推薦使用
關(guān)于如何保存數(shù)據(jù)的,可以直接使用 kv系統(tǒng)更加簡單方便,不必參考本文的 nv操作,本文nv操作僅供大家參考。
kv系統(tǒng)可以保存數(shù)據(jù)到flash,只需要簡單的兩個函數(shù)即可:
//刪除kv
void DeleteKVCache(const char* key);
//增加kv
void AddKVCache(const char* key, const char* value, boolean isNew);
//獲取kv值
int GetValueByCache(const char* key, char* value, unsigned int maxLen);
//清除kv
int ClearKVCacheInner(void);
例如:
//把ssid寫入到kv中
AddKVCache("ssid", ssid, TRUE);
//讀取出來kv
GetValueByCache("ssid",ssid,sizeof(ssid));
可以看到更加簡單高效~~推薦大家使用
2、NV系統(tǒng)——僅hi3861支持
首先我們要使用到 hi3861 的nv操作,它支持我們自定義一些數(shù)據(jù)保存到工廠參數(shù)分區(qū),其實就是寫入到hi3861的flash中。
不過這個功能使用挺復(fù)雜的,我們以保存wifi賬戶密碼為例。
1、修改 mss_nvi_db.xml 文件
打開vendor\hisi\hi3861\hi3861\tools\nvtool\xml_file\mss_nvi_db.xml 文件,在 Factory 中增加我們的參數(shù):ID為0x0B 。

截圖的內(nèi)容是這個:
- <NV ID="0x0B" NAME="INIT_CONFIG_SSID_MY" PARAM_NAME="wal_cfg_ssid_my" PARAM_VALUE="{[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]}" CATEGORY="FTM" DEV="CCO-STA-NDM" DESCRIPTION="" />
2、修改 nv_factory_struct_def.txt 文件 增加 結(jié)構(gòu)體
修改 vendor\hisi\hi3861\hi3861\tools\nvtool\h_file\nv\nv_factory_struct_def.txt,增加結(jié)構(gòu)體:
- typedef struct {
- hi_u8 ssid[50];
- hi_u8 passwd[50];
- } wal_cfg_ssid_my;
3、編寫代碼,讀取寫入數(shù)據(jù)
通常來說,需要先執(zhí)行一次 hi_nv_init(0xA000, 0x2000, 0x1000); 進(jìn)行初始化,但是由于系統(tǒng)啟動的時候已經(jīng)初始化過了,所以我們不需要重復(fù)初始化。
- //寫入到工廠區(qū)
- /* NV值寫入 */
- wal_cfg_ssid_my nv;
- memset(&nv, 0, sizeof(wal_cfg_ssid_my));
- memcpy_s(&nv.ssid[0], sizeof(wal_cfg_ssid_my), ssid, ssid_len);
- memcpy_s(&nv.passwd[0], sizeof(wal_cfg_ssid_my), passwd, passwd_len);
- ret = hi_factory_nv_write(NV_ID, &nv, sizeof(wal_cfg_ssid_my), 0);
- if (ret != HISI_OK) {
- printf("%x\n", ret);
- }
- /* 再次讀取寫入的NV值 */
- ret = hi_factory_nv_read(NV_ID, &nv, sizeof(wal_cfg_ssid_my), 0);
- if (ret != HISI_OK) {
- printf("%x\n", ret);
- }
- printf("nv read : %d, ssid :[%s] psswd [%s]\n",ret, nv.ssid, nv.passwd);
附件我提供了一個wifi配網(wǎng)的升級版功能的源碼,支持保存wifi賬號密碼。
完成以上操作后,我們就可以發(fā)現(xiàn)wifi賬戶密碼可以寫入到nv中了,可以永久保存數(shù)據(jù)了。查看開機(jī)打?。?nbsp;

可以看到開機(jī)后讀取到ssid 和密碼正確,并且成功連接到wifi熱點了。
我們再來看這個nv的一些內(nèi)容吧:
mss_nvi_db.xml 文件記錄了所有系統(tǒng)參數(shù)的默認(rèn)值,而且這個文件其實還分組的:

可以看到分為 Factory 和 Modem。
NV模塊用于管理系統(tǒng)關(guān)鍵配置信息。 NV存儲于Flash上,分為以下2個區(qū):
● 工廠區(qū) Factory:僅在工廠時使用。
● 非工廠區(qū) Modem :分為以下2個區(qū):
– Keep區(qū): NV項在升級后保留原值
– Modem區(qū): NV項在升級后被新版本值替換。

關(guān)于
- <GROUP NAME="Factory" ID="0x3" FEATURE="1<<0,1<<5" USEDMODE="0" PARAM_DEF_FILE="../nv/nv_factory_struct_def.txt">
每一項的說明如下:

關(guān)于
- <NV ID="0x0B" NAME="INIT_CONFIG_SSID_MY" PARAM_NAME="wal_cfg_ssid_my" PARAM_VALUE="{[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]}" CATEGORY="FTM" DEV="CCO-STA-NDM" DESCRIPTION="" />
的每一項說明如下:

另外需要注意的是工廠區(qū)的讀寫操作跟非工廠區(qū)的讀寫操作的API不同。

想了解更多內(nèi)容,請訪問:
51CTO和華為官方合作共建的鴻蒙技術(shù)社區(qū)
https://harmonyos.51cto.com/#zz