您好,登錄后才能下訂單哦!
現(xiàn)在開始編程。
先寫一個(gè)大的函數(shù):
void main(void)
{
uart_init();
uart_putc('a'); //發(fā)送數(shù)據(jù)
//uart_getc(); //接收數(shù)據(jù)
}
然后分別寫三個(gè)小的子函數(shù)
先在宏定義中聲明各個(gè)寄存器的地址,然后我們開始使用它們。
#define GPA0CON 0xE0200000
#define UCON0 0xE2900004
#define ULCON0 0xE2900000
#define UMCON0 0xE290000C
#define UFCON0 0xE2900008
#define UBRDIV0 0xE2900028
#define UDIVSLOT0 0xE290002C
#define UTRSTAT0 0xE2900010
#define UTXH0 0xE2900020
#define URXH0 0xE2900024
//下面是串口初始化程序
void uart_init(void)
{
//首先先選擇GPA0CON控制寄存器,這個(gè)寄存器的作用是把IO口設(shè)置為串口模式
//先把這個(gè)寄存器的bit0~bit7清除,再寫入0x22,則Rx Tx就設(shè)置成功了。
(*(volatile unsigned int *)GPA0CON) &= ~(0xff<<0);
(*(volatile unsigned int *)GPA0CON) |= 0x00000022;
//然后就是根據(jù)上一章講的,我們來設(shè)置ULCON:設(shè)置串口的數(shù)據(jù)位,校驗(yàn)位和停止位
//這個(gè)寄存器的[31:7] 沒有功能,這里寫0x3的意思是:
//[1:0] 為11表示八位數(shù)據(jù)位,[2] 為0表示一位停止位,[5:3] 為0表示不需要校驗(yàn)位,
//[6] 為0表示正常模式(若選擇1則表示紅外模式);
(*(volatile unsigned int *)ULCON0) = 0x3;
//然后我們再設(shè)置UCONn寄存器
//這個(gè)寄存器的[1:0] 為01,表示中斷請求或者輪詢方式,[3:2] 為01,表示中斷請求或者輪詢方式
//[10]設(shè)置0,選擇PCLK為時(shí)鐘來源。剩下很多與中斷有關(guān)的位我們先不需要管,畢竟我們用串口來做實(shí)驗(yàn),
//不需要中斷,不斷來回檢查就行了。
(*(volatile unsigned int *)UCON0) = 0x5;
//我們不使用流控,所以直接讓UMCON全都為0,禁止掉。
(*(volatile unsigned int *)UMCON0) =0;
//我們不使用FIFO模式,所以同樣把它們都設(shè)置為0就可以了。
(*(volatile unsigned int *)UFCON0) =0;
//然后就要計(jì)算配置波特率了
//PCLK_PSYS通過時(shí)鐘系統(tǒng)分析為66.7MHz
//DIV_VAL = (66700000/(115200*16)-1) = 35.18,余數(shù)0.18
(*(volatile unsigned int *)UBRDIV0) = 35;
//(rUDIVSLOT中的1的個(gè)數(shù) = 16*0.18= 2.88 = 3
//然后查閱手冊,得知為0x888
(*(volatile unsigned int *)UDIVSLOT0) = 0x0888;
}
初始化完成了,現(xiàn)在開始寫發(fā)送程序。
void uart_putc(char c)
{
//與uart功能有關(guān)的狀態(tài)寄存器,記錄了發(fā)送數(shù)據(jù)是否完成
//這個(gè)寄存器的bit3~bit31都沒有功能,
//第bit2是transmitter empty位,發(fā)送緩沖器里面沒有可供發(fā)送的數(shù)據(jù)的時(shí)候置1,有的話置0
//bit1位是如果有數(shù)據(jù)進(jìn)入緩沖區(qū)則硬件自動(dòng)置0,如果進(jìn)入的數(shù)據(jù)被發(fā)送了出去,硬件再自動(dòng)置一
//FIFO就是在發(fā)送器里面存一大堆數(shù)據(jù),所以對于FIFO模式下,檢測每次發(fā)送的數(shù)據(jù)是否發(fā)送了只能用
//檢測bit1的方法,對于不使用FIFO模式來說,一次只發(fā)送一幀數(shù)據(jù),而且都存在發(fā)送器里面,因此
//檢測bit2和bit1都可以使用。
//首先一直循環(huán)檢測,直到置1的時(shí)候,才能發(fā)送第二幀數(shù)據(jù)。
//
//bit0表示的是接收區(qū)的置位狀態(tài)
while (!((*(volatile unsigned int *)UTRSTAT0) & (1<<1)));
(*(volatile unsigned int *)UTXH0) = c;
}
//會(huì)寫發(fā)送程序以后,接收程序就簡單多了。
char uart_getc(void)
{
while (!((*(volatile unsigned int *)UTRSTAT0) & (1<<0)));
return (*(volatile unsigned int *)URXH0);
}
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。