OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3392|回复: 5

STM32F1进行大数据存卡方案

[复制链接]

28

主题

91

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
214
金钱
214
注册时间
2018-4-10
在线时间
28 小时
发表于 2021-3-27 17:37:28 | 显示全部楼层 |阅读模式
做项目遇到一个困难,请大家出出主意:利用STM32F103VGT6+ucosiii+fatffs;硬件外扩W5500网口芯片(用SPI2),读写SD卡(SPI2);目前需求是网口UDP传输两种类型的数据;一种是200字节一包,频率为100HZ;另一种是1K单包,每次传输10-30K不定,每包间隔10ms,每次传输间隔100ms;要求两种数据都需要存卡;同时系统还有别的3个任务处理,实时性要求不高;

最开始采用方案为W5500读为到单独循环任务,每次出发读任务后,直接切换存卡任务进行存卡,失败,猜测可能频率太快,读写跟不上;
后来采用RAM中定义两个大数组,W5500读出数据,切换赋值给数组,实现一个读网口数据,一个存卡;目前问题是第二类数据太快,数组太小读写跟不上;定义太大RAM不够用

请问大家针对这种操作,用什么方式比较好?
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

28

主题

91

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
214
金钱
214
注册时间
2018-4-10
在线时间
28 小时
 楼主| 发表于 2021-3-27 17:50:28 | 显示全部楼层
回复 支持 反对

使用道具 举报

5

主题

356

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4648
金钱
4648
注册时间
2019-4-30
在线时间
902 小时
发表于 2021-3-28 12:17:34 | 显示全部楼层
定义两个4KB,然后用DMA去做双缓存的乒乓操作不行么?F1没有硬件双缓存,但是可以自己手动切换
回复 支持 反对

使用道具 举报

5

主题

356

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4648
金钱
4648
注册时间
2019-4-30
在线时间
902 小时
发表于 2021-3-28 12:19:28 | 显示全部楼层
然后文件常开状态,写一次记得SYNC一次
回复 支持 反对

使用道具 举报

5

主题

356

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4648
金钱
4648
注册时间
2019-4-30
在线时间
902 小时
发表于 2021-3-28 15:36:04 | 显示全部楼层
我测试fatfs下f103写入4KB大概是4MS左右
回复 支持 反对

使用道具 举报

28

主题

91

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
214
金钱
214
注册时间
2018-4-10
在线时间
28 小时
 楼主| 发表于 2021-3-29 11:26:55 | 显示全部楼层
a1281854907 发表于 2021-3-28 12:17
定义两个4KB,然后用DMA去做双缓存的乒乓操作不行么?F1没有硬件双缓存,但是可以自己手动切换

4K不太够,暂时没用DMA,因为还需要解析一些东西;不是存一个文件,目前是16k左右切换一个文件;然后每3600个文件换一个文件夹,因为文件数太多写入速度更慢;ucos操作系统切换感觉不快呢
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-5-26 08:40

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表