找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索

STC8单片机的485通讯程序 实现不了 求帮助

查看数: 5321 | 评论数: 11 | 收藏 3
关灯 | 提示:支持键盘翻页<-左 右->
    组图打开中,请稍候......
发布时间: 2019-7-1 18:35

正文摘要:

使用串口3定时器3做波特率发生器写了一个小程序,但是通讯实现不了,求指教 #include "STC81.h" #include "intrins.h" #include "485.h" #define FOSC   24000000UL #define BRT  ...

回复

ID:47286 发表于 2021-5-13 18:12
1. 串口无需设置推挽 什么都不动就行 就是说 初始化时 和串口相关的端口什么都不做 维持原有状态即可 但通常我用的时候都会在RxD和TxD管脚接上拉电阻 也只是为了稳定性 不用上拉我试过 可以用
2. 485控制端口无需推挽 准双向即可驱动485芯片 无需上拉 无需限流 当然 有个限流更保险一点
3. 你先调试TTL通讯 只要TTL正常 在发送函数中 先RE485=1然后是标准的TTL发送语句最后RE485=0 恢复到接收状态即可
4. 无所谓用串口几 都一样 STC的串口234和1的不同基本上就是寄存器不能位寻址 加上自己扩展的几组功能寄存器 其它没什么不一样的

评分

参与人数 1黑币 +20 收起 理由
admin + 20 回帖助人的奖励!

查看全部评分

ID:155507 发表于 2021-5-13 15:48
yhy08090 发表于 2021-5-13 12:36
P0M1 &= 0xFE;        P0M0 &= 0xFE;                          //设置P0.0为准双向口
        P0M1 &= 0x ...

芯片型号 : STC8A8K64S4A12

关于此芯片的重要说明:
  所有串口(包括串口1、串口2、串口3、串口4)的发送端口均需要
      软件设置为强推挽输出模式或者外接3~5K的上拉电阻
ID:911776 发表于 2021-5-13 12:36
P0M1 &= 0xFE;        P0M0 &= 0xFE;                          //设置P0.0为准双向口
        P0M1 &= 0xFD;        P0M0 |= 0x02;                          //设置P0.1为推挽输出
这里为什么需要设置呢?
ID:49198 发表于 2019-7-23 13:58
clarence123 发表于 2019-7-2 11:43
还有就是我用的串口3,是不是应该设置成推挽输出

是的STC需要设置推挽输出或者外接上拉电阻的
ID:323902 发表于 2019-7-2 11:43
还有就是我用的串口3,是不是应该设置成推挽输出
ID:323902 发表于 2019-7-2 11:02
xuyaqi 发表于 2019-7-1 21:19
很多文件都没有,最好把工程发出来。

目前在用昆仑通泰的触摸屏和STC8传输数据,没有明确的工程
ID:323902 发表于 2019-7-2 10:05
angmall 发表于 2019-7-1 20:50
给你改了,对比一下就知道哪里错了。

万分感谢!串口已通,但有几点问题我不太明白:

1.数据包用串口助手发送几十次后才能收到数据,接收73位数据后后面收不到数
2.接收到的数据和发送的内容完全不同

盼您解答,再次向您表示感谢!
ID:47286 发表于 2019-7-1 21:42
发送的时候 要 RE485=1; 发送完毕再清零
ID:94031 发表于 2019-7-1 21:19
很多文件都没有,最好把工程发出来。
ID:155507 发表于 2019-7-1 20:50
给你改了,对比一下就知道哪里错了。



  1. #include "STC81.h"
  2. #include "intrins.h"
  3. #include "485.h"
  4. #define FOSC   24000000UL
  5. #define BRT  (65536-FOSC/9600/4)
  6. #define uchar unsigned char
  7. bit busy;
  8. char wptr;
  9. char rptr;
  10. char buffer[16];

  11. void Uart3Isr() interrupt 17 using 1
  12. {
  13.         IE2 &= 0xF7;                                  // 串口3中断关闭
  14.         if(S3CON&0x02)   //在停止位开始发送时,该位置1
  15.         {
  16.                 S3CON &= ~0x02;              //清除S3CON寄存器对应S3TI位(该位必须软件清零)
  17.                 busy=0;
  18.         }
  19.         if(S3CON&0x01)        //串行接收到停止位的中间时刻时,该位置1
  20.         {
  21.                 S3CON &= ~0x01;         //清除S3CON寄存器对应S3RI位(该位必须软件清零)
  22.                 buffer[wptr++]=S3BUF;
  23.                 wptr&=0x0f;
  24.                 if((buffer[7]==0x00)&&(buffer[8]==0x00))
  25.                 {
  26.                         RUN11=RUN21=RUN31=RUN41=0;
  27.                         STOP11=STOP21=STOP31=STOP41=0;
  28.                 }
  29.         }
  30.         IE2 |= 0x08;                     // 串口3中断打开
  31. }
  32. void Uart3Init()
  33. {
  34.         RE485=0;//RS485设置为接收方向
  35.         //S3CON=0x50;
  36.         S3CON |= 0x50;                  //串口3选择定时器3为波特率发生器,启动串行接收器
  37.         S3CON &= 0x70;                  //8位数据,可变波特率
  38.         T3L=BRT;
  39.         T3H=BRT>>8;
  40.         T4T3M|=0x0a;
  41.         wptr=0x00;
  42.         rptr=0x00;
  43.         busy=0;
  44. }
  45. void Uart3Send(char dat)
  46. {
  47.         while(busy);
  48.         busy=1;
  49.         S3BUF=dat;
  50. }
  51. void main()
  52. {
  53.         P0M1 &= 0xFE;        P0M0 &= 0xFE;                          //设置P0.0为准双向口
  54.         P0M1 &= 0xFD;        P0M0 |= 0x02;                          //设置P0.1为推挽输出
  55.         P_SW2=0x02;
  56.         Uart3Init();
  57.         //IE2=0x08;
  58.         IE2 |= 0x08;         // 串口3中断打开
  59.         IE2 &= 0xDF;         // 关闭定时器3中断
  60.         EA=1;
  61.         while(1)
  62.         {
  63.                 if(rptr!=wptr)
  64.                 {
  65.                         Uart3Send(buffer[rptr++]);
  66.                         rptr&=0x0f;
  67.                 }
  68.         }
  69. }


复制代码

小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表