RT-thread应用讲解——FLASH分区

RT-thread应用讲解——FLASH分区

前言

因为单片机的存储比较小,所以我们经常会用到外置FLASH来存储一些文件、数据或者OTA等。如果一个FLASH只用来做单一的功能,那只需要把所有内存都分配到这个功能上就行了,但是如果要用一个FLASH同时做多个功能,比如我用一部分内存来做文件系统,一部分用来存OTA升级固件,那在操作内存的时候就要注意地址的分配了,为了方便内存管理,我们通常会进行分区处理。
RT-thread系统就有分区和内存管理相关的软件包,这一点还是很方便的。
FAL软件包:http://packages.rt-thread.org/detail.html?package=fal

FAL软件包可以用于片内flash也可以用于片外flash,我这一讲主要介绍片外flash的使用。

一、挂载FLASH

首先我们要把这个片外flash挂载上。这个我之前的教程已经介绍过了,不知道的同学可以先看下我之前的博客。
RT-thread应用讲解——norflash

二、ENV配置

1、打开on-chip flash

在这里插入图片描述

2、打开FAL软件包

在这里插入图片描述

3、重新生成工程

设置完之后保存退出,然后重新生成工程即可。
在env输入下面的命令,重新生成新的工程。
提示:会使用env的话应该都知道这个操作,不多说了。

scons --target=mdk5

三、分区处理

1、定义flash设备表

打开fal_cfg.h文件(在board\ports文件夹里面),找到flash设备的定义,增加片外flash的定义。
注意:fal软件包里面也会有一个fal_cfg.h文件,这个只是demo,默认是不加入到工程里面的,也不会起作用。

定义flash设备表示例代码如下:

extern const struct fal_flash_dev stm32_onchip_flash_16k;
extern const struct fal_flash_dev stm32_onchip_flash_64k;
extern const struct fal_flash_dev stm32_onchip_flash_128k;
extern struct fal_flash_dev nor_flash0;

/* flash device table */
#define FAL_FLASH_DEV_TABLE                                          \
{                                                                    \
    &stm32_onchip_flash_16k,                                         \
    &stm32_onchip_flash_64k,                                         \
    &stm32_onchip_flash_128k,                                        \
    &nor_flash0,                                                     \
}

在这里插入图片描述

2、定义flash分区表

同样是在fal_cfg.h文件里面,根据自己的需要定义分区表。
示例代码如下:

/* ====================== Partition Configuration ========================== */
#ifdef FAL_PART_HAS_TABLE_CFG

/* partition table */
#define FAL_PART_TABLE                                                               \
{                                                                                    \
    {FAL_PART_MAGIC_WROD, "bootload", "onchip_flash_16k", 0 * 1024, 128 * 1024, 0},  \
    {FAL_PART_MAGIC_WROD, "app", "onchip_flash_128k", 0 * 1024, 384 * 1024, 0},      \
    {FAL_PART_MAGIC_WROD, "download", "norflash0", 0 * 1024, 256 * 1024, 0},         \
    {FAL_PART_MAGIC_WROD, "factory", "norflash0", 256 * 1024, 384 * 1024, 0},        \
    {FAL_PART_MAGIC_WROD, "easyflash", "norflash0", 640 * 1024, 128 * 1024, 0},      \
    {FAL_PART_MAGIC_WROD, "cmb_log", "norflash0", 768* 1024, 128 * 1024, 0},         \
    {FAL_PART_MAGIC_WROD, "filesystem", "norflash0", 896 * 1024, 15488 * 1024, 0},   \
}

#endif /* FAL_PART_HAS_TABLE_CFG */
#endif /* _FAL_CFG_H_ */

上面这个分区表详细描述信息如下:

分区名FLASH设备名偏移地址内存大小说明
“bootload”“onchip_flash_16k”0128 * 1024 字节bootload引导程序
“app”“onchip_flash_128k”0384 * 1024 字节应用程序
“download”“norflash0”0256 * 1024 字节OTA升级固件
“factory”“norflash0”256 * 1024384 * 1024 字节恢复出厂固件
“cmb_log”“norflash0”640 * 1024128 * 1024 字节运行日志
“filesystem”“norflash0”896 * 102415488 * 1024 字节文件系统

提示:FLASH设备名要根据实际情况来写,比如onchip_flash_16k和onchip_flash_128k是默认的一个定义(在drv_flash_f4.c文件),stm32_onchip_flash_16k指定的起始地址就是stm32f4系列rom的起始地址,onchip_flash_128k则是从128k偏移开始的,如果这几个定义不满足你的需求可以自己在drv_flash_f4.c文件再定义一个。

最后贴一个fal_cfg.h文件完整的代码:

/*
 * Copyright (c) 2006-2018, RT-Thread Development Team
 *
 * SPDX-License-Identifier: Apache-2.0
 *
 * Change Logs:
 * Date           Author       Notes
 * 2018-12-5      SummerGift   first version
 */

#ifndef _FAL_CFG_H_
#define _FAL_CFG_H_

#include <rtthread.h>
#include <board.h>

#define FLASH_SIZE_GRANULARITY_16K   (4 * 16 * 1024)
#define FLASH_SIZE_GRANULARITY_64K   (64 * 1024)
#define FLASH_SIZE_GRANULARITY_128K  (7 * 128 * 1024)

#define STM32_FLASH_START_ADRESS_16K  STM32_FLASH_START_ADRESS
#define STM32_FLASH_START_ADRESS_64K  (STM32_FLASH_START_ADRESS_16K + FLASH_SIZE_GRANULARITY_16K)
#define STM32_FLASH_START_ADRESS_128K (STM32_FLASH_START_ADRESS_64K + FLASH_SIZE_GRANULARITY_64K)

extern const struct fal_flash_dev stm32_onchip_flash_16k;
extern const struct fal_flash_dev stm32_onchip_flash_64k;
extern const struct fal_flash_dev stm32_onchip_flash_128k;
extern struct fal_flash_dev nor_flash0;

/* flash device table */
#define FAL_FLASH_DEV_TABLE                                          \
{                                                                    \
    &stm32_onchip_flash_16k,                                         \
    &stm32_onchip_flash_64k,                                         \
    &stm32_onchip_flash_128k,                                        \
    &nor_flash0,                                                     \
}
/* ====================== Partition Configuration ========================== */
 #ifdef FAL_PART_HAS_TABLE_CFG

/* partition table */
#define FAL_PART_TABLE                                                               \
{                                                                                    \
    {FAL_PART_MAGIC_WROD, "bootload", "onchip_flash_16k", 0 * 1024, 128 * 1024, 0},  \
    {FAL_PART_MAGIC_WROD, "app", "onchip_flash_128k", 0 * 1024, 384 * 1024, 0},      \
    {FAL_PART_MAGIC_WROD, "download", "norflash0", 0 * 1024, 256 * 1024, 0},         \
    {FAL_PART_MAGIC_WROD, "factory", "norflash0", 256 * 1024, 384 * 1024, 0},        \
    {FAL_PART_MAGIC_WROD, "easyflash", "norflash0", 640 * 1024, 128 * 1024, 0},      \
    {FAL_PART_MAGIC_WROD, "cmb_log", "norflash0", 768* 1024, 128 * 1024, 0},         \
    {FAL_PART_MAGIC_WROD, "filesystem", "norflash0", 896 * 1024, 15488 * 1024, 0},   \
}

#endif /* FAL_PART_HAS_TABLE_CFG */
#endif /* _FAL_CFG_H_ */

3、FAL初始化

在你的工程里面调用fal_init()函数,比如我这里是在main函数里面调用的(放其他位置也是可以的,只要调用了就行)。
在这里插入图片描述
提示:调用fal_init()函数之前要先包含fal.h这个头文件,不然就找不到这个函数了。

四、运行测试

正常运行的日志如下:
在这里插入图片描述

可以通过输出的日志再次核对你的分区是否有误。

fal本身就提供了一些测试命令,可以通过msh命令完成测试。
具体的命令可以输入fal查看。
在这里插入图片描述
关于这些测试的命令,我这里就简单地列一下,FAL软件包官方的介绍里面已经有详细的解析了,可以自行查阅。
FAL软件包:http://packages.rt-thread.org/detail.html?package=fal

1、指定待操作的Flash设备或Flash分区

示例如下:

fal probe download

2、擦除数据

示例如下:

fal erase 0 4096

3、写入数据

示例如下:

fal write 0 00 01 02 03 04

4、读取数据

示例如下:

fal read 0 5

5、性能测试

性能测试将会测试Flash的擦除、写入及读取速度,同时将会测试写入及读取数据的准确性,保证整个 Flash 或整个分区的 写入与读取数据的一致性。
示例如下:

fal bench 4096 yes

最后贴一个完整的测试示例:
在这里插入图片描述

五、结束语

好了,关于FLASH分区的介绍就到这里,如果还有什么问题,欢迎在评论区留言。如果这篇文章能够帮到你,就给我点个赞吧,如果想了解更多RT-thread和单片机的内容,可以关注一下博主,后续我还会继续分享更多的经验给大家。

教程相关源码:
https://pan.baidu.com/s/1N2D8dM31deKIqNqaIQfPiA
提取码:7nsx

RT-thread相关教程汇总:https://blog.csdn.net/ShenZhen_zixian/article/details/120563891

  • 5
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: RT-Thread应用开发实战 PDF是一本关于RT-Thread嵌入式实时操作系统的实用指南。本书详细介绍了RT-Thread的基本概念和组成部分,介绍其多线程和实时性能优势,以及内核和驱动程序的开发方式。本书涵盖了多个应用场景,包括网络通信,文件系统,多媒体,以及图形用户界面等,并提供了具体实现案例和示例代码。本书的重点在于实践,通过实例演示,读者可以掌握如何构建实际应用和维护嵌入式系统的能力。 RT-Thread是一个开源的实时操作系统,可应用于嵌入式系统和物联网设备。由于其小型内核和高效的多线程机制,RT-Thread已成为一种广受欢迎的解决方案。本书的目的是帮助读者深入理解RT-Thread的工作原理和设计思路,学习如何构建高可靠性的嵌入式应用。 本书重点介绍了以下内容: 1. RT-Thread的开发环境和基本概念。 2. RT-Thread的内核和驱动程序开发方法。 3. RT-Thread的网络通信机制和应用案例。 4. RT-Thread文件系统和多媒体支持。 5. RT-Thread的图形用户界面设计与实现。 6. RT-Thread应用调试和性能优化技巧。 通过本书的阅读,读者可以深入了解RT-Thread的开发方法和使用技巧,从而更加有效地构建实际应用和维护嵌入式系统。 ### 回答2: 《RT-Thread 应用开发实战》是一本深入浅出介绍 RT-Thread 实现和应用开发的经典教材,共分为 10 章,作者采用了大量的实例代码和案例分析,帮助读者快速掌握 RT-Thread 的原理、使用方法和相关技巧。此书的阅读适合开发人员、嵌入式工程师、学生以及其他对嵌入式开发感兴趣的读者。 本书首先介绍了 RT-Thread 的基本概念和应用场景,包括嵌入式系统的软件架构、RTOS、多任务处理、任务、线程和 IPC 等基础知识。其次,本书详细讲述了 RT-Thread 的内核原理和驱动开发,包括线程、内存管理、中断处理、编译器、芯片、外设等相关知识。此外,本书还介绍了通过 CLI 库、AT 命令、LwM2M、MQTT、CMSIS-DAP 等外部库和协议实现应用开发的方法。最后,本书提供了一系列实用性极强的案例,包括 Ethernet、SD 卡、串口、I2C、SPI、USB 等常见应用的案例分享,帮助读者深入理解 RT-Thread应用场景和业务需求。 总的来说,本书通过清晰详细的讲解让读者掌握了 RT-Thread 的基础知识和应用开发技巧,并且提供了丰富的实例案例帮助读者在实际开发中遇到问题能够更好地解决。如果您正在进行嵌入式开发或对此感兴趣,那么这本书是绝对值得推荐的读物之一。 ### 回答3: 《RT-Thread应用开发实战》是一本针对嵌入式行业开发者编写的一本实用型技术书籍。该书对于初学者和专业人士来说都是一本非常重要的参考书。书中详细介绍了如何使用RT-Thread实现实时操作系统的开发和应用。 本书主要是从实战角度出发,以针对性和实用性为主,向读者展示了RT-Thread实践应用开发的方法。首先,本书从工具的安装、使用以及环境配置入手,让读者对RT-Thread有个初步的了解,方便读者上手实际开发。接着从任务、内存、文件系统、网络协议等方面介绍了RT-Thread的使用,详细讲解了每一部分的实现原理,并通过实例演示了每一部分的实际应用。 此外,本书还结合实际开发经验,分享了一些有用的技巧和经验。并提供了大量的代码示例、图表和实用工具,这些实用的资源能够有效地加快读者的开发进度,降低技术实现的难度。 总之,《RT-Thread应用开发实战》本是一本很实用的技术书籍,不仅可以帮助开发人员了解如何使用RT-Thread进行嵌入式应用开发,还可以帮助每一位读者深入理解实时操作系统和嵌入式系统的实现原理。无论是专业人士还是初学者,这本书都是值得推荐的好书。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值