找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 5996|回复: 2
收起左侧

stc15w408as串口可用程序

[复制链接]
ID:437179 发表于 2020-1-10 08:45 | 显示全部楼层 |阅读模式
可用串口调试

单片机源程序如下:
  1. #include "stc15w.h"


  2. //typedef unsigned char BYTE;
  3. //typedef unsigned int WORD;

  4. #define FOSC 11059200L          //系统频率
  5. #define BAUD 115200             //串口波特率

  6. #define NONE_PARITY     0       //无校验
  7. #define ODD_PARITY      1       //奇校验
  8. #define EVEN_PARITY     2       //偶校验
  9. #define MARK_PARITY     3       //标记校验
  10. #define SPACE_PARITY    4       //空白校验

  11. #define PARITYBIT NONE_PARITY   //定义校验位
  12. #define CCP_S0 0x00                 //P_SW1.4
  13. #define CCP_S1 0x00                 //P_SW1.5

  14. #define S1_S0 0x40              //P_SW1.6
  15. #define S1_S1 0x80              //P_SW1.7
  16. u8 cnt=0;
  17. u8 TX_BUF[6]={0};
  18. u16 count0=0;
  19. u16 count1=0;
  20. u16 length=0;
  21. //BYTE cnt;                           //存储PCA计时溢出次数
  22. //DWORD count0;                       //记录上一次的捕获值
  23. //DWORD count1;                       //记录本次的捕获值
  24. //DWORD length;                       //存储信号的时间长度(count1 - count0)

  25. bit busy;

  26. void SendData(u8 dat);
  27. void SendString(char *s);
  28. void delay_us(u16 t)
  29. {
  30.    u8 i;
  31.    while(t--)
  32.    {
  33.                 _nop_();
  34.                 _nop_();
  35.                 i = 1;
  36.                 while (--i);   
  37.    }
  38. }
  39. void delay_ms(u16 t)
  40. {
  41.    while(t--)
  42.    {
  43. //      CLRWDT;
  44.       delay_us(1000);
  45.    }
  46. }
  47. void PCA_config(void)
  48. {
  49.         P1M0 = 0x00;
  50.     P1M1 = 0x00;
  51.     P_SW1 |=0x00 ;                    //(P1.2/ECI, P1.1/CCP0, P1.0/CCP1, P3.7/CCP2)
  52.     CCON = 0;                       //初始化PCA控制寄存器
  53.                                     //PCA定时器停止
  54.                                     //清除CF标志
  55.                                     //清除模块中断标志
  56.     CL = 0;                         //复位PCA寄存器
  57.     CH = 0;
  58.     CCAP0L = 0;
  59.     CCAP0H = 0;
  60.     CMOD = 0x09;                    //设置PCA时钟源为系统时钟,且使能PCA计时溢出中断
  61.     CCAPM0 = 0x21;                  //PCA模块0为16位捕获模式(上升沿捕获,可测从高电平开始的整个周期),且产生捕获中断
  62. //  CCAPM0 = 0x11;                  //PCA模块0为16位捕获模式(下降沿捕获,可测从低电平开始的整个周期),且产生捕获中断
  63. //  CCAPM0 = 0x31;                  //PCA模块0为16位捕获模式(上升沿/下降沿捕获,可测高电平或者低电平宽度),且产生捕获中断
  64.     CR = 1;                         //PCA定时器开始工作
  65.     EA = 1;

  66.     cnt = 0;
  67.     count0 = 0;
  68.     count1 = 0;
  69. }
  70. /*----------------------------
  71. PCA 中断服务程序
  72. -----------------------------*/
  73. void PCA_isr() interrupt 7
  74. {
  75.     if (CCF0)
  76.     {
  77.         CCF0 = 0;
  78.         if (CF && ((CCAP0H & 0x80) == 0))
  79.         {
  80.             CF = 0;
  81.             cnt++;
  82.         }
  83.         count0 = count1;            //备份上一次的捕获值
  84.         ((u8 *)&count1)[3] = CCAP0L;  //保存本次的捕获值
  85.         ((u8 *)&count1)[2] = CCAP0H;
  86.         ((u8 *)&count1)[1] = cnt;
  87.         ((u8 *)&count1)[0] = 0;
  88.         length = count1 - count0;   //计算两次捕获的差值,即得到时间长度
  89.         ((u8 *)&length)[0] = 0;
  90.     }
  91.     if (CF)
  92.     {
  93.         CF = 0;
  94.         cnt++;                      //PCA计时溢出次数+1
  95.     }
  96. }
  97. /*----------------------------
  98. UART 中断服务程序
  99. -----------------------------*/
  100. void Uart() interrupt 4 using 1
  101. {
  102.     if (RI)
  103.     {
  104.         RI = 0;                 //清除RI位
  105.         P0 = SBUF;              //P0显示串口数据

  106.     }
  107.     if (TI)
  108.     {
  109.         TI = 0;                 //清除TI位
  110.         busy = 0;               //清忙标志
  111.     }
  112. }

  113. /*----------------------------
  114. 发送串口数据
  115. ----------------------------*/
  116. void SendData(u8 dat)
  117. {
  118.     while (busy);               //等待前面的数据发送完成
  119.     ACC = dat;                  //获取校验位P (PSW.0)
  120.     if (P)                      //根据P来设置校验位
  121.     {
  122. #if (PARITYBIT == ODD_PARITY)
  123.         TB8 = 0;                //设置校验位为0
  124. #elif (PARITYBIT == EVEN_PARITY)
  125.         TB8 = 1;                //设置校验位为1
  126. #endif
  127.     }
  128.     else
  129.     {
  130. #if (PARITYBIT == ODD_PARITY)
  131.         TB8 = 1;                //设置校验位为1
  132. #elif (PARITYBIT == EVEN_PARITY)
  133.         TB8 = 0;                //设置校验位为0
  134. #endif
  135.     }
  136.     busy = 1;
  137.     SBUF = ACC;                 //写数据到UART数据寄存器
  138. }

  139. /*----------------------------
  140. 发送字符串
  141. ----------------------------*/
  142. void SendString(char *s)
  143. {
  144.     while (*s)                  //检测字符串结束标志
  145.     {
  146.         SendData(*s++);         //发送当前字符
  147.     }
  148. }
  149. /* 整型数转换为字符串,str-字符串指针,dat-待转换数,返回值-字符串长度 */
  150. u8 Int_To_String(u8 *str, int dat)
  151. {
  152.     u8 i = 0;
  153.     u8 len = 0;
  154.     u8 buf[6];
  155.    
  156.     if (dat < 0)  //如果为负数,首先取绝对值,并在指针上添加负号
  157.     {
  158.         dat = -dat;
  159.         *str++ = '-';
  160.         len++;
  161.     }
  162.     do {          //先转换为低位在前的十进制数组
  163.         buf[i++] = dat % 10;
  164.         dat /= 10;
  165.     } while (dat > 0);
  166.     len += i;     //i最后的值就是有效字符的个数
  167.     while (i-- > 0)   //将数组值转换为ASCII码反向拷贝到接收指针上
  168.     {
  169.         *str++ = buf[i] + '0';
  170.     }
  171.     *str = '\0';  //添加字符串结束符
  172.    
  173.     return len;   //返回字符串长度
  174. }
  175. void main()
  176. {
  177.        
  178. //    ACC = P_SW1;
  179. //    ACC &= ~(S1_S0 | S1_S1);    //S1_S0=0 S1_S1=0
  180.     P_SW1 = 0x00;                //(P3.0/RxD, P3.1/TxD)
  181. #if (PARITYBIT == NONE_PARITY)
  182.     SCON = 0x50;                //8位可变波特率
  183. #elif (PARITYBIT == ODD_PARITY) || (PARITYBIT == EVEN_PARITY) || (PARITYBIT == MARK_PARITY)
  184.     SCON = 0xda;                //9位可变波特率,校验位初始为1
  185. #elif (PARITYBIT == SPACE_PARITY)
  186.     SCON = 0xd2;                //9位可变波特率,校验位初始为0
  187. #endif

  188.     T2L = (65536 - (FOSC/4/BAUD));   //设置波特率重装值
  189.     T2H = (65536 - (FOSC/4/BAUD))>>8;
  190.     AUXR = 0x14;                //T2为1T模式, 并启动定时器2
  191.     AUXR |= 0x01;               //选择定时器2为串口1的波特率发生器
  192.     ES = 1;                     //使能串口1中断
  193.     EA = 1;
  194.         PCA_config();
  195.     SendString("STC15W408AS\r\nUart Test !\r\n");
  196.     while(1)
  197.         {
  198.                 SendString("时间间隔为:");
  199.                 Int_To_String(TX_BUF,length);
  200.                 SendString("\r\n");
  201.                 delay_ms(300);       
  202.         }

  203. }
复制代码

所有资料51hei提供下载:
串口.zip (52.55 KB, 下载次数: 148)
回复

使用道具 举报

ID:631012 发表于 2020-12-30 06:11 | 显示全部楼层
多谢,老兄的源码,多路继电器成功了。
回复

使用道具 举报

ID:361216 发表于 2022-6-15 14:42 | 显示全部楼层
谢谢,先试试来看。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

Powered by 单片机教程网

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