你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

STM32F407,USB(3300,MSC),SDIO,DMA,读写卡速度【已解决】

[复制链接]
第109位梁山好汉 提问时间:2018-7-16 13:45 /
本帖最后由 第109位梁山好汉 于 2018-7-20 15:05 编辑

测试基于CubeMX生成的模板,想把USB数据转存到SD,可是将USB和SD连接到一起的速度太太低了!!!
这是我做的一些测试。

测试条件:
STM32 F407 , hal, SDIO(24M), DMA
闪迪 16G Class10
       USBHS(USB3300)(MSC)
       WIN10,USB2.0/USB3.0

测试 一:
SD卡,多扇区连续访问(200k)
       写:6.9MB/S
       读:10.85MB/S

测试 二:
       USB
       写:10.6MB/S
       读:14.4MB/S

测试 三:USB + SD
       写:300KB/S
       读:700KB/S

调试时,我把
STORAGE_Read_HS(uint8_t lun, uint8_t *buf,uint32_t blk_addr, uint16_t blk_len)
STORAGE_Write_HS(uint8_t lun, uint8_t *buf,uint32_t blk_addr, uint16_t blk_len)
blk_len 参数仿真查看,发现每次数据通讯都为 1 扇区,数据长度(512字节),怀疑是此处的时间开销,没有真正发挥 SDIO,DMA连续数据访问的优势。大家有遇到这种情况的吗?
  1. <div class="blockcode"><blockquote>/**
  2.   * @brief  .
  3.   * @param  lun: .
  4.   * @retval USBD_OK if all operations are OK else USBD_FAIL
  5.   */
  6. int8_t STORAGE_Init_HS(uint8_t lun)
  7. {
  8.   /* USER CODE BEGIN 9 */
  9.   return (USBD_OK);
  10.   /* USER CODE END 9 */
  11. }

  12. /**
  13.   * @brief  .
  14.   * @param  lun: .
  15.   * @param  block_num: .
  16.   * @param  block_size: .
  17.   * @retval USBD_OK if all operations are OK else USBD_FAIL
  18.   */
  19. int8_t STORAGE_GetCapacity_HS(uint8_t lun, uint32_t *block_num, uint16_t *block_size)
  20. {
  21.   /* USER CODE BEGIN 10 */
  22.    
  23.     HAL_SD_CardInfoTypeDef pCardInfo;
  24.    
  25.     HAL_SD_GetCardInfo(&hsd, &pCardInfo);
  26.    
  27.     *block_num  = pCardInfo.LogBlockNbr;
  28.     *block_size = pCardInfo.LogBlockSize;
  29.    
  30.     return (USBD_OK);
  31.   /* USER CODE END 10 */
  32. }

  33. /**
  34.   * @brief  .
  35.   * @param  lun: .
  36.   * @retval USBD_OK if all operations are OK else USBD_FAIL
  37.   */
  38. int8_t STORAGE_IsReady_HS(uint8_t lun)
  39. {
  40.   /* USER CODE BEGIN 11 */

  41.   if(HAL_SD_GetCardState(&hsd) == HAL_SD_CARD_TRANSFER)
  42.     return (USBD_OK);
  43.   else
  44.     return (USBD_FAIL);

  45.   /* USER CODE END 11 */
  46. }

  47. /**
  48.   * @brief  .
  49.   * @param  lun: .
  50.   * @retval USBD_OK if all operations are OK else USBD_FAIL
  51.   */
  52. int8_t STORAGE_IsWriteProtected_HS(uint8_t lun)
  53. {
  54.   /* USER CODE BEGIN 12 */
  55.   return (USBD_OK);
  56.   /* USER CODE END 12 */
  57. }

  58. /**
  59.   * @brief  .
  60.   * @param  lun: .
  61.   * @param  buf: .
  62.   * @param  blk_addr: .
  63.   * @param  blk_len: .
  64.   * @retval USBD_OK if all operations are OK else USBD_FAIL
  65.   */
  66. int8_t STORAGE_Read_HS(uint8_t lun, uint8_t *buf, uint32_t blk_addr, uint16_t blk_len)
  67. {
  68.   /* USER CODE BEGIN 13 */
  69.    
  70.     int8_t ret = USBD_FAIL;

  71.     if( HAL_SD_ReadBlocks_DMA(&hsd, buf, blk_addr, blk_len) == HAL_OK )
  72.     {
  73.         ret = USBD_OK;
  74.     }
  75.    
  76.     if( USBD_OK == ret )
  77.     {
  78.         while(HAL_SD_GetState(&hsd) == HAL_SD_STATE_BUSY){};
  79.         
  80.         while( HAL_SD_GetCardState(&hsd) != HAL_SD_CARD_TRANSFER ){};
  81.     }
  82.    
  83.     return ret;
  84.   
  85.   /* USER CODE END 13 */
  86. }

  87. /**
  88.   * @brief  .
  89.   * @param  lun: .
  90.   * @param  buf: .
  91.   * @param  blk_addr: .
  92.   * @param  blk_len: .
  93.   * @retval USBD_OK if all operations are OK else USBD_FAIL
  94.   */
  95. int8_t STORAGE_Write_HS(uint8_t lun, uint8_t *buf, uint32_t blk_addr, uint16_t blk_len)
  96. {
  97.   /* USER CODE BEGIN 14 */
  98.    
  99.     int8_t ret = USBD_FAIL;

  100.     if( HAL_SD_WriteBlocks_DMA(&hsd, buf, blk_addr, blk_len) == HAL_OK )
  101.     {
  102.         ret = USBD_OK;
  103.     }
  104.    
  105.     if( USBD_OK == ret )
  106.     {
  107.         while(HAL_SD_GetState(&hsd) == HAL_SD_STATE_BUSY){};
  108.         
  109.         while( HAL_SD_GetCardState(&hsd) != HAL_SD_CARD_TRANSFER ){};
  110.     }

  111.     return ret;
  112.    
  113.   /* USER CODE END 14 */
  114. }

  115. /**
  116.   * @brief  .
  117.   * @param  None
  118.   * @retval .
  119.   */
  120. int8_t STORAGE_GetMaxLun_HS(void)
  121. {
  122.   /* USER CODE BEGIN 15 */
  123.   return (STORAGE_LUN_NBR - 1);
  124.   /* USER CODE END 15 */
  125. }
复制代码

收藏 2 评论3 发布时间:2018-7-16 13:45

举报

3个回答
第109位梁山好汉 回答时间:2018-7-20 14:58:11
本帖最后由 第109位梁山好汉 于 2018-7-20 15:28 编辑

工程配置修改:
111.jpg 222.jpg

测试环境:
测试环境:
WIN10 USB2.0/USB3.0
闪迪 class10 sdio(24M) dma USBFS(usb3300)

读取速度:7.8~8.0MB
写入速度:4.5~6.0MB
333.jpg 444.jpg
eefishing 回答时间:2018-7-25 13:26:01
怎么解决的啊?可以分享下吗
第109位梁山好汉 回答时间:2018-7-27 18:05:54
eefishing 发表于 2018-7-25 13:26
怎么解决的啊?可以分享下吗

1 楼里面
关于意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
招聘信息
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
关注我们
st-img 微信公众号
st-img 手机版