OpenEdv-开源电子网

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

用FATFS文件系统对SD卡连续写数据,速度很慢正常吗?

[复制链接]

5

主题

100

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
361
金钱
361
注册时间
2012-8-10
在线时间
40 小时
发表于 2013-1-15 16:07:21 | 显示全部楼层 |阅读模式
旗舰版的开发板,用FATFS文件系统连续写24字节的数据到SD卡,发现写一次都要耗时6ms左右,时间是用示波器测得的,这是正常的还是我的程序那里有问题,请大家帮忙看看? 谢谢!!
u8 buffer[24]="01234567890123456789abc";
        f_mount(0,&fs);
res=f_open(&file,"0:1.txt",0x13);     

while(1){
                     LED0=0;
                        f_lseek(&file,f_size(&file));
                        res=f_write(&file,buffer,24,&br);
                        f_sync(&file);
                        LED0=1;
                        delay_ms(10);
                    }
用示波器测得LED0 的IO口的低电平大约为6ms左右,也就是说那三句写sd函数要运行6ms左右,怎么这么慢呢,是不是这样写SD卡不对呀?
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165516
金钱
165516
注册时间
2010-12-1
在线时间
2116 小时
发表于 2013-1-15 17:07:49 | 显示全部楼层
这样当然慢了,就写24个字节,很多花销都耗在指令发送上面了。
你要测试,一次写很多数据测试。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

5

主题

100

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
361
金钱
361
注册时间
2012-8-10
在线时间
40 小时
 楼主| 发表于 2013-1-15 17:27:20 | 显示全部楼层
谢谢原子大哥!我试过512字节的,差别不是很大,再大的就没有试过了,您的文件那个文件系统一次最大支持发送多少字节的数据呀?
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165516
金钱
165516
注册时间
2010-12-1
在线时间
2116 小时
发表于 2013-1-15 19:09:49 | 显示全部楼层
回复【3楼】hwl1023:
---------------------------------
比如一次写10M字节,看要多久写完
然后用总字节/时间,得到速度。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

2

主题

15

帖子

0

精华

新手上路

积分
48
金钱
48
注册时间
2014-7-6
在线时间
4 小时
发表于 2014-7-30 11:50:15 | 显示全部楼层
回复【3楼】hwl1023:
---------------------------------
你好 可以把你的写SD卡的程序发一份上来吗 我不太会写
回复 支持 反对

使用道具 举报

5

主题

100

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
361
金钱
361
注册时间
2012-8-10
在线时间
40 小时
 楼主| 发表于 2014-7-30 17:57:32 | 显示全部楼层
回复【5楼】llcg1314:
---------------------------------
原子哥的开发板程序有这个写卡的吧,FATFS那个实验。
回复 支持 反对

使用道具 举报

2

主题

15

帖子

0

精华

新手上路

积分
48
金钱
48
注册时间
2014-7-6
在线时间
4 小时
发表于 2014-7-31 09:03:18 | 显示全部楼层
回复【6楼】hwl1023:
---------------------------------
我用SDIO模式 但是我不太会往SD 卡中写ADC得到的值 和记录当前时间 麻烦你有这块的程序 发一份给我可以吗 谢谢
回复 支持 反对

使用道具 举报

5

主题

100

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
361
金钱
361
注册时间
2012-8-10
在线时间
40 小时
 楼主| 发表于 2014-7-31 10:50:40 | 显示全部楼层
回复【7楼】llcg1314:
---------------------------------
你是用文件系统往SD卡里写文件吗?是的话用FATFS写文件很简单,原子哥的教程有详细的说明。
回复 支持 反对

使用道具 举报

13

主题

43

帖子

0

精华

初级会员

Rank: 2

积分
115
金钱
115
注册时间
2014-11-16
在线时间
0 小时
发表于 2014-11-21 17:18:37 | 显示全部楼层
我也在测试FATFS的写入速度,写1m的char,需要910ms左右,不知道正常不
回复 支持 反对

使用道具 举报

13

主题

43

帖子

0

精华

初级会员

Rank: 2

积分
115
金钱
115
注册时间
2014-11-16
在线时间
0 小时
发表于 2014-11-21 17:24:13 | 显示全部楼层
5m字节用了22s,不该这么慢,哪里没设置好呢
回复 支持 反对

使用道具 举报

13

主题

43

帖子

0

精华

初级会员

Rank: 2

积分
115
金钱
115
注册时间
2014-11-16
在线时间
0 小时
发表于 2014-11-21 18:10:47 | 显示全部楼层
打开文件成功[2014-11-21 06:08:57.587]
4k*2k字符开始写入[2014-11-21 06:08:57.587]
4k*2k字符写完成[2014-11-21 06:09:08.322]
4k*2k关闭文件成功[2014-11-21 06:09:08.333]


8m字节,用时大概11s
回复 支持 反对

使用道具 举报

4

主题

28

帖子

0

精华

初级会员

Rank: 2

积分
64
金钱
64
注册时间
2012-11-8
在线时间
0 小时
发表于 2015-1-13 13:37:38 | 显示全部楼层
回复【4楼】正点原子:
---------------------------------
原子哥,你看一楼的程序,只调用打开函数,没有调用关闭,合适么?
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165516
金钱
165516
注册时间
2010-12-1
在线时间
2116 小时
发表于 2015-1-13 19:43:56 | 显示全部楼层
回复【12楼】cmc:
---------------------------------
测试用无妨。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

4

主题

28

帖子

0

精华

初级会员

Rank: 2

积分
64
金钱
64
注册时间
2012-11-8
在线时间
0 小时
发表于 2015-1-19 15:58:46 | 显示全部楼层
回复【13楼】正点原子:
---------------------------------
如果是工业上用呢?会带来什么样的隐患么?
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165516
金钱
165516
注册时间
2010-12-1
在线时间
2116 小时
发表于 2015-1-19 23:12:01 | 显示全部楼层
回复【14楼】cmc:
---------------------------------
这就要看别人代码怎么写了.
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

3

主题

8

帖子

0

精华

新手上路

积分
40
金钱
40
注册时间
2014-12-4
在线时间
0 小时
发表于 2015-1-20 20:53:30 | 显示全部楼层
能不能把代码也发我一下,我也想学习学习,1296546428,qq邮箱
回复 支持 反对

使用道具 举报

5

主题

100

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
361
金钱
361
注册时间
2012-8-10
在线时间
40 小时
 楼主| 发表于 2015-1-21 15:05:13 | 显示全部楼层
当初写上面的函数的确只是测试使用,因为要循环的测试写数据的速度所以没有调用f_close(),其实调用f_sync()也能保存新写的数据了。

http://elm-chan.org/fsw/ff/en/sync.html
回复 支持 反对

使用道具 举报

1

主题

2

帖子

0

精华

新手入门

积分
26
金钱
26
注册时间
2015-4-7
在线时间
0 小时
发表于 2015-5-16 21:27:52 | 显示全部楼层
回复【10楼】echo12211:
---------------------------------
为什么我用fatf函数调用f_write只有51k/s左右的写入速度呀?请大神帮忙看下一下
SD_Init();
  exfuns_init();  
   f_mount(fs[0],"0:",1); 
        f_open(&fdst, "0:/new.txt", FA_CREATE_ALWAYS | FA_WRITE);
for(i=0;i<10000;i++)
{
f_write(&fdst, buffer, 511, &bw);
f_sync(&fdst); //刷新缓存信息
}
回复 支持 反对

使用道具 举报

1

主题

13

帖子

0

精华

新手上路

积分
37
金钱
37
注册时间
2014-12-22
在线时间
0 小时
发表于 2015-6-15 20:06:35 | 显示全部楼层
回复【15楼】正点原子:
---------------------------------
原子哥,我用FATFS文件系统往SD写入采集的数据,512KB为一组,那我下一组怎么老是覆盖前面那一组的数据,怎么设置指针的偏移位置,下一组从第一组的队尾开始写。急急急~~~
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165516
金钱
165516
注册时间
2010-12-1
在线时间
2116 小时
发表于 2015-6-17 00:56:09 | 显示全部楼层
回复【19楼】杨泽松yzs:
---------------------------------
 f_lseek
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

1

主题

13

帖子

0

精华

新手上路

积分
37
金钱
37
注册时间
2014-12-22
在线时间
0 小时
发表于 2015-6-17 11:00:29 | 显示全部楼层
回复【20楼】正点原子:
---------------------------------
原子哥,我用的是这个函数,但是每次后面一组的数据还是覆盖了前面的那组。
while(1)
{


for(a=0;a<1000;a++)

{

ADXL345_Read_Average(&x,&y,&z,10);
Adxl_Show_Num(60+48,170,x,0);
       Adxl_Show_Num(60+48,190,y,0);
Adxl_Show_Num(60+48,210,z,0);

                write_data=x; 


write_data[++b]=y;


write_data[++b]=z;

      b++;

}



    res=f_open(file,"0:/data.txt",FA_OPEN_ALWAYS|FA_READ|FA_WRITE );



if(res!=FR_OK)
{
LCD_ShowString(60,130,200,16,16,"f_open() failed");
}
else
{
    LCD_ShowString(60,130,200,16,16,"f_open() success");


  
for(i=0;i<3000;i++)

{  
   f_printf(file,"%d  ",write_data);
   printf("%d ",write_data);


     
}
 f_lseek(file,10000); 
t2++;
delay_ms(200);      
LED0=!LED0;
}
程序是这样的。
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165516
金钱
165516
注册时间
2010-12-1
在线时间
2116 小时
发表于 2015-6-17 23:57:21 | 显示全部楼层
回复【21楼】杨泽松yzs:
---------------------------------
f_lseek(file,10000);  
你这样,每次都是定位到10000这个地方啊
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

1

主题

13

帖子

0

精华

新手上路

积分
37
金钱
37
注册时间
2014-12-22
在线时间
0 小时
发表于 2015-6-18 14:10:31 | 显示全部楼层
回复【22楼】正点原子:
---------------------------------
哦,那问下应该怎么改呀,还是没搞好。
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165516
金钱
165516
注册时间
2010-12-1
在线时间
2116 小时
发表于 2015-6-19 00:12:05 | 显示全部楼层
回复【23楼】杨泽松yzs:
---------------------------------
可以参考下我们例程
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

4

主题

46

帖子

0

精华

初级会员

Rank: 2

积分
82
金钱
82
注册时间
2014-12-24
在线时间
0 小时
发表于 2015-6-19 09:48:16 | 显示全部楼层
回复【23楼】杨泽松yzs:
---------------------------------
这个是定位函数,你每次定位到指定位置读写,当然会覆盖,要写一次移动一次
回复 支持 反对

使用道具 举报

13

主题

49

帖子

0

精华

初级会员

Rank: 2

积分
121
金钱
121
注册时间
2015-1-26
在线时间
0 小时
发表于 2015-9-9 16:27:28 | 显示全部楼层
回复【11楼】echo12211:
---------------------------------
这么快啊,我现在516K要用5分钟啊,你可以告诉我,程序怎么写的吗?多谢了。我都快哭了。
回复 支持 反对

使用道具 举报

4

主题

18

帖子

0

精华

新手上路

积分
21
金钱
21
注册时间
2016-6-1
在线时间
7 小时
发表于 2016-6-2 16:40:19 | 显示全部楼层
我是其他的开发板,下载的STM32开发指南,fatfs那章没有建立txt,楼主可以发份程序和资料来看看吗
回复 支持 反对

使用道具 举报

1

主题

8

帖子

0

精华

新手上路

积分
37
金钱
37
注册时间
2013-6-6
在线时间
6 小时
发表于 2016-8-4 13:58:55 | 显示全部楼层
正点原子 发表于 2013-1-15 19:09
回复【3楼】hwl1023:
---------------------------------
比如一次写10M字节,看要多久写完
然后用总字节/ ...

请问原子哥,在MCU里面怎么实现一次性写入10MB数据,

mf_write((uint8_t *)mem1base, 100000);  

这个函数一次性最多只能写入u16类型长度,且MCU里面也没有10MB缓冲区
回复 支持 反对

使用道具 举报

12

主题

51

帖子

0

精华

初级会员

Rank: 2

积分
158
金钱
158
注册时间
2017-11-5
在线时间
31 小时
发表于 2019-8-9 21:36:01 | 显示全部楼层
echo12211 发表于 2014-11-21 18:10
打开文件成功[2014-11-21&nbsp;06:08:57.587]
4k*2k字符开始写入[2014-11-21&nbsp;06:08:57.587]
4k*2k字符 ...

一次写8M,你哪来的那么大的缓存呢
回复 支持 反对

使用道具 举报

0

主题

1

帖子

0

精华

新手入门

积分
6
金钱
6
注册时间
2020-1-27
在线时间
1 小时
发表于 2020-1-27 14:50:07 | 显示全部楼层
请问原子哥 我在STM32F103单片机移植了一个文件系统  初始化的时候读取一个SD卡的总容量和剩余容量  需要2分钟左右 这样正常吗
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-5-20 03:07

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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