国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

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

3天內不再提示

基于OpenHarmony3.1的LittleFS文件系統hdf驅動實現

電子發燒友開源社區 ? 來源:未知 ? 作者:電子發燒友開源社 ? 2022-09-30 18:32 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1.簡介

LittleFS是一個小型的Flash文件系統,它結合日志結構(log-structured)文件系統和COW(copy-on-write)文件系統的思想,以日志結構存儲元數據,以COW結構存儲數據。這種特殊的存儲方式,使LittleFS具有強大的掉電恢復能力(power-loss resilience)。分配COW數據塊時LittleFS采用了名為統計損耗均衡的動態損耗均衡算法,使Flash設備的壽命得到有效保障。同時LittleFS針對資源緊缺的小型設備進行設計,具有極其有限的ROMRAM占用,并且所有RAM的使用都通過一個可配置的固定大小緩沖區進行分配,不會隨文件系統的擴大占據更多的系統資源。當在一個資源非常緊缺的小型設備上,尋找一個具有掉電恢復能力并支持損耗均衡的Flash文件系統時,LittleFS是一個比較好的選擇。

LittleFS在嵌入式開發過程中經常遇到,但是如何在OpenHarmony中使用呢?本文基于OpenHarmony 3.1Release + 小凌派-RK2206開發板做LittleFS文件系統移植,現將相關移植經驗發布,分享給大家。文中如有問題,請大家幫忙指正。

2.LittleFS移植過程

本文基于OpenHarmony3.1Release做LittleFS移植,小凌派-RK2206開發板內部Flash有8MB大小,其中4~8MB區間為空閑區域。我將4M~5M作為LittleFS文件系統的/data目錄掛載硬件設備。具體移植過程主要如下所示:

1、hcs配置

1.1、hdf.hcs

創建/device/soc/rockchip/rk2206/hcs_config/hdf.hcs文件,具體如下:

  #include "device_info/device_info.hcs"
  #include "fs/fs_config.hcs"
  #include "gpio/gpio_config.hcs"
  #include "i2c/i2c_config.hcs"
  #include "spi/spi_config.hcs"
  root {
    module = "rockchip,rk2206_chip";
  }

(左右移動查看全部內容)

如上所述,我將在device_info/device_info.hcs添加LittleFS設備,并在fs/fs_config.hcs添加LittleFS具體信息。

1.2、BUILD.gn
新建//device/soc/rockchip/rk2206/hdf_config/BUILD.gn,具體代碼如下所示:

  import("http://drivers/adapter/khdf/liteos_m/hdf.gni")
  module_switch = defined(LOSCFG_DRIVERS_HDF)
  module_name = get_path_info(rebase_path("."), "name")
  hdf_driver(module_name) {
   hcs_sources = [ "hdf.hcs" ]
  }

(左右移動查看全部內容)

上述代碼將在編譯OpenHarmony3.1Rlease時,將編譯hdf.hcs。

1.3、device_info.hcs
創建/device/soc/rockchip/rk2206/hcs_config/device_info/device_info.hcs文件,在文件中添加LittleFS設備,具體代碼如下所示:

device_fs :: device {
     device0 :: deviceNode {
      policy = 0;
      priority = 5;
      permission = 0777;
      moduleName = "HDF_PLATFORM_FS_LITTLEFS";
      serviceName = "littlefs_config";
      deviceMatchAttr = "rockchip_rk2206_fs_littlefs";
  }
}

(左右移動查看全部內容)

上述代碼表示建設一個設備驅動,該驅動的模塊名稱(即moduleName)為“HDF_PLATFORM_FS_LITTLEFS”,OpenHamrony系統依據該名稱匹配驅動程序;設備匹配信息(即deviceMatchAttr)添加小凌派開發板Flash特殊信息(比如:分區信息,掛載目錄名、起始地址、結束地址等)。

1.4、fs_config.hcs

新建//device/soc/rockchip/rk2206/hdf_config/fs/fs_config.hcs文件,該文件主要寫清楚設備掛載信息,具體如下:

root {
    platform {
      fs_config {
        template fs_controller {
          match_attr = "";
          mount_points = [];
          block_size = [];
          block_start = [];
          block_count = [];
        }


        fs_littefs :: fs_controller {
          match_attr = "rockchip_rk2206_fs_littlefs";
          mount_points = ["/data"];
          block_size = [4096];
          block_start = [1024];
          block_count = [256];
        }
      }
    }
  }

(左右移動查看全部內容)

(1)points:掛載目錄。
(2)block_size:Flash的擦除塊大小。
(3)block_start:該掛載Flash區域的起始塊地址,實際Flash地址為block_size * block_start。
(4)block_count:該掛載Flash區域的存儲塊總數。

注意:match_attr所表示的字符串要與device_info.hcs所表示的字符串要一致。

2、hdf驅動
新建//device/soc/rockchip/rk2206/hdf_driver/fs文件夾,文件夾下創建2個文件,具體如下所示:

2.1、fs_driver.c
2.1.1、添加必要的頭文件

#include 
#include 
#include "los_config.h"
#include "hdf_log.h"
#include "hdf_device_desc.h"
#include "device_resource_if.h"
#include "osal_mem.h"
#include "lfs_api.h"

(左右移動查看全部內容)

2.1.2、添加HDF驅動

添加LittleFS匹配的hdf驅動,具體代碼如下所示:

static struct HdfDriverEntry g_fsDriverEntry = {
  .moduleVersion = 1,
  .moduleName = "HDF_PLATFORM_FS_LITTLEFS",
  .Bind = fs_driver_bind,
  .Init = fs_driver_init,
  .Release = fs_driver_release,
};

(左右移動查看全部內容)

HDF_INIT(g_fsDriverEntry);

其中,moduleName必須要與device_info.hcs中的moduleName保持一致。

2.1.3、fs_driver_init函數

fs_driver_init為hdf驅動加載函數。OpenHarmony啟動時,將根據hcs的編寫匹配對應的驅動程序,并運行fs_driver_init函數。該函數負責:

(1)讀取hcs文件的配置參數。

(2)初始化Flash。

(3)適配LittleFS對應的read、write、erase和sync函數,并適配LittleFS相關參數。

(4)掛載LittleFS。

具體代碼如下所示:

static int32_t fs_driver_init(struct HdfDeviceObject *device)
{
   int result;
   int32_t ret;
   struct FileOpInfo *file_op_info = NULL;


   if (device == NULL) {
     PRINT_ERR("device is null
");
     return HDF_ERR_INVALID_OBJECT;
   }
   if (device->property == NULL)
   {
     PRINT_ERR("device is null
");
     return HDF_ERR_INVALID_OBJECT;
   }


   /* Flash設備初始化 */
   FlashInit();


/* 讀取hcS參數 */
   ret = fs_driver_readdrs(device->property, &m_fs_cfg[0]);
   if (ret != HDF_SUCCESS)
   {
     PRINT_ERR("%s: fs_driver_readdrs faiLED(%d)
", ret);
     return ret;
   }
    
/* 適配LitteleFS對應的函數和參數 */
   for (int i = 0; i < sizeof(m_fs_cfg) / sizeof(m_fs_cfg[0]); i++) {
     if (m_fs_cfg[i].mount_point == NULL)
     {
       PRINT_LOG("m_fs_cfg[%d].mount_point is null
", i);
       continue;
     }


     m_fs_cfg[i].lfs_cfg.read = flash_littlefs_read;
     m_fs_cfg[i].lfs_cfg.prog = flash_littlefs_write;
     m_fs_cfg[i].lfs_cfg.erase = flash_littlefs_erase;
     m_fs_cfg[i].lfs_cfg.sync = flash_littlefs_sync;


     m_fs_cfg[i].lfs_cfg.read_size = 4;
     m_fs_cfg[i].lfs_cfg.prog_size = 4;
     m_fs_cfg[i].lfs_cfg.cache_size = 256;
     m_fs_cfg[i].lfs_cfg.lookahead_size = 64;
     m_fs_cfg[i].lfs_cfg.block_cycles = 1000;


     m_fs_cfg[i].lfs_cfg.file_max = LFS_FILE_MAX;
     m_fs_cfg[i].lfs_cfg.name_max = LFS_NAME_MAX;
      
/* 準備掛載 */
     result = SetDefaultMountPath(i, m_fs_cfg[i].mount_point);
     if (result != VFS_OK)
     {
       PRINT_ERR("SetDefaultMountPath(%d, %d) failed(%d)
", i, m_fs_cfg[i].mount_point, result);
       continue;
     }
      
/* 掛載目錄 */
     result = mount(NULL, m_fs_cfg[i].mount_point, "littlefs", 0, &m_fs_cfg[i].lfs_cfg);
     printf("%s: mount fs on '%s' %s
", __func__, m_fs_cfg[i].mount_point, (result == 0) ? "succeed" : "failed");
     if (CheckPathIsMounted(m_fs_cfg[i].mount_point, &file_op_info) == TRUE) {
       int lfs_ret = lfs_mkdir(&file_op_info->lfsInfo, m_fs_cfg[i].mount_point);
       if (lfs_ret == LFS_ERR_OK) {
         PRINT_LOG("create root dir(%s) success.
", m_fs_cfg[i].mount_point);
       } else if (lfs_ret == LFS_ERR_EXIST) {
         PRINT_LOG("root dir(%s) exist.
", m_fs_cfg[i].mount_point);
       } else {
         PRINT_LOG("create root dir(%s) failed.", m_fs_cfg[i].mount_point);
       }
     }
  }
    
  return HDF_SUCCESS;
}

(左右移動查看全部內容)

2.2、BUILD.gn

BUILD.gn負責將fs_driver.c編譯到內核中,具體源代碼如下所示:

import("http://drivers/adapter/khdf/liteos_m/hdf.gni")
module_switch = defined(LOSCFG_SOC_SERIES_RK22XX) && defined(LOSCFG_DRIVERS_HDF_PLATFORM) && defined(LOSCFG_FS_LITTLEFS)
module_name = get_path_info(rebase_path("."), "name")
hdf_driver(module_name) {
 sources = [
   "fs_driver.c",
 ]
 include_dirs = [ "." ]
}

(左右移動查看全部內容)

3、測試程序

我在main函數中添加一個任務,負責每隔5秒讀寫文件。具體代碼如下所示:

/* 文件系統測試 */
static void file_rw()
{
  static unsigned int cur = 0;
  char file_name[] = "/data/a.txt";
  int fd_w, fd_r;
  unsigned char buffer[256];
  /* 寫操作 */
  fd_w = open(file_name, O_WRONLY | O_CREAT);
  if (fd_w == -1)
  {
    printf("write: %s open failed!
", file_name);
    return;
  }
  memset(buffer, 0, sizeof(buffer));
  snprintf(buffer, sizeof(buffer), "Hello World and %d
", cur++);
  printf("write: %s", buffer);
  write(fd_w, buffer, strlen(buffer));
  close(fd_w);


  /* 讀操作 */
  fd_r = open(file_name, O_RDONLY);
  if (fd_r == -1)
  {
    printf("read: %s open failed!
", file_name);
    return;
  }
  lseek(fd_r, 0, SEEK_SET);
  memset(buffer, 0, sizeof(buffer));
  read(fd_r, buffer, sizeof(buffer));
  printf("read: %s", buffer);
  close(fd_r);
}


static void IotProcess(void *arg)
{
  static const unsigned int SLEEP_MAXSEC = 5;


  while (1)
  {
    printf("%s: sleep %d sec!
", __func__, SLEEP_MAXSEC);


    /* 文件系統測試 */
    file_rw(); 


    LOS_Msleep(SLEEP_MAXSEC * 1000);
  }
}

(左右移動查看全部內容)

3

結果

程序編譯燒寫到開發板后,按下開發板的RESET按鍵,通過串口軟件查看日志如下:

[MAIN:D]Main: OpenHarmony start schedule...
Entering scheduler
IotProcess: sleep 5 sec!
write: Hello World and 0
read: Hello World and 0
IotProcess: sleep 5 sec!
write: Hello World and 1
read: Hello World and 1
IotProcess: sleep 5 sec!
write: Hello World and 2
read: Hello World and 2
......

(左右移動查看全部內容)


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

    關注

    0

    文章

    10

    瀏覽量

    3002
  • OpenHarmony
    +關注

    關注

    33

    文章

    3952

    瀏覽量

    21096

原文標題:基于OpenHarmony3.1的LittleFS文件系統hdf驅動實現

文章出處:【微信號:HarmonyOS_Community,微信公眾號:電子發燒友開源社區】歡迎添加關注!文章轉載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    【瑞薩FPB-RA6E2試用】SPI通信:W25Q64+LittleFS

    littlefs文件系統實現通過文件的形式管理內存,不在需要手動指定存儲和讀取的位置,同時littlefs還有擦寫平衡的功能。 首先需要下
    發表于 01-11 22:46

    明晚8點|睿擎文件系統實戰:從開發到發布全流程解析

    文件操作到鏡像發布,一次直播掌握完整開發流程!在嵌入式系統開發中,文件系統是數據存儲、配置管理和資源訪問的核心基礎。然而在實際開發中,文件操作效率低下、鏡像打包流程復雜、
    的頭像 發表于 11-11 11:53 ?638次閱讀
    明晚8點|睿擎<b class='flag-5'>文件系統</b>實戰:從開發到發布全流程解析

    睿擎派文件系統指南:從開發到發布全流程實踐 | 技術解析

    在嵌入式系統開發中,文件系統扮演著至關重要的角色,它負責數據的持久化存儲、配置文件管理和資源訪問等核心功能。睿擎平臺提供了一套完整的文件系統解決方案,從開發階段的API調用到調試階段的
    的頭像 發表于 11-05 18:13 ?8094次閱讀
    睿擎派<b class='flag-5'>文件系統</b>指南:從開發到發布全流程實踐 | 技術解析

    使用ulog 寫入日志到文件系統,無法使用cat命令讀取文件內容怎么解決?

    1.我使用ulog+littlefs寫入日志,日志正常寫入,但是沒法使用cat指令讀取文件內容失敗,必須關掉ulog,才能讀取日志文件顯示的內容,發現上次日志是正常寫入的。 2.調試發現ulog打開
    發表于 10-13 06:12

    nor掛載一個littlefs文件系統之后,把裝置斷電重啟,重啟后裝置沒有運行是為什么?

    ;Yaffs2filesystemret=%drn",ret); return 0; } 裝置再main中掛載一個littlefs文件系統,并再這個文件系統中創建一個文件
    發表于 09-18 08:16

    rtt 5.1.0使用最新版的littleFS異常的原因?

    項目中使用文件系統(存儲介質是spi nor flash),測試發現正在寫文件掉電會導致文件系統破壞,于是將elm(fatfs)換成littleFS,遇到一個比較奇怪的問題就是:如果首
    發表于 09-10 06:43

    技術貼|【RK3588】ELF 2開發板如何添加exFAT和NTFS文件系統格式

    如何通過系統配置實現對該兩種文件系統的支持,并配置自動掛載功能。Windows系統格式化存儲設備在使用TF卡前,需通過Windows自帶工具將其格式化為目標
    的頭像 發表于 08-27 17:21 ?3523次閱讀
    技術貼|【RK3588】ELF 2開發板如何添加exFAT和NTFS<b class='flag-5'>文件系統</b>格式

    Linux三大主流文件系統解析

    還在為選擇哪個文件系統而糾結?作為一名摸爬滾打多年的運維老鳥,我將用最接地氣的方式,帶你徹底搞懂 Linux 三大主流文件系統的奧秘。
    的頭像 發表于 08-05 17:37 ?1440次閱讀

    飛凌嵌入式ElfBoard ELF 1板卡-文件系統簡介

    文件系統Journalling Flash File System Version 2是一個可讀寫,壓縮,日志型文件系統。其功能是管理在MTD設備上實現的日志型文件系統。啟動時間依賴于
    發表于 06-19 17:22

    服務器數據恢復—ocfs2文件系統被格式化為Ext4文件系統的數據恢復案例

    服務器存儲數據恢復環境&故障: 人為誤操作將Ext4文件系統誤裝入一臺服務器存儲上的Ocfs2文件系統數據卷上,導致原Ocfs2文件系統被格式化為Ext4文件系統
    的頭像 發表于 06-10 12:03 ?726次閱讀
    服務器數據恢復—ocfs2<b class='flag-5'>文件系統</b>被格式化為Ext4<b class='flag-5'>文件系統</b>的數據恢復案例

    迅為RK3568開發板實操-HDF驅動配置UART-修改HCS配置

    /hdf_config/khdf/device_info/device_info.hcs 文件,device_info.hcs 中添加以下內容: 1、device3 :: deviceNode { 2
    發表于 05-22 11:32

    【北京迅為】iTOP-RK3568開發板鴻蒙OpenHarmony系統南向驅動開發實操-HDF驅動配置UART

    【北京迅為】iTOP-RK3568開發板鴻蒙OpenHarmony系統南向驅動開發實操-HDF驅動配置UART
    的頭像 發表于 03-25 11:02 ?1726次閱讀
    【北京迅為】iTOP-RK3568開發板鴻蒙<b class='flag-5'>OpenHarmony</b><b class='flag-5'>系統</b>南向<b class='flag-5'>驅動</b>開發實操-<b class='flag-5'>HDF</b><b class='flag-5'>驅動</b>配置UART

    如何正確選擇嵌入式文件系統

    Linux嵌入式系統中,文件系統和緩存機制常導致數據存儲穩定性問題。本文通過案例分析原因,對比不同文件系統特性,為開發者提供優化建議,助力提升數據穩定性和系統可靠性。前言基于Linux
    的頭像 發表于 03-17 11:35 ?1103次閱讀
    如何正確選擇嵌入式<b class='flag-5'>文件系統</b>?

    北京迅為iTOP-RK3568開發板OpenHarmony系統南向驅動開發實操-HDF驅動配置LED

    北京迅為iTOP-RK3568開發板OpenHarmony系統南向驅動開發實操-HDF驅動配置LED
    的頭像 發表于 03-14 14:41 ?1346次閱讀
    北京迅為iTOP-RK3568開發板<b class='flag-5'>OpenHarmony</b><b class='flag-5'>系統</b>南向<b class='flag-5'>驅動</b>開發實操-<b class='flag-5'>HDF</b><b class='flag-5'>驅動</b>配置LED

    北京迅為RK3568開發板OpenHarmony系統南向驅動開發內核HDF驅動框架架構

    北京迅為RK3568開發板OpenHarmony系統南向驅動開發內核HDF驅動框架架構
    的頭像 發表于 03-11 14:13 ?1849次閱讀
    北京迅為RK3568開發板<b class='flag-5'>OpenHarmony</b><b class='flag-5'>系統</b>南向<b class='flag-5'>驅動</b>開發內核<b class='flag-5'>HDF</b><b class='flag-5'>驅動</b>框架架構