📄 pic16f1526.h
字号:
unsigned RD6 : 1;
unsigned RD7 : 1;
};
} PORTDbits @ 0x00F;
#endif
// Register: PORTE
volatile unsigned char PORTE @ 0x010;
// bit and bitfield definitions
volatile bit RE0 @ ((unsigned)&PORTE*8)+0;
volatile bit RE1 @ ((unsigned)&PORTE*8)+1;
volatile bit RE2 @ ((unsigned)&PORTE*8)+2;
volatile bit RE3 @ ((unsigned)&PORTE*8)+3;
volatile bit RE4 @ ((unsigned)&PORTE*8)+4;
volatile bit RE5 @ ((unsigned)&PORTE*8)+5;
volatile bit RE6 @ ((unsigned)&PORTE*8)+6;
volatile bit RE7 @ ((unsigned)&PORTE*8)+7;
#ifndef _LIB_BUILD
volatile union {
struct {
unsigned RE0 : 1;
unsigned RE1 : 1;
unsigned RE2 : 1;
unsigned RE3 : 1;
unsigned RE4 : 1;
unsigned RE5 : 1;
unsigned RE6 : 1;
unsigned RE7 : 1;
};
} PORTEbits @ 0x010;
#endif
// Register: PIR1
volatile unsigned char PIR1 @ 0x011;
// bit and bitfield definitions
// TMR1 Overflow Interrupt Flag bit
volatile bit TMR1IF @ ((unsigned)&PIR1*8)+0;
// TMR2 to PR2 Match Interrupt Flag bit
volatile bit TMR2IF @ ((unsigned)&PIR1*8)+1;
// CCP1 Interrupt Flag bit
volatile bit CCP1IF @ ((unsigned)&PIR1*8)+2;
// Master Synchronous Serial Port (MSSP) Interrupt Flag bit
volatile bit SSP1IF @ ((unsigned)&PIR1*8)+3;
// EUSART Transmit Interrupt Flag bit
volatile bit TX1IF @ ((unsigned)&PIR1*8)+4;
// EUSART Receive Interrupt Flag bit
volatile bit RC1IF @ ((unsigned)&PIR1*8)+5;
// A/D Converter Interrupt Flag bit
volatile bit ADIF @ ((unsigned)&PIR1*8)+6;
// Timer1 Gate Interrupt Flag bit
volatile bit TMR1GIF @ ((unsigned)&PIR1*8)+7;
volatile bit SSPIF @ ((unsigned)&PIR1*8)+3;
volatile bit TXIF @ ((unsigned)&PIR1*8)+4;
volatile bit RCIF @ ((unsigned)&PIR1*8)+5;
#ifndef _LIB_BUILD
volatile union {
struct {
unsigned TMR1IF : 1;
unsigned TMR2IF : 1;
unsigned CCP1IF : 1;
unsigned SSP1IF : 1;
unsigned TX1IF : 1;
unsigned RC1IF : 1;
unsigned ADIF : 1;
unsigned TMR1GIF : 1;
};
struct {
unsigned : 3;
unsigned SSPIF : 1;
unsigned TXIF : 1;
unsigned RCIF : 1;
};
} PIR1bits @ 0x011;
#endif
// Register: PIR2
volatile unsigned char PIR2 @ 0x012;
// bit and bitfield definitions
volatile bit CCP2IF @ ((unsigned)&PIR2*8)+0;
volatile bit TMR8IF @ ((unsigned)&PIR2*8)+1;
volatile bit TMR10IF @ ((unsigned)&PIR2*8)+2;
volatile bit BCL1IF @ ((unsigned)&PIR2*8)+3;
volatile bit TMR3GIF @ ((unsigned)&PIR2*8)+5;
volatile bit TMR5GIF @ ((unsigned)&PIR2*8)+6;
volatile bit OSFIF @ ((unsigned)&PIR2*8)+7;
volatile bit BCLIF @ ((unsigned)&PIR2*8)+3;
#ifndef _LIB_BUILD
volatile union {
struct {
unsigned CCP2IF : 1;
unsigned TMR8IF : 1;
unsigned TMR10IF : 1;
unsigned BCL1IF : 1;
unsigned : 1;
unsigned TMR3GIF : 1;
unsigned TMR5GIF : 1;
unsigned OSFIF : 1;
};
struct {
unsigned : 3;
unsigned BCLIF : 1;
};
} PIR2bits @ 0x012;
#endif
// Register: PIR3
volatile unsigned char PIR3 @ 0x013;
// bit and bitfield definitions
volatile bit TMR3IF @ ((unsigned)&PIR3*8)+0;
volatile bit TMR4IF @ ((unsigned)&PIR3*8)+1;
volatile bit TMR5IF @ ((unsigned)&PIR3*8)+2;
volatile bit TMR6IF @ ((unsigned)&PIR3*8)+3;
volatile bit CCP3IF @ ((unsigned)&PIR3*8)+4;
volatile bit CCP4IF @ ((unsigned)&PIR3*8)+5;
volatile bit CCP5IF @ ((unsigned)&PIR3*8)+6;
volatile bit CCP6IF @ ((unsigned)&PIR3*8)+7;
#ifndef _LIB_BUILD
volatile union {
struct {
unsigned TMR3IF : 1;
unsigned TMR4IF : 1;
unsigned TMR5IF : 1;
unsigned TMR6IF : 1;
unsigned CCP3IF : 1;
unsigned CCP4IF : 1;
unsigned CCP5IF : 1;
unsigned CCP6IF : 1;
};
} PIR3bits @ 0x013;
#endif
// Register: PIR4
volatile unsigned char PIR4 @ 0x014;
// bit and bitfield definitions
volatile bit SSP2IF @ ((unsigned)&PIR4*8)+0;
volatile bit BCL2IF @ ((unsigned)&PIR4*8)+1;
volatile bit CCP7IF @ ((unsigned)&PIR4*8)+2;
volatile bit CCP8IF @ ((unsigned)&PIR4*8)+3;
volatile bit TX2IF @ ((unsigned)&PIR4*8)+4;
volatile bit RC2IF @ ((unsigned)&PIR4*8)+5;
volatile bit CCP9IF @ ((unsigned)&PIR4*8)+6;
volatile bit CCP10IF @ ((unsigned)&PIR4*8)+7;
#ifndef _LIB_BUILD
volatile union {
struct {
unsigned SSP2IF : 1;
unsigned BCL2IF : 1;
unsigned CCP7IF : 1;
unsigned CCP8IF : 1;
unsigned TX2IF : 1;
unsigned RC2IF : 1;
unsigned CCP9IF : 1;
unsigned CCP10IF : 1;
};
} PIR4bits @ 0x014;
#endif
// Register: TMR0
volatile unsigned char TMR0 @ 0x015;
// bit and bitfield definitions
// bit and bitfield definitions
// Register: TMR1L
volatile unsigned char TMR1L @ 0x016;
// bit and bitfield definitions
// Register: TMR1H
volatile unsigned char TMR1H @ 0x017;
// bit and bitfield definitions
// Register: TMR1
volatile unsigned int TMR1 @ 0x016;
// Register: T1CON
volatile unsigned char T1CON @ 0x018;
// bit and bitfield definitions
volatile bit TMR1ON @ ((unsigned)&T1CON*8)+0;
volatile bit nT1SYNC @ ((unsigned)&T1CON*8)+2;
volatile bit T1OSCEN @ ((unsigned)&T1CON*8)+3;
volatile bit T1CKPS0 @ ((unsigned)&T1CON*8)+4;
volatile bit T1CKPS1 @ ((unsigned)&T1CON*8)+5;
volatile bit TMR1CS0 @ ((unsigned)&T1CON*8)+6;
volatile bit TMR1CS1 @ ((unsigned)&T1CON*8)+7;
#ifndef _LIB_BUILD
volatile union {
struct {
unsigned TMR1ON : 1;
unsigned : 1;
unsigned nT1SYNC : 1;
unsigned T1OSCEN : 1;
unsigned T1CKPS0 : 1;
unsigned T1CKPS1 : 1;
unsigned TMR1CS0 : 1;
unsigned TMR1CS1 : 1;
};
struct {
unsigned : 4;
unsigned T1CKPS : 2;
unsigned TMR1CS : 2;
};
} T1CONbits @ 0x018;
#endif
// Register: T1GCON
volatile unsigned char T1GCON @ 0x019;
// bit and bitfield definitions
volatile bit T1GSS0 @ ((unsigned)&T1GCON*8)+0;
volatile bit T1GSS1 @ ((unsigned)&T1GCON*8)+1;
volatile bit T1GVAL @ ((unsigned)&T1GCON*8)+2;
volatile bit T1GGO_nDONE @ ((unsigned)&T1GCON*8)+3;
volatile bit T1GSPM @ ((unsigned)&T1GCON*8)+4;
volatile bit T1GTM @ ((unsigned)&T1GCON*8)+5;
volatile bit T1GPOL @ ((unsigned)&T1GCON*8)+6;
volatile bit TMR1GE @ ((unsigned)&T1GCON*8)+7;
#ifndef _LIB_BUILD
volatile union {
struct {
unsigned T1GSS0 : 1;
unsigned T1GSS1 : 1;
unsigned T1GVAL : 1;
unsigned T1GGO_nDONE : 1;
unsigned T1GSPM : 1;
unsigned T1GTM : 1;
unsigned T1GPOL : 1;
unsigned TMR1GE : 1;
};
struct {
unsigned T1GSS : 2;
};
} T1GCONbits @ 0x019;
#endif
// Register: TMR2
volatile unsigned char TMR2 @ 0x01A;
// bit and bitfield definitions
// Register: PR2
volatile unsigned char PR2 @ 0x01B;
// bit and bitfield definitions
// Register: T2CON
volatile unsigned char T2CON @ 0x01C;
// bit and bitfield definitions
volatile bit T2CKPS0 @ ((unsigned)&T2CON*8)+0;
volatile bit T2CKPS1 @ ((unsigned)&T2CON*8)+1;
volatile bit TMR2ON @ ((unsigned)&T2CON*8)+2;
volatile bit T2OUTPS0 @ ((unsigned)&T2CON*8)+3;
volatile bit T2OUTPS1 @ ((unsigned)&T2CON*8)+4;
volatile bit T2OUTPS2 @ ((unsigned)&T2CON*8)+5;
volatile bit T2OUTPS3 @ ((unsigned)&T2CON*8)+6;
#ifndef _LIB_BUILD
volatile union {
struct {
unsigned T2CKPS0 : 1;
unsigned T2CKPS1 : 1;
unsigned TMR2ON : 1;
unsigned T2OUTPS0 : 1;
unsigned T2OUTPS1 : 1;
unsigned T2OUTPS2 : 1;
unsigned T2OUTPS3 : 1;
};
struct {
unsigned T2CKPS : 2;
unsigned : 1;
unsigned T2OUTPS : 4;
};
} T2CONbits @ 0x01C;
#endif
//
// Special function register definitions: Bank 1
//
// Register: TRISA
// PORTA Data Direction Control Register
volatile unsigned char TRISA @ 0x08C;
// bit and bitfield definitions
volatile bit TRISA0 @ ((unsigned)&TRISA*8)+0;
volatile bit TRISA1 @ ((unsigned)&TRISA*8)+1;
volatile bit TRISA2 @ ((unsigned)&TRISA*8)+2;
volatile bit TRISA3 @ ((unsigned)&TRISA*8)+3;
volatile bit TRISA4 @ ((unsigned)&TRISA*8)+4;
volatile bit TRISA5 @ ((unsigned)&TRISA*8)+5;
volatile bit TRISA6 @ ((unsigned)&TRISA*8)+6;
volatile bit TRISA7 @ ((unsigned)&TRISA*8)+7;
#ifndef _LIB_BUILD
volatile union {
struct {
unsigned TRISA0 : 1;
unsigned TRISA1 : 1;
unsigned TRISA2 : 1;
unsigned TRISA3 : 1;
unsigned TRISA4 : 1;
unsigned TRISA5 : 1;
unsigned TRISA6 : 1;
unsigned TRISA7 : 1;
};
} TRISAbits @ 0x08C;
#endif
// Register: TRISB
// PORTB Data Direction Control Register
volatile unsigned char TRISB @ 0x08D;
// bit and bitfield definitions
volatile bit TRISB0 @ ((unsigned)&TRISB*8)+0;
volatile bit TRISB1 @ ((unsigned)&TRISB*8)+1;
volatile bit TRISB2 @ ((unsigned)&TRISB*8)+2;
volatile bit TRISB3 @ ((unsigned)&TRISB*8)+3;
volatile bit TRISB4 @ ((unsigned)&TRISB*8)+4;
volatile bit TRISB5 @ ((unsigned)&TRISB*8)+5;
volatile bit TRISB6 @ ((unsigned)&TRISB*8)+6;
volatile bit TRISB7 @ ((unsigned)&TRISB*8)+7;
#ifndef _LIB_BUILD
volatile union {
struct {
unsigned TRISB0 : 1;
unsigned TRISB1 : 1;
unsigned TRISB2 : 1;
unsigned TRISB3 : 1;
unsigned TRISB4 : 1;
unsigned TRISB5 : 1;
unsigned TRISB6 : 1;
unsigned TRISB7 : 1;
};
} TRISBbits @ 0x08D;
#endif
// Register: TRISC
// PORTC Data Direction Control Register
volatile unsigned char TRISC @ 0x08E;
// bit and bitfield definitions
volatile bit TRISC0 @ ((unsigned)&TRISC*8)+0;
volatile bit TRISC1 @ ((unsigned)&TRISC*8)+1;
volatile bit TRISC2 @ ((unsigned)&TRISC*8)+2;
volatile bit TRISC3 @ ((unsigned)&TRISC*8)+3;
volatile bit TRISC4 @ ((unsigned)&TRISC*8)+4;
volatile bit TRISC5 @ ((unsigned)&TRISC*8)+5;
volatile bit TRISC6 @ ((unsigned)&TRISC*8)+6;
volatile bit TRISC7 @ ((unsigned)&TRISC*8)+7;
#ifndef _LIB_BUILD
volatile union {
struct {
unsigned TRISC0 : 1;
unsigned TRISC1 : 1;
unsigned TRISC2 : 1;
unsigned TRISC3 : 1;
unsigned TRISC4 : 1;
unsigned TRISC5 : 1;
unsigned TRISC6 : 1;
unsigned TRISC7 : 1;
};
} TRISCbits @ 0x08E;
#endif
// Register: TRISD
// PORTD Data Direction Control Register
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -