[KungFu32位 MCU] KF32A156的flash驱动flash driver放置在ram的操作方式

[复制链接]
 楼主| tpgf 发表于 2024-4-15 16:00 | 显示全部楼层 |阅读模式
敲重点
目前很多主机厂对于flash驱动有要求:在平时不需要的时候,并不会将flash擦写函数放在程序中,这样可以防止在单片机异常环境下进行了flash的不当操作导致程序或者数据损坏。故而需要将flash驱动单独拎出来,在需要的时候再拷进去。
针对这个要求,我们可以进行如下操作
1、将flash擦写函数定义好(156的擦写函数是已经封好的,内部我们看不到,151系列目前可以查看),并在主函数中进行引用(防止被优化)。

2、建立一个数组,将相关的擦写函数进行提取,本质上就是将擦写函数编译生成二进制数复制下来放置在数组中。

3、创建一个接收usigned int32 类型的空函数指针,注意要加上形参,根据擦写函数实际要传入的参数进行定义。然后再定义两个该类型的空函数,正常都是一个擦,一个写。

4、将第2步的数组的起始地址赋值给第3步的空函数,这样就完成了以上操作。

这里要说明的是,在实际的使用中,为了防止异常跑到flash驱动函数里面,这个数组里面的数据并不是长期存储在flash上面,或者ram上面。
下面是图示步骤:
1、flash的驱动函数在默认的库里面,位置如下,一般只需要擦和写的即可。读是可以指针直接获取的。然后在main函数中随便调用一下,防止优化。

81921661cdeaa77955.png

2、编译完成后,我们找到对应的二进制数据

22214661cde9996ad8.png

3、将这些数据提取出来,创建数组,放到数组里面。(这里没有使用通讯传输,客户如果需要通讯测试可自行创建空数组通过通讯的方式将数据发送至数组里面)

9559661cde83b9fdf.png

4、创建unsigned int 类型的空函数指针,且附上参数,再将存放数据的数组进行赋值。操作如下图:

13373661cde791eea6.png

39513661cde7268f20.png

总结:这样我们再调用定义的函数即可实现flash driver的功能啦。
————————————————

                            版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

原文链接:https://blog.csdn.net/Fanshijun1/article/details/129808531

85555661cde88bd995.png
您需要登录后才可以回帖 登录 | 注册

本版积分规则

2347

主题

17448

帖子

21

粉丝
快速回复 在线客服 返回列表 返回顶部

2347

主题

17448

帖子

21

粉丝
快速回复 在线客服 返回列表 返回顶部