野火电子论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 22735|回复: 11

SD卡写入速度极其慢

[复制链接]
发表于 2014-2-19 11:12:34 | 显示全部楼层 |阅读模式
代码是用的野火M3-FATFS,只是修改了main.c文件。main()函数是这么写的:
int main(void)
{        
        int res;
        FIL fdst;
        FATFS fs;
        UINT bw;                          // File R/W count
        BYTE buffer[512];            // file copy buffer
        CHAR Buf1 = 60;
        CHAR Buf2 = 70;
        
        int i;
        f_mount(0,&fs);
        res = f_open(&fdst, "0:/demo.txt", FA_READ | FA_WRITE | FA_OPEN_ALWAYS);
        if ( res == FR_OK )
          {
                for(i=0;i<100;i++)
                {
                        f_write(&fdst, &Buf1, sizeof(Buf1), &bw);
                        f_lseek(&fdst, fdst.fsize);
                        f_sync(&fdst);
                        
                        f_write(&fdst, &Buf2, sizeof(Buf2), &bw);
                        f_lseek(&fdst, fdst.fsize);
                        f_sync(&fdst);
                }
                f_close(&fdst);
                f_mount(0, NULL);
          }      
  while (1){}
}

我用LED灯做的指示,写完所有数据后点亮,在上面写入200个8bit char变量的情况下需要1分钟左右。我用示波器量SD卡CLK引脚是24MHz,并且SD卡4个数据引脚都有信号,说明是开启了4bit模式的。SDIO+DMA+24MHz+4bit+SD_WriteMultiBlocks(),怎么会这么慢呢?
回复

使用道具 举报

 楼主| 发表于 2014-2-19 11:16:13 | 显示全部楼层
我的SD卡在电脑上的写入速度是5M/s。
diskio.c下有这么一句:
#define BLOCK_SIZE     512         /* Block Size in Bytes */
我看网上说SD卡扇区大小可以为512, 1024, 2048, 4096等,越大写入速度越快。可是当我把这个值改为1024后,连创建demo.txt都失败,在电脑上查看什么文件都没有。那么所谓的SD卡扇区到底是在哪里改呢?
回复 支持 反对

使用道具 举报

发表于 2014-2-19 11:38:45 | 显示全部楼层
就是这个BLOCK_SIZE  宏控制扇区大小的,sd卡物理扇区是512,你要改成其它值可能还要作其它修改,文件系统也要设置相应的扇区大小   
回复 支持 反对

使用道具 举报

 楼主| 发表于 2014-2-19 12:01:05 | 显示全部楼层
晋奇 发表于 2014-2-19 11:38
就是这个BLOCK_SIZE  宏控制扇区大小的,sd卡物理扇区是512,你要改成其它值可能还要作其它修改,文件系统也 ...

我在ffconf.h下找到一个:

#define        _MAX_SS                512                /* 512, 1024, 2048 or 4096 */
/* Maximum sector size to be handled.
/  Always set 512 for memory card and hard disk but a larger value may be
/  required for on-board flash memory, floppy disk and optical disk.
/  When _MAX_SS is larger than 512, it configures FatFs to variable sector size
/  and GET_SECTOR_SIZE command must be implememted to the disk_ioctl function. */

当我把这个和diskio.c的那个都改为1024时,SD卡还是不可用。目前只发现当两者都为512时SD卡可用。
回复 支持 反对

使用道具 举报

发表于 2014-2-19 12:03:35 | 显示全部楼层
杏仁露2014 发表于 2014-2-19 12:01
我在ffconf.h下找到一个:

#define        _MAX_SS                512                /* 512, 1024, 2048 or 4096 */

sd卡的底层驱动也要改,本来只是写一个512字节,现在上层每来一个block底层要写1024字节。但我觉得改起来还是太麻烦了,虽然我没有测试写入速度多快,但是没感觉慢呀
回复 支持 反对

使用道具 举报

发表于 2014-2-19 12:08:03 | 显示全部楼层
因为上述的代码包括了f_open(&fdst, "0:/demo.txt", FA_READ | FA_WRITE | FA_OPEN_ALWAYS);

里面执行SD卡初始化,所以是比较忙,但如果需要1分钟,这个就不正常了。试下换个卡看看呗
回复 支持 反对

使用道具 举报

发表于 2014-2-19 12:22:45 | 显示全部楼层
王清铭 发表于 2014-2-19 12:08
因为上述的代码包括了f_open(&fdst, "0:/demo.txt", FA_READ | FA_WRITE | FA_OPEN_ALWAYS);

里面执行SD ...

fatfs0.09的源码就有这个缺陷,以前旧版的fatfs源码初始化sd卡是在f_mount函数进行的
回复 支持 反对

使用道具 举报

发表于 2014-2-19 12:23:44 | 显示全部楼层
郑倚云 发表于 2014-2-19 12:22
fatfs0.09的源码就有这个缺陷,以前旧版的fatfs源码初始化sd卡是在f_mount函数进行的

这个f_open只是在写文件的时候执行一次,不会影响太大吧
回复 支持 反对

使用道具 举报

 楼主| 发表于 2014-2-19 13:06:53 | 显示全部楼层
晋奇 发表于 2014-2-19 12:23
这个f_open只是在写文件的时候执行一次,不会影响太大吧

我找到影响速度的语句了。是:

f_sync(&fdst);

把这句屏蔽掉(2处),速度就非常之快了。我令main()函数里的i=65535测试,2秒钟就写完了。
回复 支持 反对

使用道具 举报

发表于 2014-2-19 13:09:25 | 显示全部楼层
杏仁露2014 发表于 2014-2-19 13:06
我找到影响速度的语句了。是:

f_sync(&fdst);

学习了 。这个函数强制把数据从内存写入到sd卡,所以操作变慢了
回复 支持 反对

使用道具 举报

 楼主| 发表于 2014-2-19 13:14:25 | 显示全部楼层
王清铭 发表于 2014-2-19 12:08
因为上述的代码包括了f_open(&fdst, "0:/demo.txt", FA_READ | FA_WRITE | FA_OPEN_ALWAYS);

里面执行SD ...

f_mount()之后,如果没有f_open(),可以直接进行f_write()操作?
f_open()应该是必须要的吧?
回复 支持 反对

使用道具 举报

发表于 2014-2-19 13:19:53 | 显示全部楼层
杏仁露2014 发表于 2014-2-19 13:14
f_mount()之后,如果没有f_open(),可以直接进行f_write()操作?
f_open()应该是必须要的吧?

必须f_open
回复 支持 反对

使用道具 举报

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

本版积分规则

联系站长|手机版|野火电子官网|野火淘宝店铺|野火电子论坛 ( 粤ICP备14069197号 ) 大学生ARM嵌入式2群

GMT+8, 2024-5-15 15:42 , Processed in 0.029118 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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