作业2:甲乙两机进行双机通信。要求:甲机Pl口开关的状态通过串行口发送到乙机, 乙机接收到后,通过P2口的发光二极管显示:乙机PI口开关的状态通过串行口发送到甲机, 甲机接收到后,通过P2口的发光二极管显示。 甲、乙两机都选择方式1—8位异步通信方式,波特率为1200bit/s,甲、乙两机既发送又接收 ,因此甲、乙两机的串口控制字为50H。 由于选择的是方式1, 波特率由定时/计数器Tl的溢出率和电源控制寄存器PCON中的SMOD位决定, 则需对定时/计数器T1初始化。。使用c语言
时间: 2024-02-13 21:02:49 浏览: 73
以下是实现要求的C语言代码:
甲机代码:
```c
#include <reg52.h> // 8051单片机库文件
void init_serial() // 初始化串口
{
TMOD |= 0x20; // 设置定时器1为8位自动重载模式
SCON = 0x50; // 设置串口为方式1并启用接收
TH1 = 0xFD; // 设置波特率为1200bps
TL1 = TH1; // 初始化定时器1计数值
PCON |= 0x80; // 设置SMOD位为1,使波特率加倍
TR1 = 1; // 启动定时器1
ES = 1; // 允许串口中断
EA = 1; // 允许总中断
}
void send_data(unsigned char data) // 发送数据
{
SBUF = data; // 将数据写入发送缓冲区
while(!TI); // 等待发送完成
TI = 0; // 清除发送完成标志
}
void main()
{
init_serial(); // 初始化串口
P2 = 0x00; // 初始状态为关闭
while(1) {
if(P1 & 0x01) { // 检测PL口开关状态
send_data(0x01); // 发送开关状态
P2 |= 0x01; // 打开P2口发光二极管
} else {
send_data(0x00); // 发送开关状态
P2 &= ~0x01; // 关闭P2口发光二极管
}
}
}
void serial_isr() interrupt 4 // 串口中断服务程序
{
unsigned char data;
if(RI) { // 接收完成
data = SBUF; // 读取接收到的数据
RI = 0; // 清除接收完成标志
if(data & 0x01) { // 检测PI口开关状态
P2 |= 0x02; // 打开P2口发光二极管
} else {
P2 &= ~0x02; // 关闭P2口发光二极管
}
}
}
```
乙机代码:
```c
#include <reg52.h> // 8051单片机库文件
void init_serial() // 初始化串口
{
TMOD |= 0x20; // 设置定时器1为8位自动重载模式
SCON = 0x50; // 设置串口为方式1并启用接收
TH1 = 0xFD; // 设置波特率为1200bps
TL1 = TH1; // 初始化定时器1计数值
PCON |= 0x80; // 设置SMOD位为1,使波特率加倍
TR1 = 1; // 启动定时器1
ES = 1; // 允许串口中断
EA = 1; // 允许总中断
}
void send_data(unsigned char data) // 发送数据
{
SBUF = data; // 将数据写入发送缓冲区
while(!TI); // 等待发送完成
TI = 0; // 清除发送完成标志
}
void main()
{
init_serial(); // 初始化串口
P2 = 0x00; // 初始状态为关闭
while(1) {
if(P1 & 0x01) { // 检测PI口开关状态
send_data(0x01); // 发送开关状态
P2 |= 0x01; // 打开P2口发光二极管
} else {
send_data(0x00); // 发送开关状态
P2 &= ~0x01; // 关闭P2口发光二极管
}
}
}
void serial_isr() interrupt 4 // 串口中断服务程序
{
unsigned char data;
if(RI) { // 接收完成
data = SBUF; // 读取接收到的数据
RI = 0; // 清除接收完成标志
if(data & 0x01) { // 检测PL口开关状态
P2 |= 0x02; // 打开P2口发光二极管
} else {
P2 &= ~0x02; // 关闭P2口发光二极管
}
}
}
```
阅读全文