1 /* 2 * This definitions of the PIC16F946 MCU. 3 * 4 * This file is part of the GNU PIC library for SDCC, originally 5 * created by Molnar Karoly <molnarkaroly@users.sf.net> 2016. 6 * 7 * This file is generated automatically by the cinc2h.pl, 2016-04-13 17:23:01 UTC. 8 * 9 * SDCC is licensed under the GNU Public license (GPL) v2. Note that 10 * this license covers the code to the compiler and other executables, 11 * but explicitly does not cover any code or objects generated by sdcc. 12 * 13 * For pic device libraries and header files which are derived from 14 * Microchip header (.inc) and linker script (.lkr) files Microchip 15 * requires that "The header files should state that they are only to be 16 * used with authentic Microchip devices" which makes them incompatible 17 * with the GPL. Pic device libraries and header files are located at 18 * non-free/lib and non-free/include directories respectively. 19 * Sdcc should be run with the --use-non-free command line option in 20 * order to include non-free header files and libraries. 21 * 22 * See http://sdcc.sourceforge.net/ for the latest information on sdcc. 23 */ 24 25 #include <pic16f946.h> 26 27 //============================================================================== 28 29 __at(0x0000) __sfr INDF; 30 31 __at(0x0001) __sfr TMR0; 32 33 __at(0x0002) __sfr PCL; 34 35 __at(0x0003) __sfr STATUS; 36 __at(0x0003) volatile __STATUSbits_t STATUSbits; 37 38 __at(0x0004) __sfr FSR; 39 40 __at(0x0005) __sfr PORTA; 41 __at(0x0005) volatile __PORTAbits_t PORTAbits; 42 43 __at(0x0006) __sfr PORTB; 44 __at(0x0006) volatile __PORTBbits_t PORTBbits; 45 46 __at(0x0007) __sfr PORTC; 47 __at(0x0007) volatile __PORTCbits_t PORTCbits; 48 49 __at(0x0008) __sfr PORTD; 50 __at(0x0008) volatile __PORTDbits_t PORTDbits; 51 52 __at(0x0009) __sfr PORTE; 53 __at(0x0009) volatile __PORTEbits_t PORTEbits; 54 55 __at(0x000A) __sfr PCLATH; 56 57 __at(0x000B) __sfr INTCON; 58 __at(0x000B) volatile __INTCONbits_t INTCONbits; 59 60 __at(0x000C) __sfr PIR1; 61 __at(0x000C) volatile __PIR1bits_t PIR1bits; 62 63 __at(0x000D) __sfr PIR2; 64 __at(0x000D) volatile __PIR2bits_t PIR2bits; 65 66 __at(0x000E) __sfr TMR1; 67 68 __at(0x000E) __sfr TMR1L; 69 70 __at(0x000F) __sfr TMR1H; 71 72 __at(0x0010) __sfr T1CON; 73 __at(0x0010) volatile __T1CONbits_t T1CONbits; 74 75 __at(0x0011) __sfr TMR2; 76 77 __at(0x0012) __sfr T2CON; 78 __at(0x0012) volatile __T2CONbits_t T2CONbits; 79 80 __at(0x0013) __sfr SSPBUF; 81 82 __at(0x0014) __sfr SSPCON; 83 __at(0x0014) volatile __SSPCONbits_t SSPCONbits; 84 85 __at(0x0015) __sfr CCPR1; 86 87 __at(0x0015) __sfr CCPR1L; 88 89 __at(0x0016) __sfr CCPR1H; 90 91 __at(0x0017) __sfr CCP1CON; 92 __at(0x0017) volatile __CCP1CONbits_t CCP1CONbits; 93 94 __at(0x0018) __sfr RCSTA; 95 __at(0x0018) volatile __RCSTAbits_t RCSTAbits; 96 97 __at(0x0019) __sfr TXREG; 98 99 __at(0x001A) __sfr RCREG; 100 101 __at(0x001B) __sfr CCPR2; 102 103 __at(0x001B) __sfr CCPR2L; 104 105 __at(0x001C) __sfr CCPR2H; 106 107 __at(0x001D) __sfr CCP2CON; 108 __at(0x001D) volatile __CCP2CONbits_t CCP2CONbits; 109 110 __at(0x001E) __sfr ADRESH; 111 112 __at(0x001F) __sfr ADCON0; 113 __at(0x001F) volatile __ADCON0bits_t ADCON0bits; 114 115 __at(0x0081) __sfr OPTION_REG; 116 __at(0x0081) volatile __OPTION_REGbits_t OPTION_REGbits; 117 118 __at(0x0085) __sfr TRISA; 119 __at(0x0085) volatile __TRISAbits_t TRISAbits; 120 121 __at(0x0086) __sfr TRISB; 122 __at(0x0086) volatile __TRISBbits_t TRISBbits; 123 124 __at(0x0087) __sfr TRISC; 125 __at(0x0087) volatile __TRISCbits_t TRISCbits; 126 127 __at(0x0088) __sfr TRISD; 128 __at(0x0088) volatile __TRISDbits_t TRISDbits; 129 130 __at(0x0089) __sfr TRISE; 131 __at(0x0089) volatile __TRISEbits_t TRISEbits; 132 133 __at(0x008C) __sfr PIE1; 134 __at(0x008C) volatile __PIE1bits_t PIE1bits; 135 136 __at(0x008D) __sfr PIE2; 137 __at(0x008D) volatile __PIE2bits_t PIE2bits; 138 139 __at(0x008E) __sfr PCON; 140 __at(0x008E) volatile __PCONbits_t PCONbits; 141 142 __at(0x008F) __sfr OSCCON; 143 __at(0x008F) volatile __OSCCONbits_t OSCCONbits; 144 145 __at(0x0090) __sfr OSCTUNE; 146 __at(0x0090) volatile __OSCTUNEbits_t OSCTUNEbits; 147 148 __at(0x0091) __sfr ANSEL; 149 __at(0x0091) volatile __ANSELbits_t ANSELbits; 150 151 __at(0x0092) __sfr PR2; 152 153 __at(0x0093) __sfr SSPADD; 154 155 __at(0x0094) __sfr SSPSTAT; 156 __at(0x0094) volatile __SSPSTATbits_t SSPSTATbits; 157 158 __at(0x0095) __sfr WPU; 159 __at(0x0095) volatile __WPUbits_t WPUbits; 160 161 __at(0x0095) __sfr WPUB; 162 __at(0x0095) volatile __WPUBbits_t WPUBbits; 163 164 __at(0x0096) __sfr IOC; 165 __at(0x0096) volatile __IOCbits_t IOCbits; 166 167 __at(0x0096) __sfr IOCB; 168 __at(0x0096) volatile __IOCBbits_t IOCBbits; 169 170 __at(0x0097) __sfr CMCON1; 171 __at(0x0097) volatile __CMCON1bits_t CMCON1bits; 172 173 __at(0x0098) __sfr TXSTA; 174 __at(0x0098) volatile __TXSTAbits_t TXSTAbits; 175 176 __at(0x0099) __sfr SPBRG; 177 178 __at(0x009C) __sfr CMCON0; 179 __at(0x009C) volatile __CMCON0bits_t CMCON0bits; 180 181 __at(0x009D) __sfr VRCON; 182 __at(0x009D) volatile __VRCONbits_t VRCONbits; 183 184 __at(0x009E) __sfr ADRESL; 185 186 __at(0x009F) __sfr ADCON1; 187 __at(0x009F) volatile __ADCON1bits_t ADCON1bits; 188 189 __at(0x0105) __sfr WDTCON; 190 __at(0x0105) volatile __WDTCONbits_t WDTCONbits; 191 192 __at(0x0107) __sfr LCDCON; 193 __at(0x0107) volatile __LCDCONbits_t LCDCONbits; 194 195 __at(0x0108) __sfr LCDPS; 196 __at(0x0108) volatile __LCDPSbits_t LCDPSbits; 197 198 __at(0x0109) __sfr LVDCON; 199 __at(0x0109) volatile __LVDCONbits_t LVDCONbits; 200 201 __at(0x010C) __sfr EEDATA; 202 __at(0x010C) volatile __EEDATAbits_t EEDATAbits; 203 204 __at(0x010C) __sfr EEDATL; 205 __at(0x010C) volatile __EEDATLbits_t EEDATLbits; 206 207 __at(0x010D) __sfr EEADR; 208 __at(0x010D) volatile __EEADRbits_t EEADRbits; 209 210 __at(0x010D) __sfr EEADRL; 211 __at(0x010D) volatile __EEADRLbits_t EEADRLbits; 212 213 __at(0x010E) __sfr EEDATH; 214 __at(0x010E) volatile __EEDATHbits_t EEDATHbits; 215 216 __at(0x010F) __sfr EEADRH; 217 __at(0x010F) volatile __EEADRHbits_t EEADRHbits; 218 219 __at(0x0110) __sfr LCDDATA0; 220 __at(0x0110) volatile __LCDDATA0bits_t LCDDATA0bits; 221 222 __at(0x0111) __sfr LCDDATA1; 223 __at(0x0111) volatile __LCDDATA1bits_t LCDDATA1bits; 224 225 __at(0x0112) __sfr LCDDATA2; 226 __at(0x0112) volatile __LCDDATA2bits_t LCDDATA2bits; 227 228 __at(0x0113) __sfr LCDDATA3; 229 __at(0x0113) volatile __LCDDATA3bits_t LCDDATA3bits; 230 231 __at(0x0114) __sfr LCDDATA4; 232 __at(0x0114) volatile __LCDDATA4bits_t LCDDATA4bits; 233 234 __at(0x0115) __sfr LCDDATA5; 235 __at(0x0115) volatile __LCDDATA5bits_t LCDDATA5bits; 236 237 __at(0x0116) __sfr LCDDATA6; 238 __at(0x0116) volatile __LCDDATA6bits_t LCDDATA6bits; 239 240 __at(0x0117) __sfr LCDDATA7; 241 __at(0x0117) volatile __LCDDATA7bits_t LCDDATA7bits; 242 243 __at(0x0118) __sfr LCDDATA8; 244 __at(0x0118) volatile __LCDDATA8bits_t LCDDATA8bits; 245 246 __at(0x0119) __sfr LCDDATA9; 247 __at(0x0119) volatile __LCDDATA9bits_t LCDDATA9bits; 248 249 __at(0x011A) __sfr LCDDATA10; 250 __at(0x011A) volatile __LCDDATA10bits_t LCDDATA10bits; 251 252 __at(0x011B) __sfr LCDDATA11; 253 __at(0x011B) volatile __LCDDATA11bits_t LCDDATA11bits; 254 255 __at(0x011C) __sfr LCDSE0; 256 __at(0x011C) volatile __LCDSE0bits_t LCDSE0bits; 257 258 __at(0x011D) __sfr LCDSE1; 259 __at(0x011D) volatile __LCDSE1bits_t LCDSE1bits; 260 261 __at(0x011E) __sfr LCDSE2; 262 __at(0x011E) volatile __LCDSE2bits_t LCDSE2bits; 263 264 __at(0x0185) __sfr TRISF; 265 __at(0x0185) volatile __TRISFbits_t TRISFbits; 266 267 __at(0x0187) __sfr TRISG; 268 __at(0x0187) volatile __TRISGbits_t TRISGbits; 269 270 __at(0x0188) __sfr PORTF; 271 __at(0x0188) volatile __PORTFbits_t PORTFbits; 272 273 __at(0x0189) __sfr PORTG; 274 __at(0x0189) volatile __PORTGbits_t PORTGbits; 275 276 __at(0x018C) __sfr EECON1; 277 __at(0x018C) volatile __EECON1bits_t EECON1bits; 278 279 __at(0x018D) __sfr EECON2; 280 281 __at(0x0190) __sfr LCDDATA12; 282 __at(0x0190) volatile __LCDDATA12bits_t LCDDATA12bits; 283 284 __at(0x0191) __sfr LCDDATA13; 285 __at(0x0191) volatile __LCDDATA13bits_t LCDDATA13bits; 286 287 __at(0x0192) __sfr LCDDATA14; 288 __at(0x0192) volatile __LCDDATA14bits_t LCDDATA14bits; 289 290 __at(0x0193) __sfr LCDDATA15; 291 __at(0x0193) volatile __LCDDATA15bits_t LCDDATA15bits; 292 293 __at(0x0194) __sfr LCDDATA16; 294 __at(0x0194) volatile __LCDDATA16bits_t LCDDATA16bits; 295 296 __at(0x0195) __sfr LCDDATA17; 297 __at(0x0195) volatile __LCDDATA17bits_t LCDDATA17bits; 298 299 __at(0x0196) __sfr LCDDATA18; 300 __at(0x0196) volatile __LCDDATA18bits_t LCDDATA18bits; 301 302 __at(0x0197) __sfr LCDDATA19; 303 __at(0x0197) volatile __LCDDATA19bits_t LCDDATA19bits; 304 305 __at(0x0198) __sfr LCDDATA20; 306 __at(0x0198) volatile __LCDDATA20bits_t LCDDATA20bits; 307 308 __at(0x0199) __sfr LCDDATA21; 309 __at(0x0199) volatile __LCDDATA21bits_t LCDDATA21bits; 310 311 __at(0x019A) __sfr LCDDATA22; 312 __at(0x019A) volatile __LCDDATA22bits_t LCDDATA22bits; 313 314 __at(0x019B) __sfr LCDDATA23; 315 __at(0x019B) volatile __LCDDATA23bits_t LCDDATA23bits; 316 317 __at(0x019C) __sfr LCDSE3; 318 __at(0x019C) volatile __LCDSE3bits_t LCDSE3bits; 319 320 __at(0x019D) __sfr LCDSE4; 321 __at(0x019D) volatile __LCDSE4bits_t LCDSE4bits; 322 323 __at(0x019E) __sfr LCDSE5; 324 __at(0x019E) volatile __LCDSE5bits_t LCDSE5bits; 325