qepuemc 发表于 2025-10-20 22:19:31

qepuemc 发表于 2025-10-8 17:24
其实不是这样的。不只是自动换行的问题,最大的问题是数据乱码。这个问题一直没解决。一直没在意。现在我 ...

/*---------------------------------------------------------------------*/
/* --- STC MCU Limited ------------------------------------------------*/
/* --- STC 1T Series MCU Demo Programme -------------------------------*/
/* --- Mobile: (86)13922805190 ----------------------------------------*/
/* --- Fax: 86-0513-55012956,55012947,55012969 ------------------------*/
/* --- Tel: 86-0513-55012928,55012929,55012966 ------------------------*/
/* --- Web: www.STCAI.com ---------------------------------------------*/
/* --- Web: www.STCMCUDATA.com---------------------------------------*/
/* --- BBS: www.STCAIMCU.com-----------------------------------------*/
/* --- QQ:800003751 -------------------------------------------------*/
/* 如果要在程序中使用此代码,请在程序中注明使用了STC的资料及程序      */
/*---------------------------------------------------------------------*/

/*************功能说明    **************

本例程基于STC8H8K64U为主控芯片的实验箱9进行编写测试,STC8G、STC8H系列芯片可通用参考.

串口1全双工中断方式收发通讯程序。

通过PC向MCU发送数据, MCU收到后通过串口1把收到的数据原样返回.

用定时器做波特率发生器,建议使用1T模式(除非低波特率用12T),并选择可被波特率整除的时钟频率,以提高精度。

下载时, 选择时钟 22.1184MHz (用户可自行修改频率).

******************************************/

#include "stc8h.h"       //包含此头文件后,不需要再包含"reg51.h"头文件

#define MAIN_Fosc       11059200L   //定义主时钟(精确计算115200波特率)


typedef   unsigned char   u8;
typedef   unsigned int    u16;
typedef   unsigned long   u32;


#define   Baudrate1         115200L
#define   UART1_BUF_LENGTH    64


u8TX1_Cnt;    //发送计数
u8RX1_Cnt;    //接收计数
bit B_TX1_Busy; //发送忙标志

bit rx_js=0;                         //串口接收结束

unsigned char   xdata RX1_js; //接收数据存放数组

unsigned int    RX1_js_index; //接收索引
unsigned char   xdata RX1_Buffer; //接收数据存放数组

void UART1_config(u8 brt);   // 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
void PrintString1(u8 *puts);









void Timer0_Isr(void) interrupt 1
{
       
rx_js=1;
       
}

void Timer0_Init(void)                //5毫秒@11.0592MHz
{
        AUXR |= 0x80;                        //定时器时钟1T模式
        TMOD &= 0xF0;                        //设置定时器模式
        TL0 = 0x00;                                //设置定时初始值
        TH0 = 0x28;                                //设置定时初始值
        TF0 = 0;                                //清除TF0标志
        TR0 = 0;                                //定时器0开始计时
        ET0 = 0;                                //使能定时器0中断
}







//========================================================================
// 函数: void main(void)
// 描述: 主函数。
// 参数: none.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 备注:
//========================================================================
void main(void)
{
    P_SW2 |= 0x80;//扩展寄存器(XFR)访问使能
Timer0_Init();
    P0M1 = 0x30;   P0M0 = 0x30;   //设置P0.4、P0.5为漏极开路(实验箱加了上拉电阻到3.3V)
    P1M1 = 0x30;   P1M0 = 0x30;   //设置P1.4、P1.5为漏极开路(实验箱加了上拉电阻到3.3V)
    P2M1 = 0x3c;   P2M0 = 0x3c;   //设置P2.2~P2.5为漏极开路(实验箱加了上拉电阻到3.3V)
    P3M1 = 0x50;   P3M0 = 0x50;   //设置P3.4、P3.6为漏极开路(实验箱加了上拉电阻到3.3V)
    P4M1 = 0x3c;   P4M0 = 0x3c;   //设置P4.2~P4.5为漏极开路(实验箱加了上拉电阻到3.3V)
    P5M1 = 0x0c;   P5M0 = 0x0c;   //设置P5.2、P5.3为漏极开路(实验箱加了上拉电阻到3.3V)
    P6M1 = 0xff;   P6M0 = 0xff;   //设置为漏极开路(实验箱加了上拉电阻到3.3V)
    P7M1 = 0x00;   P7M0 = 0x00;   //设置为准双向口

    UART1_config(1);    // 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
    EA = 1; //允许总中断

    PrintString1("STC8H8K64U UART1 Test Programme!\r\n");//UART1发送一个字符串

    while (1)
    {
                       
                        /*
                       
      if((TX1_Cnt != RX1_Cnt) && (!B_TX1_Busy))   //收到数据, 发送空闲
      {
                                       
                                       
                                              SBUF = RX1_Cnt;   //把收到的数据远样返回
                                        B_TX1_Busy = 1;
      while(B_TX1_Busy);
                                       
            //SBUF = RX1_Buffer;   //把收到的数据远样返回
            //B_TX1_Busy = 1;
            if(++TX1_Cnt >= UART1_BUF_LENGTH)   TX1_Cnt = 0;

      }
                               
                                */
                       
                        if (rx_js==1)
                               
                        {
                                        //关闭定时器
                                        TR0 = 0;                                //定时器0开始计时
                                        ET0 = 0;                                //使能定时器0中断
                               
                                //复位串口
                                B_TX1_Busy = 0;
                                TX1_Cnt = 0;
                                RX1_Cnt = 0;
                                rx_js=0;
                               
                        SBUF = RX1_Buffer;    B_TX1_Busy = 1;    while(B_TX1_Busy);
                        SBUF = RX1_Buffer;    B_TX1_Busy = 1;    while(B_TX1_Busy);
                        SBUF = RX1_Buffer;    B_TX1_Busy = 1;    while(B_TX1_Busy);
                        SBUF = RX1_Buffer;    B_TX1_Busy = 1;    while(B_TX1_Busy);
                        SBUF = RX1_Buffer;    B_TX1_Busy = 1;    while(B_TX1_Busy);
                        SBUF = RX1_Buffer;    B_TX1_Busy = 1;    while(B_TX1_Busy);
                        SBUF = RX1_Buffer;    B_TX1_Busy = 1;    while(B_TX1_Busy);
                        SBUF = RX1_Buffer;    B_TX1_Busy = 1;    while(B_TX1_Busy);
                        SBUF = RX1_Buffer;    B_TX1_Busy = 1;    while(B_TX1_Busy);
                       
                       
                        }
                               
                               
    }
}


//========================================================================
// 函数: void PrintString1(u8 *puts)
// 描述: 串口1发送字符串函数。
// 参数: puts:字符串指针.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 备注:
//========================================================================
void PrintString1(u8 *puts) //发送一个字符串
{
    for (; *puts != 0;puts++)   //遇到停止符0结束
    {
      SBUF = *puts;
      B_TX1_Busy = 1;
      while(B_TX1_Busy);
    }
}

//========================================================================
// 函数: SetTimer2Baudraye(u16 dat)
// 描述: 设置Timer2做波特率发生器。
// 参数: dat: Timer2的重装值.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 备注:
//========================================================================
void SetTimer2Baudraye(u16 dat)// 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
{
    AUXR &= ~(1<<4);    //Timer stop
    AUXR &= ~(1<<3);    //Timer2 set As Timer
    AUXR |=(1<<2);    //Timer2 set as 1T mode
    T2H = dat / 256;
    T2L = dat % 256;
    IE2&= ~(1<<2);    //禁止中断
    AUXR |=(1<<4);    //Timer run enable
}

//========================================================================
// 函数: void UART1_config(u8 brt)
// 描述: UART1初始化函数。
// 参数: brt: 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 备注:
//========================================================================
void UART1_config(u8 brt)    // 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
{
    /*********** 波特率使用定时器2 *****************/
    if(brt == 2)
    {
      AUXR |= 0x01;       //S1 BRT Use Timer2;
      SetTimer2Baudraye(65536UL - (MAIN_Fosc / 4) / Baudrate1);
    }

    /*********** 波特率使用定时器1 *****************/
    else
    {
      TR1 = 0;
      AUXR &= ~0x01;      //S1 BRT Use Timer1;
      AUXR |=(1<<6);    //Timer1 set as 1T mode
      TMOD &= ~(1<<6);    //Timer1 set As Timer
      TMOD &= ~0x30;      //Timer1_16bitAutoReload;
      TH1 = (u8)((65536UL - (MAIN_Fosc / 4) / Baudrate1) / 256);
      TL1 = (u8)((65536UL - (MAIN_Fosc / 4) / Baudrate1) % 256);
      ET1 = 0;    //禁止中断
      INTCLKO &= ~0x02;   //不输出时钟
      TR1= 1;
    }
    /*************************************************/

    SCON = (SCON & 0x3f) | 0x40;    //UART1模式, 0x00: 同步移位输出, 0x40: 8位数据,可变波特率, 0x80: 9位数据,固定波特率, 0xc0: 9位数据,可变波特率
//PS= 1;    //高优先级中断
    ES= 1;    //允许中断
    REN = 1;    //允许接收
    P_SW1 &= 0x3f;
    P_SW1 |= 0x80;      //UART1 switch to, 0x00: P3.0 P3.1, 0x40: P3.6 P3.7, 0x80: P1.6 P1.7, 0xC0: P4.3 P4.4
//PCON2 |=(1<<4);   //内部短路RXD与TXD, 做中继, ENABLE,DISABLE

    B_TX1_Busy = 0;
    TX1_Cnt = 0;
    RX1_Cnt = 0;
}


//========================================================================
// 函数: void UART1_int (void) interrupt UART1_VECTOR
// 描述: UART1中断函数。
// 参数: nine.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 备注:
//========================================================================
void UART1_int (void) interrupt 4
{
    if(RI)
    {
      RI = 0;
        //开始定时器               
        TL0 = 0x00;                                //设置定时初始值
        TH0 = 0x28;                                //设置定时初始值
        TR0 = 1;                                //定时器0开始计时
        ET0 = 1;                                //使能定时器0中断
                       
                       
      RX1_Buffer = SBUF;
      if(++RX1_Cnt >= UART1_BUF_LENGTH)   RX1_Cnt = 0;    //防溢出
    }

    if(TI)
    {
      TI = 0;
      B_TX1_Busy = 0;
    }
}


这个也是没有问题的。两个电路都可以用。

summerrain19 发表于 2025-11-5 09:11:19

网上虽然很多分享的工程,其实大部分都达不到工程的实际应用水平,充其量不过是实现了功能而已!

qepuemc 发表于 2025-11-6 06:36:41

summerrain19 发表于 2025-11-5 09:11
网上虽然很多分享的工程,其实大部分都达不到工程的实际应用水平,充其量不过是实现了功能而已! ...

没办法,每个人的思想都不一样,知识量也不一样。今天的知识,到了天可能就是落后的,直正用的产品的好多都不是新的。开发都会一次次的进步。最后能不能得到市场的认可还和推广还得看人。

summerrain19 发表于 2025-11-6 09:08:39

qepuemc 发表于 2025-11-6 06:36
没办法,每个人的思想都不一样,知识量也不一样。今天的知识,到了天可能就是落后的,直正用的产品的好多 ...

我看过你了文件,你是不画原理图直接画的PCB吗?很粗糙!{:xiaoku:}

qepuemc 发表于 2025-11-7 08:00:05

summerrain19 发表于 2025-11-6 09:08
我看过你了文件,你是不画原理图直接画的PCB吗?很粗糙!

是的。我不会画原理图。只搞实物测试。可以把你细的给看看吗

summerrain19 发表于 2025-11-7 09:05:33

qepuemc 发表于 2025-11-7 08:00
是的。我不会画原理图。只搞实物测试。可以把你细的给看看吗

没有,我的很粗{:xiaoku:}

qepuemc 发表于 2025-11-7 10:41:21

summerrain19 发表于 2025-11-7 09:05
没有,我的很粗

666
页: 1 2 [3]
查看完整版本: 485通信错误用STC单片机和485芯片做USB转串口有错误