新聞中心

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

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

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

3個(gè)獨(dú)立的串口,每一個(gè)都可以利用DMA

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

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

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

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

發(fā)送器中FIFO的還未發(fā)得數(shù)據(jù)到達(dá)Tx FIFO閥值的時(shí)候,Tx中斷產(chǎn)生了。(我覺(jué)得應(yīng)該理解為:發(fā)送器中FIFO發(fā)送結(jié)束,即為空的時(shí)候產(chǎn)生中斷。)


功能:在串口上輸入16字節(jié),包括回車,然后會(huì)把輸入的字符回顯在串口終端上。


程序代碼:

//函數(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è)置為T(mén)XD0,和RXD0模式
rGPHUP = 0x7ff; //不加上拉電阻
//初始化UART
rULCON0 = 0x03; //每次發(fā)送8位數(shù)據(jù),一個(gè)停止位,無(wú)校驗(yàn),普通模式
rUCON0 = (0x05) | (1<<9);//設(shè)置接收和發(fā)送都是用中斷的方式
rUFCON0 = (0x3<<6) | (0x2<<4) | (0x01<<0); //使能FIFO,發(fā)送48字節(jié),接收16字節(jié)
rUMCON0 = 0;
//設(shè)置時(shí)鐘頻率
rUBRDIV0 = 26;
}
//初始化中斷
void int_init(void)
{
rINTMOD=0x0;//中斷模式寄存器
pISR_UART0 = (int)Uart0;//設(shè)中斷服務(wù)函數(shù)地址
rINTSUBMSK = ~(0x3); //打開(kāi)UART0發(fā)送和接收中斷屏蔽
rINTMSK = ~(0x1<<28); //打開(kāi)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)測(cè)試可以完成功能。

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



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

評(píng)論


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

關(guān)閉