色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

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

恩智浦MCU加油站 ? 來源:未知 ? 2023-06-29 09:05 ? 次閱讀

上期帶大家了解了FAL組件和DFS文件系統的功能特點和使用方法,本期將繼續解讀如何將EasyFlsh移植到FAL分區。

簡述EasyFlash

關于EasyFlash的來源我們已經講過,EasyFlash是一款開源的輕量級嵌入式Flash存儲器庫,方便開發者更加輕松的實現基于Flash存儲器的常見應用開發。非常適合智能家居、可穿戴、工控、醫療、物聯網等需要斷電存儲功能的產品,資源占用極低,支持各種 MCU 片上存儲器。

EasyFlash不僅能夠實現對產品的設定參數或運行日志等信息的掉電保存功能,還封裝了簡潔的增加、刪除、修改及查詢方法,降低了開發者對產品參數的處理難度,也保證了產品在后期升級時擁有更好的擴展性。讓Flash變為NoSQL(非關系型數據庫)模型的小型鍵值(Key-Value)存儲數據庫。

EasyFlash軟件包使用

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

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

移植EasyFlash

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

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

編寫EasyFlash測試用例

/*
  * 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測試結果

打開串口助手,輸入命令:
  1. msh />easyflash_sample

復制代碼

第一次命令調用:49613442-1615-11ee-962d-dac502259ad0.png第二次RESET開發板后調用:

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

結語

至此,FAL分區管理EasyFlash變量管理已經全部介紹完畢了,經歷從移植軟件模擬SPI框架到LPC55S69,到移植過程中不斷遇到的問題,解決問題并提供應用示例,并完成開發日記、開發筆記及應用教學,作者坦言整個過程還是受益良多的。希望大家懷揣著一顆求知及授學之心,共同建設好這個領域!

參考資料

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

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

本文轉載自:

END

更多恩智浦AI-IoT市場和產品信息,邀您同時關注“NXP客棧”微信公眾號

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

NXP客棧


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

長按二維碼,關注我們

恩智浦MCU加油站


這是由恩智浦官方運營的公眾號,著重為您推薦恩智浦MCU的產品信息、開發技巧、教程文檔、培訓課程等內容。

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

長按二維碼,關注我們


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

文章出處:【微信公眾號:恩智浦MCU加油站】歡迎添加關注!文章轉載請注明出處。


聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • mcu
    mcu
    +關注

    關注

    146

    文章

    17310

    瀏覽量

    352193
  • 恩智浦
    +關注

    關注

    14

    文章

    5877

    瀏覽量

    108077

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

文章出處:【微信號:NXP_SMART_HARDWARE,微信公眾號:恩智浦MCU加油站】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    消防物證管理系統 DW-S404實現消防物證智能化管理

    一、系統概述 智慧消防物證管理系統DW-S404系統旨在借助現代信息技術,達成消防物證管理的高效化、安全化及智能化管理目標。該系統運用物聯網、大數據、云計算等先進技術,實現對消防物證從
    的頭像 發表于 12-07 17:45 ?167次閱讀
    消防物證<b class='flag-5'>管理</b>系統 DW-<b class='flag-5'>S</b>404實現消防物證智能化<b class='flag-5'>管理</b>

    迅為RK3568開發板傳統分區和定制擴展分區鏡像對比

    的系統,如物聯網和智能設備,減少了鏡像管理和維護的復雜性。 通過上述對比,開發者可以根據項目需求選擇合適的鏡像管理方式,從而確保系統的高效運行與便捷維護,如果想要使用傳統的 rk 傳統分區鏡像,只需
    發表于 11-19 10:50

    使用FAL分區管理easyflash變量管理

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

    武裝部戰備器材管理系統實現裝備倉庫管理“四化”新模式

    管理系統
    jf_72884372
    發布于 :2024年08月14日 15:44:09

    鴻蒙開發文件管理:【@ohos.volumeManager (卷管理)】

    該模塊提供卷、磁盤查詢和管理的相關功能:包括查詢卷信息,對卷的掛載卸載、對磁盤分區以及卷的格式化等功能。
    的頭像 發表于 06-14 10:12 ?489次閱讀
    鴻蒙開發文件<b class='flag-5'>管理</b>:【@ohos.volumeManager (卷<b class='flag-5'>管理</b>)】

    涉案財物管理系統DW-S405|基于物聯網技術的管理模式

    涉案財物管理系統(DW-S405)是針對公安機關、法院、海關等部門對涉案財物的管理需求而設計的系統。通過對涉案財物的信息化管理,可以提高案件處理的效率和質量,同時也能夠有效地防止涉案財
    的頭像 發表于 05-14 18:30 ?541次閱讀
    涉案財物<b class='flag-5'>管理</b>系統DW-<b class='flag-5'>S</b>405|基于物聯網技術的<b class='flag-5'>管理</b>模式

    【Vision Board創客營連載體驗】RA8D1 Vision Board 實現 FAL 同時調用片上以及外掛 Flash

    /board/ports/fal_cfg.h 文件中定義設備表與分區表,我這里將 BootLoader 和 APP 放在片上 Flash,外掛 Flash 單獨分區: #ifndef
    發表于 04-24 17:31

    請問CherryUSB使用msc類如何掛載到fal分區

    。 主板上采用16MB的nor flash,其中fal有兩個分區,能夠正常格式化和讀寫。 現在打算把fal中的一個分區模擬成u盤,分區
    發表于 02-26 08:17

    Harmony 鴻蒙頁面級變量的狀態管理

    頁面級變量的狀態管理 @State、@Prop、@Link、@Provide、@Consume、@ObjectLink、@Observed和@Watch用于管理頁面級變量的狀態。 @S
    的頭像 發表于 01-25 10:42 ?633次閱讀
    Harmony 鴻蒙頁面級<b class='flag-5'>變量</b>的狀態<b class='flag-5'>管理</b>

    Harmony 鴻蒙應用級變量的狀態管理

    應用級變量的狀態管理 在前面的章節中,已經講述了如何管理頁面級變量的狀態,本章將說明如何管理應用級變量
    的頭像 發表于 01-24 21:30 ?533次閱讀
    Harmony 鴻蒙應用級<b class='flag-5'>變量</b>的狀態<b class='flag-5'>管理</b>

    Harmony 鴻蒙頁面級變量的狀態管理

    頁面級變量的狀態管理 @State、@Prop、@Link、@Provide、@Consume、@ObjectLink、@Observed和@Watch用于管理頁面級變量的狀態。 @S
    發表于 01-24 20:04
    主站蜘蛛池模板: 亚洲欧美一区二区三区蜜芽 | 国产小视频在线高清播放 | 精彩国产萝视频在线 | 囯产少妇BBBBBB高潮喷水一 | 99热久久这里只精品国产WWW | 又黄又爽又无遮挡在线观看免费 | 亚洲黄色片免费看 | 东京热无码中文字幕av专区 | 国产高清在线a视频大全 | 亚洲色欲色欲综合网站 | 日本高清免费一本视频在线观看 | 国产日韩久久久精品影院首页 | 世界上第一个得抑郁症的人是谁 | 中字幕久久久人妻熟女天美传媒 | 最新日本免费一区 | 被滋润的艳妇疯狂呻吟白洁老七 | 二级片免费看 | 欧美成人精品高清在线观看 | 97蜜桃网123 97蜜桃123 | 真实处破女全过程完免费观看 | 97无码欧美熟妇人妻蜜桃天美 | 儿子日母亲B好爽 | 亚洲热在线视频 | 亚洲国产精品久久人人爱 | 动漫美女人物被黄漫在线看 | 午夜在线视频国产极品片 | 中国午夜伦理片 | 男女疯狂一边摸一边做羞羞视频 | 色美妞论坛 | 亚洲人成www在线播放 | 男男高H啪肉Np文多攻多一受 | 国产又湿又黄又硬又刺激视频 | 超大BBWWW| 青柠在线观看免费全集 | 插我一区二区在线观看 | 亚洲偷偷自拍免费视频在线 | 日本高清免费一本在线观看 | 偷拍自偷拍亚洲精品 | 欧美AAAAAA级午夜福利视频 | 亚洲欧洲日产国码中学 | 国产97精品久久久天天A片 |