OpenEdv-开源电子网

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

spi 挂载 fatfs 系统 读写速度 ???

[复制链接]

259

主题

806

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1887
金钱
1887
注册时间
2012-10-28
在线时间
353 小时
发表于 2016-11-20 21:07:46 | 显示全部楼层 |阅读模式
1金钱
spi 挂载 fatfs 系统 读写速度 大概测试了一下,速度那真是慢啦,看来使用 spi的器件来挂载 fatfs 感觉使用价值不大啊
读写 8192*4个Byte ,接近 7s,


222.png



void QSPI_FlashFatfsDemo(void)
{
  uint32_t RWDataSize = 8192 * 4;
  uint8_t  * qspi_tx_buff =  (uint8_t  *)mymalloc(SRAMEX, RWDataSize );       
  uint8_t  * qspi_rx_buff =  (uint8_t  *)mymalloc(SRAMEX, RWDataSize );       

  uint8_t res;
  FATFS qspi_fs;//逻辑磁盘工作区.         
  FIL file;                          //文件1
  UINT bw;                        //读写变量

  uint32_t cc;
  uint8_t i = 0;  
  u8 work[_MAX_SS];         /* Work area (larger is better for processing time) */  

  uint32_t  TimeBegin, TimeEnd;

  if(( !qspi_tx_buff) || ( !qspi_rx_buff ))
    printf("QSPI mymalloc Error ... ... \r\n");

  for(cc=0;cc < ( RWDataSize );cc++)
  {
    qspi_tx_buff[cc] = i * 1;
    qspi_rx_buff[cc] = 0 ;
    i ++;
  }

  res = f_mount( &qspi_fs,"3:",1);                                 //挂载 QSPI FLASH.分配盘符号为 3:
  if(FR_OK != res)
  {
    printf("f_mount NAND 失败 ... ...  0x%x\r\n", res);

    if(0x0D == res)
    {
      if(QSPI_EraseChip())           // 使用 fatfs 格式化函数前,先 擦除 QSPI flash 整个芯片,时间比较久,大概 2分钟左右
      {
        printf("QSPI Flash Format Error ... ...  \r\n");
      }

      res = f_mkfs("3:", 1, 4096, work, sizeof(work) );         //格式化FLASH,2,盘符;1,不需要引导区,8个扇区为1个簇
      if(res == 0)
      {
        res = f_setlabel((const TCHAR *)"3SPIDISK");                //设置Flash磁盘的名字为:QSPIDISK
        if(FR_OK == res)
        {
          printf("QSPI Flash 磁盘设置成功  ... ... \r\n");
        }

        printf("QSPI Flash Format Finish  ... ... \r\n");                //格式化完成
      }
      else
        printf("QSPI Flash Format Error   ... ... \r\n");           //格式化失败      
    }
  }
  else
    printf("f_mount QSPI 成功 ... ...  \r\n");

  TimeBegin = HAL_GetTick();
//  res = f_opendir(&DirInf, "3:");     /* 2: 表示盘符 ,在读写文件前必须先打开目录 */
  res = f_open(&file, "3:/QSPI.txt", FA_CREATE_ALWAYS | FA_WRITE );

  res = f_write(&file, &qspi_tx_buff[0], RWDataSize, &bw);

  res = f_close(&file);
  TimeEnd = HAL_GetTick();
  printf("QSPI Flash Write  8192 * 4  End   ... ... %dms\r\n\r\n" ,  TimeEnd - TimeBegin);    // 写入 8192*4 字节测试耗时147ms


  TimeBegin = HAL_GetTick();
//  res = f_opendir(&DirInf, "3:");     /* 2: 表示盘符  文件关闭后需要重新打开 根目录,否则读取失败 */
  res = f_open(&file, "3:/QSPI.txt", FA_READ);
  res = f_read (&file, &qspi_rx_buff[0], RWDataSize, &bw );
  res = f_mount( NULL, "3:", 1);   

  TimeEnd = HAL_GetTick();
  printf("QSPI Flash Read  8192 * 4  End   ... ... %dms\r\n\r\n" ,  TimeEnd - TimeBegin);    // 读取 8192*4 字节测试耗时6ms


  if( Buffercmp_8(&qspi_tx_buff[0], &qspi_rx_buff[0], RWDataSize ) == 0)
    printf("QSPI Flash Fatfs Read Write 8192 * 4 Test OK     .. DD \r\n\r\n");
  else
    printf("QSPI Flash Fatfs Read Write 8192 * 4 Test Error  .. EE \r\n\r\n");


  myfree(SRAMEX, qspi_tx_buff);
  myfree(SRAMEX, qspi_rx_buff);

}







正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165377
金钱
165377
注册时间
2010-12-1
在线时间
2111 小时
发表于 2016-11-21 13:06:00 | 显示全部楼层
QSPI的话,速度快不少,应该是几十甚至上百KB/S
回复

使用道具 举报

259

主题

806

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1887
金钱
1887
注册时间
2012-10-28
在线时间
353 小时
 楼主| 发表于 2016-11-22 09:45:20 | 显示全部楼层
正点原子 发表于 2016-11-21 13:06
QSPI的话,速度快不少,应该是几十甚至上百KB/S

你好,这个就是qspi 挂载 fatfs 系统的读写测试啊,怎么我的会这么慢啦 ?、

程序是使用你们的历程程序进行测试的啊 ,有没有可能是我的这个 qspi的芯片有问题啊 ??

qspi 芯片 w25q256fv
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165377
金钱
165377
注册时间
2010-12-1
在线时间
2111 小时
发表于 2016-11-27 14:32:55 | 显示全部楼层
hpdell 发表于 2016-11-22 09:45
你好,这个就是qspi 挂载 fatfs 系统的读写测试啊,怎么我的会这么慢啦 ?、

程序是使用你们的历程程 ...

我测试我们例程,速度还可以,直接用USB读卡器实验测试的,全新的 QSPI FLASH芯片,速度可以上百KB
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

54

主题

372

帖子

0

精华

高级会员

Rank: 4

积分
972
金钱
972
注册时间
2016-6-15
在线时间
473 小时
发表于 2016-11-27 18:27:43 | 显示全部楼层
SPI NANDFLASH 读写速度快很多,SPI NORFLASH最主要是擦除和写耗时,
回复

使用道具 举报

43

主题

481

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1352
金钱
1352
注册时间
2014-12-24
在线时间
321 小时
发表于 2016-11-27 19:40:52 | 显示全部楼层
自己去看看flash芯片资料啊,资料都不看就盲目搞,效果不好还不知道去看看资料为啥这样。
去看看nor flash的擦除和写入时间就明白了。
回复

使用道具 举报

259

主题

806

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1887
金钱
1887
注册时间
2012-10-28
在线时间
353 小时
 楼主| 发表于 2016-11-27 21:37:04 | 显示全部楼层
jinggx 发表于 2016-11-27 19:40
自己去看看flash芯片资料啊,资料都不看就盲目搞,效果不好还不知道去看看资料为啥这样。
去看看nor flash ...

啊,你好牛逼哟,
回复

使用道具 举报

43

主题

481

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1352
金钱
1352
注册时间
2014-12-24
在线时间
321 小时
发表于 2016-11-28 00:01:32 | 显示全部楼层
hpdell 发表于 2016-11-27 21:37
啊,你好牛逼哟,

我不牛,不过我看你确实水平欠缺,经常问些没深度的问题
hp,dell这两个电脑品牌也值得一说,几乎来说,买这两个品牌的,都觉得自己很懂电脑,但是事实上却恰恰相反,从性能,价格,服务上说要哪样没哪样,却还以为捡到宝了

话说,人吧,是该谦虚,所以说这些你一定不爽。但你这语气明显不服不奋啊,可能你自己觉得自己是个有料的人,可这么简单的问题自己都不去研究,就算有些水平也是个浮躁的程序猿
回复

使用道具 举报

2

主题

10

帖子

0

精华

新手上路

积分
40
金钱
40
注册时间
2010-12-14
在线时间
5 小时
发表于 2016-11-28 01:03:51 | 显示全部楼层
晕,这都能中枪,DELL?????????
好吧,我不说别的了
回复

使用道具 举报

259

主题

806

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1887
金钱
1887
注册时间
2012-10-28
在线时间
353 小时
 楼主| 发表于 2016-11-29 10:06:20 | 显示全部楼层
jinggx 发表于 2016-11-28 00:01
我不牛,不过我看你确实水平欠缺,经常问些没深度的问题
hp,dell这两个电脑品牌也值得一说,几乎来 ...

哦,看来你很厉害呀,估计在不久的将来应该是国家级别的领导人物,不过,就算你是国家级领导人物,估计也没有什么人愿意跟随你的,你就自己慢慢的嘚瑟吧
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-3-1 16:50

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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