说明:本文涉及到一些底层的 .py 编译脚本以及编辑原理,笔者也不是完全明白,本文的主要目的是介绍一下流程,供小白使用。
接上文:【屏驱MCU】RT-Thread 文件系统接口解析
屏驱MCU系列文章【屏驱MCU】实现文件路径的的挂载
- [0. 个人简介 && 授权须知](#0. 个人简介 && 授权须知)
- [1. 从编译的提示信息开始](#1. 从编译的提示信息开始)
- [1.1 将【设置路径下的文件】编译生成 rodata.fatfs](#1.1 将【设置路径下的文件】编译生成 rodata.fatfs)
- [1.2 生成 pbp_cfg.bin](#1.2 生成 pbp_cfg.bin)
- [1.3 生成 Image header](#1.3 生成 Image header)
- [1.4 合并生成 img 镜像文件](#1.4 合并生成 img 镜像文件)
- [2. 关于 makefatfs.py](#2. 关于 makefatfs.py)
- [2.1 工作流程](#2.1 工作流程)
- [2.2 参数解析](#2.2 参数解析)
- [2.3 使用案例](#2.3 使用案例)
- [3. flash 分区中](#3. flash 分区中)
0. 个人简介 && 授权须知
📋 个人简介
- 💖 作者简介:大家好,我是喜欢记录零碎知识点的菜鸟打工人。😎
- 📝 个人主页:欢迎访问我的博客主页🔥
- 🎉 支持我:点赞👍+收藏⭐️+留言📝
- 📣 系列专栏:嵌入式开发专栏 🍁 🍁
- 💬格言:写文档啊不是写文章,重要的还是直白!🔥
转载文章,禁止声明原创;不允许直接二次转载,转载请根据原文链接联系作者
若无需改版,在文首清楚标注作者及来源/原文链接,并删除【原创声明】,即可直接转载。
但对于未注明转载来源/原文链接的文章,我将保留追述的权利。
作者:积跬步、至千里
比如,我想把某个路径下的【文件】,挂载到文件系统中
选择数据的路径为 xxxxxxxxxxxx
挂载的文件系统为 fatfs
1. 从编译的提示信息开始
1.1 将【设置路径下的文件】编译生成 rodata.fatfs
调用
makefatfs.py
文件,利用tools/scripts/
文件夹下的脚本工具,
将inputdir
,也就是你在menuconfig
中设置的工程文件夹路径中的文件,
编译输出为rodata.fatfs
文件,输出路径为outfile
更通俗的,将 gui_guider_demo/lvgl_src
路径下的所有文件添加到编译中,生成 rodata.fatfs
python3 F:\luban-lite\tools/scripts/makefatfs.py
--auto --cluster 8 --sector 512
--tooldir F:\luban-lite\tools/scripts/
--inputdir F:\luban-lite/packages/artinchip/lvgl-ui/aic_demo/gui_demo/lvgl_src
--outfile F:\luban-lite\output/d13x_kunlunpi88-nor_rt-thread_helloworld/images/rodata.fatfs
1.2 生成 pbp_cfg.bin
调用
mk_private_resource.exe
,结合两个.json
文件中的配置信息,生成pbp_cfg.bin
文件
F:\luban-lite\tools/scripts/mk_private_resource.exe -v -l
F:\luban-lite\output/d13x_kunlunpi88-nor_rt-thread_helloworld/images/pbp_cfg.json,
F:\luban-lite\output/d13x_kunlunpi88-nor_rt-thread_helloworld/images/partition.json
-o F:\luban-lite\output/d13x_kunlunpi88-nor_rt-thread_helloworld/images/pbp_cfg.bin
1.3 生成 Image header
psram
python3
F:\luban-lite\tools/scripts/elf_parse.py
output\d13x_kunlunpi88-nor_rt-thread_helloworld\images\d13x.elf
F:\luban-lite\output/d13x_kunlunpi88-nor_rt-thread_helloworld/images/
riscv64-unknown-elf-
F:\luban-lite\tools/scripts/mk_image.exe -v -c
F:\luban-lite\output/d13x_kunlunpi88-nor_rt-thread_helloworld/images/image_cfg.json
-d F:\luban-lite\output/d13x_kunlunpi88-nor_rt-thread_helloworld/images/
Creating F:\luban-lite\output/d13x_kunlunpi88-nor_rt-thread_helloworld/images/d13x_os.itb ...
Creating F:\luban-lite\output/d13x_kunlunpi88-nor_rt-thread_helloworld/images/bootloader.aic ...
Image header is generated.
1.4 合并生成 img 镜像文件
2. 关于 makefatfs.py
2.1 工作流程
makefatfs.py
是一个用于创建FAT
文件系统的Python
脚本。它可以将指定的路径内容编译成Bin
文件。
脚本主要工作流程:
- 分析指定路径。读取和分析指定的路径,获取其中的文件和文件夹信息。
- 构建文件系统结构。根据获取到的文件和文件夹信息,在内存中构建 FAT 文件系统的结构,包括目录项、文件分配表等。
- 写入 Bin 文件。将构建好的文件系统结构按照特定的格式和规则,逐字节地写入到生成的 Bin 文件中。
2.2 参数解析
--auto --cluster 8 --sector 512
参数解释如下:
--auto
表示是自动计算文件的大小--cluster 8
表示簇大小为8字节--sector 512
表示,存储时,扇区的大小为 512 字节
2.3 使用案例
以下是一些 makefatfs.py
参数调整的实际案例:
案例一:为小型嵌入式设备创建紧凑的文件系统
需求:在一个资源有限的嵌入式设备中,只需要存储少量的配置文件和小的日志文件,要求尽可能节省存储空间。
参数调整:
--size 2048000
(设置分区大小为 2MB)--cluster-size 512
(使用较小的簇大小)
案例二:为多媒体存储创建大容量高性能文件系统
需求:用于存储大量的图片、音频和视频文件,需要较高的读写性能。
参数调整:
--size 1024000000
(设置分区大小为 1GB)--cluster-size 4096
(较大的簇大小适合大文件存储)