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