



Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| Product Status             | Active                                                                   |
|----------------------------|--------------------------------------------------------------------------|
| Core Processor             | PIC                                                                      |
| Core Size                  | 8-Bit                                                                    |
| Speed                      | 40MHz                                                                    |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                        |
| Peripherals                | Brown-out Detect/Reset, LVD, Power Control PWM, QEI, POR, PWM, WDT       |
| Number of I/O              | 36                                                                       |
| Program Memory Size        | 8KB (4K x 16)                                                            |
| Program Memory Type        | FLASH                                                                    |
| EEPROM Size                | 256 x 8                                                                  |
| RAM Size                   | 768 x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 4.2V ~ 5.5V                                                              |
| Data Converters            | A/D 9x10b                                                                |
| Oscillator Type            | Internal                                                                 |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                       |
| Mounting Type              | Through Hole                                                             |
| Package / Case             | 40-DIP (0.600", 15.24mm)                                                 |
| Supplier Device Package    | 40-PDIP                                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18f4331-e-p |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

## 2.0 GUIDELINES FOR GETTING STARTED WITH PIC18F MICROCONTROLLERS

## 2.1 Basic Connection Requirements

Getting started with the PIC18F2331/2431/4331/4431 family of 8-bit microcontrollers requires attention to a minimal set of device pin connections before proceeding with development.

The following pins must always be connected:

- All VDD and Vss pins (see Section 2.2 "Power Supply Pins")
- All AVDD and AVss pins, regardless of whether or not the analog device features are used (see Section 2.2 "Power Supply Pins")
- MCLR pin
   (see Section 2.3 "Master Clear (MCLR) Pin")

These pins must also be connected if they are being used in the end application:

- PGC/PGD pins used for In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>) and debugging purposes (see **Section 2.4 "ICSP Pins"**)
- OSCI and OSCO pins when an external oscillator source is used

(see Section 2.5 "External Oscillator Pins")

Additionally, the following pins may be required:

• VREF+/VREF- pins are used when external voltage reference for analog modules is implemented

Note: The AVDD and AVss pins must always be connected, regardless of whether any of the analog modules are being used.

The minimum mandatory connections are shown in Figure 2-1.



## 2.3 Master Clear (MCLR) Pin

The MCLR pin provides two specific device functions: Device Reset, and Device Programming and Debugging. If programming and debugging are not required in the end application, a direct connection to VDD may be all that is required. The addition of other components, to help increase the application's resistance to spurious Resets from voltage sags, may be beneficial. A typical configuration is shown in Figure 2-1. Other circuit designs may be implemented, depending on the application's requirements.

During programming and debugging, the resistance and capacitance that can be added to the pin must be considered. Device programmers and debuggers drive the MCLR pin. Consequently, specific voltage levels (VIH and VIL) and fast signal transitions must not be adversely affected. Therefore, specific values of R1 and C1 will need to be adjusted based on the application and PCB requirements. For example, it is recommended that the capacitor, C1, be isolated from the MCLR pin during programming and debugging operations by using a jumper (Figure 2-2). The jumper is replaced for normal run-time operations.

Any components associated with the  $\overline{\text{MCLR}}$  pin should be placed within 0.25 inch (6 mm) of the pin.

#### FIGURE 2-2: EXAMPLE OF MCLR PIN CONNECTIONS



## 2.4 ICSP Pins

The PGC and PGD pins are used for In-Circuit Serial Programming<sup>TM</sup> (ICSP<sup>TM</sup>) and debugging purposes. It is recommended to keep the trace length between the ICSP connector and the ICSP pins on the device as short as possible. If the ICSP connector is expected to experience an ESD event, a series resistor is recommended, with the value in the range of a few tens of ohms, not to exceed 100 $\Omega$ .

Pull-up resistors, series diodes, and capacitors on the PGC and PGD pins are not recommended as they will interfere with the programmer/debugger communications to the device. If such discrete components are an application requirement, they should be removed from the circuit during programming and debugging. Alternatively, refer to the AC/DC characteristics and timing requirements information in the respective device Flash programming specification for information on capacitive loading limits and pin input voltage high (VIH) and input low (VIL) requirements.

For device emulation, ensure that the "Communication Channel Select" (i.e., PGCx/PGDx pins) programmed into the device matches the physical connections for the ICSP to the Microchip debugger/emulator tool.

For more information on available Microchip development tools connection requirements, refer to **Section 25.0 "Development Support"**.

| TABLE 5-3: | INITIALIZATION CO | NDITIONS FOR AL | L REGISTERS (CONTI | NUED) |
|------------|-------------------|-----------------|--------------------|-------|
|            |                   |                 |                    |       |

| Register             | Applicable Devices |      | Power-on Reset,<br>Brown-out Reset | MCLR Resets<br>WDT Reset<br>RESET Instruction<br>Stack Resets | Wake-up via WDT<br>or Interrupt |           |           |
|----------------------|--------------------|------|------------------------------------|---------------------------------------------------------------|---------------------------------|-----------|-----------|
| CAP3BUFL/<br>MAXCNTL | 2331               | 2431 | 4331                               | 4431                                                          | XXXX XXXX                       | սսսս սսսս | uuuu uuuu |
| CAP1CON              | 2331               | 2431 | 4331                               | 4431                                                          | -0 0000                         | -0 0000   | -u uuuu   |
| CAP2CON              | 2331               | 2431 | 4331                               | 4431                                                          | -0 0000                         | -0 0000   | -u uuuu   |
| CAP3CON              | 2331               | 2431 | 4331                               | 4431                                                          | -0 0000                         | -0 0000   | -u uuuu   |
| DFLTCON              | 2331               | 2431 | 4331                               | 4431                                                          | -000 0000                       | -000 0000 | -uuu uuuu |

**Legend:** u = unchanged, x = unknown, - = unimplemented bit, read as '0', q = value depends on condition. Shaded cells indicate conditions do not apply for the designated device.

**Note 1:** One or more bits in the INTCONx or PIRx registers will be affected (to cause wake-up).

2: When the wake-up is due to an interrupt and the GIEL or GIEH bit is set, the PC is loaded with the interrupt vector (0008h or 0018h).

**3:** When the wake-up is due to an interrupt and the GIEL or GIEH bit is set, the TOSU, TOSH and TOSL are updated with the current value of the PC. The STKPTR is modified to point to the next location in the hardware stack.

4: See Table 5-2 for Reset value for specific condition.

**5:** Bits 6 and 7 of PORTA, LATA and TRISA are enabled depending on the oscillator mode selected. When not enabled as PORTA pins, they are disabled and read '0'.

**6:** Bit 3 of PORTE and LATE are enabled if MCLR functionality is disabled. When not enabled as the PORTE pin, they are disabled and read as '0'. The 28-pin devices do not have only RE3 implemented.

#### 6.5.4 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. A list of these registers is given in Table 6-1 and Table 6-2.

The SFRs can be classified into two sets: those associated with the "core" function and those related to the peripheral functions. Those registers related to the "core" are described in this section, while those related to the operation of the peripheral features are described in the section of that peripheral feature.

The SFRs are typically distributed among the peripherals whose functions they control.

The unused SFR locations will be unimplemented and read as '0's.

#### TABLE 6-1: SPECIAL FUNCTION REGISTER MAP FOR PIC18F2331/2431/4331/4431 DEVICES

| Address | Name                    | Address | Name                    | Address | Name    | Address | Name                 | Address | Name                 |
|---------|-------------------------|---------|-------------------------|---------|---------|---------|----------------------|---------|----------------------|
| FFFh    | TOSU                    | FDFh    | INDF2 <sup>(1)</sup>    | FBFh    | CCPR1H  | F9Fh    | IPR1                 | F7Fh    | PTCON0               |
| FFEh    | TOSH                    | FDEh    | POSTINC2 <sup>(1)</sup> | FBEh    | CCPR1L  | F9Eh    | PIR1                 | F7Eh    | PTCON1               |
| FFDh    | TOSL                    | FDDh    | POSTDEC2(1)             | FBDh    | CCP1CON | F9Dh    | PIE1                 | F7Dh    | PTMRL                |
| FFCh    | STKPTR                  | FDCh    | PREINC2 <sup>(1)</sup>  | FBCh    | CCPR2H  | F9Ch    | (2)                  | F7Ch    | PTMRH                |
| FFBh    | PCLATU                  | FDBh    | PLUSW2 <sup>(1)</sup>   | FBBh    | CCPR2L  | F9Bh    | OSCTUNE              | F7Bh    | PTPERL               |
| FFAh    | PCLATH                  | FDAh    | FSR2H                   | FBAh    | CCP2CON | F9Ah    | ADCON3               | F7Ah    | PTPERH               |
| FF9h    | PCL                     | FD9h    | FSR2L                   | FB9h    | ANSEL1  | F99h    | ADCHS                | F79h    | PDC0L                |
| FF8h    | TBLPTRU                 | FD8h    | STATUS                  | FB8h    | ANSEL0  | F98h    | (2)                  | F78h    | PDC0H                |
| FF7h    | TBLPTRH                 | FD7h    | TMR0H                   | FB7h    | T5CON   | F97h    | (2)                  | F77h    | PDC1L                |
| FF6h    | TBLPTRL                 | FD6h    | TMR0L                   | FB6h    | QEICON  | F96h    | TRISE <sup>(3)</sup> | F76h    | PDC1H                |
| FF5h    | TABLAT                  | FD5h    | TOCON                   | FB5h    | (2)     | F95h    | TRISD <sup>(3)</sup> | F75h    | PDC2L                |
| FF4h    | PRODH                   | FD4h    | (2)                     | FB4h    | (2)     | F94h    | TRISC                | F74h    | PDC2H                |
| FF3h    | PRODL                   | FD3h    | OSCCON                  | FB3h    | (2)     | F93h    | TRISB                | F73h    | PDC3L <sup>(3)</sup> |
| FF2h    | INTCON                  | FD2h    | LVDCON                  | FB2h    | (2)     | F92h    | TRISA                | F72h    | PDC3H <sup>(3)</sup> |
| FF1h    | INTCON2                 | FD1h    | WDTCON                  | FB1h    | (2)     | F91h    | PR5H                 | F71h    | SEVTCMPL             |
| FF0h    | INTCON3                 | FD0h    | RCON                    | FB0h    | SPBRGH  | F90h    | PR5L                 | F70h    | SEVTCMPH             |
| FEFh    | INDF0 <sup>(1)</sup>    | FCFh    | TMR1H                   | FAFh    | SPBRG   | F8Fh    | (2)                  | F6Fh    | PWMCON0              |
| FEEh    | POSTINC0 <sup>(1)</sup> | FCEh    | TMR1L                   | FAEh    | RCREG   | F8Eh    | (2)                  | F6Eh    | PWMCON1              |
| FEDh    | POSTDEC0(1)             | FCDh    | T1CON                   | FADh    | TXREG   | F8Dh    | LATE <sup>(3)</sup>  | F6Dh    | DTCON                |
| FECh    | PREINC0 <sup>(1)</sup>  | FCCh    | TMR2                    | FACh    | TXSTA   | F8Ch    | LATD <sup>(3)</sup>  | F6Ch    | FLTCONFIG            |
| FEBh    | PLUSW0 <sup>(1)</sup>   | FCBh    | PR2                     | FABh    | RCSTA   | F8Bh    | LATC                 | F6Bh    | OVDCOND              |
| FEAh    | FSR0H                   | FCAh    | T2CON                   | FAAh    | BAUDCON | F8Ah    | LATB                 | F6Ah    | OVDCONS              |
| FE9h    | FSR0L                   | FC9h    | SSPBUF                  | FA9h    | EEADR   | F89h    | LATA                 | F69h    | CAP1BUFH             |
| FE8h    | WREG                    | FC8h    | SSPADD                  | FA8h    | EEDATA  | F88h    | TMR5H                | F68h    | CAP1BUFL             |
| FE7h    | INDF1 <sup>(1)</sup>    | FC7h    | SSPSTAT                 | FA7h    | EECON2  | F87h    | TMR5L                | F67h    | CAP2BUFH             |
| FE6h    | POSTINC1 <sup>(1)</sup> | FC6h    | SSPCON                  | FA6h    | EECON1  | F86h    | (2)                  | F66h    | CAP2BUFL             |
| FE5h    | POSTDEC1(1)             | FC5h    | (2)                     | FA5h    | IPR3    | F85h    | (2)                  | F65h    | CAP3BUFH             |
| FE4h    | PREINC1 <sup>(1)</sup>  | FC4h    | ADRESH                  | FA4h    | PIR3    | F84h    | PORTE                | F64h    | CAP3BUFL             |
| FE3h    | PLUSW1 <sup>(1)</sup>   | FC3h    | ADRESL                  | FA3h    | PIE3    | F83h    | PORTD <sup>(3)</sup> | F63h    | CAP1CON              |
| FE2h    | FSR1H                   | FC2h    | ADCON0                  | FA2h    | IPR2    | F82h    | PORTC                | F62h    | CAP2CON              |
| FE1h    | FSR1L                   | FC1h    | ADCON1                  | FA1h    | PIR2    | F81h    | PORTB                | F61h    | CAP3CON              |
| FE0h    | BSR                     | FC0h    | ADCON2                  | FA0h    | PIE2    | F80h    | PORTA                | F60h    | DFLTCON              |

Note 1: This is not a physical register.

2: Unimplemented registers are read as '0'.

3: This register is not available on 28-pin devices.

## PIC18F2331/2431/4331/4431

|           |                                                                                                         |                 |                       |                 | 1 200 1/240     | 1/400 1/44      | 51)              |        |                      |
|-----------|---------------------------------------------------------------------------------------------------------|-----------------|-----------------------|-----------------|-----------------|-----------------|------------------|--------|----------------------|
| File Name | Bit 7                                                                                                   | Bit 6           | Bit 5                 | Bit 4           | Bit 3           | Bit 2           | Bit 1            | Bit 0  | Value on<br>POR, BOR |
| TOSU      | _                                                                                                       | _               | _                     | Top-of-Stack l  | Jpper Byte (TO  | S<20:16>)       |                  |        | 0 0000               |
| TOSH      | Top-of-Stack H                                                                                          | ligh Byte (TOS  | <15:8>)               | •               |                 |                 |                  |        | 0000 0000            |
| TOSL      | Top-of-Stack L                                                                                          | ow Byte (TOS·   | <7:0>)                |                 |                 |                 |                  |        | 0000 0000            |
| STKPTR    | STKFUL                                                                                                  | STKUNF          | —                     | SP4             | SP3             | SP2             | SP1              | SP0    | 00-0 0000            |
| PCLATU    | _                                                                                                       | —               | bit 21 <sup>(3)</sup> | Holding Regis   | ter for PC<20:  | 16>             |                  |        | 0 0000               |
| PCLATH    | Holding Regis                                                                                           | ter for PC<15:8 | }>                    |                 |                 |                 |                  |        | 0000 0000            |
| PCL       | PC Low Byte (PC<7:0>)                                                                                   |                 |                       |                 |                 |                 |                  |        | 0000 0000            |
| TBLPTRU   | _                                                                                                       | —               | bit 21 <sup>(3)</sup> | Program Mem     | ory Table Poin  | ter Upper Byte  | (TBLPTR<20:1     | 6>)    | 00 0000              |
| TBLPTRH   | Program Mem                                                                                             | ory Table Point | ter High Byte (       | BLPTR<15:8>     | )               |                 |                  |        | 0000 0000            |
| TBLPTRL   | Program Mem                                                                                             | ory Table Point | ter Low Byte (T       | BLPTR<7:0>)     |                 |                 |                  |        | 0000 0000            |
| TABLAT    | Program Mem                                                                                             | ory Table Latch | า                     |                 |                 |                 |                  |        | 0000 0000            |
| PRODH     | Product Regis                                                                                           | ter High Byte   |                       |                 |                 |                 |                  |        | xxxx xxxx            |
| PRODL     | Product Regis                                                                                           | ter Low Byte    |                       |                 |                 |                 |                  |        | xxxx xxxx            |
| INTCON    | GIE/GIEH                                                                                                | PEIE/GIEL       | TMR0IE                | INT0IE          | RBIE            | TMR0IF          | <b>INT0IF</b>    | RBIF   | 0000 000x            |
| INTCON2   | RBPU                                                                                                    | INTEDG0         | INTEDG1               | INTEDG2         | _               | TMR0IP          | _                | RBIP   | 1111 -1-1            |
| INTCON3   | INT2IP                                                                                                  | INT1IP          | _                     | INT2IE          | INT1IE          | _               | INT2IF           | INT1IF | 11-0 0-00            |
| INDF0     | Uses contents of FSR0 to address data memory – value of FSR0 not changed (not a physical register)      |                 |                       |                 |                 |                 |                  | N/A    |                      |
| POSTINC0  | Uses contents of FSR0 to address data memory – value of FSR0 post-incremented (not a physical register) |                 |                       |                 |                 |                 |                  |        | N/A                  |
| POSTDEC0  | Uses contents of FSR0 to address data memory – value of FSR0 post-decremented (not a physical register) |                 |                       |                 |                 |                 |                  | N/A    |                      |
| PREINC0   | Uses contents of FSR0 to address data memory – value of FSR0 pre-incremented (not a physical register)  |                 |                       |                 |                 |                 |                  | N/A    |                      |
| PLUSW0    | Uses contents of FSR0 to address data memory – value of FSR0 offset by W (not a physical register)      |                 |                       |                 |                 |                 |                  | N/A    |                      |
| FSR0H     | _                                                                                                       | —               | —                     | _               | Indirect Data I | Memory Addres   | ss Pointer 0 Hig | h      | xxxx                 |
| FSR0L     | Indirect Data I                                                                                         | Memory Addres   | s Pointer 0 Lo        | w Byte          |                 |                 |                  |        | xxxx xxxx            |
| WREG      | Working Regis                                                                                           | ster            |                       |                 |                 |                 |                  |        | xxxx xxxx            |
| INDF1     | Uses contents                                                                                           | of FSR1 to ad   | dress data mei        | mory – value of | FSR1 not char   | nged (not a phy | sical register)  |        | N/A                  |
| POSTINC1  | Uses contents                                                                                           | of FSR1 to ad   | dress data mei        | mory – value of | FSR1 post-inc   | remented (not   | a physical regis | ter)   | N/A                  |
| POSTDEC1  | Uses contents                                                                                           | of FSR1 to ad   | dress data mei        | mory – value of | FSR1 post-dec   | cremented (not  | a physical regi  | ster)  | N/A                  |
| PREINC1   | Uses contents                                                                                           | of FSR1 to ad   | dress data mei        | mory – value of | FSR1 pre-incre  | emented (not a  | physical regist  | er)    | N/A                  |
| PLUSW1    | Uses contents                                                                                           | of FSR1 to ad   | dress data mei        | mory – value of | FSR1 offset by  | / W (not a phys | ical register)   |        | N/A                  |
| FSR1H     | —                                                                                                       | —               | _                     | _               | Indirect Data I | Memory Addres   | ss Pointer 1 Hig | h Byte | 0000                 |
| FSR1L     | Indirect Data I                                                                                         | Memory Addres   | s Pointer 1 Lo        | w Byte          |                 |                 |                  |        | xxxx xxxx            |
| BSR       | —                                                                                                       | —               | _                     | _               | Bank Select R   | legister        |                  |        | 0000                 |
| INDF2     | Uses contents                                                                                           | of FSR2 to ad   | dress data mei        | nory – value of | FSR2 not char   | nged (not a phy | vsical register) |        | N/A                  |
| POSTINC2  | Uses contents                                                                                           | of FSR2 to ad   | dress data mei        | mory – value of | FSR2 post-inc   | remented (not   | a physical regis | ter)   | N/A                  |
| POSTDEC2  | Uses contents                                                                                           | of FSR2 to ad   | dress data mei        | mory – value of | FSR2 post-dec   | cremented (not  | a physical regi  | ster)  | N/A                  |
| PREINC2   | Uses contents                                                                                           | of FSR2 to ad   | dress data mei        | mory – value of | FSR2 pre-incre  | emented (not a  | physical regist  | er)    | N/A                  |
| PLUSW2    | Uses contents                                                                                           | of FSR2 to ad   | dress data mei        | mory – value of | FSR2 offset by  | / W (not a phys | ical register)   |        | N/A                  |
| FSR2H     | _                                                                                                       | _               | _                     | _               | Indirect Data I | Memory Addres   | ss Pointer 2 Hig | h Byte | 0000                 |
| FSR2L     | Indirect Data I                                                                                         | Memory Addres   | s Pointer 2 Lo        | w Byte          |                 |                 |                  |        | xxxx xxxx            |
| STATUS    |                                                                                                         | _               | _                     | N               | OV              | Z               | DC               | С      | x xxxx               |
| TMR0H     | Timer0 Regist                                                                                           | er High Byte    |                       |                 |                 |                 |                  |        | 0000 0000            |
| TMR0L     | Timer0 Regist                                                                                           | er Low Byte     |                       |                 |                 |                 |                  |        | xxxx xxxx            |
| TOCON     | TMR0ON                                                                                                  | T016BIT         | TOCS                  | TOSE            | PSA             | T0PS2           | T0PS1            | T0PS0  | 1111 1111            |

## TABLE 6-2: REGISTER FILE SUMMARY (PIC18F2331/2431/4331/4431)

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

Note 1: RA6 and associated bits are configured as port pins in RCIO, ECIO and INTIO2 (with port function on RA6) Oscillator modes only and read '0' in all other oscillator modes.

2: RA7 and associated bits are configured as port pins in INTIO2 Oscillator mode only and read '0' in all other modes.

3: Bit 21 of the PC is only available in Test mode and Serial Programming modes.

4: These registers and/or bits are not implemented on the PIC18F2331/2431 devices and read as '0'.

5: The RE3 port bit is only available for PIC18F4331/4431 devices when the MCLRE fuse (CONFIG3H<7>) is programmed to '0'; otherwise, RE3 reads '0'. This bit is read-only.

## 6.7.3.1 FSR Registers and the INDF Operand

At the core of Indirect Addressing are three sets of registers: FSR0, FSR1 and FSR2. Each represents a pair of 8-bit registers, FSRnH and FSRnL. The four upper bits of the FSRnH register are not used so each FSR pair holds a 12-bit value. This represents a value that can address the entire range of the data memory in a linear fashion. The FSR register pairs, then, serve as pointers to data memory locations.

Indirect Addressing is accomplished with a set of Indirect File Operands: INDF0 through INDF2. These can be thought of as "virtual" registers; they are mapped in the SFR space but are not physically implemented. Reading or writing to a particular INDF register actually accesses its corresponding FSR register pair. A read from INDF1, for example, reads the data at the address indicated by FSR1H:FSR1L. Instructions that use the INDF registers as operands actually use the contents of their corresponding FSR as a pointer to the instruction's target. The INDF operand is just a convenient way of using the pointer.

Because Indirect Addressing uses a full 12-bit address, data RAM banking is not necessary. Thus, the current contents of the BSR and the Access RAM bit have no effect on determining the target address.

## 6.7.3.2 FSR Registers and POSTINC, POSTDEC, PREINC and PLUSW

In addition to the INDF operand, each FSR register pair also has four additional indirect operands. Like INDF, these are "virtual" registers that cannot be indirectly read or written to. Accessing these registers actually accesses the associated FSR register pair, but also performs a specific action on its stored value. They are:

- POSTDEC: accesses the FSR value, then automatically decrements it by 1 afterwards
- POSTINC: accesses the FSR value, then automatically increments it by 1 afterwards
- PREINC: increments the FSR value by 1, then uses it in the operation
- PLUSW: adds the signed value of the W register (range of -127 to 128) to that of the FSR and uses the new value in the operation.

In this context, accessing an INDF register uses the value in the FSR registers without changing them. Similarly, accessing a PLUSW register gives the FSR value offset by that in the W register; neither value is actually changed in the operation. Accessing the other virtual registers changes the value of the FSR registers.

Operations on the FSRs with POSTDEC, POSTINC and PREINC affect the entire register pair; that is, rollovers of the FSRnL register from FFh to 00h carry over to the FSRnH register. On the other hand, results of these operations do not change the value of any flags in the STATUS register (e.g., Z, N, OV, etc.).



## FIGURE 6-7: INDIRECT ADDRESSING

## PIC18F2331/2431/4331/4431

| R/W-0         | U-0                        | U-0                | R/W-0          | U-0               | R/W-0            | U-0             | R/W-0  |  |
|---------------|----------------------------|--------------------|----------------|-------------------|------------------|-----------------|--------|--|
| OSCFIE        | <u> </u>                   | —                  | EEIE           | —                 | LVDIE            | —               | CCP2IE |  |
| bit 7         | ·                          | •                  |                |                   |                  |                 | bit 0  |  |
|               |                            |                    |                |                   |                  |                 |        |  |
| Legend:       |                            |                    |                |                   |                  |                 |        |  |
| R = Readable  | e bit                      | W = Writable       | bit            | U = Unimplen      | nented bit, read | d as '0'        |        |  |
| -n = Value at | POR                        | '1' = Bit is set   |                | '0' = Bit is clea | ared             | x = Bit is unkn | iown   |  |
|               |                            |                    |                |                   |                  |                 |        |  |
| bit 7         | OSCFIE: Osc                | illator Fail Inter | rupt Enable bi | t                 |                  |                 |        |  |
|               | 1 = Enabled                |                    |                |                   |                  |                 |        |  |
|               | 0 = Disabled               |                    |                |                   |                  |                 |        |  |
| bit 6-5       | Unimplement                | ted: Read as 'd    | )'             |                   |                  |                 |        |  |
| bit 4         | EEIE: Interrup             | ot Enable bit      |                |                   |                  |                 |        |  |
|               | 1 = Enabled                |                    |                |                   |                  |                 |        |  |
|               | 0 = Disabled               |                    |                |                   |                  |                 |        |  |
| bit 3         | Unimplement                | ted: Read as 'd    | )'             |                   |                  |                 |        |  |
| bit 2         | LVDIE: Low-V               | /oltage Detect I   | nterrupt Enabl | le bit            |                  |                 |        |  |
|               | 1 = Enabled                |                    |                |                   |                  |                 |        |  |
|               | 0 = Disabled               |                    |                |                   |                  |                 |        |  |
| bit 1         | Unimplemented: Read as '0' |                    |                |                   |                  |                 |        |  |
| bit 0         | CCP2IE: CCF                | P2 Interrupt Ena   | able bit       |                   |                  |                 |        |  |
|               | 1 = Enabled                |                    |                |                   |                  |                 |        |  |
|               | 0 = Disabled               |                    |                |                   |                  |                 |        |  |

### REGISTER 10-8: PIE2: PERIPHERAL INTERRUPT ENABLE REGISTER 2

| Name   | Bit 7                 | Bit 6                 | Bit 5               | Bit 4                    | Bit 3      | Bit 2  | Bit 1  | Bit 0               | Reset Values<br>on Page: |
|--------|-----------------------|-----------------------|---------------------|--------------------------|------------|--------|--------|---------------------|--------------------------|
| PORTA  | RA7 <sup>(1)</sup>    | RA6 <sup>(1)</sup>    | RA5                 | RA4                      | RA3        | RA2    | RA1    | RA0                 | 57                       |
| LATA   | LATA7 <sup>(1)</sup>  | LATA6 <sup>(1)</sup>  | LATA Data           | ATA Data Output Register |            |        |        |                     |                          |
| TRISA  | TRISA7 <sup>(1)</sup> | TRISA6 <sup>(1)</sup> | PORTA Da            | ata Directio             | n Register |        |        |                     | 57                       |
| ADCON1 | VCFG1                 | VCFG0                 | —                   | FIFOEN                   | BFEMT      | BFOVFL | ADPNT1 | ADPNT0              | 56                       |
| ANSEL0 | ANS7 <sup>(2)</sup>   | ANS6 <sup>(2)</sup>   | ANS5 <sup>(2)</sup> | ANS4                     | ANS3       | ANS2   | ANS1   | ANS0                | 56                       |
| ANSEL1 | _                     | _                     |                     | _                        | _          | _      | _      | ANS8 <sup>(2)</sup> | 56                       |

TABLE 11-2: SUMMARY OF REGISTERS ASSOCIATED WITH PORTA

Legend: — = unimplemented, read as '0'. Shaded cells are not used by PORTA.

**Note 1:** RA<7:6> and their associated latch and data direction bits are enabled as I/O pins based on oscillator configuration; otherwise, they are read as '0'.

2: ANS5 through ANS8 are available only on the PIC18F4331/4431 devices.

| Pin                         | Function             | TRIS<br>Setting      | I/O | l/O<br>Type      | Description                                                                            |
|-----------------------------|----------------------|----------------------|-----|------------------|----------------------------------------------------------------------------------------|
| RD0/T0CKI/                  | RD0                  | 0                    | 0   | DIG              | LATD<0> data output.                                                                   |
| T5CKI                       |                      | 1                    | Ι   | ST               | PORTD<0> data input.                                                                   |
|                             | T0CKI <sup>(1)</sup> | 1                    | Ι   | ST               | Timer0 alternate clock input.                                                          |
|                             | T5CKI <sup>(1)</sup> | 1                    |     | ST               | Timer5 alternate clock input.                                                          |
| RD1/SDO                     | RD1                  | 0                    | 0   | DIG              | LATD<1> data output.                                                                   |
|                             |                      | 1                    | Ι   | ST               | PORTD<1> data input.                                                                   |
|                             | SDO <sup>(1)</sup>   | 0                    | 0   | DIG              | SPI data out; takes priority over port data.                                           |
| RD2/SDI/SDA                 | RD2                  | 0                    | 0   | DIG              | LATD<2> data output.                                                                   |
|                             |                      | 1                    |     | ST               | PORTD<2> data input.                                                                   |
|                             | SDI <sup>(1)</sup>   | 1                    |     | ST               | SPI data input (SSP module).                                                           |
|                             | SDA <sup>(1)</sup>   | 0                    | 0   | DIG              | I <sup>2</sup> C <sup>™</sup> data output (SSP module); takes priority over port data. |
|                             |                      | 1                    |     | I <sup>2</sup> C | I <sup>2</sup> C data input (SSP module).                                              |
| RD3/SCK/SCL RD3             |                      | 0                    | 0   | DIG              | LATD<3> data output.                                                                   |
|                             |                      | 1                    |     | ST               | PORTD<3> data input.                                                                   |
|                             | SCK <sup>(1)</sup>   | 0                    | 0   | DIG              | SPI clock output (SSP module); takes priority over port data.                          |
|                             |                      | 1                    | Ι   | ST               | SPI clock input (SSP module).                                                          |
|                             | SCL <sup>(1)</sup>   | 0                    | 0   | DIG              | I <sup>2</sup> C clock output (SSP module); takes priority over port data.             |
|                             |                      | 1                    | Ι   | l <sup>2</sup> C | I <sup>2</sup> C clock input (SSP module); input type depends on module setting.       |
| RD4/FLTA                    | RD4                  | 0                    | 0   | DIG              | LATD<4> data output.                                                                   |
|                             |                      | 1                    | Ι   | ST               | PORTD<4> data input.                                                                   |
|                             | FLTA(2)              | 1                    | Ι   | ST               | Fault Interrupt Input Pin A.                                                           |
| RD5/PWM4                    | RD5                  | 0                    | 0   | DIG              | LATD<5> data output.                                                                   |
|                             |                      | 1                    | Ι   | ST               | PORTD<5> data input.                                                                   |
|                             | PWM4 <sup>(3)</sup>  | 0                    | 0   | DIG              | PWM Output 4; takes priority over port data.                                           |
| RD6/PWM6                    | RD6                  | 0                    | 0   | DIG              | LATD<6> data output.                                                                   |
|                             |                      | 1                    | -   | ST               | PORTD<6> data input.                                                                   |
|                             | PWM6                 | 0                    | 0   | DIG              | PWM Output 6; takes priority over port data.                                           |
| RD7/PWM7                    | RD7                  | 0                    | 0   | DIG              | LATD<7> data output.                                                                   |
| 1 I ST PORTD<7> data input. |                      | PORTD<7> data input. |     |                  |                                                                                        |
|                             | PWM7                 | 0                    | 0   | DIG              | PWM Output 7; takes priority over port data.                                           |

TABLE 11-7: PORTD I/O SUMMARY

**Legend:** DIG = Digital level output; TTL = TTL input buffer; ST = Schmitt Trigger input buffer;

x = Don't care (TRIS bit does not affect port direction or is overridden for this option).

Note 1: RC3 is the alternate pin for T0CKI/T5CKI; RC4 is the alternate pin for SDI/SDA; RC5 is the alternate pin for SCK/SCL; RC7 is the alternate pin for SDO.

2: RC1 is the alternate pin for FLTA.

**3:** RB5 is the alternate pin for PWM4.

#### TABLE 11-8: SUMMARY OF REGISTERS ASSOCIATED WITH PORTD

| Name  | Bit 7                         | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Reset Values<br>on Page: |
|-------|-------------------------------|-------|-------|-------|-------|-------|-------|-------|--------------------------|
| PORTD | RD7                           | RD6   | RD5   | RD4   | RD3   | RD2   | RD1   | RD0   | 57                       |
| LATD  | LATD Data Output Register     |       |       |       |       |       | 57    |       |                          |
| TRISD | PORTD Data Direction Register |       |       |       |       |       | 57    |       |                          |

## PIC18F2331/2431/4331/4431







## 14.0 TIMER2 MODULE

The Timer2 module has the following features:

- 8-bit Timer register (TMR2)
- 8-bit Period register (PR2)
- Readable and writable (both registers)
- Software programmable prescaler (1:1, 1:4, 1:16)
- Software programmable postscaler (1:1 to 1:16)
- Interrupt on TMR2 match with PR2
- SSP module optional use of TMR2 output to generate clock shift

Timer2 has a control register, shown in Register 14-1. TMR2 can be shut off by clearing control bit, TMR2ON (T2CON<2>), to minimize power consumption. Figure 14-1 is a simplified block diagram of the Timer2 module. Register 14-1 shows the Timer2 Control register. The prescaler and postscaler selection of Timer2 are controlled by this register.

## 14.1 Timer2 Operation

Timer2 can be used as the PWM time base for the PWM mode of the CCP module. The TMR2 register is readable and writable, and is cleared on any device Reset. The input clock (Fosc/4) has a prescale option of 1:1, 1:4 or 1:16, selected by control bits, T2CKPS<1:0> (T2CON<1:0>). The match output of TMR2 goes through a 4-bit postscaler (which gives a 1:1 to 1:16 scaling inclusive) to generate a TMR2 interrupt, latched in flag bit, TMR2IF (PIR1<1>).

The TMR2 and PR2 registers are both directly readable and writable. The TMR2 register is cleared on any device Reset, while the PR2 register initializes at FFh.

The prescaler and postscaler counters are cleared when any of the following occurs:

- · A write to the TMR2 register
- A write to the T2CON register
- Any device Reset (Power-on Reset, MCLR Reset, Watchdog Timer Reset or Brown-out Reset)

TMR2 is not cleared when T2CON is written.

#### REGISTER 14-1: T2CON: TIMER2 CONTROL REGISTER

| U-0   | R/W-0   | R/W-0   | R/W-0   | R/W-0   | R/W-0  | R/W-0   | R/W-0   |
|-------|---------|---------|---------|---------|--------|---------|---------|
| —     | TOUTPS3 | TOUTPS2 | TOUTPS1 | TOUTPS0 | TMR2ON | T2CKPS1 | T2CKPS0 |
| bit 7 |         |         |         |         |        |         | bit 0   |

| Legend:           |                     |                       |                    |
|-------------------|---------------------|-----------------------|--------------------|
| R = Readable bit  | W = Writable bit    | U = Unimplemented bit | , read as '0'      |
| -n = Value at POR | '1' = Bit is set    | '0' = Bit is cleared  | x = Bit is unknown |
|                   |                     |                       |                    |
| bit 7 Unimple     | mented: Read as '0' |                       |                    |

|         | oninplemented. Read as 0                         |
|---------|--------------------------------------------------|
| bit 6-3 | TOUTPS<3:0>: Timer2 Output Postscale Select bits |
|         | 0000 = 1:1 Postscale                             |
|         | 0001 = 1:2 Postscale                             |
|         | •                                                |
|         | •                                                |
|         | •                                                |
|         | 1111 = 1:16 Postscale                            |
| bit 2   | TMR2ON: Timer2 On bit                            |
|         | 1 = Timer2 is on                                 |
|         | 0 = Timer2 is off                                |
| bit 1-0 | T2CKPS<1:0>: Timer2 Clock Prescale Select bits   |
|         | 00 = Prescaler is 1                              |
|         | 01 = Prescaler is 4                              |
|         | 1x = Prescaler is 16                             |
|         |                                                  |

The CCPR1H register and a 2-bit internal latch are used to double buffer the PWM duty cycle. This double buffering is essential for glitchless PWM operation. When the CCPR1H and 2-bit latch match TMR2, concatenated with an internal 2-bit Q clock or two bits of the TMR2 prescaler, the CCP1 pin is cleared. The maximum PWM resolution (bits) for a given PWM frequency is given by the following equation:

#### **EQUATION 16-3:**



| Note: | If the PWM duty cycle value is longer than |
|-------|--------------------------------------------|
|       | the PWM period, the CCP1 pin will not be   |
|       | cleared.                                   |

## 16.5.3 SETUP FOR PWM OPERATION

The following steps should be taken when configuring the CCP1 module for PWM operation:

- 1. Set the PWM period by writing to the PR2 register.
- 2. Set the PWM duty cycle by writing to the CCPR1L register and CCP1CON<5:4> bits.
- 3. Make the CCP1 pin an output by clearing the TRISC<2> bit.
- 4. Set the TMR2 prescale value and enable Timer2 by writing to T2CON.
- 5. Configure the CCP1 module for PWM operation.

## TABLE 16-3: EXAMPLE PWM FREQUENCIES AND RESOLUTIONS AT 40 MHz

| PWM Frequency              | 2.44 kHz | 9.77 kHz | 39.06 kHz | 156.25 kHz | 312.50 kHz | 416.67 kHz |
|----------------------------|----------|----------|-----------|------------|------------|------------|
| Timer Prescaler (1, 4, 16) | 16       | 4        | 1         | 1          | 1          | 1          |
| PR2 Value                  | FFh      | FFh      | FFh       | 3Fh        | 1Fh        | 17h        |
| Maximum Resolution (bits)  | 10       | 10       | 10        | 8          | 7          | 6.58       |

#### TABLE 16-4: REGISTERS ASSOCIATED WITH PWM AND TIMER2

| Name    | Bit 7                                   | Bit 6        | Bit 5        | Bit 4     | Bit 3   | Bit 2  | Bit 1         | Bit 0   | Reset Values<br>on Page: |  |
|---------|-----------------------------------------|--------------|--------------|-----------|---------|--------|---------------|---------|--------------------------|--|
| INTCON  | GIE/GIEH                                | PEIE/GIEL    | TMR0IE       | INT0IE    | RBIE    | TMR0IF | <b>INT0IF</b> | RBIF    | 54                       |  |
| PIR1    | —                                       | ADIF         | RCIF         | TXIF      | SSPIF   | CCP1IF | TMR2IF        | TMR1IF  | 57                       |  |
| PIE1    | —                                       | ADIE         | RCIE         | TXIE      | SSPIE   | CCP1IE | TMR2IE        | TMR1IE  | 57                       |  |
| IPR1    | _                                       | ADIP         | RCIP         | TXIP      | SSPIP   | CCP1IP | TMR2IP        | TMR1IP  | 57                       |  |
| TRISC   | PORTC Da                                | ta Direction | Register     |           |         |        |               |         | 57                       |  |
| TMR2    | Timer2 Register                         |              |              |           |         |        |               |         |                          |  |
| PR2     | Timer2 Per                              | iod Register |              |           |         |        |               |         | 55                       |  |
| T2CON   | —                                       | TOUTPS3      | TOUTPS2      | TOUTPS1   | TOUTPS0 | TMR2ON | T2CKPS1       | T2CKPS0 | 55                       |  |
| CCPR1L  | Capture/Co                              | mpare/PWN    | 1 Register 1 | Low Byte  |         |        |               |         | 56                       |  |
| CCPR1H  | Capture/Co                              | mpare/PWN    | 1 Register 1 | High Byte |         |        |               |         | 56                       |  |
| CCP1CON | —                                       | _            | DC1B1        | DC1B0     | CCP1M3  | CCP1M2 | CCP1M1        | CCP1M0  | 56                       |  |
| CCPR2L  | Capture/Compare/PWM Register 2 Low Byte |              |              |           |         |        |               |         |                          |  |
| CCPR2H  | Capture/Co                              | mpare/PWN    | 1 Register 2 | High Byte |         |        |               |         | 56                       |  |
| CCP2CON |                                         |              | DC2B1        | DC2B0     | CCP2M3  | CCP2M2 | CCP2M1        | CCP2M0  | 56                       |  |

**Legend:** x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used by PWM and Timer2.

### 17.1.2 PERIOD MEASUREMENT MODE

The Period Measurement mode is selected by setting CAPxM<3:0> = 0101. In this mode, the value of Timer5 is latched into the CAPxBUF register on the rising edge of the input capture trigger and Timer5 is subsequently reset to 0000h (optional by setting CAPxREN = 1) on the next TCY (see capture and Reset relationship in Figure 17-4).

#### 17.1.3 PULSE-WIDTH MEASUREMENT MODE

The Pulse-Width Measurement mode can be configured for two different edge sequences, such that the pulse width is based on either the falling to rising edge of the CAPx input pin (CAPxM<3:0> = 0110), or on the rising to falling edge (CAPxM<3:0> = 0111). Timer5 is always reset on the edge when the measurement is first initiated. For example, when the measurement is based on the falling to rising edge, Timer5 is first reset on the falling edge, and thereafter, the timer value is captured on the rising edge. Upon entry into the Pulse-Width Measurement mode, the very first edge detected on the CAPx pin is always captured. The TMR5 value is reset on the first active edge (see Figure 17-5).

### FIGURE 17-5: PULSE-WIDTH MEASUREMENT MODE TIMING

|                        |                                                                                 | 67 66 60 k                                                   | xlinic.                                  | 208 024                                  | nadada                                                 | or oz os os                                         |                          |                                                              |                                           | kontoniko                     | X                      | nkaladis                          | 401030                           | -<br>Kyk               | a1a2a2a2                                     |
|------------------------|---------------------------------------------------------------------------------|--------------------------------------------------------------|------------------------------------------|------------------------------------------|--------------------------------------------------------|-----------------------------------------------------|--------------------------|--------------------------------------------------------------|-------------------------------------------|-------------------------------|------------------------|-----------------------------------|----------------------------------|------------------------|----------------------------------------------|
|                        |                                                                                 | NNV                                                          | ψ'n                                      | w                                        | VVV                                                    | NNN                                                 | ſ                        | hhhh                                                         | MM                                        | ſ₩                            |                        | ŴŴ                                | VVV                              |                        | NVV                                          |
| TMR8 <sup>(3)</sup>    |                                                                                 | X                                                            | X0                                       | 013                                      | <br>                                                   | ()                                                  | ***                      |                                                              |                                           | 002                           |                        | 0000 X                            | 00001                            |                        | 0902                                         |
| CAP1 P                 | n <sup>(2)</sup>                                                                |                                                              | }                                        |                                          |                                                        |                                                     |                          | }<br>{                                                       | }<br>                                     | \$                            |                        |                                   | -                                | )<br>9 {<br>{          |                                              |
| CAP18U                 | (8)a                                                                            |                                                              |                                          | ;                                        |                                                        |                                                     | }<br>                    | 0015                                                         | <u>}</u>                                  |                               |                        | 0001                              |                                  |                        | 0062                                         |
| TMR5 B                 | 556} <sup>{4,\$</sup> }                                                         |                                                              | ,<br>                                    | :<br>:<br>:                              |                                                        |                                                     | ·                        | }                                                            |                                           |                               |                        | ~~~~~                             |                                  | 8<br>[<br>             |                                              |
| Instructio<br>Executio | n<br>19<br>19<br>19<br>19<br>19<br>19<br>19<br>19<br>19<br>19<br>19<br>19<br>19 | 237 CAPIC                                                    | 3<br>88 X<br>1                           |                                          |                                                        |                                                     |                          | ,                                                            | \$                                        |                               |                        |                                   |                                  |                        |                                              |
| Note 1:<br>2:          | TMR5 is<br>IC1 is measure                                                       | a synchro<br>conligured<br>ment), No                         | nous 8<br>In P<br>noise 1                | me bas<br>ulse-W<br>filter o             | se Inputito<br>1dth - Mee<br>1 OAP1 In                 | the input<br>surement<br>put is used                | oa<br>ri<br>d. 1         | pture; presoa<br>vode - (CAP13<br>The sovwar ins             | ier ≈ 1:1<br>vi <s:0><br/>struction</s:0> | . it inor<br>≃ 01.:<br>Noada  | N883<br>1.1.)<br>3.2.4 | no ants<br>rísing<br>49300N       | avery Q<br>to fallir<br>when V   | 1 19<br>12 - 1<br>14 = | sing edge.<br>pulse-widti<br>0111.           |
| ng n<br>Dire           | TMRS vis<br>ture ever<br>updated<br>(see blot                                   | itue is later<br>nt, the write<br>with the in<br>re 4 when 1 | ied by<br>EwdEal<br>Cremei<br>Reset d    | CAP18<br>Iways t<br>nted ve<br>pcours)   | WF on To<br>ske prece<br>sue of the                    | Y rising ec<br>dence. All<br>time base              | ige<br>In<br>9 0 e       | ). In the avent<br>put Capture B<br>n the next To            | that a w<br>lutters, (<br>v clock (       | rrite to<br>DAP 18<br>ságe w  | TM<br>UF<br>her        | RS coin<br>, CAP28<br>n the cap   | sides wit<br>OF and<br>sture eve | h ar<br>CAI<br>sní i   | r input cap<br>*380F, an<br>iakes pisco      |
| đ <sub>e</sub> t.      | TMRS R<br>Is stway<br>failing Pt<br>Measure                                     | eset is nor<br>s present c<br>ilse-Width<br>ment mod-        | mally r<br>in the<br>Measu<br>3, it is - | an asyı<br>adge ti<br>Bremer<br>active ( | schronous<br>hat first in<br>it mode); i<br>on each fi | : Reset si;<br>Wates the<br>Lis active<br>Wang edge | sag<br>pi<br>cro<br>s de | ai to TMR5, W<br>use-width me<br>e each rising c<br>stocted. | /han us/<br>asuram<br>odge def            | ed in P<br>ent (Le<br>rected, | uis<br>., v<br>Br      | e-Widih<br>vhen oor<br>Had fattin | Measun<br>Higured<br>g to risia  | sme<br>in ti<br>tg P   | int modie, i<br>he rising tr<br>fulse-Wildti |
| Š1                     | TMR5 8                                                                          | eset oulse                                                   | is activ                                 | valed c                                  | s file can                                             | ture edae.                                          | T)                       | he CAP REN                                                   | bit has                                   | no bee                        | rin                    | a in this                         | mode.                            |                        |                                              |

| Name                    | Bit 7                                             | Bit 6                | Bit 5                  | Bit 4                 | Bit 3                                                | Bit 2        | Bit 1         | Bit 0        | Reset<br>Values<br>on Page: |
|-------------------------|---------------------------------------------------|----------------------|------------------------|-----------------------|------------------------------------------------------|--------------|---------------|--------------|-----------------------------|
| INTCON                  | GIE/GIEH                                          | GIE/GIEH PEIE/GIEL T |                        | INT0IE                | RBIE                                                 | TMR0IF       | INT0IF        | RBIF         | 54                          |
| IPR3                    | —                                                 | _                    | —                      | PTIP                  | IC3DRIP                                              | IC2QEIP      | IC1IP         | TMR5IP       | 56                          |
| PIE3                    | —                                                 | —                    | —                      | PTIE                  | IC3DRIE                                              | IC2QEIE      | IC1IE         | TMR5IE       | 56                          |
| PIR3                    | —                                                 | —                    | —                      | PTIF                  | IC3DRIF                                              | IC2QEIF      | IC1IF         | TMR5IF       | 56                          |
| PTCON0                  | PTOPS3                                            | PTOPS2               | PTOPS1                 | PTOPS0                | PTCKPS1                                              | PTCKPS0      | PTMOD1        | PTMOD0       | 58                          |
| PTCON1                  | PTEN                                              | PTDIR                | —                      | —                     |                                                      | —            | —             | —            | 58                          |
| PTMRL <sup>(1)</sup>    | PWM Time                                          | Base Registe         | er (lower 8 bits)      |                       |                                                      |              |               |              | 58                          |
| PTMRH <sup>(1)</sup>    |                                                   | UN                   | USED                   |                       | PWM Time                                             | Base Registe | er (upper 4 b | oits)        | 58                          |
| PTPERL <sup>(1)</sup>   | PWM Time                                          | Base Period          | Register (lowe         | r 8 bits)             |                                                      |              |               |              | 58                          |
| PTPERH <sup>(1)</sup>   |                                                   | UN                   | USED                   |                       | PWM Time                                             | Base Period  | Register (up  | oper 4 bits) | 58                          |
| SEVTCMPL <sup>(1)</sup> | PWM Special Event Compare Register (lower 8 bits) |                      |                        |                       |                                                      |              |               |              |                             |
| SEVTCMPH <sup>(1)</sup> |                                                   | UN                   | USED                   |                       | PWM Special Event Compare Register<br>(upper 4 bits) |              |               |              | 58                          |
| PWMCON0                 | _                                                 | PWMEN2               | PWMEN1                 | PWMEN0                | PMOD3 <sup>(2)</sup>                                 | PMOD2        | PMOD1         | PMOD0        | 58                          |
| PWMCON1                 | SEVOPS3                                           | SEVOPS2              | SEVOPS1                | SEVOPS0               | SEVTDIR                                              | —            | UDIS          | OSYNC        | 58                          |
| DTCON                   | DTPS1                                             | DTPS0                | DT5                    | DT4                   | DT3                                                  | DT2          | DT1           | DT0          | 58                          |
| FLTCONFIG               | BRFEN                                             | FLTBS <sup>(2)</sup> | FLTBMOD <sup>(2)</sup> | FLTBEN <sup>(2)</sup> | FLTCON                                               | FLTAS        | FLTAMOD       | FLTAEN       | 58                          |
| OVDCOND                 | POVD7 <sup>(2)</sup>                              | POVD6 <sup>(2)</sup> | POVD5                  | POVD4                 | POVD3                                                | POVD2        | POVD1         | POVD0        | 58                          |
| OVDCONS                 | POUT7 <sup>(2)</sup>                              | POUT6 <sup>(2)</sup> | POUT5                  | POUT4                 | POUT3                                                | POUT2        | POUT1         | POUT0        | 58                          |
| PDC0L <sup>(1)</sup>    | PWM Duty                                          | Cycle #0L Re         | egister (lower 8       | bits)                 |                                                      |              |               |              | 58                          |
| PDC0H <sup>(1)</sup>    | UNU                                               | JSED                 | PWM Duty Cy            | /cle #0H Regi         | ster (upper 6                                        | bits)        |               |              | 58                          |
| PDC1L <sup>(1)</sup>    | PWM Duty                                          | Cycle #1L reg        | gister (lower 8        | bits)                 |                                                      |              |               |              | 58                          |
| PDC1H <sup>(1)</sup>    | UNU                                               | JSED                 | PWM Duty Cy            | /cle #1H Regi         | ster (upper 6                                        | bits)        |               |              | 58                          |
| PDC2L <sup>(1)</sup>    | PWM Duty                                          | Cycle #2L Re         | egister (lower 8       | bits)                 |                                                      |              |               |              | 58                          |
| PDC2H <sup>(1)</sup>    | UNU                                               | JSED                 | PWM Duty Cy            | cle #2H Regi          | ster (upper 6                                        | bits)        |               |              | 58                          |
| PDC3L <sup>(1,2)</sup>  | PWM Duty                                          | Cycle #3L Re         | egister (lower 8       | bits)                 |                                                      |              |               |              | 58                          |
| PDC3H <sup>(1,2)</sup>  | UNU                                               | JSED                 | PWM Duty Cy            | cle #3H Regi          | ster (upper 6                                        | bits)        |               |              | 58                          |

#### TABLE 18-6: REGISTERS ASSOCIATED WITH THE POWER CONTROL PWM MODULE

Legend: — = Unimplemented, read as '0'. Shaded cells are not used with the power control PWM.

Note 1: Double-buffered register pairs. Refer to text for explanation of how these registers are read and written to.

2: Unimplemented in PIC18F2331/2431 devices; maintain these bits clear. Reset values shown are for PIC18F4331/4431 devices.

## 20.3.5 BREAK CHARACTER SEQUENCE

The Enhanced USART module has the capability of sending the special Break character sequences that are required by the LIN/J2602 bus standard. The Break character transmit consists of a Start bit, followed by twelve '0' bits and a Stop bit. The Frame Break character is sent whenever the SENDB and TXEN bits (TXSTA<3> and TXSTA<5>) are set while the Transmit Shift register is loaded with data. Note that the value of data written to TXREG will be ignored and all '0's will be transmitted.

The SENDB bit is automatically reset by hardware after the corresponding Stop bit is sent. This allows the user to preload the transmit FIFO with the next transmit byte following the Break character (typically, the Sync character in the LIN/J2602 specification).

Note that the data value written to the TXREG for the Break character is ignored. The write simply serves the purpose of initiating the proper sequence.

The TRMT bit indicates when the transmit operation is active or Idle, just as it does during normal transmission. See Figure 20-9 for the timing of the Break character sequence.

### 20.3.5.1 Break and Sync Transmit Sequence

The following sequence will send a message frame header made up of a Break, followed by an Auto-Baud Sync byte. This sequence is typical of a LIN/J2602 bus master.

- 1. Configure the EUSART for the desired mode.
- 2. Set the TXEN and SENDB bits to setup the Break character.
- 3. Load the TXREG with a dummy character to initiate transmission (the value is ignored).
- 4. Write '55h' to TXREG to load the Sync character into the transmit FIFO buffer.
- 5. After the Break has been sent, the SENDB bit is reset by hardware. The Sync character now transmits in the preconfigured mode.

When the TXREG becomes empty, as indicated by the TXIF, the next data byte can be written to TXREG.

#### 20.3.6 RECEIVING A BREAK CHARACTER

The Enhanced USART module can receive a Break character in two ways.

The first method forces configuration of the baud rate at a frequency of 9/13 of the typical speed. This allows for the Stop bit transition to be at the correct sampling location (13 bits for Break versus Start bit and 8 data bits for typical data).

The second method uses the auto-wake-up feature described in Section 20.3.4 "Auto-Wake-up on Sync Break Character". By enabling this feature, the EUSART will sample the next two transitions on RX/DT, cause an RCIF interrupt and receive the next data byte followed by another interrupt.

Note that following a Break character, the user will typically want to enable the Auto-Baud Rate Detect feature. For both methods, the user can set the ABD bit before placing the EUSART in its Sleep mode.

#### FIGURE 20-9: SEND BREAK CHARACTER SEQUENCE



## 23.4 Fail-Safe Clock Monitor

The Fail-Safe Clock Monitor (FSCM) allows the microcontroller to continue operation, in the event of an external oscillator failure, by automatically switching the system clock to the internal oscillator block. The FSCM function is enabled by setting the Fail-Safe Clock Monitor Enable bit, FCMEN (CONFIG1H<6>).

When FSCM is enabled, the INTRC oscillator runs at all times to monitor clocks to peripherals and provide an instant backup clock in the event of a clock failure. Clock monitoring (shown in Figure 23-3) is accomplished by creating a sample clock signal, which is the INTRC output divided by 64. This allows ample time between FSCM sample clocks for a peripheral clock edge to occur. The peripheral system clock and the sample clock are presented as inputs to the Clock Monitor latch (CM). The CM is set on the falling edge of the system clock source, but cleared on the rising edge of the sample clock.



Clock failure is tested for on the falling edge of the sample clock. If a sample clock falling edge occurs while the CM is still set, a clock failure has been detected (Figure 23-4). This causes the following:

- the FSCM generates an oscillator fail interrupt by setting bit, OSCFIF (PIR2<7>);
- the system clock source is switched to the internal oscillator block (OSCCON is not updated to show the current clock source – this is the fail-safe condition); and
- the WDT is reset.

Since the postscaler frequency from the internal oscillator block may not be sufficiently stable, it may be desirable to select another clock configuration and enter an alternate power-managed mode (see Section 23.3.1 "Special Considerations for Using Two-Speed Start-up" and Section 4.1.4 "Multiple Sleep Commands" for more details). This can be done to attempt a partial recovery or execute a controlled shutdown.

To use a higher clock speed on wake-up, the INTOSC or postscaler clock sources can be selected to provide a higher clock speed by setting bits, IRCF<2:0>, immediately after Reset. For wake-ups from Sleep, the INTOSC or postscaler clock sources can be selected by setting the IRCF<2:0> bits prior to entering Sleep mode.

Adjustments to the internal oscillator block using the OSCTUNE register also affect the period of the FSCM by the same factor. This can usually be neglected, as the clock frequency being monitored is generally much higher than the sample clock frequency.

The FSCM will detect failures of the primary or secondary clock sources only. If the internal oscillator block fails, no failure would be detected, nor would any action be possible.

#### 23.4.1 FSCM AND THE WATCHDOG TIMER

Both the FSCM and the WDT are clocked by the INTRC oscillator. Since the WDT operates with a separate divider and counter, disabling the WDT has no effect on the operation of the INTRC oscillator when the FSCM is enabled.

As already noted, the clock source is switched to the INTOSC clock when a clock failure is detected. Depending on the frequency selected by the IRCF<2:0> bits, this may mean a substantial change in the speed of code execution. If the WDT is enabled with a small prescale value, a decrease in clock speed allows a WDT time-out to occur and a subsequent device Reset. For this reason, Fail-Safe Clock Monitor events also reset the WDT and postscaler, allowing it to start timing from when execution speed was changed and decreasing the likelihood of an erroneous time-out.

## 23.4.2 EXITING FAIL-SAFE OPERATION

The fail-safe condition is terminated by either a device Reset, or by entering a power-managed mode. On Reset, the controller starts the primary clock source specified in Configuration Register 1H (with any required start-up delays that are required for the oscillator mode, such as the OST or PLL timer). The INTOSC multiplexer provides the system clock until the primary clock source becomes ready (similar to a Two-Speed Start-up). The clock system source is then switched to the primary clock (indicated by the OSTS bit in the OSCCON register becoming set). The Fail-Safe Clock Monitor then resumes monitoring the peripheral clock.

The primary clock source may never become ready during start-up. In this case, operation is clocked by the INTOSC multiplexer. The OSCCON register will remain in its Reset state until a power-managed mode is entered.

Entering a power-managed mode by loading the OSCCON register and executing a SLEEP instruction will clear the fail-safe condition. When the fail-safe condition is cleared, the clock monitor will resume monitoring the peripheral clock.

#### 23.5.2 DATA EEPROM CODE PROTECTION

The entire data EEPROM is protected from external reads and writes by two bits: CPD and WRTD. CPD inhibits external reads and writes of data EEPROM. WRTD inhibits external writes to data EEPROM. The CPU can continue to read and write data EEPROM regardless of the protection bit settings.

#### 23.5.3 CONFIGURATION REGISTER PROTECTION

The Configuration registers can be write-protected. The WRTC bit controls protection of the Configuration registers. In normal execution mode, the WRTC bit is readable only. WRTC can only be written via ICSP or an external programmer.

## 23.6 ID Locations

Eight memory locations (20000h-200007h) are designated as ID locations, where the user can store checksum or other code identification numbers. These locations are both readable and writable during normal execution through the TBLRD and TBLWT instructions, or during program/verify. The ID locations can be read when the device is code-protected.

## 23.7 In-Circuit Serial Programming

PIC18F2331/2431/4331 microcontrollers can be serially programmed while in the end application circuit. This is simply done with two lines for clock and data, and three other lines for power, ground and the programming voltage. This allows customers to manufacture boards with unprogrammed devices, and then program the microcontroller just before shipping the product. This also allows the most recent firmware or a custom firmware to be programmed.

## 23.8 In-Circuit Debugger

When the DEBUG bit in the CONFIG4L Configuration register is programmed to a '0', the In-Circuit Debugger functionality is enabled. This function allows simple debugging functions when used with MPLAB<sup>®</sup> IDE. When the microcontroller has this feature enabled, some resources are not available for general use. Table 23-4 shows which resources are required by the background debugger.

| I/O pins:       | RB6, RB7  |
|-----------------|-----------|
| Stack:          | 2 levels  |
| Program Memory: | <1 Kbytes |
| Data Memory:    | 16 bytes  |

To use the In-Circuit Debugger function of the microcontroller, the design must implement In-Circuit Serial Programming connections to  $\overline{\text{MCLR}/\text{VPP}}$ , VDD, VSS, RB7 and RB6. This will interface to the In-Circuit Debugger module available from Microchip or one of the third party development tool companies.

## 23.9 Single-Supply ICSP™ Programming

The LVP bit in Configuration Register 4L (CONFIG4L<2>) enables Single-Supply ICSP Programming. When LVP is enabled, the microcontroller can be programmed without requiring high voltage being applied to the MCLR/VPP pin, but the RB5/PGM pin is then dedicated to controlling Program mode entry and is not available as a general purpose I/O pin.

LVP is enabled in erased devices.

While programming, using Single-Supply Programming, VDD is applied to the MCLR/VPP pin as in normal execution mode. To enter Programming mode, VDD is applied to the PGM pin.

- Note 1: High-voltage programming is always available, regardless of the state of the LVP bit or the PGM pin, by applying VIHH to the MCLR pin.
  - 2: When Single-Supply Programming is enabled, the RB5 pin can no longer be used as a general purpose I/O pin.
  - **3:** When LVP is enabled externally, pull the PGM pin to Vss to allow normal program execution.

If Single-Supply ICSP Programming mode will not be used, the LVP bit can be cleared and RB5/PGM becomes available as the digital I/O pin RB5. The LVP bit may be set or cleared only when using standard high-voltage programming (VIHH applied to the MCLR/ VPP pin). Once LVP has been disabled, only the standard high-voltage programming is available and must be used to program the device.

Memory that is not code-protected can be erased using either a block erase, or erased row by row, then written at any specified VDD. If code-protected memory is to be erased, a block erase is required. If a block erase is to be performed when using Single-Supply Programming, the device must be supplied with VDD of 4.5V to 5.5V.

## TABLE 24-1: OPCODE FIELD DESCRIPTIONS

| Field           | Description                                                                                                  |
|-----------------|--------------------------------------------------------------------------------------------------------------|
| a               | RAM access bit:                                                                                              |
|                 | a = 0: RAM location in Access RAM (BSR register is ignored)                                                  |
|                 | a = 1: RAM bank is specified by BSR register                                                                 |
| bbb             | Bit address within an 8-bit file register (0 to 7).                                                          |
| BSR             | Bank Select Register. Used to select the current RAM bank.                                                   |
| d               | Destination select bit:                                                                                      |
|                 | d = 0: store result in the register f                                                                        |
| dest            | Destination either the WREG register or the specified register file locations                                |
| f               | 8-bit register file address (0x00 to 0xEF)                                                                   |
| fg              | 12-bit register file address (0x00 to 0xFF). This is the source address                                      |
| fd              | 12-bit register file address (0x000 to 0xFFE). This is the destination address                               |
| k               | Literal field, constant data or label (may be either an 8-bit, 12-bit or a 20-bit value)                     |
| label           | Label name                                                                                                   |
| mm              | The mode of the TBI PTR register for the table read and table write instructions                             |
|                 | Only used with table read and table write instructions:                                                      |
| *               | No Change to register (such as TBLPTR with table reads and writes).                                          |
| *+              | Post-Increment register (such as TBLPTR with table reads and writes).                                        |
| * _             | Post-Decrement register (such as TBLPTR with table reads and writes).                                        |
| +*              | Pre-Increment register (such as TBLPTR with table reads and writes).                                         |
| n               | The relative address (2's complement number) for relative branch instructions, or the direct address for     |
|                 | Call/Branch and Return instructions.                                                                         |
| PRODH           | Product of Multiply High Byte.                                                                               |
| PRODL           | Product of Multiply Low Byte.                                                                                |
| s               | Fast Call/Return Mode Select bit:                                                                            |
|                 | s = 0: do not update into/from Shadow registers                                                              |
|                 | s = 1: certain registers loaded into/from snadow registers (Fast mode)                                       |
| u               | Unused or Unchanged.                                                                                         |
| WREG            | Depit earse (fo) or (1/)                                                                                     |
| x               | The assembler will generate code with $x = 0$ . It is the recommended form of use for compatibility with all |
|                 | Microchip software tools.                                                                                    |
| TBLPTR          | 21-bit Table Pointer (points to a Program Memory location).                                                  |
| TABLAT          | 8-bit Table Latch.                                                                                           |
| TOS             | Top-of-Stack.                                                                                                |
| PC              | Program Counter.                                                                                             |
| PCL             | Program Counter Low Byte.                                                                                    |
| PCH             | Program Counter High Byte.                                                                                   |
| PCLATH          | Program Counter High Byte Latch.                                                                             |
| PCLATU          | Program Counter Upper Byte Latch.                                                                            |
| GIE             | Global Interrupt Enable bit.                                                                                 |
| WDT             | Watchdog Timer.                                                                                              |
| TO              | Time-out bit.                                                                                                |
| PD              | Power-Down bit.                                                                                              |
| C, DC, Z, OV, N | ALU Status bits: Carry, Digit Carry, Zero, Overflow, Negative.                                               |
| [ ]             | Optional.                                                                                                    |
| ( )             | Contents.                                                                                                    |
| $\rightarrow$   | Assigned to.                                                                                                 |
| < >             | Register bit field.                                                                                          |
| E               | In the set of.                                                                                               |
| italics         | User-defined term (font is Courier New).                                                                     |

# PIC18F2331/2431/4331/4431

Before Instruction W

After Instruction W

=

=

0xB5

0x1A

| тѕт         | FSZ                                              | Test f, Ski                                                                                                                      | Test f, Skip if 0                                                                                                                                                                                                                                                                                                                |                 |  |  |  |  |  |
|-------------|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|
| Synta       | ax:                                              | [label] T                                                                                                                        | [label] TSTFSZ f [,a]                                                                                                                                                                                                                                                                                                            |                 |  |  |  |  |  |
| Oper        | ands:                                            | 0 ≤ f ≤ 255<br>a ∈ [0,1]                                                                                                         | $\begin{array}{l} 0 \leq f \leq 255 \\ a \in [0,1] \end{array}$                                                                                                                                                                                                                                                                  |                 |  |  |  |  |  |
| Oper        | ation:                                           | skip if f = 0                                                                                                                    | skip if f = 0                                                                                                                                                                                                                                                                                                                    |                 |  |  |  |  |  |
| Statu       | s Affected:                                      | None                                                                                                                             |                                                                                                                                                                                                                                                                                                                                  |                 |  |  |  |  |  |
| Enco        | ding:                                            | 0110                                                                                                                             | 011a fff                                                                                                                                                                                                                                                                                                                         | f ffff          |  |  |  |  |  |
| Desc        | ription:                                         | If 'f' = 0, the<br>during the c<br>is discarded<br>making this<br>is '0', the Ad<br>overriding the<br>then the bar<br>the BSR va | If 'f' = 0, the next instruction, fetched<br>during the current instruction execution,<br>is discarded and a NOP is executed,<br>making this a two-cycle instruction. If 'a'<br>is '0', the Access Bank will be selected,<br>overriding the BSR value. If 'a' is '1',<br>then the bank will be selected as per<br>the BSR value. |                 |  |  |  |  |  |
| Word        | ls:                                              | 1                                                                                                                                |                                                                                                                                                                                                                                                                                                                                  |                 |  |  |  |  |  |
| Cycle       | es:                                              | 1(2)<br>Note: 3 cy<br>by a                                                                                                       | 1(2)<br><b>Note:</b> 3 cycles if skip and followed<br>by a 2-word instruction.                                                                                                                                                                                                                                                   |                 |  |  |  |  |  |
| QC          | ycle Activity:                                   |                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                  |                 |  |  |  |  |  |
|             | Q1                                               | Q2                                                                                                                               | Q3                                                                                                                                                                                                                                                                                                                               | Q4              |  |  |  |  |  |
|             | Decode                                           | Read<br>register 'f'                                                                                                             | Process<br>Data                                                                                                                                                                                                                                                                                                                  | No<br>operation |  |  |  |  |  |
| lf sk       | ip:                                              |                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                  |                 |  |  |  |  |  |
|             | Q1                                               | Q2                                                                                                                               | Q3                                                                                                                                                                                                                                                                                                                               | Q4              |  |  |  |  |  |
|             | No                                               | No                                                                                                                               | No                                                                                                                                                                                                                                                                                                                               | No              |  |  |  |  |  |
|             | operation                                        | operation                                                                                                                        | operation                                                                                                                                                                                                                                                                                                                        | operation       |  |  |  |  |  |
| If sk       | ip and followed                                  | d by 2-word in:                                                                                                                  | struction:                                                                                                                                                                                                                                                                                                                       | <b>.</b>        |  |  |  |  |  |
|             | Q1                                               | Q2                                                                                                                               | Q3                                                                                                                                                                                                                                                                                                                               | Q4              |  |  |  |  |  |
|             | No                                               | No                                                                                                                               | No                                                                                                                                                                                                                                                                                                                               | No              |  |  |  |  |  |
|             | No                                               | No                                                                                                                               | No                                                                                                                                                                                                                                                                                                                               | No              |  |  |  |  |  |
|             | operation                                        | operation                                                                                                                        | operation                                                                                                                                                                                                                                                                                                                        | operation       |  |  |  |  |  |
| <u>Exan</u> | nple:                                            | HERE T<br>NZERO<br>ZERO :                                                                                                        | HERE TSTFSZ CNT<br>NZERO :<br>ZERO :                                                                                                                                                                                                                                                                                             |                 |  |  |  |  |  |
|             | Before Instruc<br>PC = Ado                       | tion<br>dress (HERE)                                                                                                             |                                                                                                                                                                                                                                                                                                                                  |                 |  |  |  |  |  |
|             | After Instructic<br>If CNT<br>PC<br>If CNT<br>PC | on<br>= 0x0<br>= Ad<br>≠ 0x0<br>= Ad                                                                                             | DO,<br>dress (zero<br>DO,<br>dress (nzer                                                                                                                                                                                                                                                                                         | )<br>0)         |  |  |  |  |  |

| XORLW             | Exclusiv                            | Exclusive OR Literal with W                                                               |       |          |  |  |  |  |  |
|-------------------|-------------------------------------|-------------------------------------------------------------------------------------------|-------|----------|--|--|--|--|--|
| Syntax:           | [label]                             | [label] XORLW k                                                                           |       |          |  |  |  |  |  |
| Operands:         | $0 \le k \le 25$                    | 5                                                                                         |       |          |  |  |  |  |  |
| Operation:        | (W) .XOR                            | $k \rightarrow W$                                                                         |       |          |  |  |  |  |  |
| Status Affected:  | N, Z                                |                                                                                           |       |          |  |  |  |  |  |
| Encoding:         | 0000                                | 1010                                                                                      | kkkk  | kkkk     |  |  |  |  |  |
| Description:      | The conte<br>the 8-bit lit<br>in W. | The contents of W are XORed with<br>the 8-bit literal, 'k'. The result is placed<br>in W. |       |          |  |  |  |  |  |
| Words:            | 1                                   |                                                                                           |       |          |  |  |  |  |  |
| Cycles:           | 1                                   |                                                                                           |       |          |  |  |  |  |  |
| Q Cycle Activity: |                                     |                                                                                           |       |          |  |  |  |  |  |
| Q1                | Q2                                  | Q3                                                                                        |       | Q4       |  |  |  |  |  |
| Decode            | Read<br>literal 'k'                 | Proces<br>Data                                                                            | ss Wr | ite to W |  |  |  |  |  |
| Example:          | XORLW                               | )xAF                                                                                      |       |          |  |  |  |  |  |

NOTES: