



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²C, SPI, UART/USART                                                       |
| Peripherals                | Brown-out Detect/Reset, LVD, Power Control PWM, QEI, POR, PWM, WDT         |
| Number of I/O              | 24                                                                         |
| Program Memory Size        | 8KB (4K x 16)                                                              |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | 256 x 8                                                                    |
| RAM Size                   | 768 × 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 5.5V                                                                  |
| Data Converters            | A/D 5x10b                                                                  |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 28-SOIC (0.295", 7.50mm Width)                                             |
| Supplier Device Package    | 28-SOIC                                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18lf2331-i-so |

Email: info@E-XFL.COM

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

If the IRCF bits and the INTSRC bit are all clear, the INTOSC output is not enabled and the IOFS bit will remain clear; there will be no indication of the current clock source. The INTRC source is providing the device clocks.

If the IRCF bits are changed from all clear (thus, enabling the INTOSC output), or if INTSRC is set, the IOFS bit becomes set after the INTOSC output becomes stable. Clocks to the device continue while the INTOSC source stabilizes, after an interval of TIOBST.

If the IRCF bits were previously at a non-zero value, or if INTSRC was set before setting SCS1 and the INTOSC source was already stable, the IOFS bit will remain set. On transitions from RC\_RUN mode to PRI\_RUN mode, the device continues to be clocked from the INTOSC multiplexer while the primary clock is started. When the primary clock becomes ready, a clock switch to the primary clock occurs (see Figure 4-4). When the clock switch is complete, the IOFS bit is cleared, the OSTS bit is set and the primary clock is providing the device clock. The IDLEN and SCS bits are not affected by the switch. The INTRC source will continue to run if either the WDT or the Fail-Safe Clock Monitor is enabled.









#### 6.0 MEMORY ORGANIZATION

There are three memory types in enhanced MCU devices. These memory types are:

- Program Memory
- Data RAM
- Data EEPROM

As Harvard architecture devices, the data and program memories use separate buses, enabling concurrent access of the two memory spaces. The data EEPROM, for practical purposes, can be regarded as a peripheral device, since it is addressed and accessed through a set of control registers.

Additional detailed information on the operation of the Flash program memory is provided in **Section 8.0 "Flash Program Memory"**. Data EEPROM is discussed separately in **Section 7.0 "Data EEPROM Memory"**.

#### FIGURE 6-1: PROGRAM MEMORY MAP AND STACK FOR PIC18F2331/4331



#### 6.1 **Program Memory Organization**

PIC18 microcontrollers implement a 21-bit program counter that can address a 2-Mbyte program memory space. Accessing a location between the upper boundary of the physically implemented memory and the 2-Mbyte address will return all '0's (a NOP instruction).

The PIC18F2331/4331 devices each have 8 Kbytes of Flash memory and can store up to 4,096 single-word instructions.

The PIC18F2431/4431 devices each have 16 Kbytes of Flash memory and can store up to 8,192 single-word instructions.

PIC18 devices have two interrupt vectors. The Reset vector address is at 000000h and the interrupt vector addresses are at 000008h and 000018h.

The program memory maps for PIC18F2331/4331 and PIC18F2431/4431 devices are shown in Figure 6-1 and Figure 6-2, respectively.

FIGURE 6-2:

PROGRAM MEMORY MAP AND STACK FOR PIC18F2431/4431



#### 7.3 Reading the Data EEPROM Memory

To read a data memory location, the user must write the address to the EEADR register, clear the EEPGD control bit (EECON1<7>) and then set control bit, RD (EECON1<0>). The data is available for the very next instruction cycle; therefore, the EEDATA register can be read by the next instruction. EEDATA will hold this value until another read operation, or until it is written to by the user (during a write operation). The basic process is shown in Example 7-1.

#### 7.4 Writing to the Data EEPROM Memory

To write an EEPROM data location, the address must first be written to the EEADR register and the data written to the EEDATA register. The sequence in Example 7-2 must be followed to initiate the write cycle.

The write will not begin if this sequence is not exactly followed (write 55h to EECON2, write 0AAh to EECON2, then set WR bit) for each byte. It is strongly recommended that interrupts be disabled during this code segment.

Additionally, the WREN bit in EECON1 must be set to enable writes. This mechanism prevents accidental writes to data EEPROM due to unexpected code execution (i.e., runaway programs). The WREN bit should be kept clear at all times, except when updating the EEPROM. The WREN bit is not cleared by hardware. After a write sequence has been initiated, EECON1, EEADR and EEDATA cannot be modified. The WR bit will be inhibited from being set unless the WREN bit is set. The WREN bit must be set on a previous instruction. Both WR and WREN cannot be set with the same instruction.

At the completion of the write cycle, the WR bit is cleared in hardware and the EEPROM Interrupt Flag bit (EEIF) is set. The user may either enable this interrupt or poll this bit. EEIF must be cleared by software.

#### 7.5 Write Verify

Depending on the application, good programming practice may dictate that the value written to the memory should be verified against the original value. This should be used in applications where excessive writes can stress bits near the specification limit.

### 7.6 Protection Against Spurious Write

There are conditions when the device may not want to write to the data EEPROM memory. To protect against spurious EEPROM writes, various mechanisms have been built-in. On power-up, the WREN bit is cleared. Also, the Power-up Timer (72 ms duration) prevents EEPROM write.

The write initiate sequence and the WREN bit together help prevent an accidental write during brown-out, power glitch, or software malfunction.

#### EXAMPLE 7-1: DATA EEPROM READ

MOVLW DATA\_EE\_ADDR MOVWF EEADR BCF EECON1, EEPGD BSF EECON1, RD MOVF EEDATA, W

; Data Memory Address to read ; Point to DATA memory ; EEPROM Read ; W = EEDATA

:

#### EXAMPLE 7-2: DATA EEPROM WRITE

|                      | MOVLW                                   | DATA_EE_ADDR                                   | ;                                                             |
|----------------------|-----------------------------------------|------------------------------------------------|---------------------------------------------------------------|
|                      | MOVWF                                   | EEADR                                          | ; Data Memory Address to write                                |
|                      | MOVLW                                   | DATA_EE_DATA                                   | ;                                                             |
|                      | MOVWF                                   | EEDATA                                         | ; Data Memory Value to write                                  |
|                      | BCF                                     | EECON1, EEPGD                                  | ; Point to DATA memory                                        |
|                      | BCF                                     | EECON1, CFGS                                   | ; Access EEPROM                                               |
|                      | BSF                                     | EECON1, WREN                                   | ; Enable writes                                               |
| Required<br>Sequence | BCF<br>MOVLW<br>MOVWF<br>MOVLW<br>MOVWF | INTCON, GIE<br>55h<br>EECON2<br>0AAh<br>EECON2 | ; Disable Interrupts<br>;<br>; Write 55h<br>;<br>; Write 0AAh |
|                      | BSF                                     | EECON1, WR                                     | ; Set WR bit to begin write                                   |
|                      | BTFSC                                   | EECON1, WR                                     | ; Wait for write to complete                                  |
|                      | GOTO                                    | \$-2                                           | ;                                                             |
|                      | BSF                                     | INTCON, GIE                                    | ; Enable interrupts                                           |

#### 7.7 Operation During Code-Protect

Data EEPROM memory has its own code-protect bits in Configuration Words. External read and write operations are disabled if either of these mechanisms are enabled.

The microcontroller itself can both read and write to the internal data EEPROM, regardless of the state of the code-protect Configuration bit. Refer to Section 23.0 "Special Features of the CPU" for additional information.

#### 7.8 Protection Against Spurious Write

There are conditions when the device may not want to write to the data EEPROM memory. To protect against spurious EEPROM writes, various mechanisms have been implemented. On power-up, the WREN bit is cleared. In addition, writes to the EEPROM memory are blocked during the Power-up Timer period (TPWRT, Parameter 33).

The write/initiate sequence, and the WREN bit together, help prevent an accidental write during Brown-out Reset, power glitch or software malfunction.

#### 7.9 Using the Data EEPROM

The data EEPROM is a high-endurance, byteaddressable array that has been optimized for the storage of frequently changing information (e.g., program variables or other data that are updated often). Frequently changing values will typically be updated more often than Specification D124. If this is not the case, an array refresh must be performed. For this reason, variables that change infrequently (such as constants, IDs, calibration, etc.) should be stored in Flash program memory.

A simple data EEPROM refresh routine is shown in Example 7-3.

**Note:** If data EEPROM is only used to store constants and/or data that changes rarely, an array refresh is likely not required. See Specification D124.

|          | CLRF   | EEADR         | ; | Start at address 0         |
|----------|--------|---------------|---|----------------------------|
|          | BCF    | EECON1, CFGS  | ; | Set for memory             |
|          | BCF    | EECON1, EEPGD | ; | Set for Data EEPROM        |
|          | BCF    | INTCON, GIE   | ; | Disable interrupts         |
|          | BSF    | EECON1, WREN  | ; | Enable writes              |
| LOOP     |        |               | ; | Loop to refresh array      |
|          | BSF    | EECON1, RD    | ; | Read current address       |
|          | MOVLW  | 55h           | ; |                            |
|          | MOVWF  | EECON2        | ; | Write 55h                  |
| Required | MOVLW  | 0AAh          | ; |                            |
| Sequence | MOVWF  | EECON2        | ; | Write OAAh                 |
|          | BSF    | EECON1, WR    | ; | Set WR bit to begin write  |
|          | BTFSC  | EECON1, WR    | ; | Wait for write to complete |
|          | BRA    | \$-2          |   |                            |
|          | INCFSZ | EEADR, F      | ; | Increment address          |
|          | BRA    | LOOP          | ; | Not zero, do it again      |
|          |        |               |   |                            |
|          | BCF    | EECON1, WREN  | ; | Disable writes             |
|          | BSF    | INTCON, GIE   | ; | Enable interrupts          |
| 1        |        |               |   |                            |

EXAMPLE 7-3: DATA EEPROM REFRESH ROUTINE

### 10.0 INTERRUPTS

The PIC18F2331/2431/4331/4431 devices have multiple interrupt sources and an interrupt priority feature that allows each interrupt source to be assigned a high-priority level or a low-priority level. The high-priority interrupt vector is at 000008h and the low-priority interrupt vector is at 000018h. High-priority interrupt events will interrupt any low-priority interrupts that may be in progress.

There are thirteen registers which are used to control interrupt operation. These registers are:

- RCON
- INTCON
- INTCON2
- INTCON3
- PIR1, PIR2, PIR3
- PIE1, PIE2, PIE3
- IPR1, IPR2, IPR3

It is recommended that the Microchip header files supplied with MPLAB<sup>®</sup> IDE be used for the symbolic bit names in these registers. This allows the assembler/ compiler to automatically take care of the placement of these bits within the specified register.

In general, each interrupt source has three bits to control its operation. The functions of these bits are:

- Flag bit to indicate that an interrupt event occurred
- Enable bit that allows program execution to branch to the interrupt vector address when the flag bit is set
- Priority bit to select high priority or low priority (most interrupt sources have priority bits)

The interrupt priority feature is enabled by setting the IPEN bit (RCON<7>). When interrupt priority is enabled, there are two bits which enable interrupts globally. Setting the GIEH bit (INTCON<7>) enables all interrupts that have the priority bit set (high priority). Setting the GIEL bit (INTCON<6>) enables all interrupts that have the priority bit cleared (low priority). When the interrupt flag, enable bit and appropriate global interrupt enable bit are set, the interrupt will vector immediately to address 00008h or 000018h depending on the priority bit setting. Individual interrupts can be disabled through their corresponding enable bits.

When the IPEN bit is cleared (default state), the interrupt priority feature is disabled and interrupts are compatible with PIC<sup>®</sup> mid-range devices. In Compatibility mode, the interrupt priority bits for each source have no effect. INTCON<6> is the PEIE bit, which enables/disables all peripheral interrupt sources. INTCON<7> is the GIE bit, which enables/disables all interrupt sources. All interrupts branch to address 000008h in Compatibility mode.

When an interrupt is responded to, the global interrupt enable bit is cleared to disable further interrupts. If the IPEN bit is cleared, this is the GIE bit. If interrupt priority levels are used, this will be either the GIEH or GIEL bit. High-priority interrupt sources can interrupt a lowpriority interrupt. Low-priority interrupts are not processed while high-priority interrupts are in progress.

The return address is pushed onto the stack and the PC is loaded with the interrupt vector address (00008h or 000018h). Once in the Interrupt Service Routine, the source(s) of the interrupt can be determined by polling the interrupt flag bits. The interrupt flag bits must be cleared in software before re-enabling interrupts to avoid recursive interrupts.

The "return from interrupt" instruction, RETFIE, exits the interrupt routine and sets the GIE bit (GIEH or GIEL if priority levels are used), which re-enables interrupts.

For external interrupt events, such as the INTx pins or the PORTB input change interrupt, the interrupt latency will be three to four instruction cycles. The exact latency is the same for one or two-cycle instructions. Individual interrupt flag bits are set, regardless of the status of their corresponding enable bit or the GIE bit.

**Note:** Do not use the MOVFF instruction to modify any of the Interrupt Control registers while **any** interrupt is enabled. Doing so may cause erratic microcontroller behavior.

#### 10.2 PIR Registers

The PIR registers contain the individual flag bits for the peripheral interrupts. Due to the number of peripheral interrupt sources, there are three Peripheral Interrupt Request (Flag) Registers (PIR1, PIR2 and PIR3).

- Note 1: Interrupt flag bits are set when an interrupt condition occurs, regardless of the state of its corresponding enable bit or the Global Interrupt Enable bit, GIE (INTCON<7>).
  - 2: User software should ensure the appropriate interrupt flag bits are cleared prior to enabling an interrupt and after servicing that interrupt.

#### REGISTER 10-4: PIR1: PERIPHERAL INTERRUPT REQUEST (FLAG) REGISTER 1

| U-0   | R/W-0 | R-0  | R-0  | R/W-0 | R/W-0  | R/W-0  | R/W-0  |
|-------|-------|------|------|-------|--------|--------|--------|
| _     | ADIF  | RCIF | TXIF | SSPIF | CCP1IF | TMR2IF | TMR1IF |
| bit 7 |       |      |      |       |        |        | bit 0  |

| Levend        |                         |                                                             |                                                 |                    |
|---------------|-------------------------|-------------------------------------------------------------|-------------------------------------------------|--------------------|
| P - Poodoble  | , hit                   | M = Mritable bit                                            | 11 - Unimplomented bit                          | road as '0'        |
| R = Readable  |                         | vv = vviilable bil                                          | O = Onimplemented bit.                          | , reau as U        |
| -n = value at | PUR                     | i = Bit is set                                              | 0 = Bit is cleared                              | x = Bit is unknown |
|               |                         |                                                             |                                                 |                    |
| bit 7         | Unimplem                | nented: Read as '0'                                         |                                                 |                    |
| bit 6         | ADIF: A/D               | Converter Interrupt Flag b                                  | it                                              |                    |
|               | 1 = An A/I<br>0 = The A | D conversion completed (m<br>/D conversion is not compl     | nust be cleared in software)<br>ete             |                    |
| bit 5         | RCIF: EUS               | SART Receive Interrupt Fla                                  | ig bit                                          |                    |
|               | 1 = The E               | USART receive buffer, RC                                    | REG, is full (cleared when RCF                  | REG is read)       |
|               | 0 = The E               | USART receive buffer is er                                  | npty                                            |                    |
| bit 4         | TXIF: EUS               | SART Transmit Interrupt Fla                                 | ig bit                                          |                    |
|               | 1 = The E<br>0 = The E  | USART transmit buffer, TX<br>USART transmit buffer is f     | REG, is empty (cleared when <sup>-</sup><br>ull | TXREG is written)  |
| bit 3         | SSPIF: Sy               | nchronous Serial Port Inter                                 | rrupt Flag bit                                  |                    |
|               | 1 = The tr              | ansmission/reception is co                                  | mplete (must be cleared in sof                  | tware)             |
|               | 0 = Waitin              | ig to transmit/receive                                      |                                                 |                    |
| bit 2         | CCP1IF: C               | CCP1 Interrupt Flag bit                                     |                                                 |                    |
|               | Capture m               | ode:                                                        |                                                 |                    |
|               | 1 = A TMP<br>0 = No TM  | R1 register capture occurre<br>/IR1 register capture occurr | d (must be cleared in software<br>ed            | )                  |
|               | Compare r               | <u>mode:</u>                                                |                                                 |                    |
|               | 1 = A TMI               | R1 register compare match                                   | occurred (must be cleared in s                  | software)          |
|               | 0 = NO IN               | /IR1 register compare mate                                  | h occurred                                      |                    |
|               | Unused in               | this mode.                                                  |                                                 |                    |
| bit 1         | TMR2IF: T               | MR2 to PR2 Match Interru                                    | ot Flag bit                                     |                    |
| ~             | 1 = TMR2                | to PR2 match occurred (n                                    | nust be cleared in software)                    |                    |
|               | 0 = No Th               | /R2 to PR2 match occurred                                   | d                                               |                    |
| bit 0         | TMR1IF: 7               | MR1 Overflow Interrupt Fl                                   | aq bit                                          |                    |
| -             | 1 = TMR1                | register overflowed (must                                   | be cleared in software)                         |                    |
|               | 0 = TMR1                | register did not overflow                                   | ,                                               |                    |

### 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                             |
|         |                                                  |

| 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                       |
| IPR3    | _                                | _         | _      | PTIP   | IC3DRIP | IC2QEIP | IC1IP         | TMR5IP | 56                       |
| PIE3    | —                                | —         | —      | PTIE   | IC3DRIE | IC2QEIE | IC1IE         | TMR5IE | 56                       |
| PIR3    | —                                | —         | —      | PTIF   | IC3DRIF | IC2QEIF | IC1IF         | TMR5IF | 56                       |
| TMR5H   | I Timer5 Register High Byte      |           |        |        |         |         |               | 57     |                          |
| TMR5L   | TImer5 Register Low Byte         |           |        |        |         |         |               | 57     |                          |
| PR5H    | Timer5 Period Register High Byte |           |        |        |         |         |               | 57     |                          |
| PR5L    | Timer5 Period Register Low Byte  |           |        |        |         |         |               |        | 57                       |
| T5CON   | T5SEN                            | RESEN     | T5MOD  | T5PS1  | T5PS0   | T5SYNC  | TMR5CS        | TMR5ON | 56                       |
| CAP1CON | _                                | CAP1REN   | _      | _      | CAP1M3  | CAP1M2  | CAP1M1        | CAP1M0 | 59                       |
| DFLTCON | —                                | FLT4EN    | FLT3EN | FLT2EN | FLT1EN  | FLTCK2  | FLTCK1        | FLTCK0 | 59                       |

TABLE 15-1: REGISTERS ASSOCIATED WITH TIMER5

Legend: — = unimplemented. Shaded cells are not used by the Timer5 module.

#### 17.2.2 QEI MODES

Position measurement resolution depends on how often the Position Counter register, POSCNT, is incremented. There are two QEI Update modes to measure the rotor's position: QEI x2 and QEI x4.

| QEIM<2:0> | Mode/<br>Reset                | Description                                                                                    |
|-----------|-------------------------------|------------------------------------------------------------------------------------------------|
| 000       | _                             | QEI disabled. <sup>(1)</sup>                                                                   |
| 001       | x2 update/<br>index pulse     | Two clocks per QEA<br>pulse. INDX resets<br>POSCNT.                                            |
| 010       | x2 update/<br>period<br>match | Two clocks per QEA pulse.<br>POSCNT is reset by the<br>period match (MAXCNT).                  |
| 011       | _                             | Unused.                                                                                        |
| 100       | _                             | Unused.                                                                                        |
| 101       | x4 update/<br>index pulse     | Four clocks per QEA and QEB pulse pair. INDX resets POSCNT.                                    |
| 110       | x4 update/<br>period<br>match | Four clocks per QEA and<br>QEB pulse pair.<br>POSCNT is reset by the<br>period match (MAXCNT). |
| 111       | —                             | Unused.                                                                                        |

**Note 1:** QEI module is disabled. The position counter and the velocity measurement functions are fully disabled in this mode.

#### 17.2.2.1 QEI x2 Update Mode

QEI x2 Update mode is selected by setting the QEI Mode Select bits (QEIM<2:0>) to '001' or '010'. In this mode, the QEI logic detects every edge on the QEA input only. Every rising and falling edge on the QEA signal clocks the position counter.

The position counter can be reset by either an input on the INDX pin (QEIM<2:0> = 001), or by a period match, even when the POSCNT register pair equals MAXCNT (QEIM<2:0> = 010).

#### 17.2.2.2 QEI x4 Update Mode

QEI x4 Update mode provides for a finer resolution of the rotor position, since the counter increments or decrements more frequently for each QEA/QEB input pulse pair than in QEI x2 mode. This mode is selected by setting the QEI mode select bits to '101' or '110'. In QEI x4, the phase measurement is made on the rising and the falling edges of both QEA and QEB inputs. The position counter is clocked on every QEA and QEB edge.

Like QEI x2 mode, the position counter can be reset by an input on the pin (QEIM<2:0> = 101), or by the period match event (QEIM<2:0> = 010).

#### 17.2.3 QEI OPERATION

The Position Counter register pair (POSCNTH: POSCNTL) acts as an integrator, whose value is proportional to the position of the sensor rotor that corresponds to the number of active edges detected. POSCNT can either increment or decrement, depending on a number of selectable factors which are decoded by the QEI logic block. These include the Count mode selected, the phase relationship of QEA to QEB ("lead/lag"), the direction of rotation and if a Reset event occurs. The logic is detailed in the sections that follow.

#### 17.2.3.1 Edge and Phase Detect

In the first step, the active edges of QEA and QEB are detected, and the phase relationship between them is determined. The position counter is changed based on the selected QEI mode.

In QEI x2 Update mode, the position counter increments or decrements on every QEA edge based on the phase relationship of the QEA and QEB signals.

In QEI x4 Update mode, the position counter increments or decrements on every QEA and QEB edge based on the phase relationship of the QEA and QEB signals. For example, if QEA leads QEB, the position counter is incremented by '1'. If QEB lags QEA, the position counter is decremented by '1'.

#### 17.2.3.2 Direction of Count

The QEI control logic generates a signal that sets the UP/DOWN bit (QEICON<5>); this, in turn, determines the direction of the count. When QEA leads QEB, UP/DOWN is set (= 1) and the position counter increments on every active edge. When QEA lags QEB, UP/DOWN is cleared and the position counter decrements on every active edge.

#### TABLE 17-5: DIRECTION OF ROTATION

| Current            | P   | Previous Signal<br>Detected |      |      |                       |  |  |
|--------------------|-----|-----------------------------|------|------|-----------------------|--|--|
| Signal<br>Detected | Ris | sing                        | Fall | ling | Cntrl. <sup>(1)</sup> |  |  |
|                    | QEA | QEB                         | QEA  | QEB  |                       |  |  |
| QEA Rising         |     |                             |      | х    | INC                   |  |  |
|                    |     | х                           |      |      | DEC                   |  |  |
| QEA Falling        |     |                             |      | х    | DEC                   |  |  |
|                    |     | х                           |      |      | INC                   |  |  |
| QEB Rising         | х   |                             |      |      | INC                   |  |  |
|                    |     |                             | х    |      | DEC                   |  |  |
| QEB Falling        |     |                             | х    |      | INC                   |  |  |
|                    | х   |                             |      |      | DEC                   |  |  |

**Note 1:** When UP/DOWN = 1, the position counter is incremented. When UP/DOWN = 0, the position counter is decremented.

#### 17.3 Noise Filters

The Motion Feedback Module includes three noise rejection filters on RA2/AN2/VREF-/CAP1/INDX, RA3/AN3/VREF+/CAP2/QEA and RA4/AN4/CAP3/QEB. The filter block also includes a fourth filter for the T5CKI pin. They are intended to help reduce spurious noise spikes which may cause the input signals to become corrupted at the inputs. The filter ensures that the input signals are not permitted to change until a stable value has been registered for three consecutive sampling clock cycles.

The filters are controlled using the Digital Filter Control (DFLTCON) register (see Register 17-3). The filters can be individually enabled or disabled by setting or clearing the corresponding FLTxEN bit in the DFLTCON register. The sampling frequency, which must be the same for all three noise filters, can be

programmed by the FLTCK<2:0> Configuration bits. TCY is used as the clock reference to the clock divider block.

The noise filters can either be added or removed from the input capture, or QEI signal path, by setting or clearing the appropriate FLTxEN bit, respectively. Each capture channel provides for individual enable control of the filter output. The FLT4EN bit enables or disables the noise filter available on the T5CKI input in the Timer5 module.

The filter network for all channels is disabled on Power-on and Brown-out Resets, as the DFLTCON register is cleared on Resets. The operation of the filter is shown in the timing diagram in Figure 17-14.

| REGISTER 17-3: DFLTCON: DIGITAL FILTER CONTROL REGIST | ER |
|-------------------------------------------------------|----|
|-------------------------------------------------------|----|

| U-0        | R/W-0                    | R/W-0                 | R/W-0                 | R/W-0                 | R/W-0           | R/W-0           | R/W-0  |
|------------|--------------------------|-----------------------|-----------------------|-----------------------|-----------------|-----------------|--------|
| _          | FLT4EN                   | FLT3EN <sup>(1)</sup> | FLT2EN <sup>(1)</sup> | FLT1EN <sup>(1)</sup> | FLTCK2          | FLTCK1          | FLTCK0 |
| bit 7      |                          |                       |                       |                       |                 |                 | bit 0  |
| l ogond:   |                          |                       |                       |                       |                 |                 |        |
| R = Read   | lable bit                | W = Writable I        | oit                   | U = Unimplem          | ented bit. read | d as '0'        |        |
| -n = Value | e at POR                 | '1' = Bit is set      |                       | '0' = Bit is clea     | ared            | x = Bit is unkr | iown   |
| bit 7      | Unimpleme                | nted: Read as '0      | 3                     |                       |                 |                 |        |
| bit 6      | FI T4FN: No              | ise Filter Output     | Enable bit (T5)       | CKI input)            |                 |                 |        |
|            | 1 = Enabled              | l                     |                       | or a mpacy            |                 |                 |        |
|            | 0 = Disable              | d                     |                       |                       |                 |                 |        |
| bit 5      | FLT3EN: No               | ise Filter Output     | Enable bit (CA        | .P3/QEB input)(       | 1)              |                 |        |
|            | 1 = Enabled              | 1                     |                       |                       |                 |                 |        |
|            | 0 = Disable              | d                     |                       |                       |                 |                 |        |
| bit 4      | FLT2EN: No               | ise Filter Output     | Enable bit (CA        | P2/QEA input)         | 1)              |                 |        |
|            | 1 = Enabled              | l                     |                       |                       |                 |                 |        |
|            | 0 = Disable              | d                     |                       |                       |                 |                 |        |
| bit 3      | FLT1EN: No               | ise Filter Output     | Enable bit (CA        | P1/INDX Input)        | (1)             |                 |        |
|            | 1 = Enabled              | 1                     |                       |                       |                 |                 |        |
|            | 0 = Disable              | d                     |                       |                       |                 |                 |        |
| bit 2-0    | FLTCK<2:0>               | Noise Filter Cl       | ock Divider Ra        | tio bits              |                 |                 |        |
|            | 111 = Unus               | ed                    |                       |                       |                 |                 |        |
|            | 110 = 1.128              | 5                     |                       |                       |                 |                 |        |
|            | 101 = 1.04<br>100 = 1.32 |                       |                       |                       |                 |                 |        |
|            | 011 = 1:16               |                       |                       |                       |                 |                 |        |
|            | 010 = <b>1</b> :4        |                       |                       |                       |                 |                 |        |
|            | 001 = 1:2                |                       |                       |                       |                 |                 |        |
|            | 000 = 1:1                |                       |                       |                       |                 |                 |        |
| Note 1:    | The noise filter         | output enables        | are functional i      | n both QEI and        | IC Operating    | modes.          |        |

Note: The noise filter is intended for random high-frequency filtering and not continuous high-frequency filtering.

#### 18.4.2 INTERRUPTS IN SINGLE-SHOT MODE

When the PWM time base is in the Single-Shot mode (PTMOD<1:0> = 01), an interrupt event is generated when a match with the PTPER register occurs. The PWM Time Base register (PTMR) is reset to zero on the following input clock edge and the PTEN bit is cleared. The postscaler selection bits have no effect in this Timer mode.

#### 18.4.3 INTERRUPTS IN CONTINUOUS UP/DOWN COUNT MODE

In the Continuous Up/Down Count mode (PTMOD<1:0> = 10), an interrupt event is generated each time the value of the PTMR register becomes zero and the PWM time base begins to count upwards. The postscaler selection bits may be used in this mode of the timer to reduce the frequency of the interrupt events. Figure 18-7 shows the interrupts in Continuous Up/Down Count mode.

#### FIGURE 18-6: PWM TIME BASE INTERRUPT TIMING, SINGLE-SHOT MODE



#### 18.11 PWM Output and Polarity Control

There are three device Configuration bits associated with the PWM module that provide PWM output pin control defined in the CONFIG3L Configuration register. They are:

- HPOL
- LPOL
- PWMPIN

These three Configuration bits work in conjunction with the three PWM Enable bits (PWMEN<2:0>) in the PWMCON0 register. The Configuration bits and PWM enable bits ensure that the PWM pins are in the correct states after a device Reset occurs.

#### 18.11.1 OUTPUT PIN CONTROL

The PWMEN<2:0> control bits enable each PWM output pin as required in the application.

All PWM I/O pins are general purpose I/O. When a pair of pins are enabled for PWM output, the PORT and TRIS registers controlling the pins are disabled. Refer to Figure 18-23 for details.

#### FIGURE 18-23: PWM I/O PIN BLOCK DIAGRAM

#### 18.11.2 OUTPUT POLARITY CONTROL

The polarity of the PWM I/O pins is set during device programming via the HPOL and LPOL Configuration bits in the CONFIG3L Configuration register. The HPOL Configuration bit sets the output polarity for the high side PWM outputs: PWM1, PWM3, PWM5 and PWM7. The polarity is active-low when HPOL is cleared (= 0), and active-high when it is set (= 1).

The LPOL Configuration bit sets the output polarity for the low side PWM outputs: PWM0, PWM2, PWM4 and PWM6. As with HPOL, they are active-low when LPOL is cleared and active-high when it is set.

All output signals generated by the PWM module are referenced to the polarity control bits, including those generated by Fault inputs or manual override (see **Section 18.10 "PWM Output Override**").

The default polarity Configuration bits have the PWM I/O pins in active-high output polarity.



| 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                                          | PEIE/GIEL            | TMR0IE                 | 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 Speci                                         | al Event Con         | npare Register         | (lower 8 bits)        |                            |                    |               |              | 58                          |
| SEVTCMPH <sup>(1)</sup> |                                                   | UN                   | USED                   |                       | PWM Speci<br>(upper 4 bits | al Event Con<br>3) | npare Regist  | ter          | 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 register (lower 8 bits)        |                      |                        |                       |                            |                    | 58            |              |                             |
| PDC1H <sup>(1)</sup>    | UNUSED PWM Duty Cycle #1H Register (upper 6 bits) |                      |                        |                       |                            |                    | 58            |              |                             |
| PDC2L <sup>(1)</sup>    | PWM Duty Cycle #2L Register (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 Register (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.

|       | <b>SYNC =</b> 0, <b>BRGH =</b> 1, <b>BRG16 =</b> 0 |            |                             |                       |            |                             |                       |            |                             |                       |            |                             |
|-------|----------------------------------------------------|------------|-----------------------------|-----------------------|------------|-----------------------------|-----------------------|------------|-----------------------------|-----------------------|------------|-----------------------------|
| BAUD  | Fosc                                               | = 40.000   | ) MHz                       | Fosc                  | = 20.000   | ) MHz                       | Fosc = 10.000 MHz     |            |                             | Fosc = 8.000 MHz      |            |                             |
| (K)   | Actual<br>Rate<br>(K)                              | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate<br>(K) | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate<br>(K) | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate<br>(K) | %<br>Error | SPBRG<br>value<br>(decimal) |
| 2.4   | —                                                  | _          | _                           | —                     | —          | _                           | 2.441                 | 1.73       | 255                         | 2.403                 | -0.16      | 207                         |
| 9.6   | 9.766                                              | 1.73       | 255                         | 9.615                 | 0.16       | 129                         | 9.615                 | 0.16       | 64                          | 9.615                 | -0.16      | 51                          |
| 19.2  | 19.231                                             | 0.16       | 129                         | 19.231                | 0.16       | 64                          | 19.531                | 1.73       | 31                          | 19.230                | -0.16      | 25                          |
| 57.6  | 58.140                                             | 0.94       | 42                          | 56.818                | -1.36      | 21                          | 56.818                | -1.36      | 10                          | 55.555                | 3.55       | 8                           |
| 115.2 | 113.636                                            | -1.36      | 21                          | 113.636               | -1.36      | 10                          | 125.000               | 8.51       | 4                           | _                     | —          |                             |

#### TABLE 20-3: BAUD RATES FOR ASYNCHRONOUS MODES (CONTINUED)

|       |                       | SYNC = 0, BRGH = 1, BRG16 = 0 |                             |                       |            |                             |                       |            |                             |  |  |
|-------|-----------------------|-------------------------------|-----------------------------|-----------------------|------------|-----------------------------|-----------------------|------------|-----------------------------|--|--|
| BAUD  | Foso                  | c = 4.000                     | MHz                         | Fos                   | c = 2.000  | MHz                         | Fosc = 1.000 MHz      |            |                             |  |  |
| (K)   | Actual<br>Rate<br>(K) | %<br>Error                    | SPBRG<br>value<br>(decimal) | Actual<br>Rate<br>(K) | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate<br>(K) | %<br>Error | SPBRG<br>value<br>(decimal) |  |  |
| 0.3   | —                     |                               | _                           | _                     |            | _                           | 0.300                 | -0.16      | 207                         |  |  |
| 1.2   | 1.202                 | 0.16                          | 207                         | 1.201                 | -0.16      | 103                         | 1.201                 | -0.16      | 51                          |  |  |
| 2.4   | 2.404                 | 0.16                          | 103                         | 2.403                 | -0.16      | 51                          | 2.403                 | -0.16      | 25                          |  |  |
| 9.6   | 9.615                 | 0.16                          | 25                          | 9.615                 | -0.16      | 12                          | —                     | _          | _                           |  |  |
| 19.2  | 19.231                | 0.16                          | 12                          | —                     | _          | _                           | —                     | _          | _                           |  |  |
| 57.6  | 62.500                | 8.51                          | 3                           | —                     | _          | _                           | —                     | _          | _                           |  |  |
| 115.2 | 125.000               | 8.51                          | 1                           | _                     | —          | —                           | _                     |            | —                           |  |  |

|       |                       |            |                             |                       | SYNC       | = 0, BRGH                   | <b>I</b> = 0, BRG     | i <b>16 =</b> 1 |                             |                       |                  |                             |  |
|-------|-----------------------|------------|-----------------------------|-----------------------|------------|-----------------------------|-----------------------|-----------------|-----------------------------|-----------------------|------------------|-----------------------------|--|
| BAUD  | Fosc                  | = 40.000   | ) MHz                       | Fosc = 20.000 MHz     |            |                             | Fosc = 10.000 MHz     |                 |                             | Fos                   | Fosc = 8.000 MHz |                             |  |
| (K)   | Actual<br>Rate<br>(K) | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate<br>(K) | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate<br>(K) | %<br>Error      | SPBRG<br>value<br>(decimal) | Actual<br>Rate<br>(K) | %<br>Error       | SPBRG<br>value<br>(decimal) |  |
| 0.3   | 0.300                 | 0.00       | 8332                        | 0.300                 | 0.02       | 4165                        | 0.300                 | 0.02            | 2082                        | 0.300                 | -0.04            | 1665                        |  |
| 1.2   | 1.200                 | 0.02       | 2082                        | 1.200                 | -0.03      | 1041                        | 1.200                 | -0.03           | 520                         | 1.201                 | -0.16            | 415                         |  |
| 2.4   | 2.402                 | 0.06       | 1040                        | 2.399                 | -0.03      | 520                         | 2.404                 | 0.16            | 259                         | 2.403                 | -0.16            | 207                         |  |
| 9.6   | 9.615                 | 0.16       | 259                         | 9.615                 | 0.16       | 129                         | 9.615                 | 0.16            | 64                          | 9.615                 | -0.16            | 51                          |  |
| 19.2  | 19.231                | 0.16       | 129                         | 19.231                | 0.16       | 64                          | 19.531                | 1.73            | 31                          | 19.230                | -0.16            | 25                          |  |
| 57.6  | 58.140                | 0.94       | 42                          | 56.818                | -1.36      | 21                          | 56.818                | -1.36           | 10                          | 55.555                | 3.55             | 8                           |  |
| 115.2 | 113.636               | -1.36      | 21                          | 113.636               | -1.36      | 10                          | 125.000               | 8.51            | 4                           |                       | _                | —                           |  |

|       |                       | SYNC = 0, BRGH = 0, BRG16 = 1 |                             |                       |            |                             |                       |            |                             |  |  |
|-------|-----------------------|-------------------------------|-----------------------------|-----------------------|------------|-----------------------------|-----------------------|------------|-----------------------------|--|--|
| BAUD  | Fost                  | c = 4.000                     | MHz                         | Fos                   | c = 2.000  | MHz                         | Fosc = 1.000 MHz      |            |                             |  |  |
| (K)   | Actual<br>Rate<br>(K) | %<br>Error                    | SPBRG<br>value<br>(decimal) | Actual<br>Rate<br>(K) | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate<br>(K) | %<br>Error | SPBRG<br>value<br>(decimal) |  |  |
| 0.3   | 0.300                 | 0.04                          | 832                         | 0.300                 | -0.16      | 415                         | 0.300                 | -0.16      | 207                         |  |  |
| 1.2   | 1.202                 | 0.16                          | 207                         | 1.201                 | -0.16      | 103                         | 1.201                 | -0.16      | 51                          |  |  |
| 2.4   | 2.404                 | 0.16                          | 103                         | 2.403                 | -0.16      | 51                          | 2.403                 | -0.16      | 25                          |  |  |
| 9.6   | 9.615                 | 0.16                          | 25                          | 9.615                 | -0.16      | 12                          | —                     | _          | _                           |  |  |
| 19.2  | 19.231                | 0.16                          | 12                          | —                     | —          | —                           | —                     | —          | —                           |  |  |
| 57.6  | 62.500                | 8.51                          | 3                           | —                     | —          | _                           | —                     | —          |                             |  |  |
| 115.2 | 125.000               | 8.51                          | 1                           | —                     | _          | _                           | —                     | _          | _                           |  |  |

#### 20.5.2 EUSART SYNCHRONOUS SLAVE RECEPTION

The operation of the Synchronous Master and Slave modes is identical, except in the case of Sleep, or any Idle mode and bit SREN, which is a "don't care" in Slave mode.

If receive is enabled by setting the CREN bit prior to entering Sleep or any Idle mode, then a word may be received while in this Low-Power mode. Once the word is received, the RSR register will transfer the data to the RCREG register. If the RCIE enable bit is set, the interrupt generated will wake the chip from Low-Power mode. If the global interrupt is enabled, the program will branch to the interrupt vector. To set up a Synchronous Slave Reception:

- 1. Enable the synchronous master serial port by setting bits, SYNC and SPEN, and clearing bit, CSRC.
- 2. If interrupts are desired, set enable bit, RCIE.
- 3. If 9-bit reception is desired, set bit, RX9.
- 4. To enable reception, set enable bit, CREN.
- 5. Flag bit, RCIF, will be set when reception is complete. An interrupt will be generated if enable bit, RCIE, was set.
- 6. Read the RCSTA register to get the 9th bit (if enabled) and determine if any error occurred during reception.
- 7. Read the 8-bit received data by reading the RCREG register.
- 8. If any error occurred, clear the error by clearing bit, CREN.
- If using interrupts, ensure that the GIE and PEIE bits in the INTCON register (INTCON<7:6>) are set.

| 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 | INT0IF | 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                       |
| RCSTA   | SPEN      | RX9           | SREN        | CREN       | ADDEN | FERR   | OERR   | RX9D   | 56                       |
| RCREG   | EUSART Re | ceive Registe | er          |            |       |        |        |        | 56                       |
| TXSTA   | CSRC      | TX9           | TXEN        | SYNC       | SENDB | BRGH   | TRMT   | TX9D   | 56                       |
| BAUDCON | —         | RCIDL         | —           | SCKP       | BRG16 | _      | WUE    | ABDEN  | 56                       |
| SPBRGH  | EUSART Ba | ud Rate Gene  | erator Regi | ister High | Byte  |        |        |        | 56                       |
| SPBRG   | EUSART Ba | ud Rate Gene  | erator Regi | ster Low I | Byte  |        |        |        | 56                       |

TABLE 20-10: REGISTERS ASSOCIATED WITH SYNCHRONOUS SLAVE RECEPTION

**Legend:** — = unimplemented, read as '0'. Shaded cells are not used for synchronous slave reception.

#### 24.2 Instruction Set

| ADD                              | DLW            | ADD Lite                          | ral to W                 | 1                        |                     |  |  |
|----------------------------------|----------------|-----------------------------------|--------------------------|--------------------------|---------------------|--|--|
| Synta                            | ax:            | [ <i>label</i> ] Al               | DDLW                     | k                        |                     |  |  |
| Oper                             | ands:          | $0 \le k \le 255$                 | $0 \le k \le 255$        |                          |                     |  |  |
| Oper                             | ation:         | (W) + k $\rightarrow$             | $(W) + k \to W$          |                          |                     |  |  |
| Status Affected: N, OV, C, DC, Z |                |                                   |                          |                          |                     |  |  |
| Enco                             | oding:         | 0000                              | 1111                     | kkkk                     | kkkk                |  |  |
| Desc                             | ription:       | The conter<br>8-bit literal<br>W. | nts of W a<br>'k' and th | are added<br>e result is | to the<br>placed in |  |  |
| Word                             | ls:            | 1                                 |                          |                          |                     |  |  |
| Cycle                            | es:            | 1                                 |                          |                          |                     |  |  |
| QC                               | ycle Activity: |                                   |                          |                          |                     |  |  |
|                                  | Q1             | Q2                                | Q3                       | 5                        | Q4                  |  |  |
|                                  | Decode         | Read<br>literal 'k'               | Proce<br>Data            | ess V<br>a               | Vrite to<br>W       |  |  |
|                                  |                |                                   | •                        | •                        |                     |  |  |

| ADD         | DWF                                 | ADD W to                                                                        | o f                                                                    |                                                                  |                                                  |
|-------------|-------------------------------------|---------------------------------------------------------------------------------|------------------------------------------------------------------------|------------------------------------------------------------------|--------------------------------------------------|
| Synt        | ax:                                 | [ label ] AD                                                                    | DWF f                                                                  | [,d [,a]]                                                        |                                                  |
| Oper        | ands:                               | 0 ≤ f ≤ 255<br>d ∈ [0,1]<br>a ∈ [0,1]                                           |                                                                        |                                                                  |                                                  |
| Oper        | ration:                             | (W) + (f) →                                                                     | → dest                                                                 |                                                                  |                                                  |
| Statu       | is Affected:                        | N, OV, C, I                                                                     | DC, Z                                                                  |                                                                  |                                                  |
| Enco        | oding:                              | 0010                                                                            | 01da                                                                   | ffff                                                             | ffff                                             |
| Desc        | cription:                           | Add W to r<br>result is sto<br>result is sto<br>is '0', the A<br>If 'a' is '1', | egister, 'f'.<br>pred in W.<br>pred back i<br>Access Ban<br>the BSR is | If 'd' is '0<br>If 'd' is '1<br>n registe<br>ik will be<br>used. | )′, the<br>', the<br>r, 'f'. If 'a'<br>selected. |
| Word        | ds:                                 | 1                                                                               |                                                                        |                                                                  |                                                  |
| Cycle       | es:                                 | 1                                                                               |                                                                        |                                                                  |                                                  |
| QC          | ycle Activity:                      |                                                                                 |                                                                        |                                                                  |                                                  |
|             | Q1                                  | Q2                                                                              | Q3                                                                     |                                                                  | Q4                                               |
|             | Decode                              | Read                                                                            | Proces                                                                 | s W                                                              | /rite to                                         |
|             |                                     | register 'f'                                                                    | Data                                                                   | des                                                              | stination                                        |
| <u>Exar</u> | <u>nple:</u><br>Before Instruc<br>W | ADDWF<br>tion<br>= 0x17                                                         | REG, W                                                                 |                                                                  |                                                  |
|             | REG                                 | = 0xC2                                                                          |                                                                        |                                                                  |                                                  |

After Instruction W

REG

=

=

0xD9

0xC2

Example: ADDLW 0x15

> Before Instruction W = 0x10 After Instruction

W = 0x25

| MUL   | LW                                      | Multiply L                                                                                                                                           | iteral with                                                                                                                                                              | w                                                                                                                                      |  |  |  |  |  |
|-------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Synta | ax:                                     | [label] N                                                                                                                                            | IULLW k                                                                                                                                                                  |                                                                                                                                        |  |  |  |  |  |
| Oper  | ands:                                   | $0 \le k \le 255$                                                                                                                                    | $0 \le k \le 255$                                                                                                                                                        |                                                                                                                                        |  |  |  |  |  |
| Oper  | ation:                                  | (W) x k $\rightarrow$ f                                                                                                                              | (W) x k $\rightarrow$ PRODH:PRODL                                                                                                                                        |                                                                                                                                        |  |  |  |  |  |
| Statu | is Affected:                            | None                                                                                                                                                 |                                                                                                                                                                          |                                                                                                                                        |  |  |  |  |  |
| Enco  | oding:                                  | 0000                                                                                                                                                 | 1101 kk                                                                                                                                                                  | kk kkkk                                                                                                                                |  |  |  |  |  |
| Desc  | ription:                                | An unsigne<br>out betwee<br>the 8-bit lite<br>is placed in<br>pair. PROD<br>W is uncha<br>None of the<br>Note that n<br>is possible<br>result is pos | d multiplication<br>n the contents<br>ral, 'k'. The 1<br>PRODH:PRC<br>H contains the<br>nged.<br>Status flags a<br>either Overflo<br>in this operation<br>ssible but not | in is carried<br>s of W and<br>6-bit result<br>DDL register<br>e high byte.<br>are affected.<br>w nor Carry<br>on. A Zero<br>detected. |  |  |  |  |  |
| Word  | ds:                                     | 1                                                                                                                                                    |                                                                                                                                                                          |                                                                                                                                        |  |  |  |  |  |
| Cycle | es:                                     | 1                                                                                                                                                    |                                                                                                                                                                          |                                                                                                                                        |  |  |  |  |  |
| QC    | ycle Activity:                          |                                                                                                                                                      |                                                                                                                                                                          |                                                                                                                                        |  |  |  |  |  |
|       | Q1                                      | Q2                                                                                                                                                   | Q3                                                                                                                                                                       | Q4                                                                                                                                     |  |  |  |  |  |
|       | Decode                                  | Read<br>literal 'k'                                                                                                                                  | Process<br>Data                                                                                                                                                          | Write<br>registers<br>PRODH:<br>PRODL                                                                                                  |  |  |  |  |  |
| Exan  | nple:                                   | MULLW                                                                                                                                                | 0xC4                                                                                                                                                                     |                                                                                                                                        |  |  |  |  |  |
|       | Before Instruct<br>W<br>PRODH<br>PRODL  | tion<br>= 0x<br>= ?<br>= ?                                                                                                                           | E2                                                                                                                                                                       |                                                                                                                                        |  |  |  |  |  |
|       | After Instructio<br>W<br>PRODH<br>PRODL | n = 0x<br>= 0x<br>= 0x                                                                                                                               | E2<br>AD<br>08                                                                                                                                                           |                                                                                                                                        |  |  |  |  |  |

| MULWF                                        | Multiply W with f                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                          |                                       |  |  |  |
|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|---------------------------------------|--|--|--|
| Syntax:                                      | [label] M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | IULWF f[,a]              |                                       |  |  |  |
| Operands:                                    | 0 ≤ f ≤ 255<br>a ∈ [0,1]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0 ≤ f ≤ 255<br>a ∈ [0,1] |                                       |  |  |  |
| Operation:                                   | (W) x (f) $\rightarrow$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | PRODH:PRO                | DL                                    |  |  |  |
| Status Affected:                             | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                          |                                       |  |  |  |
| Encoding:                                    | 0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 001a fff                 | f ffff                                |  |  |  |
|                                              | out between the contents of W and<br>the register file location, 'f'. The<br>16-bit result is stored in the<br>PRODH:PRODL register pair.<br>PRODH contains the high byte.<br>Both W and 'f' are unchanged.<br>None of the Status flags are affected.<br>Note that neither Overflow nor Carry<br>is possible in this operation. A Zero<br>result is possible but not detected. If<br>'a' is '0', the Access Bank will be<br>selected, overriding the BSR value. If<br>'a' = 1, then the bank will be selected<br>as per the BSR value |                          |                                       |  |  |  |
| Words:                                       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                          |                                       |  |  |  |
| Cycles:                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                          |                                       |  |  |  |
| Q Cycle Activity:                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                          |                                       |  |  |  |
| Q1                                           | Q2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Q3                       | Q4                                    |  |  |  |
| Decode                                       | Read<br>register 'f'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Process<br>Data          | Write<br>registers<br>PRODH:<br>PRODL |  |  |  |
| Example:                                     | MULWF H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | REG                      |                                       |  |  |  |
| Before Instruc<br>W<br>REG<br>PRODH<br>PRODL | tion<br>= 0x0<br>= 0x1<br>= ?<br>= ?                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | C4<br>35                 |                                       |  |  |  |

| After Instruction |   |      |
|-------------------|---|------|
| W                 | = | 0xC4 |
| REG               | = | 0xB5 |
| PRODH             | = | 0x8A |
| PRODL             | = | 0x94 |

| POF                                                                        | )            | Рор Тор                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Pop Top of Return Stack                                                                                                                                                                                                                                                                    |                          |                 |  |  |  |  |
|----------------------------------------------------------------------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-----------------|--|--|--|--|
| Synta                                                                      | ax:          | [label] F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | [label] POP                                                                                                                                                                                                                                                                                |                          |                 |  |  |  |  |
| Oper                                                                       | ands:        | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                            |                          |                 |  |  |  |  |
| Oper                                                                       | ation:       | $(TOS) \rightarrow b$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | it bucket                                                                                                                                                                                                                                                                                  |                          |                 |  |  |  |  |
| Statu                                                                      | is Affected: | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | None                                                                                                                                                                                                                                                                                       |                          |                 |  |  |  |  |
| Enco                                                                       | oding:       | 0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0000                                                                                                                                                                                                                                                                                       | 000                      | 0 0110          |  |  |  |  |
| Desc                                                                       | ription:     | The TOS we stack and then become was pushed This instruction the user to stack to income the stack to income the stack to income the stack to income stack to | The TOS value is pulled off the return<br>stack and is discarded. The TOS value<br>then becomes the previous value that<br>was pushed onto the return stack.<br>This instruction is provided to enable<br>the user to properly manage the return<br>stack to incorporate a software stack. |                          |                 |  |  |  |  |
| Word                                                                       | ds:          | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                            |                          |                 |  |  |  |  |
| Cycles:                                                                    |              | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                            |                          |                 |  |  |  |  |
| Q Cycle Activity:                                                          |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                            |                          |                 |  |  |  |  |
|                                                                            | Q1           | Q2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Q                                                                                                                                                                                                                                                                                          | 3                        | Q4              |  |  |  |  |
|                                                                            | Decode       | No<br>operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | POP 1<br>valu                                                                                                                                                                                                                                                                              | OS<br>e                  | No<br>operation |  |  |  |  |
| Exan                                                                       | nple:        | POP<br>GOTO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | NEW                                                                                                                                                                                                                                                                                        |                          |                 |  |  |  |  |
| Before Instructio<br>TOS<br>Stack (1 lev<br>After Instruction<br>TOS<br>PC |              | tion<br>level down)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | = (                                                                                                                                                                                                                                                                                        | = 0x0031A2<br>= 0x014332 |                 |  |  |  |  |
|                                                                            |              | n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ) =<br>1 =                                                                                                                                                                                                                                                                                 | )x0143<br>NEW            | 32              |  |  |  |  |

| PUSH                       | Push Top                                                                                   | of Retur                                                                                                                                                                                                                                 | n Stacl          | k                     |  |
|----------------------------|--------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-----------------------|--|
| Syntax:                    | [ <i>label</i> ] P                                                                         | USH                                                                                                                                                                                                                                      |                  |                       |  |
| Operands:                  | None                                                                                       |                                                                                                                                                                                                                                          |                  |                       |  |
| Operation:                 | $(PC + 2) \rightarrow$                                                                     | TOS                                                                                                                                                                                                                                      |                  |                       |  |
| Status Affected:           | None                                                                                       |                                                                                                                                                                                                                                          |                  |                       |  |
| Encoding:                  | 0000                                                                                       | 0000                                                                                                                                                                                                                                     | 0000             | 0101                  |  |
| Description:               | the PC + 2<br>the return s<br>value is pus<br>This instruc<br>software sta<br>then push it | The PC + 2 is pushed onto the top of<br>the return stack. The previous TOS<br>value is pushed down on the stack.<br>This instruction allows to implement a<br>software stack by modifying TOS, and<br>then push it onto the return stack |                  |                       |  |
| Words:                     | 1                                                                                          |                                                                                                                                                                                                                                          |                  |                       |  |
| Cycles:                    | 1                                                                                          |                                                                                                                                                                                                                                          |                  |                       |  |
| Q Cycle Activity:          |                                                                                            |                                                                                                                                                                                                                                          |                  |                       |  |
| Q1                         | Q2                                                                                         | Q3                                                                                                                                                                                                                                       |                  | Q4<br>No<br>operation |  |
| Decode                     | PUSH<br>PC + 2 onto<br>return stack                                                        | No<br>operatio                                                                                                                                                                                                                           | n op             |                       |  |
| Example:                   | PUSH                                                                                       |                                                                                                                                                                                                                                          |                  |                       |  |
| Before Instru<br>TOS<br>PC | ction                                                                                      | = 0x0<br>= 0x0                                                                                                                                                                                                                           | 00345A<br>000124 |                       |  |
| After Instruct<br>PC       | ion                                                                                        | = 0x0                                                                                                                                                                                                                                    | 000126           |                       |  |

#### FIGURE 26-10: CAPTURE/COMPARE/PWM TIMINGS (ALL CCP MODULES)



#### TABLE 26-10: CAPTURE/COMPARE/PWM REQUIREMENTS (ALL CCP MODULES)

| Param<br>No. | Symbol | Characteristic          |                   |             | Min                    | Мах | Units | Conditions                         |
|--------------|--------|-------------------------|-------------------|-------------|------------------------|-----|-------|------------------------------------|
| 50 TccL      |        | CCPx Input Low          | No prescaler      |             | 0.5 Tcy + 20           |     | ns    |                                    |
|              |        | Time                    | With<br>prescaler | PIC18FXX31  | 10                     |     | ns    |                                    |
|              |        |                         |                   | PIC18LFXX31 | 20                     | _   | ns    |                                    |
| 51 T         | ТссН   | CCPx Input High<br>Time | No prescaler      |             | 0.5 Tcy + 20           |     | ns    |                                    |
|              |        |                         | With<br>prescaler | PIC18FXX31  | 10                     | _   | ns    |                                    |
|              |        |                         |                   | PIC18LFXX31 | 20                     | —   | ns    |                                    |
| 52           | TccP   | CCPx Input Period       |                   |             | <u>3 Tcy + 40</u><br>N | —   | ns    | N = prescale<br>value (1, 4 or 16) |
| 53           | TccR   | CCPx Output Fal         | I Time            | PIC18FXX31  | —                      | 25  | ns    |                                    |
|              |        |                         |                   | PIC18LFXX31 | —                      | 45  | ns    |                                    |
| 54           | TccF   | CCPx Output Fal         | I Time            | PIC18FXX31  | —                      | 25  | ns    |                                    |
|              |        |                         |                   | PIC18LFXX31 |                        | 45  | ns    |                                    |



| Param<br>No. | Symbol                | Characterist                                                 | Min         | Max          | Units | Conditions |  |
|--------------|-----------------------|--------------------------------------------------------------|-------------|--------------|-------|------------|--|
| 73           | TdiV2scH,<br>TdiV2scL | Setup Time of SDI Data Input                                 | 20          |              | ns    |            |  |
| 73A          | Tb2b                  | Last Clock Edge of Byte 1 to the 1st Clock Edge<br>of Byte 2 |             | 1.5 Tcy + 40 | _     | ns         |  |
| 74           | TscH2diL,<br>TscL2diL | Hold Time of SDI Data Input to SCK Edge                      |             | 40           | _     | ns         |  |
| 75           | TdoR                  | SDO Data Output Rise Time                                    | PIC18FXX31  | —            | 25    | ns         |  |
|              |                       |                                                              | PIC18LFXX31 | —            | 45    | ns         |  |
| 76           | TdoF                  | SDO Data Output Fall Time                                    |             | —            | 25    | ns         |  |
| 78           | TscR                  | SCK Output Rise Time                                         | PIC18FXX31  | —            | 25    | ns         |  |
|              |                       |                                                              | PIC18LFXX31 | —            | 45    | ns         |  |
| 79           | TscF                  | SCK Output Fall Time                                         |             | —            | 25    | ns         |  |
| 80           | TscH2doV,<br>TscL2doV | SDO Data Output Valid after                                  | PIC18FXX31  | _            | 50    | ns         |  |
|              |                       | SCK Edge                                                     | PIC18LFXX31 | _            | 100   | ns         |  |