littefs文件系统移植

获取源码

官网:https://os.mbed.com/blog/entry/littlefs-high-integrity-embedded-fs/
源代码:https://github.com/littlefs-project/littlefs
主要是这几个文件
在这里插入图片描述

简介

Littlefs是一个小型的Flash文件系统,它结合日志结构(log-structured)文件系统和COW(copy-on-write)文件系统的思想,以日志结构存储元数据,以COW结构存储数据。这种特殊的存储方式,使Littlefs具有强大的掉电恢复能力(power-loss resilience)。分配COW数据块时Littlefs采用了名为统计损耗均衡的动态损耗均衡算法,使Flash设备的寿命得到有效保障。同时Littlefs针对资源紧缺的小型设备进行设计,具有极其有限的ROM和RAM占用,并且所有RAM的使用都通过一个可配置的固定大小缓冲区进行分配,不会随文件系统的扩大占据更多的系统资源。当在一个资源非常紧缺的小型设备上,寻找一个具有掉电恢复能力并支持损耗均衡的Flash文件系统时,Littlefs是一个比较好的选择。

关于Littlefs我们首先了解lfs.h文件当中一些主要的枚举、结构体、函数,如下表所示。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

代码思路

 使用littefs文件系统,写入数据,又将数据读取出来
 使用ram 实现

移植代码

const uint32_t FLASHSIZE = 1 * 1024;
static uint8_t *DEMOAddr;

static struct lfs_config cfg;
static lfs_t lfs;
static lfs_file_t *file;

static int lfs_read(const struct lfs_config *c, lfs_block_t block,
                    lfs_off_t off, void *buffer, lfs_size_t size) {
  memcpy(buffer, DEMOAddr + (block * c->block_size) + off, size);
  return 0;
}

static int lfs_prog(const struct lfs_config *c, lfs_block_t block,
                    lfs_off_t off, const void *buffer, lfs_size_t size) {
  memcpy(DEMOAddr + (block * c->block_size) + off, buffer, size);
  return 0;
}

static int lfs_erase(const struct lfs_config *c, lfs_block_t block) {
  memset(DEMOAddr + (block * c->block_size), 0, c->block_size);
  return 0;
}
static int lfs_sync(const struct lfs_config *c) { return 0; }

static void fs_init() {
  printf("fs_init start\n");
  cfg.read = lfs_read;
  cfg.prog = lfs_prog;
  cfg.erase = lfs_erase;
  cfg.sync = lfs_sync;

  // block device configuration
  cfg.read_size = 16;
  cfg.prog_size = 16;
  cfg.block_size = 512;
  cfg.block_count = FLASHSIZE / cfg.block_size;
  cfg.cache_size = 16;
  cfg.lookahead_size = 16;
  cfg.block_cycles = 500;

  int err = lfs_mount(&lfs, &cfg);
  if (err < 0) {
    fprintf(stderr, "mount error: error=%d\r\n", err);
    err = lfs_format(&lfs, &cfg);
    fprintf(stderr, "format error: error=%d\r\n", err);
    err = lfs_mount(&lfs, &cfg);
    if (err < 0) {
      fprintf(stderr, "mount2 error: error=%d\r\n", err);
    }
  }
  printf("fs_init ok\n");
}

int main(int argc, const char *argv[]) {
  printf("Main start\n");
  DEMOAddr = (uint8_t *)malloc(1 * 1024);
  if (DEMOAddr == NULL) {
    printf("DEMOAddr:err:\n");
  }
  int err;
  fs_init();
  printf("--------------\n");

  // read current count
  uint32_t boot_count = 0;
  err = lfs_file_open(&lfs, &file, "boot_count", LFS_O_RDWR | LFS_O_CREAT);
  printf("boot_count: %d\n", boot_count);
  printf("lfs_file_open:err:%d\n", err);
  err = lfs_file_read(&lfs, &file, &boot_count, sizeof(boot_count));
  printf("lfs_file_read:err:%d\n", err);

  // update boot count
  boot_count += 99;
  err = lfs_file_rewind(&lfs, &file);
  printf("lfs_file_rewind:err:%d\n", err);
  err = lfs_file_write(&lfs, &file, &boot_count, sizeof(boot_count));
  printf("lfs_file_write:err:%d\n", err);
  err = lfs_file_close(&lfs, &file);
  printf("lfs_file_close:err:%d\n", err);

  // read current count
  uint32_t boot_count1 = 0;
  err = lfs_file_open(&lfs, &file, "boot_count", LFS_O_RDWR | LFS_O_CREAT);
  printf("1boot_coun1: %d\n", boot_count1);
  printf("lfs_file_open:err:%d\n", err);
  err = lfs_file_read(&lfs, &file, &boot_count1, sizeof(boot_count));
  printf("2boot_coun1: %d\n", boot_count1);
  printf("lfs_file_read:err:%d\n", err);

  // remember the storage is not updated until the file is closed successfully
  err = lfs_file_close(&lfs, &file);
  printf("lfs_file_close:err:%d\n", err);
  err = lfs_unmount(&lfs);
  printf("lfs_unmount:err:%d\n", err);
  // print the boot count
  printf("boot_count: %d\n", boot_count);
  return 0;
}
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
文件系统移植SDIO是指将文件系统移植到SDIO(Secure Digital Input Output)接口上,以实现在SD卡或者其他SDIO设备上进行文件读写操作的功能。移植文件系统到SDIO上需要进行如下步骤: 首先,需要了解目标平台的硬件架构和SDIO接口的技术规范。SDIO接口是一种用于连接外部设备的接口,需要了解其数据传输协议、寄存器配置以及接口驱动程序的接口规范。 其次,需要准备适配文件系统的驱动程序。常见的文件系统包括FAT32、EXT4等,需要根据目标平台的操作系统和文件系统的特性来选择合适的文件系统驱动程序,并进行移植和适配。 接着,需要进行文件系统在SDIO接口上的初始化和配置。这包括SDIO控制器的初始化、数据传输模式的设置、寄存器的配置等操作,以确保文件系统可以正确地在SDIO接口上进行数据读写操作。 最后,进行文件系统的测试和调试。在移植文件系统到SDIO接口上之后,需要进行充分的测试和调试,确保文件读写操作的稳定性和可靠性。这包括对文件系统的读写性能、数据完整性和错误处理能力等方面进行全面的验证。 总的来说,文件系统移植到SDIO接口上需要深入了解硬件架构和接口规范,进行文件系统驱动程序的适配和移植,对SDIO接口进行初始化和配置,并进行充分的测试和调试。移植成功后,就可以在SD卡或其他SDIO设备上实现文件的读写操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

li星野

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值