求AT89C52单片机用MAX485与PC机串口通讯程序
1,我想要的结果:用串口调试助手,向单片机发送命令(字母和数字),并可以收到单片机返回来的指定的命令(字母合数字)。
2,caijianteng,你好,我运行了你的程序,发现串口调试助手中的接收区没有命令返回啊,麻烦你再解决下。 展开
如果与电脑连接的话,直接用单片机通过max232与电脑连接就行啦
如果用485,电脑端、单片机都要加个485芯片转成485才能通信
电路图如图,
把其中一端改成电脑并加个232转485模块就行啦,
单片机端程序
#include <reg51.h>
#define uchar unsigned char
sbit sendkey=P2^0;
unsigned char tempy;
void init(void)//串口初始化
{
TMOD=0x20;
TH1=0xfd;
TL1=0xfd;
PCON=0x00;
TCON=0x40;
TR1=1;
SCON=0x50;
}
void main()
{
init();
while(1)
{
//------------------
//485接收字符
sendkey=0;
while(RI==0);
tempy=SBUF;
RI=0;
//------------------
//485发送字符
sendkey=1;
SBUF=tempy;
while(TI==0);TI=0;
//-------------------
}
}
好好检查下你的硬件
程序我没有改
运行效果见图
晶振11.0592MHz
测试方法:可以将串口调试助手的发送框写上 95 10 20 25,并选上16进制发送,接收框选上16进制显示,如果每发送一次就接收到95 10 20 25,说明测试成功。
//这是一个单片机C51串口接收(中断)和发送例程,可以用来测试51单片机的中断接收
//和查询发送,另外我觉得发送没有必要用中断,因为程序的开销是一样的
#include <reg51.h>
#include <string.h>
#define INBUF_LEN 4 //数据长度
unsigned char inbuf1[INBUF_LEN];
unsigned char checksum,count3;
bit read_flag= 0 ;
void init_serialcomm( void )
{
SCON = 0x50 ; //SCON: serail mode 1, 8-bit UART, enable ucvr
TMOD |= 0x20 ; //TMOD: timer 1, mode 2, 8-bit reload
PCON |= 0x80 ; //SMOD=1;
TH1 = 0xF4 ; //Baud:4800 fosc=11.0592MHz
IE |= 0x90 ; //Enable Serial Interrupt
TR1 = 1 ; // timer 1 run
// TI=1;
}
//向串口发送一个字符
void send_char_com( unsigned char ch)
{
SBUF=ch;
while (TI== 0 );
TI= 0 ;
}
//向串口发送一个字符串,strlen为该字符串长度
void send_string_com( unsigned char *str, unsigned int strlen)
{
unsigned int k= 0 ;
do
{
send_char_com(*(str + k));
k++;
} while (k < strlen);
}
//串口接收中断函数
void serial () interrupt 4 using 3
{
if (RI)
{
unsigned char ch;
RI = 0 ;
ch=SBUF;
if (ch> 127 )
{
count3= 0 ;
inbuf1[count3]=ch;
checksum= ch- 128 ;
}
else
{
count3++;
inbuf1[count3]=ch;
checksum ^= ch;
if ( (count3==(INBUF_LEN- 1 )) && (!checksum) )
{
read_flag= 1 ; //如果串口接收的数据达到INBUF_LEN个,且校验没错,
//就置位取数标志
}
}
}
}
main()
{
init_serialcomm(); //初始化串口
while ( 1 )
{
if (read_flag) //如果取数标志已置位,就将读到的数从串口发出
{
read_flag= 0 ; //取数标志清0
send_string_com(inbuf1,INBUF_LEN);
}
}
}
接收到的数据放在inbuf1[]数组里面了!!!
还有问题的话,我可以把C51文件给你发到邮箱里
serial_rec()
interrupt
4
using
0
//需要连续接收
{
uchar
i;
uchar
r_buf[3];
//ES=0;
//
EN485=1;
for(i=0;
i<3;
i++)
//
接收数据
{
//RI
=
0;
_nop_();
_nop_();
while(!RI);
r_buf[i]=SBUF;
_nop_();
RI
=
0;
_nop_();
}
//RI
=
0;
if((r_buf[0]==0x41)&&(r_buf[1]==0x01)&&(r_buf[2]==0x42))
//
接收到的上一个字节为#,
{
setbit1=1;
//ES=1;
}
else
{
//ES=1;
setbit1=0;
}
}