S3C2440之UART操作(FIFO中斷模式)
3個獨立的串口,每一個都可以利用DMA
和中斷方式操作。每個包含2個64字節FIFO,一個接,一個發。
非FIFO模式相當于FIFO模式的一個寄存器緩沖模式。
每一個UART有7種狀態,overrun錯誤,校驗錯誤,幀錯誤,斷點,接收緩沖區準備好,發送緩沖區為空,發送移位寄存器為空。
當接收移位寄存器中的數據傳給FIFO的時候,且接收的數據觸發了Rx
發送器中FIFO的還未發得數據到達Tx FIFO閥值的時候,Tx中斷產生了。(我覺得應該理解為:發送器中FIFO發送結束,即為空的時候產生中斷。)
功能:在串口上輸入16字節,包括回車,然后會把輸入的字符回顯在串口終端上。
程序代碼:
//函數聲明
void Uart_init(void);
void int_init(void);
void __irq Uart0(void);
void Main(void);
//緩存
static unsigned char mywords[100] = {0,0};
static int data_is_ready = 0;
//初始化uart
void Uart_init(void)
{
//初始化引腳
rGPHCON = 0x00faaa;//把引腳設置為TXD0,和RXD0模式
rGPHUP
//初始化UART
rULCON0 = 0x03; //每次發送8位數據,一個停止位,無校驗,普通模式
rUCON0 = (0x05) | (1<<9);//設置接收和發送都是用中斷的方式
rUFCON0 = (0x3<<6) | (0x2<<4) | (0x01<<0); //使能FIFO,發送48字節,接收16字節
rUMCON0 = 0;
//設置時鐘頻率
rUBRDIV0 = 26;
void int_init(void)
{
rINTMOD=0x0;//中斷模式寄存器
rINTMSK = ~(0x1<<28);
//rSUBSRCPND=(BIT_SUB_TXD0);
}
void Main(void)
{
MMU_Init();
int_init();
Uart_init();
while(1);
}
//中斷處理函數
void __irq Uart0(void)
{
unsigned char *ps = mywords;
int i;
if(rSUBSRCPND & BIT_SUB_RXD0)
{
rINTSUBMSK |= BIT_SUB_RXD0;
while(((rUFSTAT0&0x1f)>0))
{
}
//發送中斷
else if(rSUBSRCPND & BIT_SUB_TXD0)
{
rINTSUBMSK |= BIT_SUB_TXD0;
}
經測試可以完成功能。
本文引用地址:http://www.104case.com/article/201611/319134.htm
評論