📄 c54dma.c
字号:
/********************************************************************************
*sx2.C v1.00 *
* 描述:完成对USB控制器CY7C68001的各项功能的控制 *
* 版权(c) 2003- 北京合众达电子技术有限责任公司 *
* 设计者: 段立锋 *
*********************************************************************************/
#include "type.h"
#include "dma54xx.h"
/*声明中断dma的函数,用于dma的中断处理*/
#pragma INTERRUPT(dma0_isr);
/*声明中断dma的函数,用于dma的中断处理*/
#pragma INTERRUPT(dma1_isr);
BOOL buffer_halffull = FALSE;
BOOL buffer_full = FALSE;
BOOL buffer_halffull1 = FALSE;
BOOL buffer_full1 = FALSE;
unsigned int dma_count = 0;
unsigned int dma_count1 = 0;
/******************************************************************************/
/* dma_init - Initialize channel specific control registers. */
/* */
/* This function is responsible for setting the DMA control registers, */
/* source address, destination address and the corresponding pages */
/* transfer count for the specified DMA channel. */
/* */
/******************************************************************************/
void dma_init(
unsigned int channel /*IN: DMA channel number */
,unsigned int dmsefc /*IN: Value to set sync & fr reg */
,unsigned int dmmcr /*IN: Value to set mode control reg */
,unsigned int dmctr /*IN: Value to set element count reg */
,unsigned int src_page /*IN: Value to set source page reg */
,unsigned int src_addr /*IN: Value to set source addr reg */
,unsigned int dst_page /*IN: Value to set dest page reg */
,unsigned int dst_addr /*IN: Value to set dest addr reg */
)
{
DMA_SUBREG_WRITE(channel, DMSRC_SUBADDR, src_addr);
REG_WRITE(DMSAI_ADDR, dst_addr);
REG_WRITE(DMSAI_ADDR, dmctr);
REG_WRITE(DMSAI_ADDR, dmsefc);
REG_WRITE(DMSAI_ADDR, dmmcr);
DMA_SUBREG_WRITE(channel, DMSRCP_SUBADDR, src_page);
REG_WRITE(DMSAI, dst_page);
}
/******************************************************************************/
/* dma_global_init - Initialize global control registers. */
/* */
/* This function is responsible for setting the DMA global control */
/* registers */
/* Notice: DMDSTP and DMSRCP are used in DMA_GLOBAL_INIT and DMA_INIT */
/* necessity should be reconsidered */
/******************************************************************************/
void dma_global_init(
unsigned int dmpre /*IN:Value for priority and enable reg*/
,unsigned int dmsrcp /*IN:Value for source page reg */
,unsigned int dmdstp /*IN:Value for dest page reg */
,unsigned int dmidx0 /*IN:Value for element index reg 0 */
,unsigned int dmidx1 /*IN:Value for element index reg 1 */
,unsigned int dmfri0 /*IN:Value for frame index reg 0 */
,unsigned int dmfri1 /*IN:Value for frame index reg 1 */
,unsigned int dmgsa /*IN:Value for global src addr reload */
,unsigned int dmgda /*IN:Value for global dst addr reload */
,unsigned int dmgcr /*IN:Value for global count reload reg*/
,unsigned int dmgfr) /*IN:Value for global frame reload reg*/
{
REG_WRITE(DMPRE_ADDR, dmpre);
DMA_SUBREG_WRITE(0, DMSRCP_SUBADDR, dmsrcp);
REG_WRITE(DMSAI_ADDR, dmdstp);
REG_WRITE(DMSAI_ADDR, dmidx0);
REG_WRITE(DMSAI_ADDR, dmidx1);
REG_WRITE(DMSAI_ADDR, dmfri0);
REG_WRITE(DMSAI_ADDR, dmfri1);
REG_WRITE(DMSAI_ADDR, dmgsa);
REG_WRITE(DMSAI_ADDR, dmgda);
REG_WRITE(DMSAI_ADDR, dmgcr);
REG_WRITE(DMSAI_ADDR, dmgfr);
}
void dma_reset_all( void )
{
int channel;
REG_WRITE(DMPRE_ADDR, 0x00);
for (channel= 0;channel < 5; channel++)
{
DMA_SUBREG_WRITE(channel, DMSRC_SUBADDR, 0x00);
REG_WRITE(DMSAI_ADDR, 0x00); //src
REG_WRITE(DMSAI_ADDR, 0x00); //dst
REG_WRITE(DMSAI_ADDR, 0x00); //ctr
REG_WRITE(DMSAI_ADDR, 0x00); //sefc
REG_WRITE(DMSAI_ADDR, 0x00); //mcr
}
DMA_SUBREG_WRITE(channel, DMSRCP_SUBADDR, 0x00);
REG_WRITE(DMSAI_ADDR, 0x00); /*DMDSTP*/
REG_WRITE(DMSAI_ADDR, 0x00); /*DMIDX0*/
REG_WRITE(DMSAI_ADDR, 0x00); /*DMIDX1*/
REG_WRITE(DMSAI_ADDR, 0x00); /*DMFRI0*/
REG_WRITE(DMSAI_ADDR, 0x00); /*DMFRI1*/
REG_WRITE(DMSAI_ADDR, 0x00); /*DMGSA*/
REG_WRITE(DMSAI_ADDR, 0x00); /*DMGDA*/
REG_WRITE(DMSAI_ADDR, 0x00); /*DMGCR*/
REG_WRITE(DMSAI_ADDR, 0x00); /*DMGRF*/
}
void dma_reset( unsigned int channel )
{
RESET_BIT(DMPRE_ADDR, channel); //disable channel
RESET_BIT(DMPRE_ADDR, channel+8); //set priority low
DMA_SUBREG_WRITE(channel, DMSRC_SUBADDR, 0x00);
REG_WRITE(DMSAI_ADDR, 0x00); //src
REG_WRITE(DMSAI_ADDR, 0x00); //dst
REG_WRITE(DMSAI_ADDR, 0x00); //ctr
REG_WRITE(DMSAI_ADDR, 0x00); //sefc
REG_WRITE(DMSAI_ADDR, 0x00); //mcr
}
void dma0_isr()
{
dma_count = dma_count +1;
if(dma_count & 0x1)
{
buffer_halffull = TRUE;
}
else
{
buffer_full = TRUE;
}
}
void dma1_isr()
{
dma_count1 = dma_count1 +1;
if(dma_count & 0x1)
{
buffer_halffull1 = TRUE;
}
else
{
buffer_full1 = TRUE;
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -