8051単片機ボーレート計算式(セットC言語ルーチン)
以下から抜粋:http://www.shuihan.com/article/315
8051モノリシックマシンは、モード2の場合にタイマ1を用いて動作し、そのボーレート=(2 smod/32)をシリアルポートボーレート発生器として用いる×(smodがPCON<7>であるタイマT 1のオーバーフロー率は、ボーレートが倍になるか否かを示し、Fsocはシステムの結晶振動の大きさである.
ボーレート式:T 1オーバーフロー率=オーバーフロー周期の逆数;オーバーフロー期間=(256-TH 1)×12/Fosc;
最終式:
ボーレート:Baud=(2 smod)× Fsoc)/(32 ×12×(256-TH1))
一般的には、ボーレートの計算ではなく、選択された伝送速度(ボーレート)がタイマ1(自動リロードモード)の初期値(TH 1)を逆算することに関心があるので、上記の式を導いてTH 1の式を得る.
TH1=256-(Fsoc×2smod)/(12×32×Baud)
次にシリアルポート送信プログラムについて、水寒はルーチンを書いて、皆さんの参考に供します.(私はSTC 12 C 5 A 40 S 2デバッグを使用していますが、原則としてSTC 89 C 5 x、AT 89 C 5 xなど8051コアのモノリシックマシンで成功しています.プログラムが簡単なので試していませんが、問題ないはずです)
8051モノリシックマシンは、モード2の場合にタイマ1を用いて動作し、そのボーレート=(2 smod/32)をシリアルポートボーレート発生器として用いる×(smodがPCON<7>であるタイマT 1のオーバーフロー率は、ボーレートが倍になるか否かを示し、Fsocはシステムの結晶振動の大きさである.
ボーレート式:T 1オーバーフロー率=オーバーフロー周期の逆数;オーバーフロー期間=(256-TH 1)×12/Fosc;
最終式:
ボーレート:Baud=(2 smod)× Fsoc)/(32 ×12×(256-TH1))
一般的には、ボーレートの計算ではなく、選択された伝送速度(ボーレート)がタイマ1(自動リロードモード)の初期値(TH 1)を逆算することに関心があるので、上記の式を導いてTH 1の式を得る.
TH1=256-(Fsoc×2smod)/(12×32×Baud)
次にシリアルポート送信プログラムについて、水寒はルーチンを書いて、皆さんの参考に供します.(私はSTC 12 C 5 A 40 S 2デバッグを使用していますが、原則としてSTC 89 C 5 x、AT 89 C 5 xなど8051コアのモノリシックマシンで成功しています.プログラムが簡単なので試していませんが、問題ないはずです)
#include "Reg52.H"
/*******************************************************************
,
(1) (SMOD=1): Max_Baud = FOSC/12/16
(2) (SMOD=0):Max_Baud = FOSC/12/32
:22.1184MHz , , =22118400/12/16=115200
*******************************************************************/
#define FOSC 22118400 //
#define BAUD 9600 //
#define SMOD 1 //
#if SMOD
#define TC_VAL (256-FOSC/16/12/BAUD)
#else
#define TC_VAL (256-FOSC/32/12/BAUD)
#endif
typedef unsigned char uint8;
typedef unsigned int uint16;
code const char str1[] = "Ther string is transmitted from 80C51!\r
";
code const char str2[] = "Author: xqlu(at)ysu.edu.cn\r
";
/*************** *******************/
void InitUART(void);
void SendOneByte(uint8);
void SendrStr(const uint8 *ptr);
/**************** ********************/
void main(void)
{
uint8 i=0;
InitUART();
while(str2[i]!='\0')
{
SendOneByte(str2[i++]);
}
SendrStr(str1);
while(1);
}
/**************** ***************/
void UART_ISR(void) interrupt 4
{
uint8 RX_Data;
// “ ” ,“ ”
if(RI)
{
RI = 0; // ,
RX_Data=SBUF;
SendOneByte(RX_Data);
}
else
TI = 0; //
}
/**************** *************/
void InitUART(void)
{
TMOD = 0x20;
SCON = 0x50;
TH1 = TC_VAL;
TL1 = TH1;
PCON = 0x80; //
ES = 1;
EA = 1;
TR1 = 1;
}
/************** *************/
void SendOneByte(uint8 c)
{
ES = 0; //
SBUF = c;
while(!TI);
TI = 0;
ES = 1;
}
/************** *************/
void SendrStr(const uint8 *ptr)
{
do
{
SendOneByte(*ptr);
}while(*ptr++!='\0');
}