标题:
stc15w408as串口可用程序
[打印本页]
作者:
LCYXK
时间:
2020-1-10 08:45
标题:
stc15w408as串口可用程序
可用串口调试
单片机源程序如下:
#include "stc15w.h"
//typedef unsigned char BYTE;
//typedef unsigned int WORD;
#define FOSC 11059200L //系统频率
#define BAUD 115200 //串口波特率
#define NONE_PARITY 0 //无校验
#define ODD_PARITY 1 //奇校验
#define EVEN_PARITY 2 //偶校验
#define MARK_PARITY 3 //标记校验
#define SPACE_PARITY 4 //空白校验
#define PARITYBIT NONE_PARITY //定义校验位
#define CCP_S0 0x00 //P_SW1.4
#define CCP_S1 0x00 //P_SW1.5
#define S1_S0 0x40 //P_SW1.6
#define S1_S1 0x80 //P_SW1.7
u8 cnt=0;
u8 TX_BUF[6]={0};
u16 count0=0;
u16 count1=0;
u16 length=0;
//BYTE cnt; //存储PCA计时溢出次数
//DWORD count0; //记录上一次的捕获值
//DWORD count1; //记录本次的捕获值
//DWORD length; //存储信号的时间长度(count1 - count0)
bit busy;
void SendData(u8 dat);
void SendString(char *s);
void delay_us(u16 t)
{
u8 i;
while(t--)
{
_nop_();
_nop_();
i = 1;
while (--i);
}
}
void delay_ms(u16 t)
{
while(t--)
{
// CLRWDT;
delay_us(1000);
}
}
void PCA_config(void)
{
P1M0 = 0x00;
P1M1 = 0x00;
P_SW1 |=0x00 ; //(P1.2/ECI, P1.1/CCP0, P1.0/CCP1, P3.7/CCP2)
CCON = 0; //初始化PCA控制寄存器
//PCA定时器停止
//清除CF标志
//清除模块中断标志
CL = 0; //复位PCA寄存器
CH = 0;
CCAP0L = 0;
CCAP0H = 0;
CMOD = 0x09; //设置PCA时钟源为系统时钟,且使能PCA计时溢出中断
CCAPM0 = 0x21; //PCA模块0为16位捕获模式(上升沿捕获,可测从高电平开始的整个周期),且产生捕获中断
// CCAPM0 = 0x11; //PCA模块0为16位捕获模式(下降沿捕获,可测从低电平开始的整个周期),且产生捕获中断
// CCAPM0 = 0x31; //PCA模块0为16位捕获模式(上升沿/下降沿捕获,可测高电平或者低电平宽度),且产生捕获中断
CR = 1; //PCA定时器开始工作
EA = 1;
cnt = 0;
count0 = 0;
count1 = 0;
}
/*----------------------------
PCA 中断服务程序
-----------------------------*/
void PCA_isr() interrupt 7
{
if (CCF0)
{
CCF0 = 0;
if (CF && ((CCAP0H & 0x80) == 0))
{
CF = 0;
cnt++;
}
count0 = count1; //备份上一次的捕获值
((u8 *)&count1)[3] = CCAP0L; //保存本次的捕获值
((u8 *)&count1)[2] = CCAP0H;
((u8 *)&count1)[1] = cnt;
((u8 *)&count1)[0] = 0;
length = count1 - count0; //计算两次捕获的差值,即得到时间长度
((u8 *)&length)[0] = 0;
}
if (CF)
{
CF = 0;
cnt++; //PCA计时溢出次数+1
}
}
/*----------------------------
UART 中断服务程序
-----------------------------*/
void Uart() interrupt 4 using 1
{
if (RI)
{
RI = 0; //清除RI位
P0 = SBUF; //P0显示串口数据
}
if (TI)
{
TI = 0; //清除TI位
busy = 0; //清忙标志
}
}
/*----------------------------
发送串口数据
----------------------------*/
void SendData(u8 dat)
{
while (busy); //等待前面的数据发送完成
ACC = dat; //获取校验位P (PSW.0)
if (P) //根据P来设置校验位
{
#if (PARITYBIT == ODD_PARITY)
TB8 = 0; //设置校验位为0
#elif (PARITYBIT == EVEN_PARITY)
TB8 = 1; //设置校验位为1
#endif
}
else
{
#if (PARITYBIT == ODD_PARITY)
TB8 = 1; //设置校验位为1
#elif (PARITYBIT == EVEN_PARITY)
TB8 = 0; //设置校验位为0
#endif
}
busy = 1;
SBUF = ACC; //写数据到UART数据寄存器
}
/*----------------------------
发送字符串
----------------------------*/
void SendString(char *s)
{
while (*s) //检测字符串结束标志
{
SendData(*s++); //发送当前字符
}
}
/* 整型数转换为字符串,str-字符串指针,dat-待转换数,返回值-字符串长度 */
u8 Int_To_String(u8 *str, int dat)
{
u8 i = 0;
u8 len = 0;
u8 buf[6];
if (dat < 0) //如果为负数,首先取绝对值,并在指针上添加负号
{
dat = -dat;
*str++ = '-';
len++;
}
do { //先转换为低位在前的十进制数组
buf[i++] = dat % 10;
dat /= 10;
} while (dat > 0);
len += i; //i最后的值就是有效字符的个数
while (i-- > 0) //将数组值转换为ASCII码反向拷贝到接收指针上
{
*str++ = buf[i] + '0';
}
*str = '\0'; //添加字符串结束符
return len; //返回字符串长度
}
void main()
{
// ACC = P_SW1;
// ACC &= ~(S1_S0 | S1_S1); //S1_S0=0 S1_S1=0
P_SW1 = 0x00; //(P3.0/RxD, P3.1/TxD)
#if (PARITYBIT == NONE_PARITY)
SCON = 0x50; //8位可变波特率
#elif (PARITYBIT == ODD_PARITY) || (PARITYBIT == EVEN_PARITY) || (PARITYBIT == MARK_PARITY)
SCON = 0xda; //9位可变波特率,校验位初始为1
#elif (PARITYBIT == SPACE_PARITY)
SCON = 0xd2; //9位可变波特率,校验位初始为0
#endif
T2L = (65536 - (FOSC/4/BAUD)); //设置波特率重装值
T2H = (65536 - (FOSC/4/BAUD))>>8;
AUXR = 0x14; //T2为1T模式, 并启动定时器2
AUXR |= 0x01; //选择定时器2为串口1的波特率发生器
ES = 1; //使能串口1中断
EA = 1;
PCA_config();
SendString("STC15W408AS\r\nUart Test !\r\n");
while(1)
{
SendString("时间间隔为:");
Int_To_String(TX_BUF,length);
SendString("\r\n");
delay_ms(300);
}
}
复制代码
所有资料51hei提供下载:
串口.zip
(52.55 KB, 下载次数: 149)
2020-1-10 08:45 上传
点击文件名下载附件
串口接上可用,注意tx,rx接法
下载积分: 黑币 -5
作者:
2314942018@qq.c
时间:
2020-12-30 06:11
多谢,老兄的源码,多路继电器成功了。
作者:
lhqsbz
时间:
2022-6-15 14:42
谢谢,先试试来看。
欢迎光临 (http://www.51hei.com/bbs/)
Powered by Discuz! X3.1