木生 发表于 2024-10-23 15:24:53

关于STC8H8K64U例程之串口2中断模式与电脑收发测试

本帖最后由 木生 于 2024-10-23 16:26 编辑

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

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

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

现在情况是单个数据可以,两个以上数据就不行。如图

DebugLab 发表于 2024-10-23 15:39:11

串口助手建议使用官方软件自带的

串口收发程序供参考:
https://www.stcaimcu.com/forum.php?mod=viewthread&tid=4598

soma 发表于 2024-10-23 15:56:57

不应该啊,如果是char接收返回,多字节也应该返回单字节啊,估计还有问题。

木生 发表于 2024-10-23 16:19:35

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

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

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


#define Baudrate29600L
#define UART2_BUF_LENGTH    64


u8TX2_Cnt;    //发送计数
u8RX2_Cnt;    //接收计数
bit B_TX2_Busy; //发送忙标志

u8xdata RX2_Buffer; //接收缓冲


void UART2_config(u8 brt);   // 选择波特率, 2: 使用Timer2做波特率, 其它值: 无效.
void PrintString2(u8 *puts);


//========================================================================
// 函数: void main(void)
// 描述: 主函数。
// 参数: none.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 备注:
//========================================================================
void main(void)
{
    P_SW2 |= 0x80;//扩展寄存器(XFR)访问使能

    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;   //设置为准双向口

    UART2_config(2);    // 选择波特率, 2: 使用Timer2做波特率, 其它值: 无效.
    EA = 1; //允许全局中断
   
    PrintString2("STC8H8K64U UART2 Test Programme!\r\n");//UART2发送一个字符串

    while (1)
    {
      if((TX2_Cnt != RX2_Cnt) && (!B_TX2_Busy))   //收到数据, 发送空闲
      {
            S2BUF = RX2_Buffer;
            B_TX2_Busy = 1;
            if(++TX2_Cnt >= UART2_BUF_LENGTH)   TX2_Cnt = 0;
      }
    }
}


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

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

//========================================================================
// 函数: void UART2_config(u8 brt)
// 描述: UART2初始化函数。
// 参数: brt: 选择波特率, 2: 使用Timer2做波特率, 其它值: 无效.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 备注:
//========================================================================
void UART2_config(u8 brt)    // 选择波特率, 2: 使用Timer2做波特率, 其它值: 无效.
{
    /*********** 波特率固定使用定时器2 *****************/
    if(brt == 2)
    {
      SetTimer2Baudraye(65536UL - (MAIN_Fosc / 4) / Baudrate2);

      S2CON &= ~(1<<7);   // 8位数据, 1位起始位, 1位停止位, 无校验
      IE2   |= 1;         //允许中断
      S2CON |= (1<<4);    //允许接收
      P_SW2 &= ~0x01;
      P_SW2 |= 0;         //UART2 switch to: 0: P1.0 P1.1,1: P4.6 P4.7

      B_TX2_Busy = 0;
      TX2_Cnt = 0;
      RX2_Cnt = 0;
    }
}

//========================================================================
// 函数: void UART2_int (void) interrupt UART2_VECTOR
// 描述: UART2中断函数。
// 参数: nine.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 备注:
//========================================================================
void UART2_int (void) interrupt 8
{
    if((S2CON & 1) != 0)
    {
      S2CON &= ~1;    //Clear Rx flag
      RX2_Buffer = S2BUF;
      if(++RX2_Cnt >= UART2_BUF_LENGTH)   RX2_Cnt = 0;
    }

    if((S2CON & 2) != 0)
    {
      S2CON &= ~2;    //Clear Tx flag
      B_TX2_Busy = 0;
    }
}

木生 发表于 2024-10-23 16:21:53

木生 发表于 2024-10-23 16:19
#include "stc8h.h"       //包含此头文件后,不需要再包含"reg51.h"头文件

#define MAIN_Fosc       1105 ...

这个是源代码,不知问题在哪里

木生 发表于 2024-10-24 11:22:10

soma 发表于 2024-10-23 15:56
不应该啊,如果是char接收返回,多字节也应该返回单字节啊,估计还有问题。 ...

感谢回复,感觉这玩意弄成了玄学;测试例子用了软件中的,也使用了例程中的,硬件上没什么就一个串口转了一个MAX485芯片!

lezjin 发表于 2024-10-24 13:48:38

用提供的代码更不应该 有问题啊,你下载时候的频率选择正确吧

zhang32568 发表于 2024-10-24 14:12:38

没有发现

木生 发表于 2024-10-24 14:20:06

lezjin 发表于 2024-10-24 13:48
用提供的代码更不应该 有问题啊,你下载时候的频率选择正确吧

频率是11.0592,是一致的,只能接收一个数据,两个以上就不对

木生 发表于 2024-10-24 14:22:54

zhang32568 发表于 2024-10-24 14:12
没有发现

我也认为代码不会有问题的,难道P1.0,P1.1驱动能力不足么?
页: [1] 2
查看完整版本: 关于STC8H8K64U例程之串口2中断模式与电脑收发测试