首页 > 新闻中心 > > 正文

stc12c2052AD的Keil C头文件

更新时间: 2006-02-27 14:42:17来源: 粤嵌教育浏览量:4285

/*
stc12c2052AD 头文件。
/*------------------------------------------------
Byte Registers
------------------------------------------------*/
sfr SP  =0x81;
sfr DPL =0x82;
sfr DPH =0x83;
sfr PCON=0x87;
sfr TCON=0x88;
sfr TMOD=0x89;
sfr TL0 =0x8A;
sfr TL1 =0x8B;
sfr TH0 =0x8C;
sfr TH1 =0x8D;
sfr SCON=0x98;
sfr SBUF=0x99;
sfr IE  =0xA8;
sfr IPH =0XB7;        /* 中断优先级扩展寄存器,用于定义扩展中断源的优先级    */
/*
    IPH^7空
    IPH^6(PPCA_LVDH)... PCA扩展定时器中断与低电压中断公用
    IPH^5(PADC_SPIH)... ADC模数转换与SPI传送结束中断公用
    IPH^4(PSH)......... ??
    IPH^3(PT1H)........
    IPH^2(PX1H)
    IPH^1(PT0H)
    IPH^0(PX0H)
*/
sfr IP =0xB8;        /* 通用中断源的优先级定义寄存器,与IPH合并使用        */
sfr PSW=0xD0;
sfr ACC=0xE0;
sfr B  =0xF0;

/* ----------------- P1口IO定义 ------------------- */
/* P1M0[7~0] P1M1[7~0]    方向作用                    */
/*    0            0        传统51准双向口模式            */
/*    0            1        推挽输出,上拉20mA            */
/*    1            0        高阻单向输入,AD必须。        */
/*    1            1        开漏输出,AD也可以选择        */
sfr P1  =0x90;                    /* P1口地址     */
sfr P1M0=0x91;                    /* P1口方向0    */
sfr P1M1=0x92;                    /* P1口方向1    */

/* ----------------- P3口IO定义 ------------------- */
/* P3M0[7~0] P3M1[7~0]    方向作用                    */
/*    0            0        传统51准双向口模式            */
/*    0            1        推挽输出,上拉20mA            */
/*    1            0        高阻单向输入,AD必须。        */
/*    1            1        开漏输出,AD也可以选择        */
sfr P3  =0xB0;                /* P3口地址     */
sfr P3M0=0xB1;                /* P3口方向0    */
sfr P3M1=0xB2;                /* P3口方向1    */

/*----------------- IAP/IAP 功能寄存器 ------------ */
sfr ISP_DATA =0XE2;            /* 收发数据寄存器    */
sfr ISP_ADDRH=0XE3;            /* 目标操作地址高8位*/
sfr ISP_ADDRL=0XE4;            /* 目标操作地址低8位*/
sfr ISP_CMD  =0XE5;            /* 操作指令寄存器    */
sfr ISP_TRIG =0XE6;            /* 触发寄存器        */
sfr ISP_CONTR=0XE7;            /* 控制寄存器        */

/* --------------- 新增功能控制寄存器 ------------- */
sfr AUXR=0X8E;            /*新增特殊功能寄存器*/
/*
其中:
    AUXR^7(T0x12)..    定时器ct0时钟源设定:0_atbit(传统1/12,1_atbit(1:1不分频;
    AUXR^6(T1x12)..    定时器ct1时钟源设定:0_atbit(传统1/12,1_atbit(1:1不分频;
    AUXR^5(UARTx6). 串口模式0时时钟设定:0_atbit(传统1/12^1_atbit(1/2 2分频;
    AUXR^4(EADCI).. ADC中断允许位:0_atbit(禁止,1_atbit(允许
    AUXR^3(ESPI)... SPI中断允许位:0_atbit(禁止,1_atbit(允许
    AUXR^2(ELVDI).. 低电压中断允许:0_atbit(禁止,1_atbit(允许
                    5V系统3.7V,3V系统2.4V以下发生中断
    AUXR^1/AUXR^0.. 保留
*/

sfr CLOCK_DIV=0XC7;        /* 空闲模式下的时钟分频,可进一步降低功耗    */
sfr WDT_CONTR=0XE1;        /* 看门狗控制寄存器                            */
/* 其中:
    WDT_CONTR^7(WDT_FLAG).. 看门狗溢出标志_atbit(1,可软件清零
    WDT_CONTR^6保留
    WDT_CONTR^5(EN_WDT).... 看门狗允许标志_atbit(1
    WDT_CONTR^4(CLR_WDT)... 看门狗清零_atbit(1,硬件自动回零
    WDT_CONTR^3(IDLE_WDT)..=1空闲模式下继续工作,_atbit(0空闲模式下不工作
    WDT_CONTR^2~0(PS2~0)... 看门狗溢出时间设定:
    0 0 0 ...... 2分频..... @20MHz下  39.3mS
    0 0 1 ...... 4分频..... @20MHz下  78.6mS
    0 1 0 ...... 8分频..... @20MHz下 157.3mS
    0 1 1 ......16分频..... @20MHz下 314.6mS
    1 0 0 ......32分频..... @20MHz下 629.1mS
    1 0 1 ......64分频..... @20MHz下  1.25S
    1 1 0 .....128分频..... @20MHz下   2.5S
    1 1 1 .....256分频..... @20MHz下    5S
    其他主频下的时间可以参照上表作相应换算。
*/
sfr SADDR         = 0XA9;        /* 从地址,未启用        */
sfr SADEN         = 0XB9;        /* 标识地址,未启用        */
sfr SPI_STATUS=0X84;        /* SPSTAT SPI状态寄存器 */
/*    其中:
    SPSTAT^7(SPIF).... SPI 传输完成标志。当一次串行传输完成时,SPIF 置位,
                        并当ESPI和EA 都置位时产生中断。当SPI 处于主模式且
                        SSIG_atbit(0 时,如果/SS 为输入并被驱动为低电平,SPIF
                        也将置位。SPIF标志通过软件向其写入“1”清零。
    SPSTAT^6(WCOL).... SPI 写冲突标志。在数据传输的过程中如果对SPI 数据寄
                        存器SPDAT 执行写操作,WCOL 将置位。WCOL 标志通过软
                        件向其写入“1”清零。
    SPSTAT^5~0保留
*/
sfr SPI_CONTR=0X85;        /* SPI控制寄存器SPCTL    */
/*    其中:
    SPCTL^7(SSIG)......    /SS 忽略。
                        1:MSTR(位4)确定器件为主机还是从机。
                        0:/SS 脚用于确定器件为主机还是从机。/SS 脚可作为I/O
                            口使用(见SPI 主从选择表)。
    SPCTL^6(SPEN)...... SPI 使能。1:SPI 使能。0:SPI 被禁止,所有SPI 管脚都作
                        为I/O 口使用。   
    SPCTL^5(DORD)...... SPI 数据顺序:1:数据字的LSB(位) 发送;
                        0:数据字的MSB(位) 发送。
    SPCTL^4(MSTR)...... 主/从模式选择(见SPI 主从选择表)。
    SPCTL^3(CPOL)...... SPI 时钟极性:1:SPICLK 空闲时为高电平。SPICLK 的前时
                        钟沿为下降沿而后沿为上升沿。0:SPICLK 空闲时为低电平。
                        SPICLK 的前时钟沿为上升沿而后沿为下降沿。
    SPCTL^2(CPHA)...... SPI 时钟相位选择:
                        1:数据在SPICLK 的前时钟沿驱动,并在后时钟沿采样。
                        0:数据在/SS 为低(SSIG=00)时被驱动,在SPICLK 的后时钟
                           沿被改变,并在前时钟沿被采样。
                            (注:SSIG_atbit(1 时的操作未定义)
    SPCTL^1~0(SPR1~0)...SPR0/SPR1是SPI 时钟速率选择控制位。
                        SPR1^SPR0:
                            0 0 -CPU_CLK/4
                            0 1 -CPU_CLK/16
                            1 0 -CPU_CLK/64
                            1 1 -CPU_CLK/128
*/
sfr SPI_DATA  =0X86;        /* SPI数据收发寄存器SPDAT    */
sfr ADC_CONTR =0XC5;        /* ADC控制寄存器            */
/*    其中:
    ADC_CONTR^7(ADC_POWER)..ADC 电源控制位。0:关闭;1:打开.
                            启动AD 转换前一定要确认AD 电源已打开,AD 转换结束
                            后关闭AD 电源可降低功耗,也可不关闭。初次打开内部
                            A/D 转换模拟电源,需适当延时,等内部模拟电源稳定
                            后,再启动A/D 转换建议启动A/D 转换后,在A/D 转换
                            结束之前,不改变任何I/O 口的状态,有利于高精度A/D
                            转换.
    ADC_CONTR^6~5(SPEED1~0).模数转换器转换速度控制位
        SPEED1 SPEED0         A/D 转换所需时间
            1     1            210个时钟周期转换一次,CPU 工作频率20MHz 时,A/D转
                            换速度约 100KHz
            1    0            420个时钟周期转换一次
            0    1            630个时钟周期转换一次
            0    0            840个时钟周期转换一次
    ADC_CONTR^4(ADC_FLAG)...模数转换器转换结束标志位,当A/D 转换完成后,ADC_FLAG
                            _atbit( 1,要由软件清0。不管是A/D 转换完成后由该位申请产
                            生中断,还是由软件查询该标志位A/D 转换是否结束,当A/D
                             转换完成后,ADC_FLAG= 1,一定要软件清0。
    ADC_CONTR^3(ADC_START)...模数转换器(ADC)转换启动控制位,设置为1时,开始转换
    ADC_CONTR^2~0(CHS2~0)....CHS0:模拟输入通道选择
        CHS2 CHS1 CHS0    模拟输入通道选择
            0 0 0         选择 P1.0 作为A/D 输入来用
            0 0 1         选择 P1.1 作为A/D 输入来用
            0 1 0         选择 P1.2 作为A/D 输入来用
            0 1 1         选择 P1.3 作为A/D 输入来用
            1 0 0         选择 P1.4 作为A/D 输入来用
            1 0 1         选择 P1.5 作为A/D 输入来用
            1 1 0         选择 P1.6 作为A/D 输入来用
            1 1 1         选择 P1.7 作为A/D 输入来用
*/
sfr ADC_DATA=0XC6;        /* A/D 转换结果特殊功能寄存器 */
sfr CCON=0XD8;        /* PCA 控制寄存器,支持位寻址后面有定义*/
/*    其中:
    CCON^7(CF)......PCA计数器阵列溢出标志。计数值翻转时该位由硬件置位。
                    如果CMOD寄存器的ECF位置位, CF标志可用来产生中断。
                    CF位可通过硬件或软件置位, 但只可通过软件清零。
    CCON^6(CR)......PCA计数器阵列运行控制位。该位通过软件置位, 用来起
                    动PCA计数器阵列计数。该位通过软件清零, 用来关闭
                    PCA计数器。
    CCON^5~2保留
    CCON^1(CCF1)....PCA模块1中断标志。当出现匹配或捕获时该位由硬件置位。
                    该位必须通过软件清零。
    CCON^0(CCF0)....PCA模块0中断标志。当出现匹配或捕获时该位由硬件置位。
                    该位必须通过软件清零。
*/

sfr CMOD    =0XD9;        /* PCA 模式寄存器 */
/*    其中:
    CMOD^7(CIDL)....计数器阵列空闲控制:CIDL_atbit(0时,空闲模式下PCA计数器继
                    续工作。CIDL=1时,空闲模式下PCA计数器停止工作。
    CMOD^6~3保留
    CMOD^2~1(CPS1,CPS0)PCA计数脉冲选择
        CPS1 CPS0     选择PCA 时钟源输入
        0    0         0,内部时钟,Fosc/12
        0    1        1,内部时钟,Fosc/2
        1    0        2,定时器0溢出,由于定时器0可以工作在1T方式,所以可以
                        达到计一个时钟就溢出, 频率反而是的, 可达
                        到Fosc
        1    1        3,ECI/P3.4脚的外部时钟输入(速率_atbit(Fosc/2)
    CMOD^0(ECF).....PCA计数溢出中断使能:ECF_atbit(1时,使能寄存器CCON CF位的
                    中断。ECF_atbit(0时,禁止该功能。
*/

sfr CH            = 0XF9;        /* PCA计数器初始值高8位    */
sfr CL         = 0XE9;        /* PCA计数器初始值低8位    */
sfr CCAPM0    =0XDA;        /* PCA 比较/ 捕获模块寄存器0    */
/*
    CCAPM0^7保留
    CCAPM0^6(ECOM0)........ 使能比较器。ECOM0= 1时使能比较器功能。
    CCAPM0^5(CAPP0)........ 正捕获。CAPP0= 1时使能上升沿捕获。
    CCAPM0^4(CAPN0)........ 负捕获。CAPN0= 1时使能下降沿捕获。
    CCAPM0^3(MAT0)......... 匹配。当MAT0= 1时, PCA计数值与模块的比较/捕获寄
                            存器的值的匹配将置位CCON寄存器的中断标志位CCF0。
    CCAPM0^2(TOG0).........    翻转。当TOG0= 1时, PCA计数值与模块的比较/捕获寄
                            存器的值的匹配将使CEXn脚翻转。(CEX0/P3.7)
    CCAPM0^1(PWM0)......... 脉宽调节模式。当PWM0= 1时, 使能CEXn脚用作脉宽调
                            节输出。
    CCAPM0^0(ECCF0)........ 使能CCF0中断。使能寄存器CCON的比较/捕获标志CCF0,
                            用来产生中断。
使用的机种基本模式组合:
 ECOM0 CAPP0 CAPN0 MAT0    TOG0 PWM0 ECCF0            模块功能
    0    0      0        0    0     0        0        无此操作
    X    1      0        0    0     0        X        16位捕获模式,由CEX0的上升沿触发
    X    0      1        0    0     0        X        16位捕获模式,由CEX0的下降沿触发
    X    1      1        0    0     0        X        16位捕获模式,由CEX0的跳变触发
    1    0      0        1    0     0        X        16位软件定时器
    1    0      0        1    1     0        X        16位高速输出
    1    0      0        0    0     1        0        8位PWM
*/
sfr CCAP0H   =0XFA;        /* 当出现捕获或比较时,它们用来保存16 位的计数值。
                               当PCA 模块用在PWM 模式中时,它们用来控制输出的
                               占空比。CCAP0H.CCAP0L分别为高低8位,组合使用    */
sfr CCAP0L   =0XEA;
sfr PCA_PWM0 =0XF2;        /* PWM下9位数的位
                                PCA_PWM0^1(EPC0H)....在PWM模式下,与CCAP0H组成9位数
                                PCA_PWM0^0(EPC0L)....在PWM模式下,与CCAP0L组成9位数
                            */
sfr CCAPM1  =0XDB;        /* PCA 比较/ 捕获模块寄存器1,支持位寻址定义在后面 */
/*
    CCAPM1^7保留
    CCAPM1^6(ECOM1)........ 使能比较器。ECOM1= 1时使能比较器功能。
    CCAPM1^5(CAPP1)........ 正捕获。CAPP1= 1时使能上升沿捕获。
    CCAPM1^4(CAPN1)........ 负捕获。CAPN1= 1时使能下降沿捕获。
    CCAPM1^3(MAT1)......... 匹配。当MAT1= 1时, PCA计数值与模块的比较/捕获寄
                            存器的值的匹配将置位CCON寄存器的中断标志位CCF1。
    CCAPM1^2(TOG1).........    翻转。当TOG1= 1时, PCA计数值与模块的比较/捕获寄
                            存器的值的匹配将使CEXn脚翻转。(CEX1/P3.5)
    CCAPM1^1(PWM1)......... 脉宽调节模式。当PWMn= 1时, 使能CEXn脚用作脉宽调
                            节输出。
    CCAPM1^0(ECCF1)........ 使能CCF1中断。使能寄存器CCON的比较/捕获标志CCF1,
                            用来产生中断。

使用的机种基本模式组合:
 ECOM1 CAPP1 CAPN1 MAT1    TOG1 PWM1 ECCF1            模块功能
    0    0      0        0    0     0        0        无此操作
    X    1      0        0    0     0        X        16位捕获模式,由CEX1的上升沿触发
    X    0      1        0    0     0        X        16位捕获模式,由CEX1的下降沿触发
    X    1      1        0    0     0        X        16位捕获模式,由CEX1的跳变触发
    1    0      0        1    0     0        X        16位软件定时器
    1    0      0        1    1     0        X        16位高速输出
    1    0      0        0    0     1        0        8位PWM
*/
sfr CCAP1H   =0XFB;        /* 当出现捕获或比较时,它们用来保存16 位的计数值。
                               当PCA 模块用在PWM 模式中时,它们用来控制输出的
                               占空比。CCAP1H.CCAP1L分别为高低8位,组合使用    */

sfr CCAP1L   =0XEB;
sfr PCA_PWM1 =0XF3;        /* PWM下9位数的位
                                PCA_PWM1^1(EPC1H)....在PWM模式下,与CCAP1H组成9位数
                                PCA_PWM1^0(EPC1L)....在PWM模式下,与CCAP1L组成9位数
                            */


/*------------------------------------------------
PCON Bit Values
------------------------------------------------*/
#define IDL_    0x01
#define STOP_   0x02
#define EWT_    0x04
#define EPFW_   0x08
#define WTR_    0x10
#define PFW_    0x20
#define POR_    0x40
#define SMOD_   0x80

/*------------------------------------------------
TCON Bit Registers
------------------------------------------------*/
sbit     IT0=TCON^0;
sbit     IE0=TCON^1;
sbit     IT1=TCON^2;
sbit     IE1=TCON^3;
sbit     TR0=TCON^4;
sbit     TF0=TCON^5;
sbit     TR1=TCON^6;
sbit     TF1=TCON^7;

/*------------------------------------------------
TMOD Bit Values
------------------------------------------------*/
#define T0_M0_   0x01
#define T0_M1_   0x02
#define T0_CT_   0x04
#define T0_GATE_ 0x08
#define T1_M0_   0x10
#define T1_M1_   0x20
#define T1_CT_   0x40
#define T1_GATE_ 0x80

#define T1_MASK_ 0xF0
#define T0_MASK_ 0x0F

/*------------------------------------------------
P1 Bit Registers
------------------------------------------------*/
sbit     P1_0= P1^0;
sbit     P1_1= P1^1;
sbit     P1_2= P1^2;
sbit     P1_3= P1^3;
sbit     P1_4= P1^4;
sbit     P1_5= P1^5;
sbit     P1_6= P1^6;
sbit     P1_7= P1^7;

sbit     ADC0= P1^0;       /* + Analog input */
sbit     ADC1= P1^1;       /* + Analog input */
sbit     ADC2= P1^2;       /* + Analog input */
sbit     ADC3= P1^3;       /* + Analog input */
sbit     ADC4= P1^4;       /* + Analog input */
sbit     ADC5= P1^5;       /* + Analog input */
sbit     ADC6= P1^6;       /* + Analog input */
sbit     ADC7= P1^7;       /* + Analog input */

/* SPI 专用IO */
sbit     SS  = P1^4;        /* 主从SPI选择,外部输入P1.4_atbit(0为从机*/
sbit     MOSI= P1^5;        /* 主输出/从输入    */
sbit     MISO= P1^6;        /* 主输入/从输出    */
sbit     SCLK= P1^7;        /* SPI时钟,主方输出,从方接收    */

/*------------------------------------------------
SCON Bit Registers
------------------------------------------------*/
sbit     RI  = SCON^0;
sbit     TI  = SCON^1;
sbit     RB8 = SCON^2;
sbit     TB8 = SCON^3;
sbit     REN = SCON^4;
sbit     SM2 = SCON^5;
sbit     SM1 = SCON^6;
sbit     SM0 = SCON^7;

/*------------------------------------------------
IE Bit Registers
------------------------------------------------*/
sbit     EX0 = IE^0;       /* 1_atbit(Enable External interrupt 0 */
sbit     ET0 = IE^1;       /* 1_atbit(Enable Timer 0 interrupt */
sbit     EX1 = IE^2;       /* 1_atbit(Enable External interrupt 1 */
sbit     ET1 = IE^3;       /* 1_atbit(Enable Timer 1 interrupt */
sbit     ES  = IE^4;       /* 1_atbit(Enable Serial port interrupt */
sbit     ET2 = IE^5;       /* 1_atbit(Enable Timer 2 interrupt */

sbit     EA  = IE^7;       /* 0_atbit(Disable all interrupts */

/*------------------------------------------------
P3 Bit Registers (Mnemonics & Ports)
------------------------------------------------*/
sbit     P3_0= P3^0;
sbit     P3_1= P3^1;
sbit     P3_2= P3^2;
sbit     P3_3= P3^3;
sbit     P3_4= P3^4;
sbit     P3_5= P3^5;
/* P3_6 Hardwired as AOUT */
sbit     P3_7= P3^7;

sbit     RXD = P3^0;       /* Serial data input */
sbit     TXD = P3^1;       /* Serial data output */
sbit     INT0= P3^2;       /* External interrupt 0 */
sbit     INT1= P3^3;       /* External interrupt 1 */
sbit     T0  = P3^4;       /* Timer 0 外部时钟输入口P3.4 */
sbit     ECI = P3^4;       /* PCA计数器阵列的可选外部时钟输入口P3.4 */
sbit     T1  = P3^5;       /* Timer 1 外部时钟输入口P3.5 */
sbit     CEX1= P3^5;        /* PCA计数器与模块的比较/捕获寄存器的值的匹配时的输出口*/
sbit     PWM1= P3^5;        /* PWM方式时PWM1的输出口P3.5/PCA1反相输出*/
sbit     CEX0= P3^7;        /* PCA计数器与模块的比较/捕获寄存器的值的匹配时的输出口*/
sbit     PWM0= P3^7;        /* PWM方式时PWM0的输出口P3.7/PCA0反相输出*/

/*------------------------------------------------
IP 中断优先级寄存器低8位
------------------------------------------------*/
sbit     PX0 = IP^0;        /* 外部中断0 P3.2    */
sbit     PT0 = IP^1;        /* 定时计数器0中断    */
sbit     PX1 = IP^2;        /* 外部中断1 P3.3    */
sbit     PT1 = IP^3;        /* 定时计数器1中断    */
sbit     PS  = IP^4;        /* 通信中断RI或TI    */

/*------------------------------------------------
PSW Bit Registers
------------------------------------------------*/
sbit     P   = PSW^0;
sbit     FL  = PSW^1;
sbit     OV  = PSW^2;
sbit     RS0 = PSW^3;
sbit     RS1 = PSW^4;
sbit     F0  = PSW^5;
sbit     AC  = PSW^6;
sbit     CY  = PSW^7;

/*------------------------------------------------
PCA 控制寄存器CCON Bit Registers
------------------------------------------------*/
sbit     CCF0= CCON^0;    /*PCA模块0中断标志。当出现匹配或捕获时该位由硬件置位。
                      该位必须通过软件清零。*/
sbit     CCF1= CCON^1;    /*PCA模块1中断标志。当出现匹配或捕获时该位由硬件置位。
                      该位必须通过软件清零。*/
sbit     CR  = CCON^6;    /*PCA计数器阵列运行控制位。该位通过软件置位, 用来起
                      动PCA计数器阵列计数。该位通过软件清零, 用来关闭
                      PCA计数器。*/
sbit     CF  = CCON^7;    /*PCA计数器阵列溢出标志。计数值翻转时该位由硬件置位。
                      如果CMOD寄存器的ECF位置位, CF标志可用来产生中断。
                      CF位可通过硬件或软件置位, 但只可通过软件清零。*/

免费预约试听课