52單片機串口中斷知識
2、帶有USART的單片機里USART一般都是做為“外部設備”,獨立于MCU進行收發工作,即其收發過程中的串-并和并-串轉換以及數據IO過程都是“自主”和“自動”的,不需要CPU逐位進行收發處理,因此,在CPU將數據送到SBUF后,便可以放手不管了,USART收發器會自動將SBUF的內容轉換成串行數據發送出去。接收時也是由USART將串行數據轉成并行數據并存放到SBUF后才會通知MCU(產生接收中斷)。MCU所需要做的只是往SBUF送數或從SBUF中取數(都只要1個指令周期)。
3、設置串口參數的時候應該能看出,為了適應串口的慢,不得不動用定時器進行延時,以“產生”所需要的波特率,而這個“延時”通常都要給8位甚至16位定時器設置初值,定時器每一次計數都需要一個指令周期,即CPU可以執行一條指令的時間,而定時器兩次串口溢出才僅僅接收或發送一個“位”,接收一個字節需要數倍于此的時間,那么這么長的時間對CPU來說,足以從容地從SBUF里取出數據并對其進行處理了。
4、即使CPU的任務相當繁重,或對接收到的每個字節都需要進行相當復雜的處理,我們也完全可以通過建立接收緩沖區的方式將暫時來不及處理的數據暫存起來,等CPU空閑時再做處理。而從SBUF取出數據并保存到緩沖區只需要很少的幾條指令就能完成,不會影響到串口繼續接收。
5、標準的RS-232協議并非只有TX、RX和GND三個引腳,即便是最簡單的9針插口,也專門設計了檢測傳輸狀態和收發請求的針腳。如果單片機真的實在無法及時完成收發動作,也完全可以利用一個口線作為狀態標識,使PC能夠知道單片機什么時候可以接收數據,而不會任由數據丟失。
6、為了增加數據傳輸的可靠性,大量數據傳輸時通常都會采用CRC校驗方式,并以“包”或“幀”的方式發送有格式約定的字節流,而非單個字符,這樣一來,完全可以通過約定一些“通信協議”的方式,使收發雙方都能夠及時知道接收的數據是否完整,并及時重發新發送出錯的數據。
# include
#include
typedef unsigned char unchar ;
unsigned char ch;
bit read_flag= 0 ;
void init_serialcom( void ) //串口通信初始設定
{
SCON = 0x50 ; //UART為模式1,8位數據,允許接收
TMOD = 0x20 ; //定時器1為模式2,8位自動重裝
PCON = 0x80 ; //SMOD=1;
TH1 = 0xFD ; //Baud:19200 fosc="11".0592MHz
TL1 = 0xFD ;
IE = 0x90 ; //Enable Serial Interrupt
TR1 = 1 ; // timer 1 run
// TI=1;
}
//向串口發送一個字符
void send_char_com( unchar ch)
{
SBUF=ch;
while (TI== 0);
TI= 0 ;
}
//串口接收中斷函數 功能:串口中斷。如果有數據從串口發送過來,首先從串口中讀出數據,賦給串口緩沖數組,清中斷標志(RI和TI中有一個為1就會馬上進入中斷服務子程序)
void serial () interrupt 4 using 3
{
if (RI)
{
RI = 0 ;
ch=SBUF;
read_flag= 1 ; //就置位取數標志
}
}
void main()
{
init_serialcom(); //初始化串口
while ( 1 )
{
if (read_flag) //如果取數標志已置位,就將讀到的數從串口發出
{
read_flag= 0 ; //取數標志清0
send_char_com(ch);
}
}
}


評論