⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 reg5123.h

📁 Keil uVision2
💻 H
字号:
/*H***************************************************************************
* NAME: AT8XC5123.h           
*----------------------------------------------------------------------------
* PURPOSE: SFR definition - include file for KEIL
*****************************************************************************/
#ifndef _AT8XC5123_H_

#define _AT8XC5123_H_

#define Sfr(x, y)	sfr x = y
#define Sbit(x, y, z)   sbit x = y ^ z
#define Sfr16(x,y)	sfr16 x = y

/*----------------------------- C51 CORE -----------------------------------*/

Sfr (SP      , 0x81);			//Stack Pointer
Sfr16 (DPTR    , 0x82);		//16 bit Data Pointer 
Sfr (DPL     , 0x82);			//Data Pointer Low byte
Sfr (DPH     , 0x83);			//Data Pointer High Byte

Sfr (PSW     , 0xD0);			//Program Status Word
Sbit (CY     , PSW   , 7);		//Carry Flag
Sbit (AC     , PSW   , 6);		//Auxilary Carry Flag
Sbit (F0     , PSW   , 5);		//Flag 0 available to the user for general purpose
Sbit (RS1    , PSW   , 4);		//Register Bank Selector bit 1
Sbit (RS0    , PSW   , 3);		//Register Bank Selector bit 0
Sbit (OV     , PSW   , 2);		//Overflow Bit
Sbit (F1     , PSW   , 1);		//General Purpose Flag
Sbit (P      , PSW   , 0);		//Parity Bit

Sfr (A       , 0xE0);			//Accumulator
Sfr (ACC     , 0xE0);			//Accumulator
Sfr (B       , 0xF0);			//B register

/*----------------------- SYSTEM CONFIGURATION -----------------------------*/

Sfr (CKSEL   , 0x85);			//Clock Selection
Sfr (PCON    , 0x87);			//Power Control
Sfr (AUXR    , 0x8E);			//Auxilary Register 0
Sfr (CKCON0  , 0x8F);			//Clock Control Register 0
Sfr (CKRL    , 0x97);			//Clock Reload
Sfr (AUXR1   , 0xA2);			//Auxilary Register 1
Sfr (PLLCON  , 0xA3);			//Phase Lock Loop Control
Sfr (PLLDIV  , 0xA4);			//Phase Lock Loop Divider
Sfr (CKCON1  , 0xAF);			//Clock Control Register 0

/*---------------------------- INTERRUPTS ----------------------------------*/

Sfr (ISEL    , 0xA1);			//Interrupt Enable Control

Sfr (IEN0    , 0xA8);			//Interrupt Enable Control 0
Sbit (EA     , IEN0  , 7);		//Global Interrupts Enable/Disable Bit
Sbit (ES     , IEN0  , 4);		//Serial Port Interrupt Enable/Disable Bit
Sbit (ET1    , IEN0  , 3);		//Timer 1 Overflow Interrupt Enable/Disable Bit
Sbit (EX1    , IEN0  , 2);		//External Interrupt 1 Enable/Disable Bit
Sbit (ET0    , IEN0  , 1);		//Timer 0 Overflow Interrupt Enable/Disable Bit
Sbit (EX0    , IEN0  , 0);		//External Interrupt 0 Enable/Disable Bit

Sfr (IPH0    , 0xB7);			//Interrupt Priority Control High 0

Sfr (IPL0    , 0xB8);			//Interrupt Priority Control Low  0
Sbit (PSL   , IPL0  , 4);		//Serial Port Interrupt Priority LSB
Sbit (PT1L  , IPL0  , 3);		//Timer 1 Overflow Interrupt Priority LSB
Sbit (PX1L  , IPL0  , 2);		//External Interrupt 1 Priority LSB
Sbit (PT0L  , IPL0  , 1);		//Timer 0 Overflow Interrupt Priority LSB
Sbit (PX0L  , IPL0  , 0);		//External Interrupt 0 Priority LSB

Sfr (IEN1    , 0xB1);			//Interrupt Enable Control 1
Sfr (IPL1    , 0xB2);			//Interrupt Priority Control Low  1
Sfr (IPH1    , 0xB3);			//Interrupt Priority Control High 1

/*------------------------------- PORTS -----------------------------------*/

Sfr (PMOD1   , 0x84);			//Port Mode Register 1

Sfr (P1      , 0x90);			//Port 1
Sbit (P1_7   , P1    , 7);
Sbit (P1_6   , P1    , 6);
Sbit (P1_5   , P1    , 5);
Sbit (P1_4   , P1    , 4);
Sbit (P1_3   , P1    , 3);
Sbit (P1_2   , P1    , 2);
Sbit (P1_1   , P1    , 1);
Sbit (P1_0   , P1    , 0);
Sbit (CCLK1  , P1    , 7);		//Alternate Card Clock
Sbit (CPRES  , P1    , 2);		//Smart Card Presence

Sfr (PMOD0   , 0x91);			//Port Mode Register 0

Sfr (P3      , 0xB0);			//Port 3
Sbit (P3_7   , P3    , 7);
Sbit (P3_6   , P3    , 6);
Sbit (P3_5   , P3    , 5);
Sbit (P3_4   , P3    , 4);
Sbit (P3_3   , P3    , 3);
Sbit (P3_2   , P3    , 2);
Sbit (P3_1   , P3    , 1);
Sbit (P3_0   , P3    , 0);
Sbit (T1     , P3    , 5);		//External Event 1
Sbit (T0     , P3    , 4);		//External Event 0
Sbit (INT1   , P3    , 3);		//External Interrupt 1
Sbit (INT0   , P3    , 2);		//External Interrupt 0
Sbit (TXD    , P3    , 1);		//UART Transmit Port
Sbit (RXD    , P3    , 0);		//UART Receive Port
Sbit (CRST1  , P3    , 5);		//Alternate Card Reset
Sbit (CIO1   , P3    , 4);		//Alternate Card I/O
Sbit (LED3   , P3    , 7);		//Led Number 3
Sbit (LED2   , P3    , 6);		//Led Number 2
Sbit (LED1   , P3    , 4);		//Led Number 1
Sbit (LED0   , P3    , 2);		//Led Number 0

Sfr (P4      , 0xC0);			//Port 4
Sbit (P4_7   , P4    , 7);
Sbit (P4_6   , P4    , 6);

Sfr (P5      , 0xE8);			//Port 5
Sbit (P5_0   , P5    , 0);

/*------------------------------- TIMERS -----------------------------------*/

Sfr (TCON    , 0x88);			//Timer-Counter 0 and 1 Control
Sbit (TF1    , TCON  , 7);		//Timer 1 Overflow Flag
Sbit (TR1    , TCON  , 6);		//Timer 1 Run Control Bit
Sbit (TF0    , TCON  , 5);		//Timer 0 Overflow Flag
Sbit (TR0    , TCON  , 4);		//Timer 0 Run Control Bit
Sbit (IE1    , TCON  , 3);		//Interrupt 1 Edge Flag
Sbit (IT1    , TCON  , 2);		//Interrupt 1 Type Control Bit
Sbit (IE0    , TCON  , 1);		//Interrupt 0 Edge Flag
Sbit (IT0    , TCON  , 0);		//Interrupt 0 Type Control Bit

Sfr (TMOD    , 0x89);			//Timer-Counter 0 and 1 Configuration
Sfr (TL0     , 0x8A);			//Timer-Counter 0 Low Byte
Sfr (TL1     , 0x8B);			//Timer-Counter 1 Low Byte
Sfr (TH0     , 0x8C);			//Timer-Counter 0 High Byte
Sfr (TH1     , 0x8D);			//Timer-Counter 1 High Byte

/*------------------------------ WATCHDOG --------------------------------*/

Sfr (WDTRST  , 0xA6);			//WatchDog Timer Reset
Sfr (WDTPRG  , 0xA7);			//WatchDog Timer Program

/*--------------------------- USB CONTROLLER -----------------------------*/

Sfr (UFNUML  , 0xBA);			//USB Frame Number Low
Sfr (UFNUMH  , 0xBB);			//USB Frame Number Low
Sfr (USBCON  , 0xBC);			//USB Global Control
Sfr (USBINT  , 0xBD);			//USB Global Interrupt
Sfr (USBIEN  , 0xBE);			//USB Global Interrupt Enable
Sfr (UEPIEN  , 0xC2);			//USB Endpoint Interrupt Enable
Sfr (USBADDR , 0xC6);			//USB Address
Sfr (UEPNUM  , 0xC7);			//USB Endpoint Number
Sfr (UEPSTAX , 0xCE);			//USB Endpoint X Status
Sfr (UEPDATX , 0xCF);			//USB Endpoint X Fifo Data
Sfr (UEPCONX , 0xD4);			//USB Endpoint X Control
Sfr (UEPRST  , 0xD5);			//USB Endpoint Reset
Sfr (UBYCTX  , 0xE2);			//USB Byte Counter Low (EPX)
Sfr (UEPINT  , 0xF8);			//USB Endpoint Interrupt
Sbit (EP6INT , UEPINT, 6);	
Sbit (EP5INT , UEPINT, 5);		
Sbit (EP4INT , UEPINT, 4);		
Sbit (EP3INT , UEPINT, 3);		
Sbit (EP2INT , UEPINT, 2);		
Sbit (EP1INT , UEPINT, 1);		
Sbit (EP0INT , UEPINT, 0);		

/*------------------------------- SCIB ----------------------------------*/

Sfr (SCTBUF  , 0xAA);			//Smart Card Transmit Buffer (Write Only)			
Sfr (SCRBUF  , 0xAA);			//Smart Card Receive Buffer (read Only)
Sfr (SCSR    , 0xAB);			//Smart Card Selection Register
Sfr (SCCON   , 0xAC);			//Smart Card Interface Contacts
Sfr (SCETU0  , 0xAC);			//Smart Card ETU Register 0
Sfr (SCISR   , 0xAD);			//Smart Card UART Interface Status
Sfr (SCETU1  , 0xAD);			//Smart Card ETU Register 1
Sfr (SCIIR   , 0xAE);			//Smart Card UART Interrupt Identification
Sfr (SCIER   , 0xAE);			//Smart Card UART Interrupt Enable
Sfr (SCWT0   , 0xB4);			//Smart Card Character-Block Waiting Time Register 0
Sfr (SCGT0   , 0xB4);			//Smart Card Transmit Guard Time Register 0
Sfr (SCWT1   , 0xB5);			//Smart Card Character-Block Waiting Time Register 1
Sfr (SCGT1   , 0xB5);			//Smart Card Transmit Guard Time Register 1
Sfr (SCWT2   , 0xB6);			//Smart Card Character-Block Waiting Time Register 2
Sfr (SCICR   , 0xB6);			//Smart Card Interface Control
Sfr (DCCKPS  , 0xBF);			//DC/DC Converter Reload Register
Sfr (SCWT3   , 0xC1);			//Smart Card Character-Block Waiting Time Register 3
Sfr (SCICLK  , 0xC1);			//Smart Card Clock Prescaler

/*------------------------------- UART ---------------------------------*/

Sfr (SCON    , 0x98);			//UART Interface Control
Sbit (SM0    , SCON  , 7);		//Serial Port Mode Bit 0		
Sbit (FE     , SCON  , 7);		//Framing error Bit
Sbit (SM1    , SCON  , 6);		//Serial Port Mode Bit 1
Sbit (SM2    , SCON  , 5);		//Serial Port Mode Bit 2
Sbit (REN    , SCON  , 4);		//Reception Enable Bit
Sbit (TB8    , SCON  , 3);		//Transmitter bit 8
Sbit (RB8    , SCON  , 2);		//Receiver Bit 8
Sbit (TI     , SCON  , 1);		//Transmit Interrupt Flag
Sbit (RI     , SCON  , 0);		//Receive Interrupt Flag

Sfr (SBUF    , 0x99);			//UART Data Buffer
Sfr (SADDR   , 0xA9);			//Slave Address
Sfr (SADEN   , 0xB9);			//Slave Address Mask

/*------------------------ BAUD RATE GENERATOR -------------------------*/

Sfr (BRL     , 0x9A);			//Baud Rate Relaod
Sfr (BDRCON  , 0x9B);			//Baud Rate Control

/*-------------------------------- LED ---------------------------------*/

Sfr (LEDCON0 , 0xF1);			//LED control 0

#endif  /* _AT8XC5123_H_ */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -