本文所说的模拟串口, 就是利用51的两个输入输出引脚P1.0和P1.1,置1或0分别代表高低电平,也就是串口通信中所说的位,如起始位用低电平,则将其置0,停止位为高电平,则将其置1,各种数据位和校验位则根据情况置1或置0。
以11.0592MHz的晶振为例,通过定时计数器0产生中断信号来模拟串口电平,下面附上具体源代码。
- /*
- Fuction:使用51单片机GPIO口模拟串口通信,通过定时计数器0来产生中断信号
- Software Designer:Jason
- */
- #include
- sbit P1_0 = P1^0;
- sbit P1_1 = P1^1;
- #define RXD P1_0
- #define TXD P1_1
- unsigned char flag;
- void init();
- void send_byte(unsigned char);
- unsigned char rec_byte();
- void wait_int();
- //将从PC机串口接收到的数据原封不动回传给PC机
- void main()
- {
- unsigned char temp;
- init();
- while(1)
- {
- if(RI == 1)
- {
- RI = 0;
- temp = rec_byte();
- send_byte(temp);
- while(!TI);
- TI = 0;
- }
- }
- }
- //端口及中断初始化
- void init()
- {
- TMOD = 0x02; //定时器0,方式2
- TH0 = 0xfd; //波特率9600
- TL0 = TH0;
- TR0 = 0; //在发送或接收时打开
- ET0 = 1; //允许定时器0中断
- EA =1; //允许所有中断
- }
- //通过串口发送一个字节数据
- void send_byte(unsigned char dat)
- {
- unsigned char i=8;
- TR0 = 1; //开启T0中断
- TXD = 0; //发送起始位0
- wait_int();
- while(i--) //发送8位数据
- {
- TXD = (bit)(dat & 0x01);
- wait_int();
- dat = dat>>1;
- }
- TXD = 1; //发送停止位1
- wait_int();
- TR0 = 0; //关闭T0中断
- }
- //通过串口接收一个字节数据
- unsigned char rec_byte()
- {
- unsigned char dat=0;
- unsigned char i=8;
- TR0 = 1; //开启T0中断
- wait_int(); //等过起始位电平
- while(i--) //接收8位数据
- {
- dat = dat<<1;
- if(RXD)
- dat |= 0x80;
- wait_int();
- }
- wait_int(); //等过停止位电平
- TR0 = 0; //关闭T0中断
- return dat;
- }
- //等待中断到来
- void wait_int()
- {
- while(!flag);
- flag = 0;
- }
- //中断服务程序
- void timer0() interrupt 1
- {
- flag = 1;
- }
上一篇:51单片机 EEPROM AT24c02 存储\读取一个字节
下一篇:51单片机普通IO口模拟IIC总线的程序实现
推荐阅读最新更新时间:2024-03-16 14:55
设计资源 培训 开发板 精华推荐
- Crucial P5高性能M.2 SSD:高速、高容量,最高3400MB/s读取
- Dragonfly Pictures 开创新一代多旋翼无人机
- ASML发布2020年第三季度财报,净销售额40亿欧
- Maxim 全新buck/boost控制器问市,设计尺寸可大幅缩减
- BittWare高端板卡级解决方案贸泽即将开售
- Akamai更新智能边缘平台,推动数字化体验
- 全新封装技术为5G赋能,长电科技亮相 IC China 2020
- 高精度Spectrum仪器AWG卡推动量子新革命
- NXP RF Airfast多芯片模块加速NEC实现MIMO 5G天线无线应用
- Kuka推出新系列的SCARA机器人,是工业生产的“可靠助手”