



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                      | 32MHz                                                                      |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                          |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                      |
| Number of I/O              | 16                                                                         |
| Program Memory Size        | 7KB (4K x 14)                                                              |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | 256 x 8                                                                    |
| RAM Size                   | 384 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                                                |
| Data Converters            | A/D 12x10b                                                                 |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 28-UFQFN Exposed Pad                                                       |
| Supplier Device Package    | 28-UQFN (4x4)                                                              |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lf1827-i-mv |

Email: info@E-XFL.COM

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

# 5.5 Fail-Safe Clock Monitor

The Fail-Safe Clock Monitor (FSCM) allows the device to continue operating should the external oscillator fail. The FSCM can detect oscillator failure any time after the Oscillator Start-up Timer (OST) has expired. The FSCM is enabled by setting the FCMEN bit in the Configuration Word 1. The FSCM is applicable to all external Oscillator modes (LP, XT, HS, EC, Timer1 Oscillator and RC).

FIGURE 5-9: FSCM BLOCK DIAGRAM



### 5.5.1 FAIL-SAFE DETECTION

The FSCM module detects a failed oscillator by comparing the external oscillator to the FSCM sample clock. The sample clock is generated by dividing the LFINTOSC by 64. See Figure 5-9. Inside the fail detector block is a latch. The external clock sets the latch on each falling edge of the external clock. The sample clock clears the latch on each rising edge of the sample clock. A failure is detected when an entire half-cycle of the sample clock elapses before the external clock goes low.

#### 5.5.2 FAIL-SAFE OPERATION

When the external clock fails, the FSCM switches the device clock to an internal clock source and sets the bit flag OSFIF of the PIR2 register. Setting this flag will generate an interrupt if the OSFIE bit of the PIE2 register is also set. The device firmware can then take steps to mitigate the problems that may arise from a failed clock. The system clock will continue to be sourced from the internal clock source until the device firmware successfully restarts the external oscillator and switches back to external operation.

The internal clock source chosen by the FSCM is determined by the IRCF<3:0> bits of the OSCCON register. This allows the internal oscillator to be configured before a failure occurs.

### 5.5.3 FAIL-SAFE CONDITION CLEARING

The Fail-Safe condition is cleared after a Reset, executing a SLEEP instruction or changing the SCS bits of the OSCCON register. When the SCS bits are changed, the OST is restarted. While the OST is running, the device continues to operate from the INTOSC selected in OSCCON. When the OST times out, the Fail-Safe condition is cleared and the device will be operating from the external clock source. The Fail-Safe condition must be cleared before the OSFIF flag can be cleared.

#### 5.5.4 RESET OR WAKE-UP FROM SLEEP

The FSCM is designed to detect an oscillator failure after the Oscillator Start-up Timer (OST) has expired. The OST is used after waking up from Sleep and after any type of Reset. The OST is not used with the EC or RC Clock modes so that the FSCM will be active as soon as the Reset or wake-up has completed. When the FSCM is enabled, the Two-Speed Start-up is also enabled. Therefore, the device will always be executing code while the OST is operating.

Note: Due to the wide range of oscillator start-up times, the Fail-Safe circuit is not active during oscillator start-up (i.e., after exiting Reset or Sleep). After an appropriate amount of time, the user should check the Status bits in the OSCSTAT register to verify the oscillator start-up and that the system clock switchover has successfully completed.

# 7.0 RESETS

There are multiple ways to reset this device:

- Power-on Reset (POR)
- Brown-out Reset (BOR)
- MCLR Reset
- WDT Reset
- RESET instruction
- Stack Overflow
- Stack Underflow
- Programming mode exit

To allow VDD to stabilize, an optional power-up timer can be enabled to extend the Reset time after a BOR or POR event.

A simplified block diagram of the On-Chip Reset Circuit is shown in Figure 7-1.

#### FIGURE 7-1: SIMPLIFIED BLOCK DIAGRAM OF ON-CHIP RESET CIRCUIT



#### 7.10 Determining the Cause of a Reset

Upon any Reset, multiple bits in the STATUS and PCON register are updated to indicate the cause of the Reset. Table 7-3 and Table 7-4 show the Reset conditions of these registers.

| STKOVF | STKUNF | RMCLR | RI | POR | BOR | то | PD | Condition                                                         |
|--------|--------|-------|----|-----|-----|----|----|-------------------------------------------------------------------|
| 0      | 0      | 1     | 1  | 0   | x   | 1  | 1  | Power-on Reset                                                    |
| 0      | 0      | 1     | 1  | 0   | x   | 0  | x  | Illegal, $\overline{\text{TO}}$ is set on $\overline{\text{POR}}$ |
| 0      | 0      | 1     | 1  | 0   | x   | x  | 0  | Illegal, PD is set on POR                                         |
| 0      | 0      | 1     | 1  | u   | 0   | 1  | 1  | Brown-out Reset                                                   |
| u      | u      | u     | u  | u   | u   | 0  | u  | WDT Reset                                                         |
| u      | u      | u     | u  | u   | u   | 0  | 0  | WDT Wake-up from Sleep                                            |
| u      | u      | u     | u  | u   | u   | 1  | 0  | Interrupt Wake-up from Sleep                                      |
| u      | u      | 0     | u  | u   | u   | u  | u  | MCLR Reset during normal operation                                |
| u      | u      | 0     | u  | u   | u   | 1  | 0  | MCLR Reset during Sleep                                           |
| u      | u      | u     | 0  | u   | u   | u  | u  | RESET Instruction Executed                                        |
| 1      | u      | u     | u  | u   | u   | u  | u  | Stack Overflow Reset (STVREN = 1)                                 |
| u      | 1      | u     | u  | u   | u   | u  | u  | Stack Underflow Reset (STVREN = 1)                                |

TABLE 7-3: RESET STATUS BITS AND THEIR SIGNIFICANCE

### TABLE 7-4: RESET CONDITION FOR SPECIAL REGISTERS<sup>(2)</sup>

| Condition                          | Program<br>Counter    | STATUS<br>Register | PCON<br>Register |
|------------------------------------|-----------------------|--------------------|------------------|
| Power-on Reset                     | 0000h                 | 1 1000             | 00 110x          |
| MCLR Reset during normal operation | 0000h                 | u uuuu             | uu Ouuu          |
| MCLR Reset during Sleep            | 0000h                 | 1 Ouuu             | uu Ouuu          |
| WDT Reset                          | 0000h                 | 0 uuuu             | uu uuuu          |
| WDT Wake-up from Sleep             | PC + 1                | 0 Ouuu             | uu uuuu          |
| Brown-out Reset                    | 0000h                 | 1 luuu             | 00 11u0          |
| Interrupt Wake-up from Sleep       | PC + 1 <sup>(1)</sup> | 1 Ouuu             | uu uuuu          |
| RESET Instruction Executed         | 0000h                 | u uuuu             | uu u0uu          |
| Stack Overflow Reset (STVREN = 1)  | 0000h                 | u uuuu             | lu uuuu          |
| Stack Underflow Reset (STVREN = 1) | 0000h                 | u uuuu             | ul uuuu          |

**Legend:** u = unchanged, x = unknown, - = unimplemented bit, reads as '0'.

**Note 1:** When the wake-up is due to an interrupt and Global Enable bit (GIE) is set, the return address is pushed on the stack and PC is loaded with the interrupt vector (0004h) after execution of PC + 1.

2: If a Status bit is not implemented, that bit will be read as '0'.

| FIGURE    | IGURE 8-2: INTERRUPT LATENCY |               |                   |                  |             |             |             |             |  |  |  |
|-----------|------------------------------|---------------|-------------------|------------------|-------------|-------------|-------------|-------------|--|--|--|
| OSC1      |                              |               |                   | MM               |             |             |             |             |  |  |  |
|           | Q1 Q2 Q3 Q4                  | Q1 Q2 Q3 Q4   | Q1 Q2 Q3 Q4       | Q1 Q2 Q3 Q4      | Q1 Q2 Q3 Q4 | Q1 Q2 Q3 Q4 | Q1 Q2 Q3 Q4 | Q1 Q2 Q3 Q4 |  |  |  |
| CLKOUT    |                              |               | Interru<br>during | pt Sampled<br>Q1 |             |             |             |             |  |  |  |
| Interrupt |                              |               |                   |                  |             |             |             |             |  |  |  |
| GIE       |                              |               |                   |                  |             |             |             |             |  |  |  |
| PC        | PC-1                         | PC            | PC                | +1               | 0004h       | 0005h       |             |             |  |  |  |
| Execute   | 1 Cycle Insti                | ruction at PC | Inst(PC)          | NOP              | NOP         | Inst(0004h) |             |             |  |  |  |
|           |                              |               |                   |                  |             |             |             |             |  |  |  |
| Interrupt |                              |               |                   |                  |             |             |             |             |  |  |  |
| GIE       |                              |               |                   |                  |             |             |             |             |  |  |  |
| PC        | PC-1                         | PC            | PC+1/FSR<br>ADDR  | New PC/<br>PC+1  | 0004h       | 0005h       |             |             |  |  |  |
| Execute-  | 2 Cycle Inst                 | ruction at PC | Inst(PC)          | NOP              | NOP         | Inst(0004h) |             |             |  |  |  |
|           |                              |               |                   |                  |             |             |             |             |  |  |  |
| Interrupt |                              |               |                   |                  |             |             |             |             |  |  |  |
| GIE       |                              |               |                   |                  |             |             |             |             |  |  |  |
| PC        | PC-1                         | PC            | FSR ADDR          | PC+1             | PC+2        | 0004h       | 0005h       |             |  |  |  |
| Execute   | 3 Cycle Inst                 | ruction at PC | INST(PC)          | NOP              | NOP         | NOP         | Inst(0004h) | Inst(0005h) |  |  |  |
| Interrupt |                              |               |                   |                  |             |             |             |             |  |  |  |
| GIE       |                              |               |                   |                  |             |             |             |             |  |  |  |
| PC        | PC-1                         | PC            | FSR ADDR          | PC+1             | PC          | +2          | 0004h       | 0005h       |  |  |  |
| Execute   | 3 Cycle Inst                 | ruction at PC | INST(PC)          | NOP              | NOP         | NOP         | NOP         | Inst(0004h) |  |  |  |

| Name       | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Register<br>on Page |
|------------|--------|--------|--------|--------|--------|--------|--------|--------|---------------------|
| ANSELA     | —      | —      | —      | ANSA4  | ANSA3  | ANSA2  | ANSA1  | ANSA0  | 123                 |
| LATA       | LATA7  | LATA6  | —      | LATA4  | LATA3  | LATA2  | LATA1  | LATA0  | 122                 |
| OPTION_REG | WPUEN  | INTEDG | TMR0CS | TMR0SE | PSA    | PS2    | PS1    | PS0    | 176                 |
| PORTA      | RA7    | RA6    | RA5    | RA4    | RA3    | RA2    | RA1    | RA0    | 122                 |
| TRISA      | TRISA7 | TRISA6 | TRISA5 | TRISA4 | TRISA3 | TRISA2 | TRISA1 | TRISA0 | 122                 |
| WPUA       | _      | _      | WPUA5  | _      | _      | _      | _      | _      | 123                 |

#### TABLE 12-3: SUMMARY OF REGISTERS ASSOCIATED WITH PORTA

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

#### TABLE 12-4: SUMMARY OF CONFIGURATION WORD ASSOCIATED WITH PORTA

| Name    | Bits | Bit -/7 | Bit -/6 | Bit 13/5 | Bit 12/4 | Bit 11/3 | Bit 10/2 | Bit 9/1 | Bit 8/0 | Register<br>on Page |
|---------|------|---------|---------|----------|----------|----------|----------|---------|---------|---------------------|
| 0015104 | 13:8 | _       | —       | FCMEN    | IESO     | CLKOUTEN | BOREN1   | BOREN0  | CPD     |                     |
| CONFIGT | 7:0  | CP      | MCLRE   | PWRTE    | WDTE1    | WDTE0    | FOSC2    | FOSC1   | FOSC0   | 44                  |

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

# 13.0 INTERRUPT-ON-CHANGE

The PORTB pins can be configured to operate as Interrupt-On-Change (IOC) pins. An interrupt can be generated by detecting a signal that has either a rising edge or a falling edge. Any individual PORTB pin can be configured to generate an interrupt. The interrupt-on-change module has the following features:

- Interrupt-on-Change enable (Master Switch)
- Individual pin configuration
- Rising and falling edge detection
- Individual pin interrupt flags

Figure 13-1 is a block diagram of the IOC module.

### 13.1 Enabling the Module

To allow individual port pins to generate an interrupt, the IOCIE bit of the INTCON register must be set. If the IOCIE bit is disabled, the edge detection on the pin will still occur, but an interrupt will not be generated.

#### 13.2 Individual Pin Configuration

For each port pin, a rising edge detector and a falling edge detector are present. To enable a pin to detect a rising edge, the associated IOCBPx bit of the IOCBP register is set. To enable a pin to detect a falling edge, the associated IOCBNx bit of the IOCBN register is set.

A pin can be configured to detect rising and falling edges simultaneously by setting both the IOCBPx bit and the IOCBNx bit of the IOCBP and IOCBN registers, respectively.

## 13.3 Interrupt Flags

The IOCBFx bits located in the IOCBF register are status flags that correspond to the Interrupt-on-change pins of the port. If an expected edge is detected on an appropriately enabled pin, then the status flag for that pin will be set, and an interrupt will be generated if the IOCIE bit is set. The IOCIF bit of the INTCON register reflects the status of all IOCBFx bits.

# 13.4 Clearing Interrupt Flags

The individual status flags, (IOCBFx bits), can be cleared by resetting them to zero. If another edge is detected during this clearing operation, the associated status flag will be set at the end of the sequence, regardless of the value actually being written.

In order to ensure that no detected edge is lost while clearing flags, only AND operations masking out known changed bits should be performed. The following sequence is an example of what should be performed.

#### EXAMPLE 13-1:

```
MOVLW 0xff
XORWF IOCBF, W
ANDWF IOCBF, F
```

### 13.5 Operation in Sleep

The interrupt-on-change interrupt sequence will wake the device from Sleep mode, if the IOCIE bit is set.

If an edge is detected while in Sleep mode, the IOCBF register will be updated prior to the first instruction executed out of Sleep.

FIGURE 13-1: INTERRUPT-ON-CHANGE BLOCK DIAGRAM



# 21.12 Timer1 Gate Control Register

The Timer1 Gate Control register (T1GCON), shown in Register 21-2, is used to control Timer1 gate.

| R/W-0/u                                                                                                                                                                                                                                         | R/W-0/u                                                                                                                                                                                                                                        | R/W-0/u                                                              | R/W-0/u                                                          | R/W/HC-0/u                       | R-x/x                          | R/W-0/u          | R/W-0/u      |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|------------------------------------------------------------------|----------------------------------|--------------------------------|------------------|--------------|--|--|
| TMR1GE                                                                                                                                                                                                                                          | T1GPOL                                                                                                                                                                                                                                         | T1GTM                                                                | T1GSPM                                                           | T1GGO/<br>DONE                   | T1GVAL                         | T1GSS            | S<1:0>       |  |  |
| bit 7                                                                                                                                                                                                                                           | •                                                                                                                                                                                                                                              | I                                                                    |                                                                  |                                  |                                | •                | bit 0        |  |  |
|                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                |                                                                      |                                                                  |                                  |                                |                  |              |  |  |
| Legend:                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                |                                                                      |                                                                  |                                  |                                |                  |              |  |  |
| R = Readable                                                                                                                                                                                                                                    | bit                                                                                                                                                                                                                                            | W = Writable                                                         | bit                                                              | U = Unimplen                     | nented bit, read               | d as '0'         |              |  |  |
| u = Bit is uncha                                                                                                                                                                                                                                | anged                                                                                                                                                                                                                                          | x = Bit is unkr                                                      | iown                                                             | -n/n = Value a                   | at POR and BO                  | R/Value at all o | other Resets |  |  |
| '1' = Bit is set                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                | '0' = Bit is clea                                                    | ared                                                             | HC = Bit is cle                  | eared by hardw                 | /are             |              |  |  |
| bit 7 <b>TMR1GE:</b> Timer1 Gate Enable bit<br><u>If TMR1ON = 0</u> :<br>This bit is ignored<br><u>If TMR1ON = 1</u> :<br>1 = Timer1 counting is controlled by the Timer1 gate function<br>0 = Timer1 counts regardless of Timer1 gate function |                                                                                                                                                                                                                                                |                                                                      |                                                                  |                                  |                                |                  |              |  |  |
| bit 6                                                                                                                                                                                                                                           | <b>TIGPOL:</b> Timer1 Gate Polarity bit<br>1 = Timer1 gate is active-high (Timer1 counts when gate is high)<br>0 = Timer1 gate is active-low (Timer1 counts when gate is low)                                                                  |                                                                      |                                                                  |                                  |                                |                  |              |  |  |
| bit 5                                                                                                                                                                                                                                           | <b>T1GTM:</b> Time<br>1 = Timer1 G<br>0 = Timer1 G<br>Timer1 gate fl                                                                                                                                                                           | er1 Gate Toggle<br>ate Toggle mo<br>ate Toggle mo<br>ip-flop toggles | e Mode bit<br>de is enabled<br>de is disabled<br>on every rising | and toggle flip-<br>g edge.      | flop is cleared                |                  |              |  |  |
| bit 4                                                                                                                                                                                                                                           | T1GSPM: Tim                                                                                                                                                                                                                                    | ner1 Gate Sing                                                       | le-Pulse Mode                                                    | bit                              |                                |                  |              |  |  |
|                                                                                                                                                                                                                                                 | 1 = Timer1 ga<br>0 = Timer1 ga                                                                                                                                                                                                                 | ate Single-Puls<br>ate Single-Puls                                   | e mode is ena<br>e mode is disa                                  | bled and is cor<br>abled         | ntrolling Timer1               | gate             |              |  |  |
| bit 3                                                                                                                                                                                                                                           | T1GGO/DON                                                                                                                                                                                                                                      | E: Timer1 Gate                                                       | e Single-Pulse                                                   | Acquisition Sta                  | atus bit                       |                  |              |  |  |
|                                                                                                                                                                                                                                                 | 1 = Timer1 ga<br>0 = Timer1 ga                                                                                                                                                                                                                 | ate single-pulse<br>ate single-pulse                                 | e acquisition is<br>e acquisition h                              | ready, waiting<br>as completed c | for an edge<br>or has not been | started          |              |  |  |
| bit 2                                                                                                                                                                                                                                           | T1GVAL: Tim                                                                                                                                                                                                                                    | er1 Gate Curre                                                       | ent State bit                                                    |                                  |                                |                  |              |  |  |
|                                                                                                                                                                                                                                                 | Indicates the current state of the Timer1 gate that could be provided to TMR1H:TMR1L.<br>Unaffected by Timer1 Gate Enable (TMR1GE).                                                                                                            |                                                                      |                                                                  |                                  |                                |                  |              |  |  |
| bit 1-0                                                                                                                                                                                                                                         | T1GSS<1:0>:                                                                                                                                                                                                                                    | : Timer1 Gate                                                        | Source Select                                                    | bits                             |                                |                  |              |  |  |
|                                                                                                                                                                                                                                                 | <b>T1GSS&lt;1:0&gt;:</b> Timer1 Gate Source Select bits<br>00 = Timer1 gate pin<br>01 = Timer0 overflow output<br>10 = Comparator 1 optionally synchronized output (SYNCC1OUT)<br>11 = Comparator 2 optionally synchronized output (SYNCC2OUT) |                                                                      |                                                                  |                                  |                                |                  |              |  |  |

#### REGISTER 21-2: T1GCON: TIMER1 GATE CONTROL REGISTER

NOTES:

# 22.0 TIMER2/4/6 MODULES

There are up to three identical Timer2-type modules available. To maintain pre-existing naming conventions, the Timers are called Timer2, Timer4 and Timer6 (also Timer2/4/6).

| Note: | The 'x' variable used in this section is |
|-------|------------------------------------------|
|       | used to designate Timer2, Timer4, or     |
|       | Timer6. For example, TxCON references    |
|       | T2CON, T4CON, or T6CON. PRx refer-       |
|       | ences PR2, PR4, or PR6.                  |

The Timer2/4/6 modules incorporate the following features:

- 8-bit Timer and Period registers (TMRx and PRx, respectively)
- Readable and writable (both registers)
- Software programmable prescaler (1:1, 1:4, 1:16, and 1:64)
- Software programmable postscaler (1:1 to 1:16)
- Interrupt on TMRx match with PRx, respectively
- Optional use as the shift clock for the MSSPx modules (Timer2 only)

See Figure 22-1 for a block diagram of Timer2/4/6.





#### 24.3.7 OPERATION IN SLEEP MODE

In Sleep mode, the TMRx register will not increment and the state of the module will not change. If the CCPx pin is driving a value, it will continue to drive that value. When the device wakes up, TMRx will continue from its previous state.

#### 24.3.8 CHANGES IN SYSTEM CLOCK FREQUENCY

The PWM frequency is derived from the system clock frequency. Any changes in the system clock frequency will result in changes to the PWM frequency. See Section 5.0 "Oscillator Module (With Fail-Safe Clock Monitor)" for additional details.

#### 24.3.9 EFFECTS OF RESET

Any Reset will force all ports to Input mode and the CCP registers to their Reset states.

#### 24.3.10 ALTERNATE PIN LOCATIONS

This module incorporates I/O pins that can be moved to other locations with the use of the alternate pin function registers, APFCON0 and APFCON1. To determine which pins can be moved and what their default locations are upon a reset, see **Section 12.1 "Alternate Pin Function"** for more information.

| Name     | Bit 7                         | Bit 6               | Bit 5         | Bit 4                  | Bit 3                  | Bit 2   | Bit 1   | Bit 0   | Register<br>on Page |  |
|----------|-------------------------------|---------------------|---------------|------------------------|------------------------|---------|---------|---------|---------------------|--|
| APFCON0  | RXDTSEL                       | SDO1SEL             | SS1SEL        | P2BSEL <sup>(2)</sup>  | CCP2SEL <sup>(2)</sup> | P1DSEL  | P1CSEL  | CCP1SEL | 119                 |  |
| CCPxCON  | PxM1 <sup>(1)</sup>           | PxM0 <sup>(1)</sup> | DCxB1         | DCxB0                  | CCPxM3                 | CCPxM2  | CCPxM1  | CCPxM0  | 226                 |  |
| CCPxAS   | CCPxASE                       | CCPxAS2             | CCPxAS1       | CCPxAS0                | PSSxAC1                | PSSxAC0 | PSSxBD1 | PSSxBD0 | 228                 |  |
| CCPTMRS  | C4TSEL1                       | C4TSEL0             | C3TSEL1       | C3TSEL0                | C2TSEL1                | C2TSEL0 | C1TSEL1 | C1TSEL0 | 227                 |  |
| INTCON   | GIE                           | PEIE                | TMR0IE        | INTE                   | IOCIE                  | TMR0IF  | INTF    | IOCIF   | 86                  |  |
| PR2      | Timer2 Period Register        |                     |               |                        |                        |         |         |         |                     |  |
| PR4      | Timer4 Module Period Register |                     |               |                        |                        |         |         |         |                     |  |
| PR6      | Timer6 Module Period Register |                     |               |                        |                        |         |         |         |                     |  |
| PSTRxCON | —                             | _                   | _             | STRxSYNC               | STRxD                  | STRxC   | STRxB   | STRxA   | 230                 |  |
| PWMxCON  | PxRSEN                        | PxDC6               | PxDC5         | PxDC4                  | PxDC3                  | PxDC2   | PxDC1   | PxDC0   | 229                 |  |
| T2CON    | —                             | T2OUTPS3            | T2OUTPS2      | T2OUTPS1               | T2OUTPS0               | TMR2ON  | T2CKPS1 | T2CKPS0 | 191                 |  |
| T4CON    | —                             | T4OUTPS3            | T4OUTPS2      | T4OUTPS1               | T4OUTPS0               | TMR4ON  | T4CKPS1 | T4CKPS0 | 191                 |  |
| T6CON    | —                             | T6OUTPS3            | T6OUTPS2      | T6OUTPS1               | T6OUTPS0               | TMR6ON  | T6CKPS1 | T6CKPS0 | 191                 |  |
| TMR2     | Holding Reg                   | ister for the 8-    | -bit TMR2 Tin | ne Base                |                        |         |         |         | 189*                |  |
| TMR4     | Holding Reg                   | ister for the 8-    | -bit TMR4 Tin | ne Base <sup>(1)</sup> |                        |         |         |         | 189*                |  |
| TMR6     | Holding Reg                   | ister for the 8     | -bit TMR6 Tin | ne Base <sup>(1)</sup> |                        |         |         |         | 189*                |  |
| TRISB    | TRISB7                        | TRISB6              | TRISB5        | TRISB4                 | TRISB3                 | TRISB2  | TRISB1  | TRISB0  | 127                 |  |

#### TABLE 24-8: SUMMARY OF REGISTERS ASSOCIATED WITH STANDARD PWM

**Legend:** — = Unimplemented locations, read as '0'. Shaded cells are not used by the PWM.

\* Page provides register information.

Note 1: Applies to ECCP modules only.

2: PIC16(L)F1827 only.

When one device is transmitting a logical one, or letting the line float, and a second device is transmitting a logical zero, or holding the line low, the first device can detect that the line is not a logical one. This detection, when used on the SCLx line, is called clock stretching. Clock stretching gives slave devices a mechanism to control the flow of data. When this detection is used on the SDAx line, it is called arbitration. Arbitration ensures that there is only one master device communicating at any single time.

### 25.3.1 CLOCK STRETCHING

When a slave device has not completed processing data, it can delay the transfer of more data through the process of Clock Stretching. An addressed slave device may hold the SCLx clock line low after receiving or sending a bit, indicating that it is not yet ready to continue. The master that is communicating with the slave will attempt to raise the SCLx line in order to transfer the next bit, but will detect that the clock line has not yet been released. Because the SCLx connection is open-drain, the slave has the ability to hold that line low until it is ready to continue communicating.

Clock stretching allows receivers that cannot keep up with a transmitter to control the flow of incoming data.

### 25.3.2 ARBITRATION

Each master device must monitor the bus for Start and Stop bits. If the device detects that the bus is busy, it cannot begin a new message until the bus returns to an Idle state.

However, two master devices may try to initiate a transmission on or about the same time. When this occurs, the process of arbitration begins. Each transmitter checks the level of the SDAx data line and compares it to the level that it expects to find. The first transmitter to observe that the two levels don't match, loses arbitration, and must stop transmitting on the SDAx line.

For example, if one transmitter holds the SDAx line to a logical one (lets it float) and a second transmitter holds it to a logical zero (pulls it low), the result is that the SDAx line will be low. The first transmitter then observes that the level of the line is different than expected and concludes that another transmitter is communicating.

The first transmitter to notice this difference is the one that loses arbitration and must stop driving the SDAx line. If this transmitter is also a master device, it also must stop driving the SCLx line. It then can monitor the lines for a Stop condition before trying to reissue its transmission. In the meantime, the other device that has not noticed any difference between the expected and actual levels on the SDAx line continues with it's original transmission. It can do so without any complications, because so far, the transmission appears exactly as expected with no other transmitter disturbing the message.

Slave Transmit mode can also be arbitrated, when a master addresses multiple slaves, but this is less common.

If two master devices are sending a message to two different slave devices at the address stage, the master sending the lower slave address always wins arbitration. When two master devices send messages to the same slave address, and addresses can sometimes refer to multiple slaves, the arbitration process must continue into the data stage.

Arbitration usually occurs very rarely, but it is a necessary process for proper multi-master support.



© 2011 Microchip Technology Inc.

# 25.7 BAUD RATE GENERATOR

The MSSPx module has a Baud Rate Generator available for clock generation in both I<sup>2</sup>C and SPI Master modes. The Baud Rate Generator (BRG) reload value is placed in the SSPxADD register (Register 25-6). When a write occurs to SSPxBUF, the Baud Rate Generator will automatically begin counting down.

Once the given operation is complete, the internal clock will automatically stop counting and the clock pin will remain in its last state.

An internal signal "Reload" in Figure 25-39 triggers the value from SSPxADD to be loaded into the BRG counter. This occurs twice for each oscillation of the

module clock line. The logic dictating when the reload signal is asserted depends on the mode the MSSPx is being operated in.

Table 25-4 demonstrates clock rates based on instruction cycles and the BRG value loaded into SSPxADD.

#### **EQUATION 25-1:**

$$FCLOCK = \frac{FOSC}{(SSPxADD + 1)(4)}$$

#### FIGURE 25-40: BAUD RATE GENERATOR BLOCK DIAGRAM



**Note:** Values of 0x00, 0x01 and 0x02 are not valid for SSPxADD when used as a Baud Rate Generator for I<sup>2</sup>C. This is an implementation limitation.

#### TABLE 25-4: MSSPX CLOCK RATE W/BRG

| Fosc   | Fcy   | BRG Value | FCLOCK<br>(2 Rollovers of BRG) |
|--------|-------|-----------|--------------------------------|
| 32 MHz | 8 MHz | 13h       | 400 kHz <sup>(1)</sup>         |
| 32 MHz | 8 MHz | 19h       | 308 kHz                        |
| 32 MHz | 8 MHz | 4Fh       | 100 kHz                        |
| 16 MHz | 4 MHz | 09h       | 400 kHz <sup>(1)</sup>         |
| 16 MHz | 4 MHz | 0Ch       | 308 kHz                        |
| 16 MHz | 4 MHz | 27h       | 100 kHz                        |
| 4 MHz  | 1 MHz | 09h       | 100 kHz                        |

**Note 1:** The I<sup>2</sup>C interface does not conform to the 400 kHz I<sup>2</sup>C specification (which applies to rates greater than 100 kHz) in all details, but may be used with care where higher rates are required by the application.

| R/W-1/1                             | R/W-1/1                                                                | R/W-1/1          | R/W-1/1         | R/W-1/1                                               | R/W-1/1             | R/W-1/1                     | R/W-1/1 |  |  |  |
|-------------------------------------|------------------------------------------------------------------------|------------------|-----------------|-------------------------------------------------------|---------------------|-----------------------------|---------|--|--|--|
|                                     |                                                                        |                  | MSK             | <7:0>                                                 |                     |                             |         |  |  |  |
| bit 7                               |                                                                        |                  |                 |                                                       |                     |                             | bit 0   |  |  |  |
|                                     |                                                                        |                  |                 |                                                       |                     |                             |         |  |  |  |
| Legend:                             |                                                                        |                  |                 |                                                       |                     |                             |         |  |  |  |
| R = Readable bit W = Writab         |                                                                        |                  | bit             | U = Unimplemented bit, read as '0'                    |                     |                             |         |  |  |  |
| u = Bit is unchanged x = Bit is unk |                                                                        |                  | nown            | -n/n = Value at POR and BOR/Value at all other Resets |                     |                             |         |  |  |  |
| '1' = Bit is set                    |                                                                        | '0' = Bit is cle | ared            |                                                       |                     |                             |         |  |  |  |
|                                     |                                                                        |                  |                 |                                                       |                     |                             |         |  |  |  |
| bit 7-1                             | MSK<7:1>:                                                              | Mask bits        |                 |                                                       |                     |                             |         |  |  |  |
|                                     | 1 = The rec                                                            | eived address b  | it n is compar  | ed to SSPxADI                                         | D <n> to detect</n> | I <sup>2</sup> C address ma | atch    |  |  |  |
|                                     | 0 = The rec                                                            | eived address b  | it n is not use | d to detect I <sup>2</sup> C                          | address match       |                             |         |  |  |  |
| bit 0                               | bit 0 MSK<0>: Mask bit for I <sup>2</sup> C Slave mode, 10-bit Address |                  |                 |                                                       |                     |                             |         |  |  |  |

## REGISTER 25-5: SSPxMSK: SSPx MASK REGISTER

- $I^2C$  Slave mode, 10-bit address (SSPxM<3:0> = 0111 or 1111): 1 = The received address bit 0 is compared to SSPxADD<0> to detect  $I^2C$  address match
  - 0 = The received address bit 0 is not used to detect I<sup>2</sup>C address match
- I<sup>2</sup>C Slave mode, 7-bit address, the bit is ignored

# REGISTER 25-6: SSPxADD: MSSPx ADDRESS AND BAUD RATE REGISTER (I<sup>2</sup>C MODE)

| R/W-0/0 |
|---------|---------|---------|---------|---------|---------|---------|---------|
|         |         |         | ADD<    | <7:0>   |         |         |         |
| bit 7   |         |         |         |         |         |         | bit 0   |

| Legend:              |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | x = Bit is unknown   | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set     | '0' = Bit is cleared |                                                       |

#### Master mode:

| bit 7-0 | ADD<7:0>: Baud Rate Clock Divider bits           |
|---------|--------------------------------------------------|
|         | SCLx pin clock period = ((ADD<7:0> + 1) *4)/Fosc |

#### <u>10-Bit Slave mode — Most Significant Address byte:</u>

- bit 7-3 **Not used:** Unused for Most Significant Address byte. Bit state of this register is a "don't care". Bit pattern sent by master is fixed by I<sup>2</sup>C specification and must be equal to '11110'. However, those bits are compared by hardware and are not affected by the value in this register.
- bit 2-1 ADD<2:1>: Two Most Significant bits of 10-bit address
- bit 0 Not used: Unused in this mode. Bit state is a "don't care".

## <u>10-Bit Slave mode — Least Significant Address byte:</u>

bit 7-0 ADD<7:0>: Eight Least Significant bits of 10-bit address

## 7-Bit Slave mode:

| bit 7-1 | ADD<7:1>: 7-bit address |
|---------|-------------------------|
|         |                         |

bit 0 Not used: Unused in this mode. Bit state is a "don't care".

| CALL             | Call Subroutine                                                                                                                                                                                                                                 |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] CALL k                                                                                                                                                                                                                         |
| Operands:        | $0 \leq k \leq 2047$                                                                                                                                                                                                                            |
| Operation:       | (PC)+ 1→ TOS,<br>k → PC<10:0>,<br>(PCLATH<6:3>) → PC<14:11>                                                                                                                                                                                     |
| Status Affected: | None                                                                                                                                                                                                                                            |
| Description:     | Call Subroutine. First, return address<br>(PC + 1) is pushed onto the stack.<br>The eleven-bit immediate address is<br>loaded into PC bits <10:0>. The upper<br>bits of the PC are loaded from<br>PCLATH. CALL is a two-cycle instruc-<br>tion. |

| CLRWDT           | Clear Watchdog Timer                                                                                                             |
|------------------|----------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] CLRWDT                                                                                                                   |
| Operands:        | None                                                                                                                             |
| Operation:       | $00h \rightarrow WDT$ $0 \rightarrow WDT \text{ prescaler,}$ $1 \rightarrow TO$ $1 \rightarrow PD$                               |
| Status Affected: | TO, PD                                                                                                                           |
| Description:     | CLRWDT instruction resets the Watch-<br>dog Timer. It also resets the prescaler<br>of the WDT.<br>Status bits TO and PD are set. |

| CALLW            | Subroutine Call With W                                                                                                                                                                                                  | CON           |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| Syntax:          | [ label ] CALLW                                                                                                                                                                                                         | Synta         |
| Operands:        | None                                                                                                                                                                                                                    | Oper          |
| Operation:       | (PC) +1 $\rightarrow$ TOS,<br>(W) $\rightarrow$ PC<7:0>,<br>(PCLATH<6:0>) $\rightarrow$ PC<14:8>                                                                                                                        | Oper<br>Statu |
| Status Affected: | None                                                                                                                                                                                                                    | Desc          |
| Description:     | Subroutine call with W. First, the return address (PC + 1) is pushed onto the return stack. Then, the contents of W is loaded into PC<7:0>, and the contents of PCLATH into PC<14:8>. CALLW is a two-cycle instruction. |               |

| COMF             | Complement f                                                                                                                                                  |  |  |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [label] COMF f,d                                                                                                                                              |  |  |  |  |  |
| Operands:        | $\begin{array}{l} 0\leq f\leq 127\\ d\in [0,1] \end{array}$                                                                                                   |  |  |  |  |  |
| Operation:       | $(\overline{f}) \rightarrow (destination)$                                                                                                                    |  |  |  |  |  |
| Status Affected: | Z                                                                                                                                                             |  |  |  |  |  |
| Description:     | The contents of register 'f' are com-<br>plemented. If 'd' is '0', the result is<br>stored in W. If 'd' is '1', the result is<br>stored back in register 'f'. |  |  |  |  |  |

| CLRF             | Clear f                                                               |  |  |  |
|------------------|-----------------------------------------------------------------------|--|--|--|
| Syntax:          | [label] CLRF f                                                        |  |  |  |
| Operands:        | $0 \leq f \leq 127$                                                   |  |  |  |
| Operation:       | $\begin{array}{l} 00h \rightarrow (f) \\ 1 \rightarrow Z \end{array}$ |  |  |  |
| Status Affected: | Z                                                                     |  |  |  |
| Description:     | The contents of register 'f' are cleared and the Z bit is set.        |  |  |  |

| DECF             | Decrement f                                                                                                                                       |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Syntax:          | [label] DECF f,d                                                                                                                                  |  |  |  |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                |  |  |  |
| Operation:       | (f) - 1 $\rightarrow$ (destination)                                                                                                               |  |  |  |
| Status Affected: | Z                                                                                                                                                 |  |  |  |
| Description:     | Decrement register 'f'. If 'd' is '0', the<br>result is stored in the W<br>register. If 'd' is '1', the result is stored<br>back in register 'f'. |  |  |  |

| CLRW             | Clear W                                                                                           |  |  |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [label] CLRW                                                                                      |  |  |  |  |  |
| Operands:        | None                                                                                              |  |  |  |  |  |
| Operation:       | $\begin{array}{l} \text{O0h} \rightarrow (\text{W}) \\ \text{1} \rightarrow \text{Z} \end{array}$ |  |  |  |  |  |
| Status Affected: | Z                                                                                                 |  |  |  |  |  |
| Description:     | W register is cleared. Zero bit (Z) set.                                                          |  |  |  |  |  |

is

### 30.3 DC Characteristics: PIC16(L)F1826/27-I/E (Power-Down)

| PIC16LF1826/27 |                         | Standard Operating Condition<br>Operating temperature -40<br>-40 |      |       |                                                                                                                               | tions (unless otherwise stated)<br>$40^{\circ}C \le TA \le +85^{\circ}C$ for industrial<br>$40^{\circ}C \le TA \le +125^{\circ}C$ for extended |     |                                    |
|----------------|-------------------------|------------------------------------------------------------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----|------------------------------------|
| PIC16F1826/27  |                         | Standard Operating Cond<br>Operating temperature                 |      |       | itions (unless otherwise stated)<br>-40°C $\leq$ TA $\leq$ +85°C for industrial<br>-40°C $\leq$ TA $\leq$ +125°C for extended |                                                                                                                                                |     |                                    |
| Param          | Device Characteristics  | Min                                                              | Tynt | Max.  | Max.                                                                                                                          | Units                                                                                                                                          |     | Conditions                         |
| No.            |                         |                                                                  | 1961 | +85°C | +125°C                                                                                                                        | onno                                                                                                                                           | VDD | Note                               |
|                | Power-down Base Current | (IPD) <sup>(2)</sup>                                             |      |       |                                                                                                                               |                                                                                                                                                |     |                                    |
| D022           |                         |                                                                  | 0.02 | 1.0   | 4.0                                                                                                                           | μA                                                                                                                                             | 1.8 | WDT, BOR, FVR, and T1OSC           |
|                |                         |                                                                  | 0.03 | 1.1   | 7.0                                                                                                                           | μA                                                                                                                                             | 3.0 | disabled, all Peripherals Inactive |
| D022           |                         | —                                                                | 15   | 35    | 50                                                                                                                            | μA                                                                                                                                             | 1.8 | WDT, BOR, FVR, and T1OSC           |
|                |                         |                                                                  | 18   | 40    | 60                                                                                                                            | μA                                                                                                                                             | 3.0 | disabled, all Peripherals Inactive |
|                |                         | —                                                                | 19   | 45    | 70                                                                                                                            | μA                                                                                                                                             | 5.0 |                                    |
| D023           |                         | _                                                                | 0.5  | 1.1   | 5.0                                                                                                                           | μΑ                                                                                                                                             | 1.8 | LPWDT Current (Note 1)             |
|                |                         |                                                                  | 0.8  | 2.0   | 8.0                                                                                                                           | μA                                                                                                                                             | 3.0 |                                    |
| D023           |                         |                                                                  | 16   | 35    | 50                                                                                                                            | μA                                                                                                                                             | 1.8 | LPWDT Current (Note 1)             |
|                |                         |                                                                  | 19   | 40    | 60                                                                                                                            | μA                                                                                                                                             | 3.0 |                                    |
|                |                         | —                                                                | 20   | 45    | 70                                                                                                                            | μA                                                                                                                                             | 5.0 |                                    |
| D023A          |                         |                                                                  | 8.5  | 23    | 32                                                                                                                            | μA                                                                                                                                             | 1.8 | FVR current (Note 1)               |
|                |                         | —                                                                | 8.5  | 26    | 40                                                                                                                            | μA                                                                                                                                             | 3.0 |                                    |
| D023A          |                         |                                                                  | 32   | 62    | 66                                                                                                                            | μA                                                                                                                                             | 1.8 | FVR current (Note 1)               |
|                |                         | —                                                                | 39   | 70    | 80                                                                                                                            | μA                                                                                                                                             | 3.0 |                                    |
|                |                         | —                                                                | 70   | 110   | 120                                                                                                                           | μA                                                                                                                                             | 5.0 |                                    |
| D024           |                         | —                                                                | 8.1  | 14    | 20                                                                                                                            | μA                                                                                                                                             | 3.0 | BOR Current (Note 1)               |
| D024           |                         |                                                                  | 34   | 57    | 70                                                                                                                            | μA                                                                                                                                             | 3.0 | BOR Current (Note 1)               |
|                |                         | —                                                                | 67   | 100   | 115                                                                                                                           | μA                                                                                                                                             | 5.0 |                                    |
| D025           |                         | —                                                                | 0.6  | 1.5   | 5.0                                                                                                                           | μA                                                                                                                                             | 1.8 | T1OSC Current (Note 1)             |
|                |                         | —                                                                | 0.8  | 2.5   | 8.0                                                                                                                           | μA                                                                                                                                             | 3.0 |                                    |
| D025           |                         | —                                                                | 16   | 35    | 50                                                                                                                            | μA                                                                                                                                             | 1.8 | T1OSC Current (Note 1)             |
|                |                         | —                                                                | 21   | 40    | 60                                                                                                                            | μA                                                                                                                                             | 3.0 |                                    |
|                |                         | —                                                                | 25   | 45    | 70                                                                                                                            | μA                                                                                                                                             | 5.0 |                                    |
| D026           |                         | —                                                                | 0.1  | 1.1   | 5.0                                                                                                                           | μA                                                                                                                                             | 1.8 | A/D Current (Note 1, Note 3), no   |
|                |                         | _                                                                | 0.1  | 2.0   | 8.0                                                                                                                           | μA                                                                                                                                             | 3.0 | conversion in progress             |
| D026           |                         | _                                                                | 16   | 35    | 50                                                                                                                            | μA                                                                                                                                             | 1.8 | A/D Current (Note 1, Note 3), no   |
|                |                         | _                                                                | 21   | 40    | 60                                                                                                                            | μA                                                                                                                                             | 3.0 | conversion in progress             |
|                |                         | —                                                                | 25   | 45    | 70                                                                                                                            | μA                                                                                                                                             | 5.0 |                                    |

These parameters are characterized but not tested.

† Data in "Typ" column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

Note 1: The peripheral current is the sum of the base IDD or IPD and the additional current consumed when this peripheral is enabled. The peripheral △ current can be determined by subtracting the base IDD or IPD current from this limit. Max values should be used when calculating total current consumption.

2: The power-down current in Sleep mode does not depend on the oscillator type. Power-down current is measured with the part in Sleep mode, with all I/O pins set to inputs state and tied to VDD.

**3:** A/D oscillator source is FRC.

#### 30.4 DC Characteristics: PIC16(L)F1826/27-I/E

| DC CHARACTERISTICS |                                        | $\begin{array}{l} \mbox{Standard Operating Conditions (unless otherwise stated)} \\ \mbox{Operating temperature -40°C $\le$ TA $\le$ +85°C for industrial} \\ \mbox{-40°C $\le$ TA $\le$ +125°C for extended} \end{array}$ |                    |      |          |       |                                                                         |  |
|--------------------|----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------|----------|-------|-------------------------------------------------------------------------|--|
| Param<br>No.       | Sym.                                   | Characteristic                                                                                                                                                                                                             | Min.               | Тур† | Max.     | Units | Conditions                                                              |  |
|                    | VIL                                    | Input Low Voltage                                                                                                                                                                                                          |                    |      |          |       |                                                                         |  |
|                    |                                        | I/O PORT:                                                                                                                                                                                                                  |                    |      |          |       |                                                                         |  |
| D030               |                                        | with TTL buffer                                                                                                                                                                                                            | —                  | _    | 0.8      | V     | $4.5V \leq V\text{DD} \leq 5.5V$                                        |  |
| D030A              |                                        |                                                                                                                                                                                                                            | —                  | —    | 0.15 VDD | V     | $1.8V \leq V \text{DD} \leq 4.5V$                                       |  |
| D031               |                                        | with Schmitt Trigger buffer                                                                                                                                                                                                |                    | _    | 0.2 VDD  | V     | $2.0V \leq V\text{DD} \leq 5.5V$                                        |  |
|                    |                                        | with I <sup>2</sup> C™ levels                                                                                                                                                                                              | —                  | _    | 0.3 VDD  | V     |                                                                         |  |
|                    |                                        | with SMBus™ levels                                                                                                                                                                                                         |                    |      | 0.8      | V     | $2.7V \le VDD \le 5.5V$                                                 |  |
| D032               |                                        | MCLR, OSC1 (RC mode) <sup>(1)</sup>                                                                                                                                                                                        |                    | _    | 0.2 Vdd  | V     |                                                                         |  |
| D033               |                                        | OSC1 (HS mode)                                                                                                                                                                                                             | —                  | _    | 0.3 VDD  | V     |                                                                         |  |
|                    | Vih                                    | Input High Voltage                                                                                                                                                                                                         | ļI                 |      |          |       |                                                                         |  |
|                    |                                        | I/O ports:                                                                                                                                                                                                                 |                    | _    | —        |       |                                                                         |  |
| D040               |                                        | with TTL buffer                                                                                                                                                                                                            | 2.0                | _    | _        | V     | $4.5V \le VDD \le 5.5V$                                                 |  |
| D040A              |                                        |                                                                                                                                                                                                                            | 0.25 VDD +<br>0.8  | _    | -        | V     | $1.8V \leq V\text{DD} \leq 4.5V$                                        |  |
| D041               |                                        | with Schmitt Trigger buffer                                                                                                                                                                                                | 0.8 VDD            | _    | _        | V     | $2.0V \le VDD \le 5.5V$                                                 |  |
|                    |                                        | with I <sup>2</sup> C™ levels                                                                                                                                                                                              | 0.7 VDD            | _    | _        | V     |                                                                         |  |
|                    |                                        | with SMBus™ levels                                                                                                                                                                                                         | 2.1                | _    | _        | V     | $2.7V \le VDD \le 5.5V$                                                 |  |
| D042               |                                        | MCLR                                                                                                                                                                                                                       | 0.8 VDD            | _    | _        | V     |                                                                         |  |
| D043A              |                                        | OSC1 (HS mode)                                                                                                                                                                                                             | 0.7 VDD            | _    | _        | V     |                                                                         |  |
| D043B              |                                        | OSC1 (RC mode)                                                                                                                                                                                                             | 0.9 VDD            | _    | _        | V     | (Note 1)                                                                |  |
|                    | lı∟                                    | Input Leakage Current <sup>(2)</sup>                                                                                                                                                                                       |                    |      |          |       |                                                                         |  |
| D060               |                                        | I/O ports                                                                                                                                                                                                                  | —                  | ± 5  | ± 100    | nA    | Vss $\leq$ VPIN $\leq$ VDD, Pin at high-<br>impedance at 85°C           |  |
| D004               |                                        |                                                                                                                                                                                                                            |                    | ± 5  | ± 1000   | nA    |                                                                         |  |
| D061               |                                        |                                                                                                                                                                                                                            | —                  | ± 50 | ± 200    | nA    | $VSS \leq VPIN \leq VDD$ at 85 C                                        |  |
| D070*              | IPUR                                   | weak Pull-up Current                                                                                                                                                                                                       | 05                 | 100  | 200      | 1     |                                                                         |  |
| D070"              |                                        |                                                                                                                                                                                                                            | 25<br>25           | 100  | 200      |       | VDD = 3.3V, VPIN = VSS<br>VDD = 5.0V, VPIN = VSS                        |  |
|                    | Voi                                    | Output Low Voltage <sup>(4)</sup>                                                                                                                                                                                          | 20                 | 140  | 000      | μη    |                                                                         |  |
| 080                | VOL                                    |                                                                                                                                                                                                                            |                    |      |          |       | $101 = 8mA$ $\sqrt{DD} = 5V$                                            |  |
| 2000               |                                        |                                                                                                                                                                                                                            |                    | _    | 0.6      | V     | IOL = 6mA, VDD = 3.3V                                                   |  |
|                    |                                        |                                                                                                                                                                                                                            |                    |      |          |       | IOL = 1.8mA, VDD = 1.8V                                                 |  |
|                    | VOH Output High Voltage <sup>(4)</sup> |                                                                                                                                                                                                                            |                    |      |          |       |                                                                         |  |
| D090               |                                        | I/O ports                                                                                                                                                                                                                  | Vdd - 0.7          | _    | _        | V     | IOH = 3.5mA, VDD = 5V<br>IOH = 3mA, VDD = 3.3V<br>IOH = 1mA, VDD = 1.8V |  |
|                    |                                        | Capacitive Loading Specs on                                                                                                                                                                                                | <b>Output Pins</b> |      |          |       |                                                                         |  |
| D101*              | COSC2                                  | OSC2 pin                                                                                                                                                                                                                   | —                  | _    | 15       | pF    | In XT, HS and LP modes when<br>external clock is used to drive<br>OSC1  |  |
| D101A*             | Сю                                     | All I/O pins                                                                                                                                                                                                               | _                  | _    | 50       | pF    |                                                                         |  |
| *                  |                                        |                                                                                                                                                                                                                            |                    |      | •        | •     | ·                                                                       |  |

These parameters are characterized but not tested.

Data in "Typ" column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are † not tested.

Note 1: In RC oscillator configuration, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended to use an external clock in RC mode.

2: Negative current is defined as current sourced by the pin.

3: The leakage current on the MCLR pin is strongly dependent on the applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltages.

4: Including OSC2 in CLKOUT mode.

#### TABLE 30-6: TIMER0 AND TIMER1 EXTERNAL CLOCK REQUIREMENTS

| Standard Operating Conditions (unless otherwise stated)<br>Operating Temperature $-40^{\circ}C \le TA \le +125^{\circ}C$ |           |                                                    |                                   |              |                                           |        |      |                        |                                    |
|--------------------------------------------------------------------------------------------------------------------------|-----------|----------------------------------------------------|-----------------------------------|--------------|-------------------------------------------|--------|------|------------------------|------------------------------------|
| Param<br>No.                                                                                                             | Sym.      | Characteristic                                     |                                   |              | Min.                                      | Тур†   | Max. | Units                  | Conditions                         |
| 40*                                                                                                                      | T⊤0H      | T0CKI High Pulse Width No Prescaler With Prescaler |                                   | No Prescaler | 0.5 Tcy + 20                              | —      | _    | ns                     |                                    |
|                                                                                                                          |           |                                                    |                                   | 10           | _                                         | _      | ns   |                        |                                    |
| 41*                                                                                                                      | T⊤0L      | T0CKI Low Pulse Width No Prescaler With Prescaler  |                                   | No Prescaler | 0.5 Tcy + 20                              | _      |      | ns                     |                                    |
|                                                                                                                          |           |                                                    |                                   | 10           | _                                         |        | ns   |                        |                                    |
| 42*                                                                                                                      | Тт0Р      | T0CKI Period                                       | 0CKI Period                       |              |                                           | _      |      | ns                     | N = prescale value<br>(2, 4,, 256) |
| 45*                                                                                                                      | TT1H      | T1CKI High<br>Time                                 | Synchronous, No Prescaler         |              | 0.5 Tcy + 20                              | —      | _    | ns                     |                                    |
|                                                                                                                          |           |                                                    | Synchronous,<br>with Prescaler    |              | 15                                        | —      | —    | ns                     |                                    |
|                                                                                                                          |           |                                                    | Asynchronous                      |              | 30                                        | —      | _    | ns                     |                                    |
| 46*                                                                                                                      | T⊤1L      | T1CKI Low<br>Time                                  | Synchronous, No Prescaler         |              | 0.5 Tcy + 20                              | _      |      | ns                     |                                    |
|                                                                                                                          |           |                                                    | Synchronous, with Prescaler       |              | 15                                        | —      |      | ns                     |                                    |
|                                                                                                                          |           |                                                    | Asynchronous                      |              | 30                                        | —      | _    | ns                     |                                    |
| 47*                                                                                                                      | T⊤1P      | T1CKI Input<br>Period                              | Synchronous                       |              | Greater of:<br>30 or <u>Tcy + 40</u><br>N | _      | —    | ns                     |                                    |
|                                                                                                                          |           |                                                    | Asynchronous                      |              | 60                                        | —      |      | ns                     |                                    |
| 48                                                                                                                       | F⊤1       | Timer1 Oscil<br>(oscillator en                     | lator Input Frequebled by setting | 32.4         | 32.768                                    | 33.1   | kHz  |                        |                                    |
| 49*                                                                                                                      | TCKEZTMR1 | Delay from E                                       | xternal Clock Ed                  | 2 Tosc       | —                                         | 7 Tosc | —    | Timers in Sync<br>mode |                                    |

These parameters are characterized but not tested.
 Data in "Typ" column is at 3.0V, 25°C unless otherwise

Data in "Typ" column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

#### FIGURE 30-11: CAPTURE/COMPARE/PWM TIMINGS (CCP)



#### TABLE 30-7: CAPTURE/COMPARE/PWM REQUIREMENTS (CCP)

| Standard Operating Conditions (unless otherwise stated)Operating Temperature $-40^{\circ}C \le TA \le +125^{\circ}C$ |      |                      |                |                       |      |       |            |                                 |  |  |
|----------------------------------------------------------------------------------------------------------------------|------|----------------------|----------------|-----------------------|------|-------|------------|---------------------------------|--|--|
| Param<br>No.                                                                                                         | Sym. | Characteris          | Min.           | Тур†                  | Max. | Units | Conditions |                                 |  |  |
| CC01*                                                                                                                | TccL | CCPx Input Low Time  | No Prescaler   | 0.5Tcy + 20           |      |       | ns         |                                 |  |  |
|                                                                                                                      |      |                      | With Prescaler | 20                    | _    |       | ns         |                                 |  |  |
| CC02*                                                                                                                | TccH | CCPx Input High Time | No Prescaler   | 0.5Tcy + 20           | _    |       | ns         |                                 |  |  |
|                                                                                                                      |      |                      | With Prescaler | 20                    | 1    | -     | ns         |                                 |  |  |
| CC03*                                                                                                                | TccP | CCPx Input Period    |                | <u>3Tcy + 40</u><br>N | _    | —     | ns         | N = prescale value (1, 4 or 16) |  |  |

\* These parameters are characterized but not tested.

† Data in "Typ" column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.



#### FIGURE 30-18: SPI SLAVE MODE TIMING (CKE = 0)





NOTES: