/**
* \file csl_dma_IntcExample.c
* \brief Test for all the channel in interrupt mode.
*/
#include "csl_dma.h"
#include "csl_intc.h"
#include <stdio.h>
#define CSL_DMA_BUFFER_SIZE 1024
/* Reference the start of the interrupt vector table */
extern void VECSTART(void);
/* Protype declaration for ISR function */
interrupt void dma_isr(void);
/* Declaration of the buffer */
Uint16 dmaSRCBuff[CSL_DMA_BUFFER_SIZE];
Uint16 dmaDESTBuff[CSL_DMA_BUFFER_SIZE];
static int count ;
static int isrEntryCount;
CSL_DMA_Handle dmaHandle;
CSL_DMA_Config dmaConfig;
CSL_DMA_Config getdmaConfig;
void main(void)
{
CSL_DMA_ChannelObj dmaObj;
CSL_Status status;
Uint16 chanNumber;
Uint16 i;
for(i = 0; i< CSL_DMA_BUFFER_SIZE; i++)
{
//dmaSRCBuff[i] = 0xFFFF;
dmaSRCBuff[i] = i;
dmaDESTBuff[i] = 0x0000;
}
dmaConfig.autoMode = CSL_DMA_AUTORELOAD_DISABLE;
dmaConfig.burstLen = CSL_DMA_TXBURST_8WORD;
dmaConfig.trigger = CSL_DMA_SOFTWARE_TRIGGER;
dmaConfig.dmaEvt = CSL_DMA_EVT_NONE;
dmaConfig.dmaInt = CSL_DMA_INTERRUPT_ENABLE;
dmaConfig.chanDir = CSL_DMA_READ;
dmaConfig.trfType = CSL_DMA_TRANSFER_MEMORY;
dmaConfig.dataLen = CSL_DMA_BUFFER_SIZE * 2;
dmaConfig.srcAddr = (Uint32)dmaSRCBuff;
dmaConfig.destAddr = (Uint32)dmaDESTBuff;
IRQ_globalDisable();
IRQ_setVecs((Uint32)&VECSTART);
IRQ_clear(DMA_EVENT);
IRQ_plug (DMA_EVENT, &dma_isr);
IRQ_enable(DMA_EVENT);
IRQ_globalEnable();
status = DMA_init();
if (status != CSL_SOK)
{
printf("DMA_init() Failed \n");
}
for( chanNumber = 0; chanNumber < CSL_DMA_CHAN_MAX; chanNumber++)
{
count = 0;
printf("\n Test for DMA Channel No : %d \t", chanNumber);
dmaHandle = DMA_open((CSL_DMAChanNum)chanNumber,&dmaObj, &status);
if (dmaHandle == NULL)
{
printf("DMA_open() Failed \n");
break;
}
status = DMA_config(dmaHandle, &dmaConfig);
if (status != CSL_SOK)
{
printf("DMA_config() Failed \n");
break;
}
status = DMA_getConfig(dmaHandle, &getdmaConfig);
if (status != CSL_SOK)
{
printf("DMA_getConfig() Failed \n");
break;
}
status = DMA_start(dmaHandle);
if (status != CSL_SOK)
{
printf("DMA_start() Failed \n");
break;
}
while(count != 1);;
status = DMA_close(dmaHandle);
if (status != CSL_SOK)
{
printf("DMA_close() Failed \n");
break;
}
status = DMA_reset(dmaHandle);
if (status != CSL_SOK)
{
printf("DMA_reset() Failed \n");
break;
}
/* validation for set and get config parameter */
if((dmaConfig.autoMode) != (getdmaConfig.autoMode))
{
printf("Mode not matched\n");
}
if(((dmaConfig.burstLen) != (getdmaConfig.burstLen)))
{
printf("Burst length not matched\n");
}
if(((dmaConfig.trigger) != (getdmaConfig.trigger)))
{
printf("Triger type not matched\n");
}
if(((dmaConfig.dmaEvt) != (getdmaConfig.dmaEvt)) )
{
printf("Event not matched\n");
}
if(((dmaConfig.dmaInt) != (getdmaConfig.dmaInt)))
{
printf("Interrupt state not matched\n");
}
if(((dmaConfig.chanDir) != (getdmaConfig.chanDir)))
{
printf("Direction read or write not matched\n");
}
if(((dmaConfig.trfType) != (getdmaConfig.trfType)))
{
printf("Transfer type not matched\n");
}
if(((dmaConfig.dataLen) != (getdmaConfig.dataLen)))
{
printf("data length of transfer not matched\n");
}
if(((dmaConfig.srcAddr) != (getdmaConfig.srcAddr)))
{
printf("Source address not matched\n");
}
if(((dmaConfig.destAddr) != (getdmaConfig.destAddr)))
{
printf("Destination address not matched\n");
}
for(i = 0; i < CSL_DMA_BUFFER_SIZE; i ++)
{
if(dmaSRCBuff[i] != dmaDESTBuff[i])
{
printf("Buffer miss matched at position %d\n",i);
break;
}
}
if(i == CSL_DMA_BUFFER_SIZE)
{
printf("Success");
}
for(i = 0; i < CSL_DMA_BUFFER_SIZE; i++)
{
dmaSRCBuff[i] = 0xFFFF;
dmaDESTBuff[i] = 0x0000;
}
}
if(isrEntryCount == 16)
{
printf("\n\n\t Test of DMA Interrupt mode Passed:\n");
}
else
{
printf("\n\n\t Test of DMA Interrupt mode Failed:\n");
}
}
interrupt void dma_isr(void)
{
int ifrValue;
ifrValue = CSL_SYSCTRL_REGS->DMAIFR;
CSL_SYSCTRL_REGS->DMAIFR |= ifrValue;
++count;
++isrEntryCount;
}
没有合适的资源?快使用搜索试试~ 我知道了~
dma.rar_The Chip_c5505_dsp dma
共9个文件
pjt:3个
c:3个
cmd:3个
1.该资源内容由用户上传,如若侵权请联系客服进行举报
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
版权申诉
0 下载量 8 浏览量
2022-09-23
08:46:13
上传
评论
收藏 7KB RAR 举报
温馨提示
Chip Support Library for C5505, the newest DSP in C55xx family. This includes sample code for the DMA
资源推荐
资源详情
资源评论
收起资源包目录
dma.rar (9个子文件)
dma
example2
VC5505_DMA.cmd 805B
csl_dma_IntcExample.c 5KB
CSL_DMA_IntcExample.pjt 1KB
example3
CSL_DMA_StopAPIExample.pjt 1KB
VC5505_DMA.cmd 805B
csl_dma_StopAPIExample.c 4KB
example1
VC5505_DMA.cmd 805B
CSL_DMA_PollExample.pjt 1KB
csl_dma_PollExample.c 4KB
共 9 条
- 1
资源评论
林当时
- 粉丝: 100
- 资源: 1万+
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功