STC32G12K128 Uart2 奇偶校验 接收正常, 发送有异常
STC32G12K128 Uart2 奇偶校验 接收正常, 发送有异常,目前这个有没有关于比较明确的做法/*---------------------------------------------------------------------*//* --- 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.STCMCU.com --------------------------------------------*/
/* --- Web: www.STCMCUDATA.com---------------------------------------*/
/* --- QQ:800003751 -------------------------------------------------*/
/* 如果要在程序中使用此代码,请在程序中注明使用了STC的资料及程序 */
/*---------------------------------------------------------------------*/
/*************功能说明 **************
本例程基于STC32G为主控芯片的实验箱进行编写测试。
使用Keil C251编译器,Memory Model推荐设置XSmall模式,默认定义变量在edata,单时钟存取访问速度快。
edata建议保留1K给堆栈使用,空间不够时可将大数组、不常用变量加xdata关键字定义到xdata空间。
串口3全双工中断方式收发通讯程序。
通过PC向MCU发送数据, MCU收到后通过串口3把收到的数据原样返回.
用定时器做波特率发生器,建议使用1T模式(除非低波特率用12T),并选择可被波特率整除的时钟频率,以提高精度。
下载时, 选择时钟 22.1184MHz (用户可自行修改频率).
******************************************/
#include "..\..\comm\STC32G.h"
#include "stdio.h"
#include "intrins.h"
typedef unsigned char u8;
typedef unsigned int u16;
typedef unsigned long u32;
#define MAIN_Fosc 22118400L // 定义主时钟(精确计算115200波特率)
//==========================================================================
#define Baudrate3 (65536 - MAIN_Fosc / 115200 / 4)
#define UART3_BUF_LENGTH 64
//==========================================================================
/*************本地常量声明 **************/
/*************IO口定义 **************/
/*************本地变量声明 **************/
u8 TX3_Cnt; // 发送计数
u8 RX3_Cnt; // 接收计数
bit B_TX3_Busy; // 发送忙标志
bit B_RxParity3; // 接收到的校验位
u8 RX3_Buffer; // 接收缓冲
/*************本地函数声明 **************/
void UART3_TxByte(u8 dat);
void UART3_config(u8 brt); // 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer3做波特率.
void PrintString3(u8 *puts);
/****************外部函数声明和外部变量声明 *****************/
/******************** 主函数 **************************/
void main(void)
{
WTST = 0;// 设置程序指令延时参数,赋值为0可将CPU执行指令的速度设置为最快
EAXFR = 1; // 扩展寄存器(XFR)访问使能
CKCON = 0; // 提高访问XRAM速度
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; // 设置为准双向口
UART3_config(0); // 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer3做波特率.
EA = 1; // 允许全局中断
PrintString3("STC32G UART3 Test Programme!\r\n"); // UART3发送一个字符串
while (1)
{
// if ((TX3_Cnt != RX3_Cnt) && (!B_TX3_Busy)) // 收到数据, 发送空闲
if ((TX3_Cnt != RX3_Cnt) ) // 收到数据, 发送空闲
{
// S3BUF = RX3_Buffer;
// B_TX3_Busy = 1;
UART3_TxByte(RX3_Buffer);
if (++TX3_Cnt >= UART3_BUF_LENGTH)
TX3_Cnt = 0;
}
}
}
void UART3_TxByte(u8 dat)
{
B_TX3_Busy = 1; // 标志发送忙
ACC = dat;
if (P) S3CON |= S3TB8; // 奇校验
// if(!P) S3CON |=S3TB8; //偶校验
else
S3CON &= ~S3TB8;
S3BUF = dat; // 发一个字节
while (B_TX3_Busy)
; // 等待发送完成
}
//========================================================================
// 函数: void PrintString3(u8 *puts)
// 描述: 串口3发送字符串函数。
// 参数: puts:字符串指针.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 备注:
//========================================================================
void PrintString3(u8 *puts)
{
for (; *puts != 0; puts++) // 遇到停止符0结束
{
UART3_TxByte(*puts);
// S3BUF = *puts;
// B_TX3_Busy = 1;
// while (B_TX3_Busy)
// ;
}
}
//========================================================================
// 函数: SetTimer2Baudraye(u32 dat)
// 描述: 设置Timer2做波特率发生器。
// 参数: dat: Timer2的重装值.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 备注:
//========================================================================
void SetTimer2Baudraye(u32 dat) // 使用Timer2做波特率.
{
T2R = 0; // Timer stop
T2_CT = 0; // Timer2 set As Timer
T2x12 = 1; // Timer2 set as 1T mode
T2H = (u8)(dat / 256);
T2L = (u8)(dat % 256);
ET2 = 0; // 禁止中断
T2R = 1; // Timer run enable
}
//========================================================================
// 函数: void UART3_config(u8 brt)
// 描述: UART3初始化函数。
// 参数: brt: 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer3做波特率.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 备注:
//========================================================================
void UART3_config(u8 brt) // 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer3做波特率.
{
if (brt == 2)
{
SetTimer2Baudraye(Baudrate3);
S3CON = 0x10; // 8位数据, 使用Timer2做波特率发生器, 允许接收
}
else
{
T3R = 0; // Timer stop
S3CON = 0x50; // 8位数据, 使用Timer3做波特率发生器, 允许接收
T3H = (u8)(Baudrate3 / 256);
T3L = (u8)(Baudrate3 % 256);
T3_CT = 0; // Timer3 set As Timer
T3x12 = 1; // Timer3 set as 1T mode
T3R = 1; // Timer run enable
}
S3CON |= (1 << 7); // 1位起始位, 8位数据, 1位校验位, 1位停止位
ES3 = 1;// 允许UART3中断
S3_S = 1; // UART3 switch bit1 to: 0: P0.0 P0.1,1: P5.0 P5.1
B_TX3_Busy = 0;
TX3_Cnt = 0;
RX3_Cnt = 0;
}
//========================================================================
// 函数: void UART3_int (void) interrupt UART3_VECTOR
// 描述: UART3中断函数。
// 参数: nine.
// 返回: none.
// 版本: VER1.0
// 日期: 2014-11-28
// 备注:
//========================================================================
void UART3_int(void) interrupt 17
{
if (S3RI)
{
S3RI = 0; // Clear Rx flag
RX3_Buffer = S3BUF;
if (++RX3_Cnt >= UART3_BUF_LENGTH)
RX3_Cnt = 0;
if (S3CON & S3RB8)
B_RxParity3 = 1; // 校验位, 用户按需要做处理
else
B_RxParity3 = 0;
}
if (S3TI)
{
S3TI = 0; // Clear Tx flag
B_TX3_Busy = 0;
}
}
发出一个字节就停止了,UART3_TxByte 这个函数 目前确认是卡死在 while (B_TX3_Busy) 这个地方,不做奇偶校验是正常正常收发的,注释掉下面这部分是能正常发,所以目前有没有一个明确的做法
if (P) S3CON |= S3TB8; // 奇校验
// if(!P) S3CON |= S3TB8; //偶校验
else
S3CON &= ~S3TB8;
论坛上找一也没有明确的做法 指导书也没有详细说明
在STC32G.h头文件里面“S3TB8”是使用位定义的方式申明的:
sbit S3TB8 = S3CON^3;
sbit S3RB8 = S3CON^2;
所以使用的时候可以直接对“S3TB8”进行位操作:
S3TB8 = 1;
S3TB8 = 0;
而不能使用这种方式操作:
S3CON |= S3TB8;
S3CON &= ~S3TB8;
乘风飞扬 发表于 2023-7-5 23:04
在STC32G.h头文件里面“S3TB8”是使用位定义的方式申明的:
sbit S3TB8 = S3CON^3; ...
好的,我做下测试验证
页:
[1]