## PIC18F2455/2550/4455/4550

## 5.3.5 SPECIAL FUNCTION REGISTERS

The Special Function Registers (SFRs) are registers used by the CPU and peripheral modules for controlling the desired operation of the device. These registers are implemented as static RAM in the data memory space. SFRs start at the top of data memory and extend downward to occupy the top segment of Bank 15, from F60h to FFFh. A list of these registers is given in Table 5-1 and Table 5-2.

The SFRs can be classified into two sets: those associated with the "core" device functionality (ALU, Resets and interrupts) and those related to the

peripheral functions. The Reset and interrupt registers are described in their respective chapters, while the ALU's STATUS register is described later in this section. Registers related to the operation of a peripheral feature are described in the chapter for that peripheral.

The SFRs are typically distributed among the peripherals whose functions they control. Unused SFR locations are unimplemented and read as '0's.

TABLE 5-1: SPECIAL FUNCTION REGISTER MAP

| Address | Name                    | Address | Name                    | Address | Name                  | Address | Name                 | Address | Name                   |
|---------|-------------------------|---------|-------------------------|---------|-----------------------|---------|----------------------|---------|------------------------|
| FFFh    | TOSU                    | FDFh    | INDF2 <sup>(1)</sup>    | FBFh    | CCPR1H                | F9Fh    | IPR1                 | F7Fh    | UEP15                  |
| FFEh    | TOSH                    | FDEh    | POSTINC2 <sup>(1)</sup> | FBEh    | CCPR1L                | F9Eh    | PIR1                 | F7Eh    | UEP14                  |
| FFDh    | TOSL                    | FDDh    | POSTDEC2 <sup>(1)</sup> | FBDh    | CCP1CON               | F9Dh    | PIE1                 | F7Dh    | UEP13                  |
| FFCh    | STKPTR                  | FDCh    | PREINC2 <sup>(1)</sup>  | FBCh    | CCPR2H                | F9Ch    | (2)                  | F7Ch    | UEP12                  |
| FFBh    | PCLATU                  | FDBh    | PLUSW2 <sup>(1)</sup>   | FBBh    | CCPR2L                | F9Bh    | OSCTUNE              | F7Bh    | UEP11                  |
| FFAh    | PCLATH                  | FDAh    | FSR2H                   | FBAh    | CCP2CON               | F9Ah    | (2)                  | F7Ah    | UEP10                  |
| FF9h    | PCL                     | FD9h    | FSR2L                   | FB9h    | (2)                   | F99h    | (2)                  | F79h    | UEP9                   |
| FF8h    | TBLPTRU                 | FD8h    | STATUS                  | FB8h    | BAUDCON               | F98h    | (2)                  | F78h    | UEP8                   |
| FF7h    | TBLPTRH                 | FD7h    | TMR0H                   | FB7h    | ECCP1DEL              | F97h    | (2)                  | F77h    | UEP7                   |
| FF6h    | TBLPTRL                 | FD6h    | TMR0L                   | FB6h    | ECCP1AS               | F96h    | TRISE <sup>(3)</sup> | F76h    | UEP6                   |
| FF5h    | TABLAT                  | FD5h    | T0CON                   | FB5h    | CVRCON                | F95h    | TRISD <sup>(3)</sup> | F75h    | UEP5                   |
| FF4h    | PRODH                   | FD4h    | (2)                     | FB4h    | CMCON                 | F94h    | TRISC                | F74h    | UEP4                   |
| FF3h    | PRODL                   | FD3h    | OSCCON                  | FB3h    | TMR3H                 | F93h    | TRISB                | F73h    | UEP3                   |
| FF2h    | INTCON                  | FD2h    | HLVDCON                 | FB2h    | TMR3L                 | F92h    | TRISA                | F72h    | UEP2                   |
| FF1h    | INTCON2                 | FD1h    | WDTCON                  | FB1h    | T3CON                 | F91h    | (2)                  | F71h    | UEP1                   |
| FF0h    | INTCON3                 | FD0h    | RCON                    | FB0h    | SPBRGH                | F90h    | (2)                  | F70h    | UEP0                   |
| FEFh    | INDF0 <sup>(1)</sup>    | FCFh    | TMR1H                   | FAFh    | SPBRG                 | F8Fh    | (2)                  | F6Fh    | UCFG                   |
| FEEh    |                         | FCEh    | TMR1L                   | FAEh    | RCREG                 | F8Eh    | (2)                  | F6Eh    | UADDR                  |
| FEDh    | POSTDEC0 <sup>(1)</sup> | FCDh    | T1CON                   | FADh    | TXREG                 | F8Dh    | LATE <sup>(3)</sup>  | F6Dh    | UCON                   |
| FECh    | PREINC0 <sup>(1)</sup>  | FCCh    | TMR2                    | FACh    | TXSTA                 | F8Ch    | LATD <sup>(3)</sup>  | F6Ch    | USTAT                  |
| FEBh    | PLUSW0 <sup>(1)</sup>   | FCBh    | PR2                     | FABh    | RCSTA                 | F8Bh    | LATC                 | F6Bh    | UEIE                   |
| FEAh    | FSR0H                   | FCAh    | T2CON                   | FAAh    | (2)                   | F8Ah    | LATB                 | F6Ah    | UEIR                   |
| FE9h    | FSR0L                   | FC9h    | SSPBUF                  | FA9h    | EEADR                 | F89h    | LATA                 | F69h    | UIE                    |
| FE8h    | WREG                    | FC8h    | SSPADD                  | FA8h    | EEDATA                | F88h    | (2)                  | F68h    | UIR                    |
| FE7h    | INDF1 <sup>(1)</sup>    | FC7h    | SSPSTAT                 | FA7h    | EECON2 <sup>(1)</sup> | F87h    | (2)                  | F67h    | UFRMH                  |
| FE6h    | POSTINC1 <sup>(1)</sup> | FC6h    | SSPCON1                 | FA6h    | EECON1                | F86h    | (2)                  | F66h    | UFRML                  |
| FE5h    | POSTDEC1 <sup>(1)</sup> | FC5h    | SSPCON2                 | FA5h    | (2)                   | F85h    | (2)                  | F65h    | SPPCON <sup>(3)</sup>  |
| FE4h    | PREINC1 <sup>(1)</sup>  | FC4h    | ADRESH                  | FA4h    | (2)                   | F84h    | PORTE                | F64h    | SPPEPS <sup>(3)</sup>  |
| FE3h    | PLUSW1 <sup>(1)</sup>   | FC3h    | ADRESL                  | FA3h    | (2)                   | F83h    | PORTD <sup>(3)</sup> | F63h    | SPPCFG <sup>(3)</sup>  |
| FE2h    | FSR1H                   | FC2h    | ADCON0                  | FA2h    | IPR2                  | F82h    | PORTC                | F62h    | SPPDATA <sup>(3)</sup> |
| FE1h    | FSR1L                   | FC1h    | ADCON1                  | FA1h    | PIR2                  | F81h    | PORTB                | F61h    | (2)                    |
| FE0h    | BSR                     | FC0h    | ADCON2                  | FA0h    | PIE2                  | F80h    | PORTA                | F60h    | (2)                    |

Note 1: Not a physical register.

- 2: Unimplemented registers are read as '0'.
- 3: These registers are implemented only on 40/44-pin devices.

## PIC18F2455/2550/4455/4550

## TABLE 5-2: REGISTER FILE SUMMARY

| File Name | Bit 7                                                                                                                                                                                                            | Bit 6          | Bit 5           | Bit 4        | Bit 3          | Bit 2          | Bit 1           | Bit 0       | Value on POR, BOR | Details on page |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-----------------|--------------|----------------|----------------|-----------------|-------------|-------------------|-----------------|
| TOSU      | Top-of-Stack Upper Byte (TOS<20:16>)                                                                                                                                                                             |                |                 |              |                |                |                 |             |                   | 53, 60          |
| TOSH      | Top-of-Stack High Byte (TOS<15:8>)                                                                                                                                                                               |                |                 |              |                |                |                 |             | 0000 0000         | 53, 60          |
| TOSL      | Top-of-Stack                                                                                                                                                                                                     | Low Byte (TO   | S<7:0>)         |              |                |                |                 |             | 0000 0000         | 53, 60          |
| STKPTR    | STKFUL                                                                                                                                                                                                           | STKUNF         | _               | SP4          | SP3            | SP2            | SP1             | SP0         | 00-0 0000         | 53, 61          |
| PCLATU    | _                                                                                                                                                                                                                | _              | _               | Holding Regi | ster for PC<20 | ):16>          |                 | ļ           | 0 0000            | 53, 60          |
| PCLATH    | Holding Regis                                                                                                                                                                                                    | ster for PC<15 | :8>             |              |                |                |                 |             | 0000 0000         | 53, 60          |
| PCL       | PC Low Byte (PC<7:0>)                                                                                                                                                                                            |                |                 |              |                |                |                 |             | 0000 0000         | 53, 60          |
| TBLPTRU   | — bit 21 <sup>(1)</sup> Program Memory Table Pointer Upper Byte (TBLPTR<20:16>)                                                                                                                                  |                |                 |              |                |                |                 | 00 0000     | 53, 84            |                 |
| TBLPTRH   | Program Memory Table Pointer High Byte (TBLPTR<15:8>)                                                                                                                                                            |                |                 |              |                |                |                 |             | 0000 0000         | 53, 84          |
| TBLPTRL   | Program Memory Table Pointer Low Byte (TBLPTR<7:0>)                                                                                                                                                              |                |                 |              |                |                |                 | 0000 0000   | 53, 84            |                 |
| TABLAT    | Program Men                                                                                                                                                                                                      | nory Table Lat | ch              | <u> </u>     |                |                |                 |             | 0000 0000         | 53, 84          |
| PRODH     | Product Regis                                                                                                                                                                                                    | ster High Byte |                 |              |                |                |                 |             | xxxx xxxx         | 53, 97          |
| PRODL     | Product Regis                                                                                                                                                                                                    | ster Low Byte  |                 |              |                |                |                 |             | xxxx xxxx         | 53, 97          |
| INTCON    | GIE/GIEH                                                                                                                                                                                                         | PEIE/GIEL      | TMR0IE          | INT0IE       | RBIE           | TMR0IF         | INT0IF          | RBIF        | 0000 000x         | 53, 101         |
| INTCON2   | RBPU                                                                                                                                                                                                             | INTEDG0        | INTEDG1         | INTEDG2      | _              | TMR0IP         | _               | RBIP        | 1111 -1-1         | 53, 102         |
| INTCON3   | INT2IP                                                                                                                                                                                                           | INT1IP         | _               | INT2IE       | INT1IE         | _              | INT2IF          | INT1IF      | 11-0 0-00         | 53, 103         |
| INDF0     |                                                                                                                                                                                                                  |                | ddress data m   |              |                | changed (not a |                 |             | N/A               | 53, 75          |
| POSTINC0  |                                                                                                                                                                                                                  |                |                 |              |                | • •            |                 |             | N/A               | 53, 76          |
| POSTDEC0  | Uses contents of FSR0 to address data memory – value of FSR0 post-incremented (not a physical register)  Uses contents of FSR0 to address data memory – value of FSR0 post-decremented (not a physical register) |                |                 |              |                |                |                 |             | N/A               | 53, 76          |
| PREINC0   | Uses contents of FSR0 to address data memory – value of FSR0 pre-incremented (not a physical register)                                                                                                           |                |                 |              |                |                |                 |             | N/A               | 53, 76          |
| PLUSW0    | Uses contents of FSR0 to address data memory – value of FSR0 pre-incremented (not a physical register) – value of FSR0 offset by W                                                                               |                |                 |              |                |                |                 | N/A         | 53, 76            |                 |
| FSR0H     | _                                                                                                                                                                                                                |                | _               | _            | Indirect Data  | Memory Addr    | ess Pointer 0 I | High Byte   | 0000              | 53, 75          |
| FSR0L     |                                                                                                                                                                                                                  |                |                 |              |                |                |                 |             | xxxx xxxx         | 53, 75          |
| WREG      | Working Register                                                                                                                                                                                                 |                |                 |              |                |                |                 |             | xxxx xxxx         | 53              |
| INDF1     | Uses contents of FSR1 to address data memory – value of FSR1 not changed (not a physical register)                                                                                                               |                |                 |              |                |                |                 | ster)       | N/A               | 53, 75          |
| POSTINC1  | Uses contents of FSR1 to address data memory – value of FSR1 post-incremented (not a physical register)                                                                                                          |                |                 |              |                |                |                 | l register) | N/A               | 53, 76          |
| POSTDEC1  | Uses contents of FSR1 to address data memory – value of FSR1 post-decremented (not a physical register)                                                                                                          |                |                 |              |                |                |                 |             | N/A               | 53, 76          |
| PREINC1   | Uses contents of FSR1 to address data memory – value of FSR1 pre-incremented (not a physical register)                                                                                                           |                |                 |              |                |                |                 | register)   | N/A               | 53, 76          |
| PLUSW1    | Uses contents of FSR1 to address data memory – value of FSR1 pre-incremented (not a physical register) – value of FSR1 offset by W                                                                               |                |                 |              |                |                |                 | register) – | N/A               | 53, 76          |
| FSR1H     | _                                                                                                                                                                                                                | _              | _               | _            | Indirect Data  | Memory Addr    | ess Pointer 1 I | ligh Byte   | 0000              | 53, 75          |
| FSR1L     | Indirect Data Memory Address Pointer 1 Low Byte                                                                                                                                                                  |                |                 |              |                |                |                 |             | xxxx xxxx         | 53, 75          |
| BSR       | Bank Select Register                                                                                                                                                                                             |                |                 |              |                |                |                 | 0000        | 54, 65            |                 |
| INDF2     | Uses contents of FSR2 to address data memory – value of FSR2 not changed (not a physical register)                                                                                                               |                |                 |              |                |                |                 | N/A         | 54, 75            |                 |
| POSTINC2  | Uses contents of FSR2 to address data memory – value of FSR2 post-incremented (not a physical register)                                                                                                          |                |                 |              |                |                |                 | N/A         | 54, 76            |                 |
| POSTDEC2  | Uses contents of FSR2 to address data memory – value of FSR2 post-decremented (not a physical register)                                                                                                          |                |                 |              |                |                | N/A             | 54, 76      |                   |                 |
| PREINC2   | Uses contents of FSR2 to address data memory – value of FSR2 pre-incremented (not a physical register)                                                                                                           |                |                 |              |                |                |                 |             | N/A               | 54, 76          |
| PLUSW2    | Uses contents of FSR2 to address data memory – value of FSR2 pre-incremented (not a physical register) – value of FSR2 offset by W                                                                               |                |                 |              |                |                |                 | N/A         | 54, 76            |                 |
| FSR2H     | — — Indirect Data Memory Address Pointer 2 High Byte                                                                                                                                                             |                |                 |              |                |                |                 | High Byte   | 0000              | 54, 75          |
| FSR2L     | Indirect Data                                                                                                                                                                                                    | Memory Addre   | ess Pointer 2 L | Low Byte     |                | ,              |                 | <u> </u>    | xxxx xxxx         | 54, 75          |
| STATUS    | _                                                                                                                                                                                                                | _              | _               | N N          | OV             | Z              | DC              | С           | x xxxx            | 54, 73          |
| TMR0H     | Timer0 Regis                                                                                                                                                                                                     | ter High Rvte  |                 | ,            |                |                |                 |             | 0000 0000         | 54, 129         |
| TMR0L     | Timer0 Regis                                                                                                                                                                                                     |                |                 |              |                |                |                 |             | xxxx xxxx         | 54, 129         |
| TOCON     | TMR00N                                                                                                                                                                                                           | T08BIT         | TOCS            | TOSE         | PSA            | T0PS2          | T0PS1           | T0PS0       |                   |                 |
| Logondi   | I IVIRUUN                                                                                                                                                                                                        | I VOBII        | 1005            | IUSE         |                | 10PS2          |                 | 10230       | 1111 1111         | 54, 127         |

Legend: x = unknown, u = unchanged, - = unimplemented, q = value depends on condition. Shaded cells are unimplemented, read as '0'.

- Note 1: Bit 21 of the TBLPTRU allows access to the device Configuration bits.
  - 2: The SBOREN bit is only available when BOREN<1:0> = 01; otherwise, the bit reads as '0'.
  - 3: These registers and/or bits are not implemented on 28-pin devices and are read as '0'. Reset values are shown for 40/44-pin devices; individual unimplemented bits should be interpreted as '-'.
  - 4: RA6 is configured as a port pin based on various primary oscillator modes. When the port pin is disabled, all of the associated bits read '0'.
  - 5: RE3 is only available as a port pin when the MCLRE Configuration bit is clear; otherwise, the bit reads as '0'.
  - **6:** RC5 and RC4 are only available as port pins when the USB module is disabled (UCON<3> = 0).
  - **7:** I<sup>2</sup>C™ Slave mode only.