cortex m0 lpc1114 串口uart查詢收發(fā)數(shù)據(jù)
LPC1114有一個串口,具備標(biāo)準(zhǔn)9針串口的所有功能引腳:
RXD、TXD、RTS、CTS、DTR、DSR、DCD、IR
一般情況下,我們只用到RXD和TXD。在這一章,只對RXD和TXD的使用做介紹。
可以用于程序下載。
可以設(shè)置奇校驗、偶校驗、無校驗。
可以設(shè)置數(shù)據(jù)位為5~8,可以設(shè)置停止位為1、1.5、2。
具有自動波特率檢測功能。
查詢方式串口收發(fā)數(shù)據(jù)
新建一個工程,結(jié)構(gòu)如下圖所示:
在uart.h文件中,輸入以下代碼:
#ifndef __NXPLPC11XX_UART_H__
#define __NXPLPC11XX_UART_H__
extern uint8_t Recived_data;
extern void UART_init(uint32_t baudrate);
extern uint8_t UART_recive(void);
extern void UART_send_byte(uint8_t byte);
extern void UART_send(uint8_t *Buffer, uint32_t Length);
#endif
在uart.c文件中,輸入以下代碼:
#include “l(fā)pc11xx.h”
#include “uart.h”
void UART_init(uint32_t baudrate)
{
uint32_t DL_value,Clear=Clear; // (用這種方式定義變量解決編譯器的Warning)
LPC_SYSCON->SYSAHBCLKCTRL |= (1<<16); // 使能IOCON時鐘
LPC_IOCON->PIO1_6 &= ~0x07;
LPC_IOCON->PIO1_6 |= 0x01; //把P1.6腳設(shè)置為RXD
LPC_IOCON->PIO1_7 &= ~0x07;
LPC_IOCON->PIO1_7 |= 0x01; //把P1.7腳設(shè)置為TXD
LPC_SYSCON->SYSAHBCLKCTRL &= ~(1<<16); // 禁能IOCON時鐘
LPC_SYSCON->UARTCLKDIV = 0x1; //時鐘分頻值為1
LPC_SYSCON->SYSAHBCLKCTRL |= (1<<12);//允許UART時鐘
LPC_UART->LCR = 0x83; //8位傳輸,1個停止位,無幾偶校驗,允許訪問除數(shù)鎖存器
DL_value = SystemCoreClock/16/baudrate ; //計算該波特率要求的除數(shù)鎖存寄存器值
LPC_UART->DLM = DL_value / 256; //寫除數(shù)鎖存器高位值
LPC_UART->DLL = DL_value % 256; //寫除數(shù)鎖存器低位值
LPC_UART->LCR = 0x03; //DLAB置0
LPC_UART->FCR = 0x07; //允許FIFO,清空RxFIFO 和 TxFIFO
Clear = LPC_UART->LSR; //讀UART狀態(tài)寄存器將清空殘留狀態(tài)
}
uint8_t UART_recive(void)
{
while(!(LPC_UART->LSR & (1<<0)));//等待接收到數(shù)據(jù)
return(LPC_UART->RBR); //讀出數(shù)據(jù)
}
void UART_send_byte(uint8_t byte)
{
LPC_UART->THR = byte;
while ( !(LPC_UART->LSR & (1<<5)) );//等待發(fā)送完
}
第3~21行,定義了串口初始化函數(shù)。
第22~26行,定義了串口接收函數(shù)。
第27~31行,定義了串口發(fā)送函數(shù)。
第5行,定義兩個變量:DL_value和Clear。DL_value記錄波特率鎖存器值,Clear用于清空UART狀態(tài)寄存器。如果只是寫成uint32_t Clear,當(dāng)你編譯的時候,將會產(chǎn)生一個提醒:variable“Clear”was set but never used.而寫成uint32_t Clear=Clear就會排除這個提示,當(dāng)然,不排除這個提醒也不會影響程序的正常執(zhí)行。
第6~11行,把P1.6和P1.7所在引腳配置為RXD TXD。
第14行,設(shè)置串口的協(xié)議,并開啟除數(shù)鎖存器的訪問允許。因為接下來我們要給除數(shù)鎖存器寫值配置串口波特率了。
第15行,計算波特率值。公式詳見官方數(shù)據(jù)手冊。
第16、17行,寫鎖存器值。
第18行,關(guān)閉鎖存器配置允許。
第19行,清空串口收發(fā)FIFO。
第20行,清空串口狀態(tài)寄存器。
第19和20行,都是為了保證串口的正常通信數(shù)據(jù)采集正確。
第24行,檢測LSR寄存器的bit0,看是否接收到數(shù)據(jù)。
第25行,返回接收到的數(shù)據(jù)。
第29行,把要發(fā)送的數(shù)據(jù)給了THR寄存器。
第30行,檢測LSR寄存器bit5,看是否發(fā)送完數(shù)據(jù)。
從接收和發(fā)送函數(shù),可以看出,收到的數(shù)據(jù)(RBR)和發(fā)送的數(shù)據(jù)(THR)保存在不同的寄存器。這一點,和普通51以及STM32是有區(qū)別的。例如,普通51單片機的收發(fā)數(shù)據(jù)都用SBUF,STM32收發(fā)數(shù)據(jù)都用DR。
在main.c文件中,輸入以下代碼:
#include “l(fā)pc11xx.h”
#include “uart.h”
void delay(void)//
{
uint16_t i,j;
for(i=0;i<5000;i++)
for(j=0;j<1000;j++);
}
int main()
{
uint8_t rec_buf;
UART_init(9600); // 把串口波特率配置為9600
while(1)
{
rec_buf = UART_recive(); // 從串口接收字符
UART_send_byte(rec_buf); // 把接收到的字節(jié)發(fā)回串口
}
}
主函數(shù)實現(xiàn)的功能是,把接收的數(shù)據(jù)再發(fā)回去。打開串口調(diào)試助手,波特率配置為9600,選擇ASCII字符發(fā)送,不管發(fā)送什么字符,都會把發(fā)送的字符返回串口調(diào)試助手顯示。從而實現(xiàn)了串口的收發(fā)功能。