【VSCode PlatformIO】 STC单片机开发头文件制作与添加方法

【VSCode PlatformIO】 STC单片机开发头文件制作与添加方法


本着授人以鱼不如授人以渔的精神,今天教大家如何制作基于VSCode PlatformIO平台开发STC系列单片机头文件制作以及添加方法。

STC系列头文件准备

  • STC系列头文件获取途径:
    • 通过STC官方工具STC-ISP,找到自己所需型号的头文件,点击下面的“保存文件”按钮进行保存。格式是后缀带.h的格式。
      在这里插入图片描述

开始头文件转换工作

  1. 新建一个VSCode项目文件夹,名字随便自己爱好随便取。将上面保存下来的头文件放到这个文件夹里面。
    在这里插入图片描述
  2. 在项目文件夹上鼠标右键,通过VSCode打开。
    在这里插入图片描述
  3. 在项目里面新建一个后缀名为.cpp的文件。
    . 在这里插入图片描述
  4. .cpp文件内添加如下代码:
    注意:修改string filename = "STC11.h";//这里填写同目录里的STC头文件名称,包含后缀名。
#include <iostream>
#include <fstream>
#include <string>

using namespace std;

int main(int argc, char *args[])
{
  string filename = "STC11.h";//这里填写同目录里的STC头文件名称包含后缀名。
  ifstream file_in(filename.c_str());

  string s;
  string previous_addr;
  while (getline(file_in, s))
  {
    if (s[0] == '/' || s[0] == '#')
      cout << s << endl;
    else if (s.length() > 4)
    {
      string::size_type type_end = s.find_first_of(' ');
      string type = s.substr(0, type_end);

      string::size_type name_begin = s.find_first_not_of(' ', type_end);
      string::size_type name_end = s.find_first_of(' ', name_begin);
      string name = s.substr(name_begin, name_end - name_begin);

      string::size_type addr_begin = s.find_first_not_of(" =", name_end);
      string::size_type addr_end = s.find_first_of(" ;", addr_begin);
      string addr = s.substr(addr_begin, addr_end - addr_begin);

      string comment;
      bool haveComment = true;
      if (addr_end == s.length() - 1)
      {
        haveComment = false;
      }

      if (haveComment)
      {
        string::size_type comment_begin = s.find_first_not_of("; ", addr_end);
        comment = s.substr(comment_begin);
      }

      if (type == "sfr")
      {
        cout << "SFR(" << name << ", " << addr << ");";
        if (haveComment)
          cout << comment;
        cout << endl;
        previous_addr = addr;
      }
      else if (type == "sbit")
      {
        string bit_offset = addr.substr(addr.length() - 1);

        cout << "SBIT(" << name << ", " << previous_addr << ", " << bit_offset << ");";
        if (haveComment)
          cout << comment;
        cout << endl;
      }
    }
  }
  return 0;
}
  1. 在代码编辑区域内,鼠标右键-Run Code.,在调试终端将输出转换后的信息,将其全部复制保存为所需要的SDCC头文件名称。

在这里插入图片描述

  • VSCode编译运行所依赖的插件需要自己下载。(没记错的话应该必须安装下面这两个。)
    在这里插入图片描述
  • 完善头文件,在头文件前面补充几个引用头文件,以方便主程序调用,消除引用异常而导致关键字上出现波浪线
#include <8051.h>
#include <compiler.h>
#include <stdbool.h>
#ifdef REG8051_H
#undef REG8051_H
#endif
  1. 将完善的头文件保存到VSCode PlatformIO 的SDCC目录对应的单片机目录下面:

例如我的电脑所在位置:C:\Users\Administrator\.platformio\packages\toolchain-sdcc\include\mcs51

  • 如果是安装的独立SDCC编译器的话,就放置mcs51目录下面:

例如我的电脑安装的位置:D:\Program Files\SDCC\include\mcs51

例如我转换后的STC11.h头文件

基本上一次到位,主要是注释内容有些是换行的内容做一下调整就可以了,需要处理的基本都处理了。

/*------------------------------------------------*/
/* --- 宏晶科技 STCMCU ---------------------------*/
/* --- Mobile: (86)13922805190 -------------------*/
/* --- Fax: 86-755-82944243 ----------------------*/
/* --- Tel: 86-755-82948412 ----------------------*/
/* --- Web: www.STCMCU.com -----------------------*/
/* 适用于: STC11Fxx   STC11Lxx -------------------*/
/* ------- STC11FxxX  STC11LxxX ------------------*/
/* ------- STC11FxxE  STC11LxxE ------------------*/
/* ------- STC11FxxXE STC11LxxXE -----------------*/
/* ------- IAP11Fxx   IAP11Lxx  ------------------*/
/* ------- IAP11FxxE  IAP11LxxE ------------------*/
/* ------- IAP11FxxXE IAP11LxxXE -----------------*/
/*------------------------------------------------*/
#ifndef __STC11_H__
#define __STC11_H__
#include <8051.h>
#include <compiler.h>
#include <stdbool.h>
#ifdef REG8051_H
#undef REG8051_H
#endif

SFR(PSW, 0xd0);//程序状态字            Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
SBIT(CY, 0xd0, 7);//进位标志
SBIT(AC, 0xd0, 6);//辅助进位标志
SBIT(F0, 0xd0, 5);//用户标志
SBIT(RS1, 0xd0, 4);//寄存器组选择位1
SBIT(RS0, 0xd0, 3);//寄存器组选择位0
SBIT(OV, 0xd0, 2);//溢出标志
SBIT(P, 0xd0, 0);//ACC的偶校验位
/
SFR(ACC, 0xe0);//累加器                Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
SBIT(ACC7, 0xe0, 7);//累加器第7位
SBIT(ACC6, 0xe0, 6);//累加器第6位
SBIT(ACC5, 0xe0, 5);//累加器第5位
SBIT(ACC4, 0xe0, 4);//累加器第4位
SBIT(ACC3, 0xe0, 3);//累加器第3位
SBIT(ACC2, 0xe0, 2);//累加器第2位
SBIT(ACC1, 0xe0, 1);//累加器第1位
SBIT(ACC0, 0xe0, 0);//累加器第0位
/
SFR(B, 0xf0);//B寄存器               Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0 
/
SFR(SP, 0x81);//堆栈指针              Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0/
SFR(DPL, 0x82);//数据指针低字节        Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
/
SFR(DPH, 0x83);//数据指针高字节        Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0

SFR(PCON, 0x87);//电源控制寄存器        Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
#define SMOD        0x80        //串口波特率倍速位,置1可使波特率快1倍
#define SMOD0       0x40        //FE/SM0选择位,0:SCON.7为SM0 1:SCON.7为FE
#define LVDF        0x20        //低压检测中断请求位,由硬件置1,需由软件清0
#define POF         0x10        //上电复位标志位,上电时由硬件置1,需由软件清0
#define GF1         0x08        //通用标志位1
#define GF0         0x04        //通用标志位0
#define PD          0x02        //掉电控制位,写1可以使MCU进入PowerDown模式
#define IDL         0x01        //空闲控制位,写1可以使MCU进入Idle模式
/
SFR(WAKE_CLKO, 0x8f);//掉电唤醒/时钟输出控制 Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1   Bit0
#define RXD_PIN_IE  0x40        //允许RXD(P3.0)下降沿置位RI中断时唤醒掉电MCU(必须打开相应中断)    
#define T1_PIN_IE   0x20        //允许T1(P3.5)下降沿置位T1中断时唤醒掉电MCU(必须打开相应中断)     
#define T0_PIN_IE   0x10        //允许T0(P3.4)下降沿置位T0中断时唤醒掉电MCU(必须打开相应中断)     
#define BRTCLKOEN   0x04        //打开P1.0脚的BRT时钟溢出脉冲,输出的时钟频率为1/2倍的BRT溢出率    
#define T1CLKOEN    0x02        //打开P3.5脚的定时器1时钟溢出脉冲,输出的时钟频率为1/2倍的T1溢出率 
#define T0CLKOEN    0x01        //打开P3.4脚的定时器0时钟溢出脉冲,输出的时钟频率为1/2倍的T0溢出率 
/
SFR(CLK_DIV, 0x97);//时钟分频寄存器        Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1   
 Bit0
#define FOSCD1      0x00        //系统时钟为Fosc
#define FOSCD2      0x01        //系统时钟为Fosc/2
#define FOSCD4      0x02        //系统时钟为Fosc/4
#define FOSCD8      0x03        //系统时钟为Fosc/8
#define FOSCD16     0x04        //系统时钟为Fosc/16
#define FOSCD32     0x05        //系统时钟为Fosc/32
#define FOSCD64     0x06        //系统时钟为Fosc/64
#define FOSCD128    0x07        //系统时钟为Fosc/128
/
SFR(BUS_SPEED, 0xa1);//数据总线速度控制器    Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1 
   Bit0
#define ALES1       0x20        //P0地址建立时间和保持时间到ALE信号的下降沿的时钟数
#define ALES0       0x10        //ALES1/ALES0=0/0:1个时钟 0/1:2个时钟 1/0:3个时钟 1/1:4个时钟     
#define RWS2        0x04        //MOVX指令的时钟数
#define RWS1        0x02        //RWS2/RWS1/RWS0=000:1个时钟 001:2个时钟 010:3个时钟 011:4个时钟  
#define RWS0        0x01        //               100:5个时钟 101:6个时钟 110:7个时钟 111:8个时钟  
/
SFR(WKTCL, 0xaa);//掉电唤醒定时器低字节  Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
/
SFR(WKTCH, 0xab);//掉电唤醒定时器高字节  Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
#define WKTEN       0x80        //掉电唤醒定时器使能位,置1时,当CPU进入掉电模式后开始计时,计时单周 
期约为560us,最大可计4095(大约2.3s)
/
SFR(WDT_CONTR, 0xc1);//看门狗定时器控制器    Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1 
   Bit0
#define WDT_FLAG    0x80        //看门狗复位标志,当看门狗溢出产生复位后,硬件自动置1,需要由软件清0 
#define EN_WDT      0x20        //软件使能看门狗,打开后不能用软件的方式关闭
#define CLR_WDT     0x10        //清看门狗定时器
#define IDLE_WDT    0x08        //IDLE模式下,看门狗定时器是否继续计时

SFR(AUXR, 0x8e);//辅助寄存器            Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
#define T0x12       0x80        //定时器0时钟控制,0:Fosc/12(传统的12分频) 1:Fosc/1(1T模式,不分频, 即12倍于传统速度)
#define T1x12       0x40        //定时器1时钟控制,0:Fosc/12(传统的12分频) 1:Fosc/1(1T模式,不分频, 即12倍于传统速度)
#define UR0x6       0x20        //串口模式0的时钟控制,0:Fosc/12(传统的12分频) 1:Fosc/2(2分频,,即6倍于传统速度)
#define BRTR        0x10        //独立波特率发生器启动控制位,1:启动独立波特率发生器 0:停止独立波特率发生器
#define BRTx12      0x04        //独立波特率发生器时钟控制,0:Fosc/12(传统的12分频) 1:Fosc/1(1T模式,不分频,即12倍于传统速度)
#define EXTRAM      0x02        //内部扩展RAM禁能位,0:内部扩展RAM有效 1:禁用内部扩展RAM
#define S1BRS       0x01        //串口1的波特率发生器选择位,0:定时器1 1:独立波特率发生器(注意串口2只能够使用独立波特率发生器)
/
SFR(AUXR1, 0xa2);//辅助寄存器1           Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
#define UAER_P1     0x80        //将串口映射到P1口,0:RXD(P3.0)TXD(P3.1) 1:RXD2(P1.6)TXD2(P1.7)    
#define GF2         0x08        //通用标志位2
#define DPS         0x01        //DPTR0/DPTR1选择位,0:DPTR0 1:DPTR1

SFR(P0, 0x80);//I/O端口0              Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0SBIT(P07, 0x80, 7);//I/O口P0.7
SBIT(P06, 0x80, 6);//I/O口P0.6
SBIT(P05, 0x80, 5);//I/O口P0.5
SBIT(P04, 0x80, 4);//I/O口P0.4
SBIT(P03, 0x80, 3);//I/O口P0.3
SBIT(P02, 0x80, 2);//I/O口P0.2
SBIT(P01, 0x80, 1);//I/O口P0.1
SBIT(P00, 0x80, 0);//I/O口P0.0
/
SFR(P1, 0x90);//I/O端口0              Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0SBIT(P17, 0x90, 7);//I/O口P1.7
SBIT(P16, 0x90, 6);//I/O口P1.6
SBIT(P15, 0x90, 5);//I/O口P1.5
SBIT(P14, 0x90, 4);//I/O口P1.4
SBIT(P13, 0x90, 3);//I/O口P1.3
SBIT(P12, 0x90, 2);//I/O口P1.2
SBIT(P11, 0x90, 1);//I/O口P1.1
SBIT(P10, 0x90, 0);//I/O口P1.0
SBIT(P1TXD, 0x90, 7);//可选串口数据输出脚
SBIT(P1RXD, 0x90, 6);//可选串口数据输入脚
SBIT(BRTCLKO, 0x90, 0);//BRT时钟溢出脉冲输出脚
/
SFR(P2, 0xa0);//I/O端口2              Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0SBIT(P27, 0xa0, 7);//I/O口P2.7
SBIT(P26, 0xa0, 6);//I/O口P2.6
SBIT(P25, 0xa0, 5);//I/O口P2.5
SBIT(P24, 0xa0, 4);//I/O口P2.4
SBIT(P23, 0xa0, 3);//I/O口P2.3
SBIT(P22, 0xa0, 2);//I/O口P2.2
SBIT(P21, 0xa0, 1);//I/O口P2.1
SBIT(P20, 0xa0, 0);//I/O口P2.0
/
SFR(P3, 0xb0);//I/O端口3              Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0SBIT(P37, 0xb0, 7);//I/O口P3.7
SBIT(P36, 0xb0, 6);//I/O口P3.6
SBIT(P35, 0xb0, 5);//I/O口P3.5
SBIT(P34, 0xb0, 4);//I/O口P3.4
SBIT(P33, 0xb0, 3);//I/O口P3.3
SBIT(P32, 0xb0, 2);//I/O口P3.2
SBIT(P31, 0xb0, 1);//I/O口P3.1
SBIT(P30, 0xb0, 0);//I/O口P3.0
SBIT(RXD, 0xb0, 0);//串口1的数据接收口
SBIT(TXD, 0xb0, 1);//串口1的数据发送口
SBIT(INT0, 0xb0, 2);//外部中断0的信号输入口
SBIT(INT1, 0xb0, 3);//外部中断1的信号输出口
SBIT(T0, 0xb0, 4);//定时器0的外部信号输入口
SBIT(T1, 0xb0, 5);//定时器1的外部信号输入口
SBIT(WR, 0xb0, 6);//外部数据存储器的写信号
SBIT(RD, 0xb0, 7);//外部数据存储器的读信号
SBIT(T0CLKO, 0xb0, 4);//定时器0的时钟溢出脉冲输出脚
SBIT(T1CLKO, 0xb0, 5);//定时器1的时钟溢出脉冲输出脚
/
SFR(P4, 0xc0);//I/O端口4              Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0SBIT(P47, 0xc0, 7);//I/O口P4.7
SBIT(P46, 0xc0, 6);//I/O口P4.6
SBIT(P45, 0xc0, 5);//I/O口P4.5
SBIT(P44, 0xc0, 4);//I/O口P4.4
SBIT(P43, 0xc0, 3);//I/O口P4.3
SBIT(P42, 0xc0, 2);//I/O口P4.2
SBIT(P41, 0xc0, 1);//I/O口P4.1
SBIT(P40, 0xc0, 0);//I/O口P4.0
/
SFR(P1M1, 0x91);//I/O口1模式控制器1     Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
/
SFR(P1M0, 0x92);//I/O口1模式控制器0     Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
/
SFR(P0M1, 0x93);//I/O口0模式控制器1     Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
/
SFR(P0M0, 0x94);//I/O口0模式控制器0     Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
/
SFR(P2M1, 0x95);//I/O口2模式控制器1     Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
/
SFR(P2M0, 0x96);//I/O口2模式控制器0     Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
/
SFR(P3M1, 0xb1);//I/O口3模式控制器1     Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
/
SFR(P3M0, 0xb2);//I/O口3模式控制器0     Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
/
SFR(P4M1, 0xb3);//I/O口4模式控制器1     Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
/
SFR(P4M0, 0xb4);//I/O口4模式控制器0     Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
/
// PxM1 PxM0
//  0    0     准双向口
//  0    1     强推挽输出
//  1    0     高阻输入态
//  1    1     开漏输出
/
SFR(P4SW, 0xbb);//P4口的功能开关        Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
#define P46EN       0x40        //传统的EA脚 0:无任何功能 1:为P4.6
#define P45EN       0x20        //传统的ALE脚 0:仍为ALE 1:为P4.5
#define P44EN       0x10        //传统的PSEN脚 0:无任何功能 1:为P4.4

SFR(IE, 0xa8);//中断使能寄存器        Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0SBIT(EA, 0xa8, 7);//总中断开关
SBIT(ELVD, 0xa8, 6);//LVD中断使能位
SBIT(ES, 0xa8, 4);//串口中断使能位
SBIT(ET1, 0xa8, 3);//定时器1中断使能位
SBIT(EX1, 0xa8, 2);//外部中断1中断使能位
SBIT(ET0, 0xa8, 1);//定时器0中断使能位
SBIT(EX0, 0xa8, 0);//外部中断0中断使能位
#define X0_INTNO    0           //外部中断0中断号,入口地址为0003H
#define T0_INTNO    1           //定时器0中断号,入口地址为000BH
#define X1_INTNO    2           //外部中断1中断号,入口地址为0013H
#define T1_INTNO    3           //定时器1中断号,入口地址为001BH
#define UART_INTNO  4           //串口中断号,入口地址为0023H
#define LVD_INTNO   6           //LVD中断号,入口地址为0033H
/
SFR(IP, 0xb8);//中断优先级寄存器      Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0SBIT(PLVD, 0xb8, 6);//LVD中断优先级控制低位
SBIT(PS, 0xb8, 4);//串口中断优先级控制低位
SBIT(PT1, 0xb8, 3);//定时器1中断优先级控制低位
SBIT(PX1, 0xb8, 2);//外部中断1中断优先级控制低位
SBIT(PT0, 0xb8, 1);//定时器0中断优先级控制低位
SBIT(PX0, 0xb8, 0);//外部中断0中断优先级控制低位

SFR(TCON, 0x88);//定时器0/1控制寄存器   Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
SBIT(TF1, 0x88, 7);//定时器1溢出标志,由硬件置1,可由软件清0或者在中断处理程序完成后由硬件自动清0   
SBIT(TR1, 0x88, 6);//定时器1的启动控制位,1:启动定时器 0:停止定时器
SBIT(TF0, 0x88, 5);//定时器0溢出标志,由硬件置1,可由软件清0或者在中断处理程序完成后由硬件自动清0   
SBIT(TR0, 0x88, 4);//定时器0的启动控制位,1:启动定时器 0:停止定时器
SBIT(IE1, 0x88, 3);//外部中断1的中断请求位,由硬件置1,可由软件清0或者在中断处理程序完成后由硬件自动0
SBIT(IT1, 0x88, 2);//外部中断1的触发类型,0:低电平触发外部中断 1:下降沿触发外部中断
SBIT(IE0, 0x88, 1);//外部中断0的中断请求位,由硬件置1,可由软件清0或者在中断处理程序完成后由硬件自动0
SBIT(IT0, 0x88, 0);//外部中断0的触发类型,0:低电平触发外部中断 1:下降沿触发外部中断
/
SFR(TMOD, 0x89);//定时器0/1模式寄存器   Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
#define GATE1       0x80        //定时器1启动控制位,0:TR1为1时启动定时器1 1:TR1为1且INT1为高电平时
才启动定时器1
#define C_T1        0x40        //定时器/计数器选择位,0:定时器(时钟源为内部时钟) 1:计数器(时钟源为
T1引脚的外部时钟)
#define T1_M0       0x00        //定时器1操作模式0:13位定时器
#define T1_M1       0x10        //定时器1操作模式1:16位定时器
#define T1_M2       0x20        //定时器1操作模式2:8位自动重载定时器
#define T1_M3       0x30        //定时器1操作模式3:定时器1停止
#define GATE0       0x08        //定时器1启动控制位,0:TR0为1时启动定时器1 1:TR0为1且INT0为高电平时才启动定时器0
#define C_T0        0x04        //定时器/计数器选择位,0:定时器(时钟源为内部时钟) 1:计数器(时钟源为T0引脚的外部时钟)
#define T0_M0       0x00        //定时器0操作模式0:13位定时器
#define T0_M1       0x01        //定时器0操作模式1:16位定时器
#define T0_M2       0x02        //定时器0操作模式2:8位自动重载定时器
#define T0_M3       0x03        //定时器0操作模式3:TL0和TH0为两组独立8位定时器
/
SFR(TL0, 0x8a);//定时器0的低8位计数值  Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
/
SFR(TL1, 0x8b);//定时器1的低8位计数值  Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
/
SFR(TH0, 0x8c);//定时器0的高8位计数值  Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
/
SFR(TH1, 0x8d);//定时器1的高8位计数值  Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0

SFR(SCON, 0x98);//串口控制寄存器        Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
SBIT(FE, 0x98, 7);//帧错误检测位,当串口模块在接收数据时没有检测到正确的停止位时,FE被硬件置1,需要由
软件来清0(当SMOD0为1,FE有效)
SBIT(SM0, 0x98, 7);//串口模式设置位
SBIT(SM1, 0x98, 6);//SM0/SM1=0/0:移位寄存器 0/1:8位可变波特率 1/0:9位固定波特率 1/1:9位可变波特率 
SBIT(SM2, 0x98, 5);//自动地址识别使能位
SBIT(REN, 0x98, 4);//使能串口接收模块
SBIT(TB8, 0x98, 3);//发送的第9位数据
SBIT(RB8, 0x98, 2);//接收的第9位数据
SBIT(TI, 0x98, 1);//发送完成中断标志
SBIT(RI, 0x98, 0);//接收完成中断标志
/
SFR(SBUF, 0x99);//串口接收/发送数据     Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
/
SFR(BRT, 0x9c);//独立波特率发生器重载值Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
/
SFR(SADDR, 0xa9);//串口设备从地址寄存器  Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0
/
SFR(SADEN, 0xb9);//串口设备从地址屏蔽位  Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0

SFR(IAP_DATA, 0xc2);//IAP数据寄存器         Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1  
  Bit0
/
SFR(IAP_ADDRH, 0xc3);//IAP地址高位寄存器     Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1 
   Bit0
/
SFR(IAP_ADDRL, 0xc4);//IAP地址低位寄存器     Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1  Bit0
/
SFR(IAP_CMD, 0xc5);//IAP命令寄存器         Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1   
 Bit0
#define IAP_IDLE    0x00        //IAP待机命令
#define IAP_READ    0x01        //IAP读字节数据命令
#define IAP_PROGRAM 0x02        //IAP字节编程命令
#define IAP_ERASE   0x03        //IAP扇区擦除命令(每扇区512字节))
/
SFR(IAP_TRIG, 0xc6);//IAP命令触发寄存器     Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0

#define IAP_TRIG0   0x5a        //IAP功能触发命令1
#define IAP_TRIG1   0xa5        //IAP功能触发命令2
/
SFR(IAP_CONTR, 0xc7);//IAP控制寄存器         Bit7    Bit6    Bit5    Bit4    Bit3    Bit2    Bit1    Bit0

#define IAPEN       0x80        //IAP使能开关
#define SWBS        0x40        //软启动选择,0:从用户AP启动 1:从ISP启动
#define SWRST       0x20        //触发软件复位
#define CMD_FAIL    0x10        //IAP命令失败标志

#endif

版权声明:本文为CSDN博主「perseverance52」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_42880082/article/details/122761289

生成海报
点赞 0

perseverance52

我还没有学会写个人说明!

暂无评论

发表评论

相关推荐

【STM32】串口接收任意字符串

前言 之前写了一篇STM32hal库串口中断接收任意字符 实际上是不完美的,他接收到换行符就完蛋了。 花了点时间深入研究了一下hal库的串口中断函数,发现他其实是不完美的,有一些BUG。 所以查了资

【ESP32DEVKITV1学习笔记】点亮一盏LED灯

前言 现在大家的课设毕设啥的都喜欢往网上传数据,而对于这些课设毕设的模块选型都喜欢这么一个原则:快速上手。那么我首选esp系列的产品,教程多,易上手。 一、环境的搭建 之前用过ard