



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, LINbus, SPI, UART/USART                                 |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                     |
| Number of I/O              | 25                                                                        |
| Program Memory Size        | 14KB (8K x 14)                                                            |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | -                                                                         |
| RAM Size                   | 1K x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 2.3V ~ 5.5V                                                               |
| Data Converters            | A/D 17x10b; D/A 1x5b, 1x8b                                                |
| Oscillator Type            | Internal                                                                  |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                         |
| Mounting Type              | Surface Mount                                                             |
| Package / Case             | 28-SSOP (0.209", 5.30mm Width)                                            |
| Supplier Device Package    | 28-SSOP                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f1716-i-ss |

Email: info@E-XFL.COM

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





- Note 1: Quartz crystal characteristics vary according to type, package and manufacturer. The user should consult the manufacturer data sheets for specifications and recommended application.
  - 2: Always verify oscillator performance over the VDD and temperature range that is expected for the application.
  - **3:** For oscillator design assistance, reference the following Microchip Application Notes:
    - AN826, "Crystal Oscillator Basics and Crystal Selection for rfPIC<sup>®</sup> and PIC<sup>®</sup> Devices" (DS00826)
    - AN849, "Basic PIC<sup>®</sup> Oscillator Design" (DS00849)
    - AN943, "Practical PIC<sup>®</sup> Oscillator Analysis and Design" (DS00943)
    - AN949, "Making Your Oscillator Work" (DS00949)

### FIGURE 6-4:

#### CERAMIC RESONATOR OPERATION (XT OR HS MODE)



# 6.2.1.3 Oscillator Start-up Timer (OST)

If the oscillator module is configured for LP, XT or HS modes, the Oscillator Start-up Timer (OST) counts 1024 oscillations from OSC1. This occurs following a Power-on Reset (POR) and when the Power-up Timer (PWRT) has expired (if configured), or a wake-up from Sleep. During this time, the program counter does not increment and program execution is suspended, unless either FSCM or Two-Speed Start-Up are enabled. In this case, code will continue to execute at the selected INTOSC frequency while the OST is counting. The OST ensures that the oscillator circuit, using a quartz crystal resonator or ceramic resonator, has started and is providing a stable system clock to the oscillator module.

In order to minimize latency between external oscillator start-up and code execution, the Two-Speed Clock Start-up mode can be selected (see **Section 6.4 "Two-Speed Clock Start-up Mode"**).

#### 10.2.3 ERASING FLASH PROGRAM MEMORY

While executing code, program memory can only be erased by rows. To erase a row:

- 1. Load the PMADRH:PMADRL register pair with any address within the row to be erased.
- 2. Clear the CFGS bit of the PMCON1 register.
- 3. Set the FREE and WREN bits of the PMCON1 register.
- 4. Write 55h, then AAh, to PMCON2 (Flash programming unlock sequence).
- 5. Set control bit WR of the PMCON1 register to begin the erase operation.

See Example 10-2.

After the "BSF PMCON1, WR" instruction, the processor requires two cycles to set up the erase operation. The user must place two NOP instructions immediately following the WR bit set instruction. The processor will halt internal operations for the typical 2 ms erase time. This is not Sleep mode as the clocks and peripherals will continue to run. After the erase cycle, the processor will resume operation with the third instruction after the PMCON1 write instruction.

# FIGURE 10-4: FLASH PROGRAM

# MEMORY ERASE FLOWCHART





# 12.8 Register Definitions: PPS Input Selection

## REGISTER 12-1: xxxPPS: PERIPHERAL xxx INPUT SELECTION

| U-0                                                                  | U-0 | U-0 | R/W-q/u | R/W-q/u | R/W-q/u     | R/W-q/u | R/W-q/u |
|----------------------------------------------------------------------|-----|-----|---------|---------|-------------|---------|---------|
| —                                                                    | —   | —   |         |         | xxxPPS<4: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 | q = value depends on peripheral                       |

| bit 7-5 | Unimplemented: Read as '0' |
|---------|----------------------------|
|         |                            |

| bit 4-3 | <ul> <li>xxxPPS&lt;4:3&gt;: Peripheral xxx Input PORTx Selection bits</li> <li>See Table 12-1 for the list of available ports for each peripheral.</li> <li>11 = Reserved. Do not use.</li> <li>10 = Peripheral input is from PORTC</li> <li>01 = Peripheral input is from PORTB</li> <li>00 = Peripheral input is from PORTA</li> </ul>                                                                                                                                                                            |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 2-0 | <pre>xxxPPS&lt;2:0&gt;: Peripheral xxx Input PORTx Bit Selection bits<br/>111 = Peripheral input is from PORTx Bit 7 (Rx7)<br/>111 = Peripheral input is from PORTx Bit 6 (Rx6)<br/>101 = Peripheral input is from PORTx Bit 5 (Rx5)<br/>100 = Peripheral input is from PORTx Bit 4 (Rx4)<br/>011 = Peripheral input is from PORTx Bit 3 (Rx3)<br/>010 = Peripheral input is from PORTx Bit 2 (Rx2)<br/>001 = Peripheral input is from PORTx Bit 1 (Rx1)<br/>000 = Peripheral input is from PORTx Bit 0 (Rx0)</pre> |

### **TABLE 12-1:**

| Peripheral               | Register                      | PORTA   | PORTB | PORTC |
|--------------------------|-------------------------------|---------|-------|-------|
| PIN interrupt            | INTPPS                        | Х       | Х     |       |
| Timer0 clock             | TOCKIPPS                      | Х       | Х     |       |
| Timer1 clock             | T1CKIPPS                      | Х       |       | Х     |
| Timer1 gate              | T1GPPS                        |         | Х     | Х     |
| CCP1                     | CCP1PPS                       |         | Х     | Х     |
| CCP2                     | CCP2PPS                       |         | Х     | Х     |
| COG                      | COGINPPS                      |         | Х     | Х     |
| MSSP                     | SSPCLKPPS                     |         | Х     | Х     |
| MSSP                     | SSPDATPPS                     |         | Х     | Х     |
| MSSP                     | SSPSSPPS                      | Х       |       | Х     |
| EUSART                   | RXPPS                         |         | Х     | Х     |
| EUSART                   | CKPPS                         |         | Х     | Х     |
| All CLCs                 | CLCIN0PPS                     | Х       |       | Х     |
| All CLCs                 | CLCIN1PPS                     | Х       |       | Х     |
| All CLCs                 | CLCIN2PPS                     |         | Х     | Х     |
| All CLCs                 | CLCIN3PPS                     |         | Х     | Х     |
| Example: $CCP1PPS = 0x0$ | 0B selects RB3 as the input t | o CCP1. | •     | •     |

**Note:** Inputs are not available on all ports. A check in a port column of a peripheral row indicates that the port selection is valid for that peripheral. Unsupported ports will input a '0'.

# 16.10 Analog Input Connection Considerations

A simplified circuit for an analog input is shown in Figure 16-4. Since the analog input pins share their connection with a digital input, they have reverse biased ESD protection diodes to VDD and Vss. The analog input, therefore, must be between Vss and VDD. If the input voltage deviates from this range by more than 0.6V in either direction, one of the diodes is forward biased and a latch-up may occur.

A maximum source impedance of  $10 \text{ k}\Omega$  is recommended for the analog sources. Also, any external component connected to an analog input pin, such as a capacitor or a Zener diode, should have very little leakage current to minimize inaccuracies introduced.

- Note 1: When reading a PORT register, all pins configured as analog inputs will read as a '0'. Pins configured as digital inputs will convert as an analog input, according to the input specification.
  - 2: Analog levels on any pin defined as a digital input, may cause the input buffer to consume more current than is specified.





# REGISTER 16-3: CMOUT: COMPARATOR OUTPUT REGISTER

| U-0   | U-0 | U-0 | U-0 | U-0 | U-0 | R-0/0  | R-0/0  |
|-------|-----|-----|-----|-----|-----|--------|--------|
| —     | —   |     | —   | —   | —   | MC2OUT | MC10UT |
| 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 |                                                       |

bit 7-2 Unimplemented: Read as '0'

bit 1 MC2OUT: Mirror Copy of C2OUT bit

bit 0 MC1OUT: Mirror Copy of C1OUT bit

### TABLE 16-3: SUMMARY OF REGISTERS ASSOCIATED WITH COMPARATOR MODULE

| Name     | Bit 7  | Bit 6  | Bit 5   | Bit 4                 | Bit 3  | Bit 2       | Bit 1      | Bit 0   | Register<br>on Page |
|----------|--------|--------|---------|-----------------------|--------|-------------|------------|---------|---------------------|
| ANSELA   | —      | —      | ANSA5   | ANSA4                 | ANSA3  | ANSA2       | ANSA1      | ANSA0   | 120                 |
| ANSELB   | —      | —      | ANSB5   | ANSB4                 | ANSB3  | ANSB2       | ANSB1      | ANSB0   | 126                 |
| CM1CON0  | C10N   | C10UT  |         | C1POL                 | C1ZLF  | C1SP        | C1HYS      | C1SYNC  | 160                 |
| CM2CON0  | C2ON   | C2OUT  | —       | C2POL                 | C2ZLF  | C2SP        | C2HYS      | C2SYNC  | 160                 |
| CM1CON1  | C1NTP  | C1INTN |         | C1PCH<2:0> C1NCH<2:0> |        |             |            |         | 161                 |
| CM2CON1  | C2NTP  | C2INTN |         | C2PCH<2:0>            |        |             | C2NCH<2:0> |         |                     |
| CMOUT    | _      | —      |         | —                     |        | _           | MC2OUT     | MC10UT  | 162                 |
| FVRCON   | FVREN  | FVRRDY | TSEN    | TSRNG                 | CDAFV  | ′R<1:0>     | ADFVI      | R<1:0>  | 151                 |
| DAC1CON0 | DAC1EN | —      | DAC10E1 | DAC10E2               | DAC1PS | SS<1:0>     | —          | DAC1NSS | 249                 |
| DAC1CON1 |        |        |         | DAC1R                 | <7:0>  |             |            |         | 249                 |
| INTCON   | GIE    | PEIE   | TMR0IE  | INTE                  | IOCIE  | TMR0IF      | INTF       | IOCIF   | 83                  |
| PIE2     | OSFIE  | C2IE   | C1IE    | —                     | BCL1IE | TMR6IE      | TMR4IE     | CCP2IE  | 85                  |
| PIR2     | OSFIF  | C2IF   | C1IF    | —                     | BCL1IF | TMR6IF      | TMR4IF     | CCP2IF  | 88                  |
| TRISA    | TRISA7 | TRISA6 | TRISA5  | TRISA4                | TRISA3 | TRISA2      | TRISA1     | TRISA0  | 119                 |
| TRISB    | TRISB7 | TRISB6 | TRISB5  | TRISB4                | TRISB3 | TRISB2      | TRISB1     | TRISB0  | 125                 |
| TRISC    | TRISC7 | TRISC6 | TRISC5  | TRISC4                | TRISC3 | TRISC2      | TRISC1     | TRISC0  | 130                 |
| RxyPPS   | _      | _      |         |                       |        | RxyPPS<4:0> | >          |         | 137                 |

Legend: — = unimplemented location, read as '0'. Shaded cells are unused by the comparator module.

# FIGURE 18-1: EXAMPLE OF FULL-BRIDGE APPLICATION



DS40001726C-page 170

# FIGURE 18-8: COG (RISING/FALLING) DEAD-BAND BLOCK



#### 18.5.4 RISING EVENT DEAD-BAND

Rising event dead band delays the turn-on of the primary outputs from when complementary outputs are turned off. The rising event dead-band time starts when the rising\_ event output goes true.

See Section 18.5.1, Asynchronous Delay Chain Dead-band Delay and Section 18.5.2, Synchronous Counter Dead-band Delay for more information on setting the rising edge dead-band time.

#### 18.5.5 FALLING EVENT DEAD-BAND

Falling event dead band delays the turn-on of complementary outputs from when the primary outputs are turned off. The falling event dead-band time starts when the falling event output goes true.

See Section 18.5.1, Asynchronous Delay Chain Dead-band Delay and Section 18.5.2, Synchronous Counter Dead-band Delay for more information on setting the rising edge dead-band time.

#### 18.5.6 DEAD-BAND OVERLAP

There are two cases of dead-band overlap:

- Rising-to-falling
- Falling-to-rising

#### 18.5.6.1 Rising-to-Falling Overlap

In this case, the falling event occurs while the rising event dead-band counter is still counting. When this happens, the primary drives are suppressed and the dead-band extends by the falling event dead-band time. At the termination of the extended dead-band time, the complementary drive goes true.

#### 18.5.6.2 Falling-to-Rising Overlap

In this case, the rising event occurs while the falling event dead-band counter is still counting. When this happens, the complementary drive is suppressed and the dead-band extends by the rising event dead-band time. At the termination of the extended dead-band time, the primary drive goes true.

### 18.6 Blanking Control

Input blanking is a function, whereby, the event inputs can be masked or blanked for a short period of time. This is to prevent electrical transients caused by the turn-on/off of power components from generating a false input event.

The COG contains two blanking counters: one triggered by the rising event and the other triggered by the falling event. The counters are cross coupled with the events they are blanking. The falling event blanking counter is used to blank rising input events and the rising event blanking counter is used to blank falling input events. Once started, blanking extends for the time specified by the corresponding blanking counter. Blanking is timed by counting COG\_clock periods from zero up to the value in the blanking count register. Use Equation 18-1 to calculate blanking times.

#### 18.6.1 FALLING EVENT BLANKING OF RISING EVENT INPUTS

The falling event blanking counter inhibits rising event inputs from triggering a rising event. The falling event blanking time starts when the rising event output drive goes false.

The falling event blanking time is set by the value contained in the COGxBLKF register (Register 18-13). Blanking times are calculated using the formula shown in Equation 18-1.

When the COGxBLKF value is zero, falling event blanking is disabled and the blanking counter output is true, thereby, allowing the event signal to pass straight through to the event trigger circuit.

#### 18.6.2 RISING EVENT BLANKING OF FALLING EVENT INPUTS

The rising event blanking counter inhibits falling event inputs from triggering a falling event. The rising event blanking time starts when the falling event output drive goes false.

The rising event blanking time is set by the value contained in the COGxBLKR register (Register 18-12).

When the COGxBLKR value is zero, rising event blanking is disabled and the blanking counter output is true, thereby, allowing the event signal to pass straight through to the event trigger circuit.

#### 18.6.3 BLANKING TIME UNCERTAINTY

When the rising and falling sources that trigger the blanking counters are asynchronous to the COG\_clock, it creates uncertainty in the blanking time. The maximum uncertainty is equal to one COG\_clock period. Refer to Equation 18-1 and Example 18-1 for more detail.

### 18.7 Phase Delay

It is possible to delay the assertion of either or both the rising event and falling events. This is accomplished by placing a non-zero value in COGxPHR or COGxPHF phase-delay count register, respectively (Register 18-14 and Register 18-15). Refer to Figure 18-10 for COG operation with CCP1 and phase delay. The delay from the input rising event signal switching to the actual assertion of the events is calculated the same as the dead-band and blanking delays. Refer to Equation 18-1.

When the phase-delay count value is zero, phase delay is disabled and the phase-delay counter output is true, thereby, allowing the event signal to pass straight through to the complementary output driver flop.

<sup>© 2013-2016</sup> Microchip Technology Inc.

| Name     | Bit 7   | Bit 6   | Bit 5   | Bit 4      | Bit 3   | Bit 2       | Bit 1     | Bit 0   | Register<br>on Page |
|----------|---------|---------|---------|------------|---------|-------------|-----------|---------|---------------------|
| ANSELA   | -       | -       | ANSA5   | ANSA4      | ANSA3   | ANSA2       | ANSA1     | ANSA0   | 120                 |
| ANSELB   | _       | _       | ANSB5   | ANSB4      | ANSB3   | ANSB2       | ANSB1     | ANSB0   | 126                 |
| ANSELC   | ANSC7   | ANSC6   | ANSC5   | ANSC4      | ANSC3   | ANSC2       | —         | _       | 131                 |
| COG1PHR  | _       | —       |         |            | G1PH    | R<5:0>      |           |         | 201                 |
| COG1PHF  | _       | —       |         |            | G1PH    | F<5:0>      |           |         | 201                 |
| COG1BLKR | _       | —       |         |            | G1BLK   | (R<5:0>     |           |         | 200                 |
| COG1BLKF | —       | —       |         |            | G1BLK   | (F<5:0>     |           |         | 200                 |
| COG1DBR  | _       | —       |         |            | G1DB    | R<5:0>      |           |         | 199                 |
| COG1DBF  | —       | —       |         | G1DBF<5:0> |         |             |           | 199     |                     |
| COG1RIS  | G1RIS7  | G1RIS6  | G1RIS5  | G1RIS4     | G1RIS3  | G1RIS2      | G1RIS1    | G1RIS0  | 190                 |
| COG1RSIM | G1RSIM7 | G1RSIM6 | G1RSIM5 | G1RSIM4    | G1RSIM3 | G1RSIM2     | G1RSIM1   | G1RSIM0 | 191                 |
| COG1FIS  | G1FIS7  | G1FIS6  | G1FIS5  | G1FIS4     | G1FIS3  | G1FIS2      | G1FIS1    | G1FIS0  | 193                 |
| COG1FSIM | G1FSIM7 | G1FSIM6 | G1FSIM5 | G1FSIM4    | G1FSIM3 | G1FSIM2     | G1FSIM1   | G1FSIM0 | 194                 |
| COG1CON0 | G1EN    | G1LD    | _       | G1C5       | 6<1:0>  |             | G1MD<2:0> |         | 188                 |
| COG1CON1 | G1RDBS  | G1FDBS  | _       | —          | G1POLD  | G1POLC      | G1POLB    | G1POLA  | 189                 |
| COG1ASD0 | G1ASE   | G1ARSEN | G1ASDI  | BD<1:0>    | G1ASD   | AC<1:0>     | —         | —       | 196                 |
| COG1ASD1 | —       | —       | _       | —          | G1AS3E  | G1AS2E      | G1AS1E    | G1AS0E  | 197                 |
| COG1STR  | G1SDATD | G1SDATC | G1SDATB | G1SDATA    | G1STRD  | G1STRC      | G1STRB    | G1STRA  | 198                 |
| INTCON   | GIE     | PEIE    | T0IE    | INTE       | IOCIE   | TOIF        | INTF      | IOCIF   | 83                  |
| COG1PPS  | —       | —       |         |            |         | COG1PPS<4:0 | >         |         | 136                 |
| PIE2     | OSFIE   | C2IE    | C1IE    | —          | BCL1IE  | TMR6IE      | TMR4IE    | CCP2IE  | 85                  |
| PIR2     | OSFIF   | C2IF    | C1IF    | _          | BCL1IF  | TMR6IF      | TMR4IF    | CCP2IF  | 88                  |
| RxyPPS   | —       | —       | _       |            |         | RxyPPS<4:0> |           |         | 137                 |

### TABLE 18-2: SUMMARY OF REGISTERS ASSOCIATED WITH COG

Legend: x = unknown, u = unchanged, - = unimplemented locations read as '0'. Shaded cells are not used by COG

# 26.7 Timer1 Interrupt

The Timer1 register pair (TMR1H:TMR1L) increments to FFFFh and rolls over to 0000h. When Timer1 rolls over, the Timer1 interrupt flag bit of the PIR1 register is set. To enable the interrupt on rollover, you must set these bits:

- TMR1ON bit of the T1CON register
- TMR1IE bit of the PIE1 register
- PEIE bit of the INTCON register
- · GIE bit of the INTCON register

The interrupt is cleared by clearing the TMR1IF bit in the Interrupt Service Routine.

Note: The TMR1H:TMR1L register pair and the TMR1IF bit should be cleared before enabling interrupts.

# 26.8 Timer1 Operation During Sleep

Timer1 can only operate during Sleep when setup in Asynchronous Counter mode. In this mode, an external crystal or clock source can be used to increment the counter. To set up the timer to wake the device:

- TMR1ON bit of the T1CON register must be set
- TMR1IE bit of the PIE1 register must be set
- · PEIE bit of the INTCON register must be set
- T1SYNC bit of the T1CON register must be set
- TMR1CS bits of the T1CON register must be configured
- T1OSCEN bit of the T1CON register must be configured

The device will wake-up on an overflow and execute the next instructions. If the GIE bit of the INTCON register is set, the device will call the Interrupt Service Routine.

Secondary oscillator will continue to operate in Sleep regardless of the  $\overline{T1SYNC}$  bit setting.

## 26.9 CCP Capture/Compare Time Base

The CCP modules use the TMR1H:TMR1L register pair as the time base when operating in Capture or Compare mode.

In Capture mode, the value in the TMR1H:TMR1L register pair is copied into the CCPR1H:CCPR1L register pair on a configured event.

In Compare mode, an event is triggered when the value CCPR1H:CCPR1L register pair matches the value in the TMR1H:TMR1L register pair. This event can be an Auto-conversion Trigger.

For more information, see Section 29.0 "Capture/Compare/PWM Modules".

# 26.10 CCP Auto-Conversion Trigger

When any of the CCP's are configured to trigger an auto-conversion, the trigger will clear the TMR1H:TMR1L register pair. This auto-conversion does not cause a Timer1 interrupt. The CCP module may still be configured to generate a CCP interrupt.

In this mode of operation, the CCPR1H:CCPR1L register pair becomes the period register for Timer1.

Timer1 should be synchronized and Fosc/4 should be selected as the clock source in order to utilize the Auto-conversion Trigger. Asynchronous operation of Timer1 can cause an Auto-conversion Trigger to be missed.

In the event that a write to TMR1H or TMR1L coincides with an Auto-conversion Trigger from the CCP, the write will take precedence.

For more information, see **Section 29.2.4** "Auto-Conversion Trigger".



### FIGURE 26-2: TIMER1 INCREMENTING EDGE

## 31.1.2.4 Receive Framing Error

Each character in the receive FIFO buffer has a corresponding framing error Status bit. A framing error indicates that a Stop bit was not seen at the expected time. The framing error status is accessed via the FERR bit of the RCSTA register. The FERR bit represents the status of the top unread character in the receive FIFO. Therefore, the FERR bit must be read before reading the RCREG.

The FERR bit is read-only and only applies to the top unread character in the receive FIFO. A framing error (FERR = 1) does not preclude reception of additional characters. It is not necessary to clear the FERR bit. Reading the next character from the FIFO buffer will advance the FIFO to the next character and the next corresponding framing error.

The FERR bit can be forced clear by clearing the SPEN bit of the RCSTA register which resets the EUSART. Clearing the CREN bit of the RCSTA register does not affect the FERR bit. A framing error by itself does not generate an interrupt.

| Note: | If all receive characters in the receive  |
|-------|-------------------------------------------|
|       | FIFO have framing errors, repeated reads  |
|       | of the RCREG will not clear the FERR bit. |

#### 31.1.2.5 Receive Overrun Error

The receive FIFO buffer can hold two characters. An overrun error will be generated if a third character, in its entirety, is received before the FIFO is accessed. When this happens the OERR bit of the RCSTA register is set. The characters already in the FIFO buffer can be read but no additional characters will be received until the error is cleared. The error must be cleared by either clearing the CREN bit of the RCSTA register or by resetting the EUSART by clearing the SPEN bit of the RCSTA register.

#### 31.1.2.6 Receiving 9-Bit Characters

The EUSART supports 9-bit character reception. When the RX9 bit of the RCSTA register is set the EUSART will shift nine bits into the RSR for each character received. The RX9D bit of the RCSTA register is the ninth and Most Significant data bit of the top unread character in the receive FIFO. When reading 9-bit data from the receive FIFO buffer, the RX9D data bit must be read before reading the eight Least Significant bits from the RCREG.

#### 31.1.2.7 Address Detection

A special Address Detection mode is available for use when multiple receivers share the same transmission line, such as in RS-485 systems. Address detection is enabled by setting the ADDEN bit of the RCSTA register.

Address detection requires 9-bit character reception. When address detection is enabled, only characters with the ninth data bit set will be transferred to the receive FIFO buffer, thereby setting the RCIF interrupt bit. All other characters will be ignored.

Upon receiving an address character, user software determines if the address matches its own. Upon address match, user software must disable address detection by clearing the ADDEN bit before the next Stop bit occurs. When user software detects the end of the message, determined by the message protocol used, software places the receiver back into the Address Detection mode by setting the ADDEN bit.

- 31.1.2.8 Asynchronous Reception Setup:
- Initialize the SPBRGH, SPBRGL register pair and the BRGH and BRG16 bits to achieve the desired baud rate (see Section 31.4 "EUSART Baud Rate Generator (BRG)").
- 2. Clear the ANSEL bit for the RX pin (if applicable).
- Enable the serial port by setting the SPEN bit. The SYNC bit must be clear for asynchronous operation.
- 4. If interrupts are desired, set the RCIE bit of the PIE1 register and the GIE and PEIE bits of the INTCON register.
- 5. If 9-bit reception is desired, set the RX9 bit.
- 6. Enable reception by setting the CREN bit.
- 7. The RCIF interrupt flag bit will be set when a character is transferred from the RSR to the receive buffer. An interrupt will be generated if the RCIE interrupt enable bit was also set.
- 8. Read the RCSTA register to get the error flags and, if 9-bit data reception is enabled, the ninth data bit.
- 9. Get the received eight Least Significant data bits from the receive buffer by reading the RCREG register.
- 10. If an overrun occurred, clear the OERR flag by clearing the CREN receiver enable bit.

#### 31.1.2.9 9-bit Address Detection Mode Setup

This mode would typically be used in RS-485 systems. To set up an Asynchronous Reception with Address Detect Enable:

- Initialize the SPBRGH, SPBRGL register pair and the BRGH and BRG16 bits to achieve the desired baud rate (see Section 31.4 "EUSART Baud Rate Generator (BRG)").
- 2. Clear the ANSEL bit for the RX pin (if applicable).
- Enable the serial port by setting the SPEN bit. The SYNC bit must be clear for asynchronous operation.
- If interrupts are desired, set the RCIE bit of the PIE1 register and the GIE and PEIE bits of the INTCON register.
- 5. Enable 9-bit reception by setting the RX9 bit.
- 6. Enable address detection by setting the ADDEN bit.
- 7. Enable reception by setting the CREN bit.
- The RCIF interrupt flag bit will be set when a character with the ninth bit set is transferred from the RSR to the receive buffer. An interrupt will be generated if the RCIE interrupt enable bit was also set.
- 9. Read the RCSTA register to get the error flags. The ninth data bit will always be set.
- 10. Get the received eight Least Significant data bits from the receive buffer by reading the RCREG register. Software determines if this is the device's address.
- 11. If an overrun occurred, clear the OERR flag by clearing the CREN receiver enable bit.
- 12. If the device has been addressed, clear the ADDEN bit to allow all received data into the receive buffer and generate interrupts.



### FIGURE 31-5: ASYNCHRONOUS RECEPTION

# 33.0 INSTRUCTION SET SUMMARY

Each instruction is a 14-bit word containing the operation code (opcode) and all required operands. The opcodes are broken into three broad categories.

- Byte Oriented
- · Bit Oriented
- · Literal and Control

The literal and control category contains the most varied instruction word format.

Table 33-3 lists the instructions recognized by the MPASM  $^{\rm TM}$  assembler.

All instructions are executed within a single instruction cycle, with the following exceptions, which may take two or three cycles:

- Subroutine takes two cycles (CALL, CALLW)
- Returns from interrupts or subroutines take two cycles (RETURN, RETLW, RETFIE)
- Program branching takes two cycles (GOTO, BRA, BRW, BTFSS, BTFSC, DECFSZ, INCSFZ)
- One additional instruction cycle will be used when any instruction references an indirect file register and the file select register is pointing to program memory.

One instruction cycle consists of 4 oscillator cycles; for an oscillator frequency of 4 MHz, this gives a nominal instruction execution rate of 1 MHz.

All instruction examples use the format '0xhh' to represent a hexadecimal number, where 'h' signifies a hexadecimal digit.

# 33.1 Read-Modify-Write Operations

Any instruction that specifies a file register as part of the instruction performs a Read-Modify-Write (R-M-W) operation. The register is read, the data is modified, and the result is stored according to either the instruction, or the destination designator 'd'. A read operation is performed on a register even if the instruction writes to that register.

#### TABLE 33-1: OPCODE FIELD DESCRIPTIONS

| Field | Description                                                                                                                                                                       |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| f     | Register file address (0x00 to 0x7F)                                                                                                                                              |
| W     | Working register (accumulator)                                                                                                                                                    |
| b     | Bit address within an 8-bit file register                                                                                                                                         |
| k     | Literal field, constant data or label                                                                                                                                             |
| x     | Don't care location (= $0$ or 1).<br>The assembler will generate code with x = $0$ .<br>It is the recommended form of use for<br>compatibility with all Microchip software tools. |
| d     | Destination select; d = 0: store result in W,<br>d = 1: store result in file register f.<br>Default is d = 1.                                                                     |
| n     | FSR or INDF number. (0-1)                                                                                                                                                         |
| mm    | Pre-post increment-decrement mode selection                                                                                                                                       |

#### TABLE 33-2: ABBREVIATION DESCRIPTIONS

| Field | Description     |  |  |  |  |  |
|-------|-----------------|--|--|--|--|--|
| PC    | Program Counter |  |  |  |  |  |
| TO    | Time-Out bit    |  |  |  |  |  |
| С     | Carry bit       |  |  |  |  |  |
| DC    | Digit Carry bit |  |  |  |  |  |
| Z     | Zero bit        |  |  |  |  |  |
| PD    | Power-Down bit  |  |  |  |  |  |

#### TABLE 34-24: SPI MODE REQUIREMENTS

| Standard Operating Conditions (unless otherwise stated) |                       |                                                                       |              |      |      |       |                                  |  |
|---------------------------------------------------------|-----------------------|-----------------------------------------------------------------------|--------------|------|------|-------|----------------------------------|--|
| Param<br>No.                                            | Symbol                | Characteristic                                                        | Min.         | Тур† | Max. | Units | Conditions                       |  |
| SP70*                                                   | TssL2scH,<br>TssL2scL | $\overline{SS}\downarrow$ to SCK $\downarrow$ or SCK $\uparrow$ input | 2.25 TCY     | _    | —    | ns    |                                  |  |
| SP71*                                                   | TscH                  | SCK input high time (Slave mode)                                      | Tcy + 20     | —    | _    | ns    |                                  |  |
| SP72*                                                   | TscL                  | SCK input low time (Slave mode)                                       | Tcy + 20     | —    | —    | ns    |                                  |  |
| SP73*                                                   | TDIV2scH,<br>TDIV2scL | Setup time of SDI data input to SCK edge                              | 100          | _    | —    | ns    |                                  |  |
| SP74*                                                   | TscH2diL,<br>TscL2diL | Hold time of SDI data input to SCK edge                               | 100          | _    | _    | ns    |                                  |  |
| SP75*                                                   | TDOR                  | SDO data output rise time                                             | —            | 10   | 25   | ns    | $3.0V \leq V\text{DD} \leq 5.5V$ |  |
|                                                         |                       |                                                                       | —            | 25   | 50   | ns    | $1.8V \leq V\text{DD} \leq 5.5V$ |  |
| SP76*                                                   | TDOF                  | SDO data output fall time                                             | —            | 10   | 25   | ns    |                                  |  |
| SP77*                                                   | TssH2doZ              | $\overline{SS}^{\uparrow}$ to SDO output high-impedance               | 10           | —    | 50   | ns    |                                  |  |
| SP78*                                                   | TscR                  | SCK output rise time<br>(Master mode)                                 | —            | 10   | 25   | ns    | $3.0V \leq V\text{DD} \leq 5.5V$ |  |
|                                                         |                       |                                                                       | —            | 25   | 50   | ns    | $1.8V \leq V\text{DD} \leq 5.5V$ |  |
| SP79*                                                   | TscF                  | SCK output fall time (Master mode)                                    | —            | 10   | 25   | ns    |                                  |  |
| SP80*                                                   | TscH2doV,<br>TscL2doV | SDO data output valid after SCK edge                                  | —            | —    | 50   | ns    | $3.0V \le V\text{DD} \le 5.5V$   |  |
|                                                         |                       |                                                                       | —            | _    | 145  | ns    | $1.8V \leq V\text{DD} \leq 5.5V$ |  |
| SP81*                                                   | TDOV2scH,<br>TDOV2scL | SDO data output setup to SCK edge                                     | 1 Tcy        | —    | _    | ns    |                                  |  |
| SP82*                                                   | TssL2doV              | SDO data output valid after $\overline{SS}\downarrow$ edge            | —            | —    | 50   | ns    |                                  |  |
| SP83*                                                   | TscH2ssH,<br>TscL2ssH | SS ↑ after SCK edge                                                   | 1.5 Tcy + 40 | _    |      | ns    |                                  |  |

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.





# TABLE 34-25: I<sup>2</sup>C BUS START/STOP BITS REQUIREMENTS

| Standard Operating Conditions (unless otherwise stated) |         |                 |              |      |      |       |            |                              |  |
|---------------------------------------------------------|---------|-----------------|--------------|------|------|-------|------------|------------------------------|--|
| Param<br>No.                                            | Symbol  | Charact         | Min.         | Тур  | Max. | Units | Conditions |                              |  |
| SP90*                                                   | Tsu:sta | Start condition | 100 kHz mode | 4700 |      | —     | ns         | Only relevant for Repeated   |  |
|                                                         |         | Setup time      | 400 kHz mode | 600  | —    | —     |            | Start condition              |  |
| SP91*                                                   | THD:STA | Start condition | 100 kHz mode | 4000 | _    | —     | ns         | After this period, the first |  |
|                                                         |         | Hold time       | 400 kHz mode | 600  | _    | —     |            | clock pulse is generated     |  |
| SP92*                                                   | Tsu:sto | Stop condition  | 100 kHz mode | 4700 |      | —     | ns         |                              |  |
|                                                         |         | Setup time      | 400 kHz mode | 600  |      | —     |            |                              |  |
| SP93                                                    | THD:STO | Stop condition  | 100 kHz mode | 4000 |      | _     | ns         |                              |  |
|                                                         |         | Hold time       | 400 kHz mode | 600  |      | _     |            |                              |  |

\* These parameters are characterized but not tested.

# FIGURE 34-22: I<sup>2</sup>C BUS DATA TIMING



Note: Unless otherwise noted, VIN = 5V, Fosc = 300 kHz, CIN = 0.1 µF, TA = 25°C.



FIGURE 35-31: IDD, HS Oscillator, 32 MHz (8 MHz + 4x PLL), PIC16LF1713/6 Only.



FIGURE 35-32: IDD, HS Oscillator, 32 MHz (8 MHz + 4x PLL), PIC16F1713/6 Only.



FIGURE 35-33: IPD Base, LP Sleep Mode, PIC16LF1713/6 Only.



FIGURE 35-34: IPD Base, LP Sleep Mode (VREGPM = 1), PIC16F1713/6 Only.



PIC16LF1713/6 Only.



FIGURE 35-36: IPD, Watchdog Timer (WDT), PIC16F1713/6 Only.

3.0

2.5

2.0

1.0

0.5 0.0

(Au) aq 1.5

# 37.0 PACKAGING INFORMATION

# 37.1 Package Marking Information



| Legend: | XXX<br>Y<br>YY<br>WW<br>NNN<br>@3<br>*  | Customer-specific information<br>Year code (last digit of calendar year)<br>Year code (last 2 digits of calendar year)<br>Week code (week of January 1 is week '01')<br>Alphanumeric traceability code<br>Pb-free JEDEC <sup>®</sup> designator for Matte Tin (Sn)<br>This package is Pb-free. The Pb-free JEDEC designator (e3)<br>can be found on the outer packaging for this package. |
|---------|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Note:   | In the even<br>be carried<br>characters | nt the full Microchip part number cannot be marked on one line, it will<br>d over to the next line, thus limiting the number of available<br>s for customer-specific information.                                                                                                                                                                                                         |

28-Lead Plastic Small Outline (SO) - Wide, 7.50 mm Body [SOIC]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging



# RECOMMENDED LAND PATTERN

|                          | MILLIMETERS |      |          |      |  |  |
|--------------------------|-------------|------|----------|------|--|--|
| Dimension                | MIN         | NOM  | MAX      |      |  |  |
| Contact Pitch            | E           |      | 1.27 BSC |      |  |  |
| Contact Pad Spacing      | С           |      | 9.40     |      |  |  |
| Contact Pad Width (X28)  | Х           |      |          | 0.60 |  |  |
| Contact Pad Length (X28) | Y           |      |          | 2.00 |  |  |
| Distance Between Pads    | Gx          | 0.67 |          |      |  |  |
| Distance Between Pads    | G           | 7.40 |          |      |  |  |

Notes:

1. Dimensioning and tolerancing per ASME Y14.5M

BSC: Basic Dimension. Theoretically exact value shown without tolerances.

Microchip Technology Drawing No. C04-2052A

# **Worldwide Sales and Service**

#### AMERICAS

Corporate Office 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7200 Fax: 480-792-7277 Technical Support: http://www.microchip.com/ support Web Address: www.microchip.com

Atlanta Duluth, GA Tel: 678-957-9614 Fax: 678-957-1455

Austin, TX Tel: 512-257-3370

Boston Westborough, MA Tel: 774-760-0087 Fax: 774-760-0088

Chicago Itasca, IL Tel: 630-285-0071 Fax: 630-285-0075

**Cleveland** Independence, OH Tel: 216-447-0464 Fax: 216-447-0643

**Dallas** Addison, TX Tel: 972-818-7423 Fax: 972-818-2924

**Detroit** Novi, MI Tel: 248-848-4000

Houston, TX Tel: 281-894-5983

Indianapolis Noblesville, IN Tel: 317-773-8323 Fax: 317-773-5453

Los Angeles Mission Viejo, CA Tel: 949-462-9523 Fax: 949-462-9608

New York, NY Tel: 631-435-6000

San Jose, CA Tel: 408-735-9110

**Canada - Toronto** Tel: 905-673-0699 Fax: 905-673-6509

#### ASIA/PACIFIC

Asia Pacific Office Suites 3707-14, 37th Floor Tower 6, The Gateway

Harbour City, Kowloon Hong Kong Tel: 852-2943-5100 Fax: 852-2401-3431

Australia - Sydney Tel: 61-2-9868-6733 Fax: 61-2-9868-6755

**China - Beijing** Tel: 86-10-8569-7000 Fax: 86-10-8528-2104

**China - Chengdu** Tel: 86-28-8665-5511 Fax: 86-28-8665-7889

China - Chongqing Tel: 86-23-8980-9588 Fax: 86-23-8980-9500

China - Dongguan Tel: 86-769-8702-9880

**China - Hangzhou** Tel: 86-571-8792-8115 Fax: 86-571-8792-8116

**China - Hong Kong SAR** Tel: 852-2943-5100 Fax: 852-2401-3431

**China - Nanjing** Tel: 86-25-8473-2460 Fax: 86-25-8473-2470

**China - Qingdao** Tel: 86-532-8502-7355 Fax: 86-532-8502-7205

China - Shanghai Tel: 86-21-5407-5533 Fax: 86-21-5407-5066

China - Shenyang Tel: 86-24-2334-2829 Fax: 86-24-2334-2393

**China - Shenzhen** Tel: 86-755-8864-2200 Fax: 86-755-8203-1760

**China - Wuhan** Tel: 86-27-5980-5300 Fax: 86-27-5980-5118

**China - Xian** Tel: 86-29-8833-7252 Fax: 86-29-8833-7256

#### ASIA/PACIFIC

**China - Xiamen** Tel: 86-592-2388138 Fax: 86-592-2388130

**China - Zhuhai** Tel: 86-756-3210040 Fax: 86-756-3210049

India - Bangalore Tel: 91-80-3090-4444 Fax: 91-80-3090-4123

India - New Delhi Tel: 91-11-4160-8631 Fax: 91-11-4160-8632

India - Pune Tel: 91-20-3019-1500

Japan - Osaka Tel: 81-6-6152-7160 Fax: 81-6-6152-9310

**Japan - Tokyo** Tel: 81-3-6880- 3770 Fax: 81-3-6880-3771

**Korea - Daegu** Tel: 82-53-744-4301 Fax: 82-53-744-4302

Korea - Seoul Tel: 82-2-554-7200 Fax: 82-2-558-5932 or 82-2-558-5934

Malaysia - Kuala Lumpur Tel: 60-3-6201-9857 Fax: 60-3-6201-9859

Malaysia - Penang Tel: 60-4-227-8870 Fax: 60-4-227-4068

Philippines - Manila Tel: 63-2-634-9065 Fax: 63-2-634-9069

**Singapore** Tel: 65-6334-8870 Fax: 65-6334-8850

**Taiwan - Hsin Chu** Tel: 886-3-5778-366 Fax: 886-3-5770-955

**Taiwan - Kaohsiung** Tel: 886-7-213-7828

Taiwan - Taipei Tel: 886-2-2508-8600 Fax: 886-2-2508-0102

Thailand - Bangkok Tel: 66-2-694-1351 Fax: 66-2-694-1350

#### EUROPE

Austria - Wels Tel: 43-7242-2244-39 Fax: 43-7242-2244-393

Denmark - Copenhagen Tel: 45-4450-2828 Fax: 45-4485-2829

France - Paris Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79

Germany - Dusseldorf Tel: 49-2129-3766400

Germany - Karlsruhe Tel: 49-721-625370

**Germany - Munich** Tel: 49-89-627-144-0 Fax: 49-89-627-144-44

Italy - Milan Tel: 39-0331-742611 Fax: 39-0331-466781

Italy - Venice Tel: 39-049-7625286

Netherlands - Drunen Tel: 31-416-690399 Fax: 31-416-690340

Poland - Warsaw Tel: 48-22-3325737

**Spain - Madrid** Tel: 34-91-708-08-90 Fax: 34-91-708-08-91

Sweden - Stockholm Tel: 46-8-5090-4654

**UK - Wokingham** Tel: 44-118-921-5800 Fax: 44-118-921-5820

07/14/15