S3C2440之UART操作(FIFO中斷模式)
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ā)了Rx
發(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
//初始化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;//中斷模式寄存器
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)測(cè)試可以完成功能。
本文引用地址:http://butianyuan.cn/article/201611/319134.htm
評(píng)論