环境:rt1052单片机+16G tf卡

为什么使用littleFS?

  1. NXP官方SDK支持!
  2. 先进的损耗平衡功能(wear leveling)可提供最长的快闪及内存寿命及最大的使用量。因为FALSH的擦除/写次数有限制,通常是10万次。
  3. RAM和FLASH用的少,也就是内存和代码和精简。
    4. 掉电保护,设备突然断电,文件系统不会损坏。
    对比FATFS, fatfs使用固定的块做文件系统管理,多次读写后,整个系统就坏了,但是其他块其实没用多少次。

    本人并不建议大家在flash上使用fatfs !

    移植使用

      1. 将lfs四个源文件和刚刚创建的两个文件添加到工程,直接编译。
        测试lfs源码是否能编译通过。
      2. 修改动态内存最大长度,  #define Heap_Size,   因为要是有标准函数malloc,见源码函数:static inline void *lfs_malloc(size_t size)

      3. 添加实际的驱动函数到结构体变量lfs_config。

        struct lfs_config lfs_cfg= {

        // block device operations

        .read  = lfs_TFCard_read,

        .prog  = lfs_TFCard_prog,

        .erase = lfs_TFCard_erase,

        .sync  = lfs_TFCard_sync,

        // block device configuration

        .read_size = LFS_READ_SIZE,

        .prog_size = LFS_PREG_SIZE,

        .block_size = LFS_BLOCK_SIZE,  block_count = LFS_BLOCK_COUNT,.lookahead = LFS_LOOKAHEAD,};

      4. 初始化:

        sd_card_t *card = &g_sd;

        /* 初始化SD外设时钟 */

        BOARD_USDHCClockConfiguration();

        card->host.base = SD_HOST_BASEADDR;

      5. card->host.sourceClock_Hz = SD_HOST_CLK_FREQ;

        /* SD主机初始化函数 */

        if (SD_HostInit(card) != kStatus_Success)

        {

        PRINTF("\r\nSD主机初始化失败\r\n");

        return -1;

        }

      6. /* 初始化SD卡 */

        if (SD_CardInit(card))

        {

        PRINTF("\r\nSD初始化失败\r\n");

        return -1;

        }

        5.挂载测试

        err = lfs_mount(lfs, &lfs_cfg);  //挂载

        6.文件操作

        err = lfs_file_open(lfs, &g_lfs_file, "update.bin", LFS_O_RDWR);

        //打开bin文件,LFS_O_RDWR,读写方式

      7. 其他功能后续补充,本次就到这里,做个记录。

littleFS在RT1052移植笔记的更多相关文章

  1. tslib移植笔记(1)【转】

    本文转载自:https://blog.csdn.net/zijie_xiao/article/details/50740950 tslib移植笔记(1)2016-04-25 tslib背景[摘自百度] ...

  2. STemWin5.22移植笔记【转】

    来自:http://www.openedv.com/posts/list/27697.htm STemWin5.22移植笔记 网上关于emwin的资料很少,我在移植的时候查了很多资料,对我一个感觉是好 ...

  3. JZ2440 u-boot-2016.11、linux-4.17和busybox-1.28.4移植笔记

    2018年5月份开始在JZ2440上陆续移植了u-boot-2016.11.u-boot-spl-2016.11.linux-4.17和busybox-1.28.4,其中linux-4.17和busy ...

  4. FreeRTOS学习及移植笔记之二:在IAR和STM32F103VET上移植FreeRTOS

    上一次,我们简单的测试了FreeRTOS的基于IAR EWARM v6.4和STM32F103VET6平台的Demo,对其有了一个基本认识.接下来我们开始自己移植FreeRTOS的过程. 1.创建一个 ...

  5. FreeRTOS学习及移植笔记之一:开始FreeRTOS之旅

    1.必要的准备工作 工欲善其事,必先利其器,在开始学习和移植之前,相应的准备工作必不可少.所以在开始我们写要准备如下: 测试环境:我准备在STM32F103平台上移植和测试FreeRTOS系统 准备F ...

  6. rt—移植笔记2(Lwip)

    首先参考f107已经有的目录结构添加Lwip这一组,添加各种.c文件及.文件. 还有drive下边的很重要的eth.c 到此,工程编译通过.(刚开始,小编是一个一个 的比对...一个一个错误排查... ...

  7. rt—移植笔记1

    将rtt源码往stm32f407移植的时候,源码串口打印引脚设置有误,以下是源码引脚配置. 以下是原理图 可见配置有误.

  8. i2c设备驱动移植笔记(二)

    说明:上一篇博客写了我在移植android驱动之TEF6606的苦逼遭遇,即驱动层向应用层提供接口支持,查找了两天的资料,不得不放弃,转而进行IIC下移植RTC设备的实验. 第一步:查找设备的数据手册 ...

  9. 三种嵌入式web服务器(Boa / lighttpd / shttpd)的 linux移植笔记

    一:移植Boa(web服务器)到嵌入式Linux系统 一.Boa程序的移植 1.下载Boa源码    下载地址: http://www.boa.org/    目前最新发行版本: 0.94.13   ...

随机推荐

  1. windows10 命令行修复系统引导

    文章介绍的方法适用于拥有一个刻录有原版win10安装镜像的用户 下载地址:https://www.microsoft.com/zh-cn/software-download/windows10 首先进 ...

  2. Fiddler查看request是由哪一个process发起的

    有一个Process列 查看到进程编号是24836 然后用chrome自带的TaskManager查看对应的是哪一个进程 https://www.lifewire.com/google-chrome- ...

  3. Diamond types are not supported at language level '5‘

    当时,我问了下大神,他们问我是不是jdk问题.因为jdk8才支持这样的棱形写法.当时自己的jdk版本是jdk8,然后就奇怪了,最后我发现原来在Language level中调成了5.0 5.0不支持6 ...

  4. Flutter -------- BottomNavigationBar 界面切换

    Android 中有BottomNavigationBar+Fragment切换 而在Flutter也有的BottomNavigationBar 效果图 底部有两种情况 底部导航栏的类型更改其项目的显 ...

  5. 【转】分享一款颜色神器ColorSchemer Studio

    原文:https://www.cnblogs.com/xyfll7/p/7569078.html ColorSchemer Studio是一款专业配色软件,网页设计或平面设计师必备工具,和ColorP ...

  6. Apache的Mesos/Marathon与Google的Kubernets的区别

    Apache的Mesos与Google的Kubernets的区别 – China Hadoophttp://chinahadoop.com/archives/2150 有哪些是Apache Mesos ...

  7. git如何将旧commit的相关notes复制到新commit?

    答: git notes copy <old-commit> <new-commit>

  8. ES6深入浅出-9 Promise-1.回调与回调地狱

    promise 回调 把fun的调用写在另外一个函数里 fun()的调用在fn2这个函数里面.也是调用了函数.这种函数的调用形式叫做回调. A打电话给C找B.但是B不在,C说等B在的时候让B给A回电话 ...

  9. 算法习题---5.6团体队列(Uva540)

    一:题目 有t个队伍的人正在排队,每次新来一个人,如果他有队友在排队,那他可以插队,直接排到他的队伍的末尾.如果没有队伍在前面,那么他直接排在长队的末尾 ENQUEUE x 将编号x的队员入队 DEQ ...

  10. 算法习题---4-8特别困的学生(UVa12108)

    一:题目 课堂上有n个学生(n<=),每个学生上课都会出现一个“清醒-睡眠”周期,其中第i个学生学习Ai分钟后睡眠Bi分钟,依次重复.其中在从清醒到睡眠时有一个条件:只有到全班睡眠人数大于清醒人 ...