OpenEdv-开源电子网

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

SDIO+DMA 单步运行可实现功能,全速运行跑飞

[复制链接]

1

主题

2

帖子

0

精华

新手入门

积分
26
金钱
26
注册时间
2014-8-27
在线时间
0 小时
发表于 2014-8-29 17:46:00 | 显示全部楼层 |阅读模式
5金钱
SDIO +DMA 写入实验  芯片是 207VG  板子是自己画的 内存只有128K
例程用的是原子哥的SDIO + DMA例程
自己移植了一下 FAT32 文件系统
SDIO 轮询方式能正常读写.

DMA出初始化因为芯片不同 自己改了一下
[mw_shl_code=c,true]DMA2->HIFCR |=0x03D<<16; /* Clear all IRQs */ DMA2_Stream6->CR &=0x00000000; DMA2_Stream6->CR &= ~0x01; /* Disable stream 3 */ DMA2_Stream6->AR = (u32)&(SDIO->FIFO); DMA2_Stream6->M0AR = (u32)mbuf; DMA2_Stream6->NDTR = bufsize/4; DMA2_Stream6->FCR |= (1 << 2) | /* Disable direct mode */ (3 << 0) ; /* FIFO threshold full */ if (dir == 0) { /* Transfer from SDIO-FIFO to memory. */ DMA2_Stream6->CR = (4 << 25) | /* Use channel 4 */ (1 << 23) | /* Memory burst 4 beats */ (1 << 21) | /* Peripheral burst 4 beats */ (3 << 16) | /* Priority level high */ (2 << 13) | /* Memory size 32-bits */ (2 << 11) | /* Peripheral size 32-bits */ (1 << 10) | /* Memory addr increment */ (1 << 5) ; /* Peripheral flow control */ } else { /* Transfer from memory to SDIO-FIFO. */ DMA2_Stream6->CR = (4 << 25) | /* Use channel 4 */ (1 << 23) | /* Memory burst 4 beats */ (1 << 21) | /* Peripheral burst 4 beats */ (3 << 16) | /* Priority level very high */ (2 << 13) | /* Memory size 32-bits */ (2 << 11) | /* Peripheral size 32-bits */ (1 << 10) | /* Memory addr increment */ (1 << 6) | /* Memory-to-peripheral */ (1 << 5) ; /* Peripheral flow control */ } /* Enable DMA channels, little endian */ DMA2_Stream6->CR |= 0x01; /* Enable stream 3 */ [/mw_shl_code]
(1)在WriteBlock函数中的DMA模式中 开启DMA 使能后(SDIO->DCTRL=1<<3)后面在查询卡是否正在写的函数 IsCardProgramming(&cardstate)  中的发送 CMD13程序跑飞了,但是单步运行却能 继续走下去,而且用WinHex看卡,数据也写入了。
(2)一开始以为是时序问题,就加了些While 循环,最后发现,在开启DMA使能后的 While循环就跑飞了。
(3)再观察SDIO->STA=0x0500 代表 data end 但是却没进入 SDIO的中断处理函数,也就是TransferEnd 一直=0。观察 DMA2_HISR=0x00210000  查手册 代表 data end 及A FIFO erro event occurred on stream6  但却不知道 是什么FIFO erro。
(5)期间我把硬件控制流打开了,没有变化。
(4)然后发现 这个板子的SDIO->CR [5] 是开启peripheral flow controller ,我尝试关闭后,发现  DMA2_HISR=0x00110000  表示发生了A half transfer event occur on strem6这个half transfer event 是什么意思? 代码如下
[mw_shl_code=c,true]}else if(DeviceMode==SD_DMA_MODE) { TransferError=SD_OK; StopCondition=0; TransferEnd=0; SDIO->MASK|=(1<<1)|(1<<3)|(1<<8)|(1<<4)|(1<<9); SD_DMA_Config((u32*)buf,blksize,1); abc=10000; while(abc!=0) abc--; SDIO->DCTRL|=1<<3; abc=10000; while(abc!=0) abc--; timeout=SDIO_DATATIMEOUT; while(((DMA2->HISR&0x00200000)==RESET)&&timeout)timeout--;//等待传输完成 if(timeout==0) { SD_Init(); //重新初始化SD卡,可以解决写入死机的问题 return SD_DATA_TIMEOUT; //超时 } timeout=SDIO_DATATIMEOUT; while((TransferEnd==0)&&(TransferError==SD_OK)&&timeout)timeout--; if(timeout==0)return SD_DATA_TIMEOUT; //超时 if(TransferError!=SD_OK)return TransferError; } SDIO->ICR=0X5FF; //清除所有标记 errorstatus=IsCardProgramming(&cardstate); while((errorstatus==SD_OK)&&((cardstate==SD_CARD_PROGRAMMING)||(cardstate==SD_CARD_RECEIVING))) { errorstatus=IsCardProgramming(&cardstate); } return errorstatus; }[/mw_shl_code]
说了这么多,我想问的是,这个历程 单步运行 能写入 但全速运行 跑飞 的原因 大概可能出在哪里,搞了好几天。
如果是 时钟问题,请问可能是哪里的时钟问题?
DMA CLK为18Mhz
先在这里谢谢了

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

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2014-8-29 23:24:44 | 显示全部楼层
STM32的DMA SDIO模式,貌似如果还有其他DMA存在,可能会有问题,这个问题我也碰到过.
单独测试DMA SDIO,可以.但是如果还有其他DMA,那么可能就会出问题了.
我现在都是用查询模式.这个就基本可以兼容所有应用了.
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

1

主题

2

帖子

0

精华

新手入门

积分
26
金钱
26
注册时间
2014-8-27
在线时间
0 小时
 楼主| 发表于 2014-9-1 15:18:20 | 显示全部楼层
回复【2楼】正点原子:
---------------------------------
请问原子个,你的例程中write block是在哪一步 进入了 SDIO_IRQHandler 的 我的例程始终没进入SDIO中断处理函数
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2014-9-1 23:05:52 | 显示全部楼层
回复【3楼】愤怒的大烧饼:
---------------------------------
请看源码。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-7-1 21:06

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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