新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > S3C2440之UART操作(FIFO中斷模式)

S3C2440之UART操作(FIFO中斷模式)

作者: 時間:2016-11-21 來源:網(wǎng)絡(luò) 收藏
關(guān)于串口的知識

3個獨立的串口,每一個都可以利用DMA

和中斷方式操作。每個包含2個64字節(jié)FIFO,一個接,一個發(fā)。

非FIFO模式相當(dāng)于FIFO模式的一個寄存器緩沖模式。

每一個UART有7種狀態(tài),overrun錯誤,校驗錯誤,幀錯誤,斷點,接收緩沖區(qū)準(zhǔn)備好,發(fā)送緩沖區(qū)為空,發(fā)送移位寄存器為空。

當(dāng)接收移位寄存器中的數(shù)據(jù)傳給FIFO的時候,且接收的數(shù)據(jù)觸發(fā)了RxFIFO的閥值,Rx中斷產(chǎn)生了。

發(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 = 0x7ff; //不加上拉電阻
//初始化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;//中斷模式寄存器
pISR_UART0 = (int)Uart0;//設(shè)中斷服務(wù)函數(shù)地址
rINTSUBMSK = ~(0x3); //打開UART0發(fā)送和接收中斷屏蔽
rINTMSK = ~(0x1<<28); //打開UART0中斷屏蔽
//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))
{
*ps++ = rURXH0;
}
data_is_ready = 1;
rSUBSRCPND = BIT_SUB_RXD0;
}
//發(fā)送中斷
else if(rSUBSRCPND & BIT_SUB_TXD0)
{
rINTSUBMSK |= BIT_SUB_TXD0;

while((!(rUFSTAT0&(1<<14))) && (*ps != r))
{
rUTXH0 = *ps++;
for(i=0; i<100;i++);
}


data_is_ready = 0;

rSUBSRCPND = BIT_SUB_TXD0;
}
rSRCPND = BIT_UART0;
rINTPND = BIT_UART0;
if(data_is_ready)
rINTSUBMSK &= ~(BIT_SUB_TXD0);
else
rINTSUBMSK &= ~(BIT_SUB_RXD0);
//rINTSUBMSK &= ~(BIT_SUB_TXD0);
}

經(jīng)測試可以完成功能。

本文引用地址:http://butianyuan.cn/article/201611/319134.htm



關(guān)鍵詞: S3C2440UART操作FIFO中斷模

評論


技術(shù)專區(qū)

關(guān)閉