本帖最后由 FSL_TICS_ZP 于 2014-3-6 09:21 编辑
小弟这两天配置DMA 程序如下
SIM->SCGC7|=SIM_SCGC7_DMA_MASK;
SIM->SCGC6|=SIM_SCGC6_DMAMUX_MASK;
SIM_ModuleClockSet(SIM_DMAMUX,ENABLE);
SIM_ModuleClockSet(SIM_DMA ,ENABLE);
DMA->DCHPRI1|=DMA_DCHPRI1_ECP_MASK |DMA_DCHPRI1_CHPRI(1);
DMA->TCD[1].NBYTES_MLNO=DMA_NBYTES_MLNO_NBYTES(1);
DMA->TCD[1].ATTR|=DMA_ATTR_DMOD(0)|DMA_ATTR_DSIZE(0)|DMA_ATTR_SSIZE(0)|DMA_ATTR_SMOD(0);
DMA->TCD[1].SADDR=(uint32_t)&(ADC0->R[0]);
DMA->TCD[1].SOFF=DMA_SOFF_SOFF(0);
DMA->TCD[1].DADDR=(uint32_t)&data;
DMA->TCD[1].DOFF=DMA_DOFF_DOFF(0);
DMA->TCD[1].SLAST=DMA_SLAST_SLAST(-4);
DMA->TCD[1].DLAST_SGA=DMA_DLAST_SGA_DLASTSGA(-4);
DMA->TCD[1].CSR=0;
DMA->TCD[1].CITER_ELINKNO=DMA_CITER_ELINKNO_CITER(4);
DMA->TCD[1].BITER_ELINKNO=DMA_BITER_ELINKNO_BITER(4);
// DMA->CR &=~DMA_CR_EMLM_MASK;
SIM_ModuleClockSet(SIM_DMAMUX,ENABLE);
DMAMUX->CHCFG[1]|=DMAMUX_CHCFG_SOURCE(40);
DMA->SERQ|=DMA_CERQ_CERQ(1);
DMAMUX->CHCFG[1]|=DMAMUX_CHCFG_ENBL_MASK;
用的是AD采样,DMA传输数据,,AD采样肯定没有问题,,但是DMA就是老是出错,无论我地址偏移和字节量怎么传输,DMA的ES寄存器总会出现800001c8
附上1c8的错误指示
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
谢谢指教啊,你说的对,但是主要问题不在这个,我中间试了好多值都不正确,官方手册上的值也试了就是不行,今天下午问题解决了,最主要的原因是在设置数据带宽时ATTR寄存器没有清零,我清了一下零后来问题就解决了,试了几个值,都对的,再一次表示感谢,嘿嘿
一周热门 更多>