【屏驱MCU】实现文件路径的的挂载

说明:本文涉及到一些底层的 .py 编译脚本以及编辑原理,笔者也不是完全明白,本文的主要目的是介绍一下流程,供小白使用。

接上文:【屏驱MCU】RT-Thread 文件系统接口解析

屏驱MCU系列文章

【屏显MCU】多媒体接口总结(一)

【DVP接口】0v5640的DVP接口设计分析(硬件)

【DVP接口】0v5640的DVP接口设计分析(软件)

【屏驱MCU】RT-Thread文件系统接口解析

【RT-Thread】串口接收数据并找出一帧完整的报文

0. 个人简介 && 授权须知

image-20230911133730620

📋 个人简介

  • 💖 作者简介:大家好,我是喜欢记录零碎知识点的菜鸟打工人。😎
  • 📝 个人主页:欢迎访问我的博客主页🔥
  • 🎉 支持我:点赞👍+收藏⭐️+留言📝
  • 📣 系列专栏:嵌入式开发专栏 🍁 🍁
  • 💬格言:写文档啊不是写文章,重要的还是直白!🔥

转载文章,禁止声明原创;不允许直接二次转载,转载请根据原文链接联系作者

若无需改版,在文首清楚标注作者及来源/原文链接,并删除【原创声明】,即可直接转载。
但对于未注明转载来源/原文链接的文章,我将保留追述的权利。

作者:积跬步、至千里

image-20230911133724204

比如,我想把某个路径下的【文件】,挂载到文件系统中
选择数据的路径为 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 文件。

脚本主要工作流程:

  1. 分析指定路径。读取和分析指定的路径,获取其中的文件和文件夹信息。
  2. 构建文件系统结构。根据获取到的文件和文件夹信息,在内存中构建 FAT 文件系统的结构,包括目录项、文件分配表等。
  3. 写入 Bin 文件。将构建好的文件系统结构按照特定的格式和规则,逐字节地写入到生成的 Bin 文件中。

2.2 参数解析

--auto --cluster 8 --sector 512 参数解释如下:

  1. --auto 表示是自动计算文件的大小
  2. --cluster 8 表示簇大小为8字节
  3. --sector 512 表示,存储时,扇区的大小为 512 字节

2.3 使用案例

以下是一些 makefatfs.py 参数调整的实际案例:

案例一:为小型嵌入式设备创建紧凑的文件系统

需求:在一个资源有限的嵌入式设备中,只需要存储少量的配置文件和小的日志文件,要求尽可能节省存储空间。

参数调整:

  • --size 2048000 (设置分区大小为 2MB)
  • --cluster-size 512 (使用较小的簇大小)

案例二:为多媒体存储创建大容量高性能文件系统

需求:用于存储大量的图片、音频和视频文件,需要较高的读写性能。
参数调整:

  • --size 1024000000 (设置分区大小为 1GB)
  • --cluster-size 4096 (较大的簇大小适合大文件存储)

3. flash 分区中

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

积跬步、至千里

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

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

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

打赏作者

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

抵扣说明:

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

余额充值