网上找了不少串口方面的材料,国内的材料都没有说到如何用中止方法来完成串口数据发送。其实,选用中止方法完成串口数据发送和选用中止方法完成串口数据接纳的进程差不多,都需求敞开8259的IRQ3或IRQ级中止,并需求设定modem操控存放器使OUT2输出低电平,设置中止答应存放器敞开发送和接纳中止。
这里有一点需求留意,《The Art of assembly language programming》中说到,发送存放器为空时串口会发生中止,可是只会发生一次,书中选用的解决办法是经过IO端口直接写入发送坚持存放器,此刻发送结束后串口便又会发生“发送坚持存放器为空”中止。(便是每次发送前都设置中止答应存放器),从实际效果来看是能够的。
51单片机与串口通讯(含代码)
串口调试
1. 发送:向总线上发指令
2. 接纳:从总线接纳指令,并剖析是地址仍是数据。
3. 守时发送:从内存中取数并向主机发送.
经过调试,以上功用根本完成,现在能够经过上位机对单片机进行实时操控。
程序如下:
//这是一个单片机C51串口接纳(中止)和发送例程,能够用来测验51单片机的中止接纳
//和查询发送,别的我觉得发送没有必要用中止,由于程序的开支是相同的
#i nclude
#i nclude
#i nclude
#define INBUF_LEN 4 //数据长度
unsigned char inbuf1[INBUF_LEN];
unsigned char checksum,count3 , flag,temp,ch;
bit read_flag=0;
sbit cp=P1^1;
sbit DIR=P1^2;
int i;
unsigned int xdata *RAMDATA;
unsigned char a[6] ={0x11,0x22,0x33,0x44,0x55,0x66} ;
void init_serialcomm(void)
{
SCON=0x50; //在11.0592MHz下,设置串行口波特率为9600,方法1,并答应接纳
PCON=0x00;
ES=1;
TMOD=0x21; //守时器作业于方法2,主动装载方法
TH0=(65536-1000)%6;
TL0=(65536-1000)/256;
TL1=0xfd;
TH1=0xfd;
ET0=1;
TR0=1;
TR1=1;
// TI=0;
EA=1;
// TI=1;
RAMDATA=0x1F45;
}
void serial () interrupt 4 using 3
{
if(RI)
{ RI=0;
ch=SBUF;
TI=1; //置SBUF空
switch(ch)
{
case 0x01 :printf(“A”); TI=0;break;
case 0x02 :printf(“B”); TI=0;break;
case 0x03 :printf(“C”); TI=0;break;
case 0x04 :printf(“D”); TI=0;break;
default :printf(“fg”); TI=0;break;
}
}
}
//向串口发送一个字符
void timer0() interrupt 1 using 3{
// char i;
flag++;
TH0=0x00;
TL0=0x00;
if(flag==10)
{// cp=!cp;
// for(i=0;i<6;i++)
P2=0x25;
TI=1;
temp=*RAMDATA;
printf(“%c”,temp);
TI=0;
// RAMDATA–;
flag=0;
}
}
//主程序
main()
{
init_serialcomm(); //初始化串口
//向6264中送数据
{
*RAMDATA=0x33;
}
while(1)
{
*RAMDATA=0x33;;
}
}
调试进程中遇到的问题:
1. 发送进程:在发送时有必要确保TI=1:即发送缓冲器为空,否则将导致数据发不出去,假如想强制发送能够用:TI=1.详细发送数据:使用printf(“akjdfaklfj”);函数直接发送即可。
2. 接纳进程:在接纳时多选用中止方法,这样能够节省CPU的时刻,进步功率,