收到停止位时SCON寄存器的TI位是1
我们又两种方法进行检测
第一种是查询TI是否置位了
第二种是TI置位后会申请中断 我们就写这个中断 因为中断是自动的
我现在很懵逼 初步推断单片机的接收和发送过程应该是
接收过程:
首先主机发送起始位 然后八个数据位 然后是终止位
八个数据位存到了SBUF寄存器里 然后终止位到来的时候RI置位(硬件完成)
这个时候自动进入串口中断 该干嘛干嘛 中断结束以后 我们可以再进行其他操作
发送过程:
这个时候注意 一旦写了SBUF=xxxxxx;
这一行写完后 SBUF自动的向外发送数据 发送完后 TI位置一 这个时候继续进入中断
但是如果我们不想让他进入串口中断 就提前关掉串口中断允许位 也就是REN=0
然后等待TI置一的时候 软件把TI=0然后再把串口接收位打开 允许继续接收数据
以上可以看出就是 SBUF存储和发送是自动的
上位机写到SBUF里面的数据不需要我们管 只要波特率正确 SBUF会自动存储上位机发送的字符
接受完成后RI=1
我们要做的是判断是否接受完成(RI是否是1)
清中断标志位RI=0
然后进中断把SBUF里面的东西存下来以备后用
而发送是自动的
SBUF=xxxx;就已经开始自动发送SBUF里面这八位 我们要做的是当TI=1表示发送完成时不要让他继续进入串口中断 而是应该提前关掉串口允许位 顺便把TI=0
#include#define uchar unsigned char
#define uint unsigned int
sbit D1=P1^0;
unsigned char flag;
unsigned char a;
int main()
{
TMOD=0x20;//方式二
TH1=0xfd;
TL1=0xfd;
TR1=1;
SM0=0;
SM1=1;
REN=1;
EA=1;//总中断
ES=1;//串口中断
//这里说一句 当接收到信号的时候RI置一 这时候SBUF已经存储了我们需要的八位数据
while(1)
{
if(flag==1)
{
ES=0;
flag=0;
SBUF=a;//这SBUF是发送缓冲器
while(!TI);//没发完的时候TI是0 发完了TI就是1 !TI是假 退出循环
TI=0;//这两行不能调位置 shit fuck you!
ES=1;//
}
//while(1);
/*if(RI==1)
{
RI=0;
P1=SBUF;
}
}*/
}
}
void ser() interrupt 4//TI RI是TMD共用一个中断 草
{
RI=0;
P1=SBUF;
a=SBUF;//这SBUF是接收缓冲器
flag=1;
}