dma.c

来自「it is a sample code for s3c2410 board.」· C语言 代码 · 共 82 行

C
82
字号
#include "4510addr.h"
#include "dma.h"

int uart_tx_gdma_finish = 0;
int uart_rx_gdma_finish = 0;

/*************************************************
* enable GDMA0
**************************************************/
void EnableGDMA0(void)
{
	uart_tx_gdma_finish = 0;
	GDMA0_RUN_ENABLE = 1;
}

/*************************************************
* enable GDMA1 
**************************************************/
void EnableGDMA1(void)
{
	uart_rx_gdma_finish = 0;
	GDMA1_RUN_ENABLE = 1;
}

/*************************************************
* GDMA0 transmit setting
* mode = MEM to UART
**************************************************/
void GDMA0_TX(char *buf, int len)
{
	GDMACON0 = GDMA_INT_ENABLE | GDMA_U0MODE | GDMA_MEM2UART | GDMA_DST_FIX | GDMA_TX_BYTE;
	GDMASRC0 = (unsigned long)(void*)buf;
	GDMACNT0 = len;
}

/*************************************************
* GDMA1 receive setting
* mode = UART to MEM
**************************************************/
void GDMA1_RX(char *buf, int len)
{
	GDMACON1 = GDMA_INT_ENABLE | GDMA_U0MODE | GDMA_SRC_FIX | GDMA_TX_BYTE;
	GDMADST1 = (unsigned long)(void*)buf;
	GDMACNT1 = len;
}


/*************************************************
* DMA0 interrupt handler
**************************************************/
void UART_TX_DMA(void)
{
	uart_tx_gdma_finish = 1;
	ClearPending(BIT_GDMA0);	
}

/*************************************************
* DMA1 interrupt handler
**************************************************/
void UART_RX_DMA(void)
{
	uart_rx_gdma_finish = 1;
	ClearPending(BIT_GDMA1);	
}

/*************************************************
* chack DMA Rx is finish
**************************************************/
int UART_RX_DMA_Finish(void)
{
	return uart_rx_gdma_finish;
}

/*************************************************
* check DMA Tx is finish
**************************************************/
int UART_TX_DMA_Finish(void)
{
	return uart_tx_gdma_finish;
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?