Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
FAL
stm32_onchip
FAL stm32片上flash数据结构stm32f2_onchip_flash
发布于 2022-08-18 16:19:33 浏览:1083
订阅该版
stm32片上flash数据结构 ```c const struct fal_flash_dev stm32f2_onchip_flash ={ .name = "stm32_onchip", .addr = 0x08000000, .len = 1024*1024, .blk_size = 128*1024, .ops = {init, read, write, erase}, .write_gran = 8}; ``` .blk_size = 128 × 1024:Flash 块/扇区大小(因为 STM32F2 各块大小不均匀,所以擦除粒度为最大块的大小:128K) 这儿的blksize到底填2048还是填128 × 1024如此大的数,有些blog说是这儿是最小擦除单位,填2048或者4096.
查看更多
4
个回答
默认排序
按发布时间排序
RTT_逍遥
认证专家
2022-08-18
https://github.com/supperthomas
看你具体擦除的地方块大小是多少,就是起始地址那里到size结束,block是多少就是多少。
红枫
认证专家
2022-08-22
这家伙很懒,什么也没写!
### rtt驱动是这样分块定义的 ``` #if defined(RT_USING_FAL) static int fal_flash_read_16k(long offset, rt_uint8_t *buf, size_t size); static int fal_flash_read_64k(long offset, rt_uint8_t *buf, size_t size); static int fal_flash_read_128k(long offset, rt_uint8_t *buf, size_t size); static int fal_flash_write_16k(long offset, const rt_uint8_t *buf, size_t size); static int fal_flash_write_64k(long offset, const rt_uint8_t *buf, size_t size); static int fal_flash_write_128k(long offset, const rt_uint8_t *buf, size_t size); static int fal_flash_erase_16k(long offset, size_t size); static int fal_flash_erase_64k(long offset, size_t size); static int fal_flash_erase_128k(long offset, size_t size); const struct fal_flash_dev stm32_onchip_flash_16k = { "onchip_flash_16k", STM32_FLASH_START_ADRESS_16K, FLASH_SIZE_GRANULARITY_16K, (16 * 1024), {NULL, fal_flash_read_16k, fal_flash_write_16k, fal_flash_erase_16k} }; const struct fal_flash_dev stm32_onchip_flash_64k = { "onchip_flash_64k", STM32_FLASH_START_ADRESS_64K, FLASH_SIZE_GRANULARITY_64K, (64 * 1024), {NULL, fal_flash_read_64k, fal_flash_write_64k, fal_flash_erase_64k} }; const struct fal_flash_dev stm32_onchip_flash_128k = { "onchip_flash_128k", STM32_FLASH_START_ADRESS_128K, FLASH_SIZE_GRANULARITY_128K, (128 * 1024), {NULL, fal_flash_read_128k, fal_flash_write_128k, fal_flash_erase_128k} }; static int fal_flash_read_16k(long offset, rt_uint8_t *buf, size_t size) { return stm32_flash_read(stm32_onchip_flash_16k.addr + offset, buf, size); } static int fal_flash_read_64k(long offset, rt_uint8_t *buf, size_t size) { return stm32_flash_read(stm32_onchip_flash_64k.addr + offset, buf, size); } static int fal_flash_read_128k(long offset, rt_uint8_t *buf, size_t size) { return stm32_flash_read(stm32_onchip_flash_128k.addr + offset, buf, size); } static int fal_flash_write_16k(long offset, const rt_uint8_t *buf, size_t size) { return stm32_flash_write(stm32_onchip_flash_16k.addr + offset, buf, size); } static int fal_flash_write_64k(long offset, const rt_uint8_t *buf, size_t size) { return stm32_flash_write(stm32_onchip_flash_64k.addr + offset, buf, size); } static int fal_flash_write_128k(long offset, const rt_uint8_t *buf, size_t size) { return stm32_flash_write(stm32_onchip_flash_128k.addr + offset, buf, size); } static int fal_flash_erase_16k(long offset, size_t size) { return stm32_flash_erase(stm32_onchip_flash_16k.addr + offset, size); } static int fal_flash_erase_64k(long offset, size_t size) { return stm32_flash_erase(stm32_onchip_flash_64k.addr + offset, size); } static int fal_flash_erase_128k(long offset, size_t size) { return stm32_flash_erase(stm32_onchip_flash_128k.addr + offset, size); } #endif #endif /* BSP_USING_ON_CHIP_FLASH */ ```
lchnu
2023-03-08
Witness, Understand, Skill
fal_rtt.c中,对blk_size的处理如下: ```c blk_dev->fal_part = fal_part; blk_dev->geometry.bytes_per_sector = fal_flash->blk_size; blk_dev->geometry.block_size = fal_flash->blk_size; blk_dev->geometry.sector_count = fal_part->len / fal_flash->blk_size; ``` 内部按字节来计算的。有些Blog说填128,应该是说错了。
mii
2023-03-08
这家伙很懒,什么也没写!
 不要怀疑,实践出真知,就是一扇区的大小,华大的是8K一扇区平均的,而ST的不平均,我之前就是填128*1024。
撰写答案
登录
注册新账号
关注者
0
被浏览
1.1k
关于作者
LeonRT
hello
提问
34
回答
20
被采纳
0
关注TA
发私信
相关问题
1
关于FAL移植
2
添加fal软件包之后编译出现错误,求助!
3
关于easyflash4.0的写入和读取norflash一些疑惑咨询
4
FAL驱动移植&构建脚本问题
5
帮我看一下这样分区会不会冲突??
6
EasyFlash 4.0疑似出BUG
7
疑似FAL日志输出与DFS冲突??
8
fal软件包偏移量大于等于当前分区的大小会报错
9
为什么片内Flash总是写失败?
10
片上flash的文件系统的建立
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
求助can通讯下怎末运用485
2
STM32F407ZGT适配串口V2驱动
3
【CFP】2025 RT-Thread全球技术大会演讲征集开始啦!
4
在 RT-Thread Studio 环境中为 ART-Pi 2 移植 CherryUSB(以 usb_device 为例)
5
嵌入式ARM RISCV toolchain工具 梳理arm-none-eabi-gcc
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
DMA
USB
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
rt-smart
FAL
I2C_IIC
cubemx
ESP8266
WIZnet_W5500
UART
ota在线升级
BSP
PWM
flash
packages_软件包
freemodbus
潘多拉开发板_Pandora
ADC
GD32
定时器
flashDB
编译报错
keil_MDK
socket
中断
rt_mq_消息队列_msg_queue
Debug
ulog
SFUD
msh
C++_cpp
at_device
本月问答贡献
聚散无由
9
个答案
6
次被采纳
RTT_逍遥
8
个答案
2
次被采纳
a1012112796
5
个答案
2
次被采纳
三世执戟
4
个答案
2
次被采纳
加缪
2
个答案
2
次被采纳
本月文章贡献
wake_mirco
2
篇文章
7
次点赞
mushroom
1
篇文章
9
次点赞
张世争
1
篇文章
7
次点赞
RTT_逍遥
1
篇文章
6
次点赞
Jack_____
1
篇文章
5
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部