具有增强的波特率发生器电路,有多个时钟源可用于产生标准波特率(详见“18.1 增强波特
率发生器”)。接收数据缓冲机制允许 UART0 在软件尚未读取前一个数据字节的情况下开始接
收第二个输入数据字节。
UART0 有两个相关的特殊功能寄存器:串行控制寄存器(SCON0)和串行数据缓冲器
(SBUF0)。用同一个 SBUF0 地址可以访问发送寄存器和接收寄存器。写 SBUF0时自动访问
发送寄存器;读 SBUF0时自动访问接收寄存器,不可能从发送数据寄存器中读数据。
如果 UART0 中断被允许,则每次发送完成(SCON0 中的 TI0 位被置‘1’)或接收到数
据字节(SCON0 中的 RI0 位被置‘1’)时将产生中断。当 CPU转向中断服务程序时硬件不清
除 UART0 中断标志。中断标志必须用软件清除,这就允许软件查询 UART0 中断的原因(发
送完成或接收完成)。
Where T1CLK is the frequency of the clock supplied to Timer 1, and T1H is the high byte of Timer 1 (reload value).
eg:
设定的UARTBaudRate=9600bps
T1CLK =48Mhz/12=4Mhz
T1H=X
计算出X,就是reload value
9600=4*10^6/(256-X)/2
X=47.666666666666666666666666666667
X≈48=0x30
T1H=0x30 (如下表倒数第二行0x30,波特率误差为0.16%,UART通讯的波特率的误差范围一般控制在2%以内,当然也要看你的硬件设计情况,不过对于9600BIT的低速率是比较容易的)
void UART0_Init()
{
Timer1_Init();
/*
TI0 (SCON0.1) The TI0 Transmit Interrupt Flag
RI0 (SCON0.0) Receive Interrupt Flag.
###the data byte will be loaded into the SBUF0 receive register
if the following conditions are met:RI0 must be logic 0,
REN0(SCON0.4)REN0 Receive Enable bit
*/
SCON0 = 0x10;//UART0 Receive Enable.UART0 reception enabled.
Interrupts_Init();
} } void Uart0_Receive_interrupt()interrupt 4
void UART0_Send_data(unsigned char Send_data)
{
SBUF0=Send_data;
while(!TI0);
TI0=0;
}
void UART0_Send_Longdata(unsigned char *str, unsigned int Stringlen)
{
unsigned int i;
do {
UART0_Send_data(*(str+i));
i++;
}
while (i
/*********************The main entry**********************/
void main( )// http://hi.baidu.com/helloelectron
{
PCA0MD &= ~( 1<<6 );//C8051F关闭看门狗
Oscillator_Init();
Port_IO_Init();
UART0_Init();
UART0_Send_Longdata(MyBlog,strlen(MyBlog)); //发送BLOG字符串
while(1)
{
if (read_flag) //如果接收完毕标志已置位,就将读到的数从串口发出
{
read_flag= 0 ; //接收完毕标志清0
UART0_Send_data(Byte); //发送接收到的字符
}
display_led(Byte);
}
}
{
if (RI0==1)
{
RI0 = 0; // 清接收中断标志RI0
Byte = SBUF0; // 从串口接收一个字符
read_flag= 1 ; //就置位取数标志
}
}
上一篇:用keil C使单片机获得随机数
下一篇:基于8051和Proteus的数字时钟 程序的编写和仿真
推荐阅读最新更新时间:2024-03-16 15:15