A. 在知道單片機振盪頻率和波特率的情況下如何計算計數初值
這涉及到很多個知識點,我們一步一步來推導。
首先單片機的種類是很多的,不同單片機類型的時鍾樹結構和UART配置方式各有差異。這里我們只討論教學中較常用的51單片機。假定使用11.0592MHz外部晶體諧振器,需要獲得19200波特率。
經典51單片機是12分頻的,1個機器周期=12個振盪周期,所以內部的工作頻率實際是11.0592MHz÷12 = 921.6kHz。
經典51單片機的UART如果工作在模式1或模式3下,波特率由定時器1的溢出時間決定,並且還會經過16分頻(SMOD=1)或32分頻(SMOD=0)。921600÷19200 = 48,48無法被32整除、只能被16整除得到3,因此必須設置SMOD=1。
定時器1的工作方式是向上累加,溢出時產生重載。因此重載初值為 100h - 3h = FDh。
B. 51單片機波特率如何設置啊
串列口的四種工作方式對應三種波特率。由於輸入的移位時鍾的來源不同,所以,各種方式的波特率計算公式也不相同。
方式0的波特率 = fosc/12
方式2的波特率 =((2^SMOD)/64)• fosc
方式1的波特率 =((2^SMOD)/32)•(T1溢出率)
方式3的波特率 =((2^SMOD)/32)•(T1溢出率)
注意:SMOD為PCON寄存器的最高位(即PCOM<7>)。
T1 溢出率 = fosc /{12×[256 -(TH1)]} --將該公式代人方式1或3
最後推出公式:TH1=256-(fosc*2^SMOD)/(baudrate*12*32);
呵呵
如果你用方式2(波特率 =((2^SMOD)/64)• fosc )的話
12M的晶振就不能得到9600波特率了(除非你改變你的晶振,但是那樣的晶振好像沒有賣) 所以你只能選擇方式1或3
而且12M的晶振在串口傳輸時會有誤差,就如你上面算的那樣結果會有小數點
TH1又只能是整數的 所以傳輸時會有誤差.
參考:
#include<reg51.h>
#define baudrate 9600UL
#define fosc 11059200UL//其中,UL是不能省略的,代表長整型。
unsigned char a,flag;
void serial_init(void)
{ unsigned char S_MOD=1;
TMOD=0x20;//T1工作在方式2
SCON=0x50;//SM0=0 SM1=1->串口通信在模式1,
//SM2=0->多級通信中使用的位,REN=1;
PCON=0;
if((PCON&0x80)==0x80) S_MOD=2;
TH1=256-(fosc*S_MOD)/(baudrate*12*32);//其中SMOD=0,
TL1=256-(fosc*S_MOD)/(baudrate*12*32);
TR1=1;ES=1;EA=1;
}