一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

【LPC55S69】使用FAL分區(qū)管理與easyflash變量管理(下集)

恩智浦MCU加油站 ? 來(lái)源:未知 ? 2023-06-29 09:05 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

上期帶大家了解了FAL組件和DFS文件系統(tǒng)的功能特點(diǎn)和使用方法,本期將繼續(xù)解讀如何將EasyFlsh移植到FAL分區(qū)。

簡(jiǎn)述EasyFlash

關(guān)于EasyFlash的來(lái)源我們已經(jīng)講過(guò),EasyFlash是一款開(kāi)源的輕量級(jí)嵌入式Flash存儲(chǔ)器庫(kù),方便開(kāi)發(fā)者更加輕松的實(shí)現(xiàn)基于Flash存儲(chǔ)器的常見(jiàn)應(yīng)用開(kāi)發(fā)。非常適合智能家居、可穿戴、工控、醫(yī)療、物聯(lián)網(wǎng)等需要斷電存儲(chǔ)功能的產(chǎn)品,資源占用極低,支持各種 MCU 片上存儲(chǔ)器。

EasyFlash不僅能夠?qū)崿F(xiàn)對(duì)產(chǎn)品的設(shè)定參數(shù)或運(yùn)行日志等信息的掉電保存功能,還封裝了簡(jiǎn)潔的增加、刪除、修改及查詢方法,降低了開(kāi)發(fā)者對(duì)產(chǎn)品參數(shù)的處理難度,也保證了產(chǎn)品在后期升級(jí)時(shí)擁有更好的擴(kuò)展性。讓Flash變?yōu)镹oSQL(非關(guān)系型數(shù)據(jù)庫(kù))模型的小型鍵值(Key-Value)存儲(chǔ)數(shù)據(jù)庫(kù)。

EasyFlash軟件包使用

打開(kāi)ENV進(jìn)入路徑:RT-Thread online packages → tools packages → EasyFlash: Lightweight embedded flash memory library.,選擇軟件包版本為最新版。配置后退出ENV,同時(shí)使用pkgs --update下載軟件包,然后再使用scons-target=mdk5重新生成MDK5文件。

4936011e-1615-11ee-962d-dac502259ad0.png

移植EasyFlash

下載完easyflash軟件包后,我們復(fù)制. t-threadsplpc55sxxlpc55s69_nxp_evkpackagesEasyFlash-latestportsef_fal_port.c到目錄. t-threadsplpc55sxxlpc55s69_nxp_evkoardportseasyflashef_fal_port.c,雙擊打開(kāi)該文件,完成以下修改:

// 修改 FAL_EF_PART_NAME 為 easyflash
#define FAL_EF_PART_NAME               "easyflash"

編寫(xiě)EasyFlash測(cè)試用例

/*
  * Copyright (c) 2006-2023, RT-Thread Development Team
  *
  * SPDX-License-Identifier: Apache-2.0
  *
  * Change Logs:
  * Date           Author       Notes
  * 2023-04-21     Wangyuqiang  the first version
  */


#include "rtthread.h"
#include "rtdevice.h"
#include "board.h"
#include "fal.h"


#include 


#include "easyflash.h"
#include 


#define FS_PARTITION_NAME  "filesystem"


#define BUF_SIZE 1024


static int fal_test(const char *partiton_name)
{
int ret;
int i, j, len;
uint8_t buf[BUF_SIZE];
const struct fal_flash_dev *flash_dev = RT_NULL;
const struct fal_partition *partition = RT_NULL;


if (!partiton_name)
     {
         rt_kprintf("Input param partition name is null!
");
return -1;
     }


     partition = fal_partition_find(partiton_name);
if (partition == RT_NULL)
     {
         rt_kprintf("Find partition (%s) failed!
", partiton_name);
         ret = -1;
return ret;
     }


     flash_dev = fal_flash_device_find(partition->flash_name);
if (flash_dev == RT_NULL)
     {
         rt_kprintf("Find flash device (%s) failed!
", partition->flash_name);
         ret = -1;
return ret;
     }


     rt_kprintf("Flash device : %s   "
"Flash size : %dK   
"
"Partition : %s   "
"Partition size: %dK
",
                 partition->flash_name,
                 flash_dev->len/1024,
                 partition->name,
                 partition->len/1024);


/* erase all partition */
     ret = fal_partition_erase_all(partition);
if (ret < 0)
     {
         rt_kprintf("Partition (%s) erase failed!
", partition->name);
         ret = -1;
return ret;
     }
     rt_kprintf("Erase (%s) partition finish!
", partiton_name);


/* read the specified partition and check data */
for (i = 0; i < partition->len;)
     {
         rt_memset(buf, 0x00, BUF_SIZE);


         len = (partition->len - i) > BUF_SIZE ? BUF_SIZE : (partition->len - i);


         ret = fal_partition_read(partition, i, buf, len);
if (ret < 0)
         {
             rt_kprintf("Partition (%s) read failed!
", partition->name);
             ret = -1;
return ret;
         }


for(j = 0; j < len; j++)
         {
if (buf[j] != 0xFF)
             {
                 rt_kprintf("The erase operation did not really succeed!
");
                 ret = -1;
return ret;
             }
         }
         i += len;
     }


/* write 0x00 to the specified partition */
for (i = 0; i < partition->len;)
     {
         rt_memset(buf, 0x00, BUF_SIZE);


         len = (partition->len - i) > BUF_SIZE ? BUF_SIZE : (partition->len - i);


         ret = fal_partition_write(partition, i, buf, len);
if (ret < 0)
         {
             rt_kprintf("Partition (%s) write failed!
", partition->name);
             ret = -1;
return ret;
         }


         i += len;
     }
     rt_kprintf("Write (%s) partition finish! Write size %d(%dK).
", partiton_name, i, i/1024);


/* read the specified partition and check data */
for (i = 0; i < partition->len;)
     {
         rt_memset(buf, 0xFF, BUF_SIZE);


         len = (partition->len - i) > BUF_SIZE ? BUF_SIZE : (partition->len - i);


         ret = fal_partition_read(partition, i, buf, len);
if (ret < 0)
         {
             rt_kprintf("Partition (%s) read failed!
", partition->name);
             ret = -1;
return ret;
         }


for(j = 0; j < len; j++)
         {
if (buf[j] != 0x00)
             {
                 rt_kprintf("The write operation did not really succeed!
");
                 ret = -1;
return ret;
             }
         }


         i += len;
     }


     ret = 0;
return ret;
}


static void fal_sample(void)
{
/* 1- init */
     fal_init();


if (fal_test("font") == 0)
     {
         rt_kprintf("Fal partition (%s) test success!
", "font");
     }
else
     {
         rt_kprintf("Fal partition (%s) test failed!
", "font");
     }


if (fal_test("download") == 0)
     {
         rt_kprintf("Fal partition (%s) test success!
", "download");
     }
else
     {
         rt_kprintf("Fal partition (%s) test failed!
", "download");
     }
}
MSH_CMD_EXPORT(fal_sample, fal sample);


static void fal_elmfat_sample(void)
{
int fd, size;
struct statfs elm_stat;
struct fal_blk_device *blk_dev;
char str[] = "elmfat mount to W25Q flash.", buf[80];


/* fal init */
     fal_init();


/* create block device */
     blk_dev = (struct fal_blk_device *)fal_blk_device_create(FS_PARTITION_NAME);
if(blk_dev == RT_NULL)
         rt_kprintf("Can't create a block device on '%s' partition.
", FS_PARTITION_NAME);
else
         rt_kprintf("Create a block device on the %s partition of flash successful.
", FS_PARTITION_NAME);


/* make a elmfat format filesystem */
if(dfs_mkfs("elm", FS_PARTITION_NAME) == 0)
         rt_kprintf("make elmfat filesystem success.
");


/* mount elmfat file system to FS_PARTITION_NAME */
if(dfs_mount(FS_PARTITION_NAME, "/", "elm", 0, 0) == 0)
         rt_kprintf("elmfat filesystem mount success.
");


/* Get elmfat file system statistics */
if(statfs("/", &elm_stat) == 0)
         rt_kprintf("elmfat filesystem block size: %d, total blocks: %d, free blocks: %d.
",
                     elm_stat.f_bsize, elm_stat.f_blocks, elm_stat.f_bfree);


if(mkdir("/user", 0x777) == 0)
         rt_kprintf("make a directory: '/user'.
");


     rt_kprintf("Write string '%s' to /user/test.txt.
", str);


/* Open the file in create and read-write mode, create the file if it does not exist*/
     fd = open("/user/test.txt", O_WRONLY | O_CREAT);
if (fd >= 0)
     {
if(write(fd, str, sizeof(str)) == sizeof(str))
             rt_kprintf("Write data done.
");


         close(fd);   
     }


/* Open file in read-only mode */
     fd = open("/user/test.txt", O_RDONLY);
if (fd >= 0)
     {
         size = read(fd, buf, sizeof(buf));


         close(fd);


if(size == sizeof(str))
             rt_kprintf("Read data from file test.txt(size: %d): %s 
", size, buf);
     }
}
MSH_CMD_EXPORT_ALIAS(fal_elmfat_sample, fal_elmfat,fal elmfat sample);


static void easyflash_sample(void)
{
/* fal init */
     fal_init();


/* easyflash init */
if(easyflash_init() == EF_NO_ERR)
     {
uint32_t i_boot_times = NULL;
char *c_old_boot_times, c_new_boot_times[11] = {0};


/* get the boot count number from Env */
         c_old_boot_times = ef_get_env("boot_times");
/* get the boot count number failed */
if (c_old_boot_times == RT_NULL)
             c_old_boot_times[0] = '0';


         i_boot_times = atol(c_old_boot_times);
/* boot count +1 */
         i_boot_times ++;
         rt_kprintf("===============================================
");
         rt_kprintf("The system now boot %d times
", i_boot_times);
         rt_kprintf("===============================================
");
/* interger to string */
sprintf(c_new_boot_times, "%d", i_boot_times);
/* set and store the boot count number to Env */
         ef_set_env("boot_times", c_new_boot_times);
         ef_save_env();
     }
}
MSH_CMD_EXPORT(easyflash_sample, easyflash sample);

EasyFlash測(cè)試結(jié)果

打開(kāi)串口助手,輸入命令:
  1. msh />easyflash_sample

復(fù)制代碼

第一次命令調(diào)用:49613442-1615-11ee-962d-dac502259ad0.png第二次RESET開(kāi)發(fā)板后調(diào)用:

498e3712-1615-11ee-962d-dac502259ad0.png

結(jié)語(yǔ)

至此,F(xiàn)AL分區(qū)管理EasyFlash變量管理已經(jīng)全部介紹完畢了,經(jīng)歷從移植軟件模擬SPI框架到LPC55S69,到移植過(guò)程中不斷遇到的問(wèn)題,解決問(wèn)題并提供應(yīng)用示例,并完成開(kāi)發(fā)日記、開(kāi)發(fā)筆記及應(yīng)用教學(xué),作者坦言整個(gè)過(guò)程還是受益良多的。希望大家懷揣著一顆求知及授學(xué)之心,共同建設(shè)好這個(gè)領(lǐng)域!

參考資料:

  • IOT-OS之RT-Thread(十一)--- FAL分區(qū)管理與easyflash變量管理

  • RT-Thread文檔中心:FAL組件

本文轉(zhuǎn)載自:

END

更多恩智浦AI-IoT市場(chǎng)和產(chǎn)品信息,邀您同時(shí)關(guān)注“NXP客?!蔽⑿殴娞?hào)

49c10750-1615-11ee-962d-dac502259ad0.jpg ? ? ?

NXP客棧


恩智浦致力于打造安全的連接和基礎(chǔ)設(shè)施解決方案,為智慧生活保駕護(hù)航。

長(zhǎng)按二維碼,關(guān)注我們

恩智浦MCU加油站


這是由恩智浦官方運(yùn)營(yíng)的公眾號(hào),著重為您推薦恩智浦MCU的產(chǎn)品信息、開(kāi)發(fā)技巧、教程文檔、培訓(xùn)課程等內(nèi)容。

49d4e6b2-1615-11ee-962d-dac502259ad0.jpg ?

長(zhǎng)按二維碼,關(guān)注我們


原文標(biāo)題:【LPC55S69】使用FAL分區(qū)管理與easyflash變量管理(下集)

文章出處:【微信公眾號(hào):恩智浦MCU加油站】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。


聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • mcu
    mcu
    +關(guān)注

    關(guān)注

    146

    文章

    17984

    瀏覽量

    367088
  • 恩智浦
    +關(guān)注

    關(guān)注

    14

    文章

    5981

    瀏覽量

    116878

原文標(biāo)題:【LPC55S69】使用FAL分區(qū)管理與easyflash變量管理(下集)

文章出處:【微信號(hào):NXP_SMART_HARDWARE,微信公眾號(hào):恩智浦MCU加油站】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    【PCA9958HN-ARD】GUI工具的使用

    :PCA9958HN-ARD評(píng)估板快速入門(mén) | NXP 半導(dǎo)體),里面包含GUI上位機(jī)軟件的安裝包和LPC55S69開(kāi)發(fā)板的固件。 然后,點(diǎn)擊setup.exe,進(jìn)行GUI上位機(jī)軟件的安裝,安裝
    發(fā)表于 06-29 10:07

    Linux系統(tǒng)中磁盤(pán)分區(qū)與掛載詳解

    磁盤(pán)分區(qū)是將物理硬盤(pán)劃分為不同的邏輯部分,每個(gè)分區(qū)都可以被視為一個(gè)獨(dú)立的存儲(chǔ)設(shè)備。通過(guò)磁盤(pán)分區(qū),我們可以更好地管理磁盤(pán)空間,實(shí)現(xiàn)數(shù)據(jù)的組織和隔離。
    的頭像 發(fā)表于 06-17 15:08 ?631次閱讀
    Linux系統(tǒng)中磁盤(pán)<b class='flag-5'>分區(qū)</b>與掛載詳解

    警用裝備管理系統(tǒng)DW-S304,對(duì)警用裝備的全生命周期追蹤管理.

    管理系統(tǒng)
    jf_85364936
    發(fā)布于 :2025年06月15日 09:19:54

    戰(zhàn)備器材管理系統(tǒng)DW-S301

    管理系統(tǒng)
    jf_72884372
    發(fā)布于 :2025年04月17日 16:28:57

    LPC55 USB端點(diǎn)rx數(shù)據(jù)無(wú)響應(yīng)是哪里出了問(wèn)題?

    我使用 LPC55S69 開(kāi)發(fā)了一個(gè) MIDI 鍵盤(pán),USB MIDI 設(shè)備基于 SDK 的 USB 串行協(xié)議,我相應(yīng)地對(duì)其進(jìn)行了修改。 在 PC 上可以正確地枚舉為 MIDI 設(shè)備,數(shù)據(jù)傳輸和接收
    發(fā)表于 04-09 08:09

    LPC55S69-EVK無(wú)法加載安全啟動(dòng)是怎么回事?

    我已按如下方式配置了我的 LPC55S69-EVK 板: ? 此外,我還配置了: TrustZone disabled image Authentication key: ROT1
    發(fā)表于 04-09 06:34

    SwdRead等待response_“LPC55s28” 超時(shí)了怎么解決?

    當(dāng)我嘗試鎖定 MCU LPC55sXX 時(shí),我遇到了以下問(wèn)題。 我正在按照以下步驟鎖定 MCU: 1.- 在 ISP 模式下配置 MCU。 2.- 將 bin 文件寫(xiě)入 CFPA。 3.- 將 bin 文件寫(xiě)入 CMPA。 4.- 驗(yàn)證 MCU 是否被鎖定并預(yù)期出現(xiàn)以下結(jié)果: 此問(wèn)題間歇性發(fā)生。
    發(fā)表于 04-08 06:52

    使用NXP控制器LPC55S69JBD100E,編程都需要SWD和JTAG嗎?

    1. 在我們的項(xiàng)目中,我們使用 NXP 控制器LPC55S69JBD100E。編程都需要 SWD 和 JTAG 嗎? 2. 您能解釋一下 Flash 編程嗎?
    發(fā)表于 03-27 07:23

    使用ConfigTools for USB創(chuàng)建新項(xiàng)目時(shí)遇到的問(wèn)題求解

    使用 ConfigTools for USB 創(chuàng)建新項(xiàng)目時(shí),存在缺少資源的問(wèn)題,無(wú)法添加它: 該問(wèn)題從 SDK 24.12.00 開(kāi)始出現(xiàn)。適用于 macOS 的 MCUXpresso。經(jīng)過(guò) LPC55s69、MCX A153 和 MCX N947 測(cè)試。
    發(fā)表于 03-26 08:06

    LPC55S69JBD100通過(guò)SPI連接到WM02C時(shí),是否支持通過(guò)bootloader進(jìn)行OTA更新?

    該恩智浦-LPC55S69JBD100通過(guò) SPI 連接到 WM02C (nRF7002) 時(shí),是否支持通過(guò) bootloader 進(jìn)行 OTA 更新?請(qǐng)解釋一下 OTA 更新過(guò)程。
    發(fā)表于 03-26 07:39

    EVK-LPC55S28的負(fù)載上限是多少?

    EVK-LPC55S28 使用晶CX3225GA16000D0PTVCC,在數(shù)據(jù)表中指定負(fù)載上限為 8pf。在 capbank appnote 中,它給出了一個(gè)示例,其中具有 8pF 值的 xtal
    發(fā)表于 03-26 06:25

    在ISP模式下無(wú)法在LPC55S69 EVK上升級(jí)應(yīng)用程序怎么解決?

    我在使用 flash magic 工具升級(jí) LPC55s69 evk 上的固件時(shí)看到問(wèn)題。 在驗(yàn)證過(guò)程中,我看到失敗。 請(qǐng)找到隨附的快照作為參考, 有人可以告訴我,這是怎么回事嗎? 一些其他信息
    發(fā)表于 03-26 06:00

    快速搞懂C語(yǔ)言程序內(nèi)存分區(qū)

    在程序運(yùn)行過(guò)程中,操作系統(tǒng)會(huì)根據(jù)程序的需要,將內(nèi)存劃分為多個(gè)功能不同的區(qū)段,以便更高效地管理內(nèi)存資源和確保程序的穩(wěn)定運(yùn)行。不同的內(nèi)存區(qū)段負(fù)責(zé)存儲(chǔ)不同類型的數(shù)據(jù)和代碼,涵蓋了從程序指令、全局變量
    的頭像 發(fā)表于 03-14 17:37 ?671次閱讀
    快速搞懂C語(yǔ)言程序內(nèi)存<b class='flag-5'>分區(qū)</b>!

    消防物證管理系統(tǒng) DW-S404實(shí)現(xiàn)消防物證智能化管理

    一、系統(tǒng)概述 智慧消防物證管理系統(tǒng)DW-S404系統(tǒng)旨在借助現(xiàn)代信息技術(shù),達(dá)成消防物證管理的高效化、安全化及智能化管理目標(biāo)。該系統(tǒng)運(yùn)用物聯(lián)網(wǎng)、大數(shù)據(jù)、云計(jì)算等先進(jìn)技術(shù),實(shí)現(xiàn)對(duì)消防物證從
    的頭像 發(fā)表于 12-07 17:45 ?504次閱讀
    消防物證<b class='flag-5'>管理</b>系統(tǒng) DW-<b class='flag-5'>S</b>404實(shí)現(xiàn)消防物證智能化<b class='flag-5'>管理</b>

    使用FAL分區(qū)管理easyflash變量管理

    1.FAL組件1.1什么是FALFAL(FlashAbstractionLayer)Flash抽象層,是對(duì)Flash及基于Flash的分區(qū)進(jìn)行管理、操作的抽象層,對(duì)上層統(tǒng)一了Flash及分區(qū)
    的頭像 發(fā)表于 10-01 08:10 ?1926次閱讀
    使用<b class='flag-5'>FAL</b><b class='flag-5'>分區(qū)</b><b class='flag-5'>管理</b>與<b class='flag-5'>easyflash</b><b class='flag-5'>變量</b><b class='flag-5'>管理</b>