#include <c8051f020.h> /*SFR定义*/
#define BAUDRATE 9600 /*UART0的波特率*/
#define SYSCLK 22118400 /*系统时钟*/
void SYSCLK_Init (void);
void PORT_Init (void);
void UART0_Init (void);
void delay(unsigned int m);
bit ReceiveBit; /*接收标志位*/
unsigned char temp;
void main(void)
{
WDTCN = 0xde; /*关看门狗*/
WDTCN = 0xad;
SYSCLK_Init (); /*初始化系统时钟*/
PORT_Init (); /*初始挂交叉开关和I/O口*/
UART0_Init (); /*初始化UART0*/
EA=1;
ES0=1;
while(1)
{
while (ReceiveBit==1)
{ /*是否接收到一个数据*/
ES0=0; /*关串口中断0*/
EA=0; /*关总中断*/
ReceiveBit=0; /*清接收标志位*/
delay(60000); /*延时*/
delay(60000);
delay(60000);
SBUF0=temp; /*将接收到数据送出*/
while(TI0==0); /*发送标志位是否产生*/
TI0=0; /*清发送标志位*/ /*是否接收到一个数据*/
}
}
}
void SYSCLK_Init (void)
{
int i; /*延时计数器*/
OSCXCN = 0x67; /*打开外部晶体振荡器*/
for (i=0; i < 256; i++) ; /*延时*/
while (!(OSCXCN & 0x80)) ; /*查询外部晶体是否稳定起振*/
OSCICN = 0x88; /*用外部晶体作为系统时钟,并使能时钟丢失检测*/
}
void PORT_Init (void)
{
XBR0 = 0x04; /*使能UART0*/
XBR1 = 0x00;
XBR2 = 0x40; /*使能交叉开关和弱上拉*/
P0MDOUT |= 0x01; /*使能TX0作为推挽输出*/
}
void UART0_Init (void)
{
SCON0 = 0x50; /*SCON0:模式1,8位UART,时能RX*/
TMOD = 0x20; /*TMOD: 定时器工作再模式2, 8位重载*/
TH1 = -(SYSCLK/BAUDRATE/16); /*设置定时1用作波特率的重载值*/
TR1 = 1; /*开定时器1*/
CKCON |= 0x10; /*定时器1用系统时钟作为它的时基*/
PCON |= 0x80; /*SMOD00 = 1*/
}
/*串口中断0子程序*/
void UART0_ISR (void) interrupt 4
{
if(!TI0) //是发送中断还是接收中断
{
RI0 = 0; /*清接收标志位*/
temp =SBUF0; /*保存接收到的数据*/
ReceiveBit=1; /*置接收标志*/
}
TI0 = 0; /*清发送标志位*/
}
/*延时子程序*/
void delay(unsigned int m)
{
unsigned int n;
n=0;
while(n < m)
{n++;}
return;
}
哦,那你认为该怎么改?去掉那一部分,改成while(1)?
追答仿照接收,也为发送,增加一个标志位。
//串口中断0子程序
void UART0_ISR (void) interrupt 4
{
if(!TI0) { //是发送中断还是接收中断.
RI0 = 0; //清接收标志位.
temp = SBUF0; //保存接收到的数据.
ReceiveBit = 1; //置接收标志.
}
else {
TI0 = 0; //清发送标志位.
TTT_Bit = 1; //置发送标志位.
}
}
呵呵,经过你这样的修改,问题还是存在啊,还是只能发送,不能接收,不过发送时是一个字节一个字节的发送。希望你再继续看看啊,谢谢啊。帮帮忙啊
追答那么,楼主怎么知道:不能接收的呢?
追问我已经调试了啊,我随时都在调试啊,呵呵
追答调试时的现象,有可能是 收到,或者是 没有收到。
你究竟是怎么想的,你就能肯定是:““不能接收””呢?
用串口调试助手调试时RX计数还是为0.
追答串口调试助手调试时RX计数还是为0,
这怎么就能理解成:““不能””接收呢?
在我的百度空间,有许多成功的串口通信实例,建议去看看。
SCON0 = 0x50;这里就有接收允许,位四就是的