



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              | 18                                                                        |
| 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 12x10b; D/A 1x8b                                                      |
| Oscillator Type            | Internal                                                                  |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                         |
| Mounting Type              | Surface Mount                                                             |
| Package / Case             | 20-VFQFN Exposed Pad                                                      |
| Supplier Device Package    | 20-QFN (4x4)                                                              |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f1619-i-ml |

Email: info@E-XFL.COM

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

#### 3.2.1.2 Indirect Read with FSR

The program memory can be accessed as data by setting bit 7 of the FSRxH register and reading the matching INDFx register. The MOVIW instruction will place the lower eight bits of the addressed word in the W register. Writes to the program memory cannot be performed via the INDF registers. Instructions that access the program memory via the FSR require one extra instruction cycle to complete. Example 3-2 demonstrates accessing the program memory via an FSR.

The HIGH operator will set bit<7> if a label points to a location in program memory.

| EXAMPLE 3-2: | ACCESSING PROGRAM |
|--------------|-------------------|
|              | MEMORY VIA FSR    |

| constants               |                    |
|-------------------------|--------------------|
| DW DATA0                | ;First constant    |
| DW DATA1                | ;Second constant   |
| DW DATA2                |                    |
| DW DATA3                |                    |
| my_function             |                    |
| ; LOTS OF CODE          |                    |
| MOVLW DATA_INDEX        |                    |
| ADDLW LOW constants     |                    |
| MOVWF FSR1L             |                    |
| MOVLW HIGH constants    | ;MSb sets          |
|                         | automatically      |
| MOVWF FSR1H             |                    |
| BTFSC STATUS, C         | ;carry from ADDLW? |
| INCF FSR1h, f           | ;yes               |
| MOVIW 0[FSR1]           |                    |
| ; THE PROGRAM MEMORY IS | IN W               |

| <b>TABLE 3-14:</b> | SPECIAL | FUNCTION REGISTER | SUMMARY      |
|--------------------|---------|-------------------|--------------|
|                    |         |                   | 0011111/1111 |

| Addr | Name                 | Bit 7              | Bit 6                   | Bit 5              | Bit 4            | Bit 3                   | Bit 2     | Bit 1     | Bit 0     | Value on<br>POR, BOR | Value on all other Resets |
|------|----------------------|--------------------|-------------------------|--------------------|------------------|-------------------------|-----------|-----------|-----------|----------------------|---------------------------|
| Bank | Bank 0               |                    |                         |                    |                  |                         |           |           |           | L                    |                           |
| 00Ch | PORTA                | —                  |                         | RA5                | RA4              | RA3                     | RA2       | RA1       | RA0       | xx xxxx              | xx xxxxx                  |
| 00Dh | PORTB <sup>(4)</sup> | RB7                | RB6                     | RB5                | RB4              |                         | —         | —         | —         | xxxx                 | xxxx                      |
| 00Eh | PORTC                | RC7 <sup>(4)</sup> | RC6 <sup>(4)</sup>      | RC5                | RC4              | RC3                     | RC2       | RC1       | RC0       | xxxx xxxx            | xxxx xxxx                 |
| 00Fh | —                    | Unimplemented      |                         |                    |                  |                         |           |           |           | —                    | —                         |
| 010h | PIR1                 | TMR1GIF            | ADIF                    | RCIF               | TXIF             | SSP1IF                  | CCP1IF    | TMR2IF    | TMR1IF    | 0000 0000            | 0000 0000                 |
| 011h | PIR2                 | OSFIF              | C2IF                    | C1IF               | _                | BCL1IF                  | TMR6IF    | TMR4IF    | CCP2IF    | -00- 0000            | -00- 0000                 |
| 012h | PIR3                 | —                  |                         | CWGIF              | ZCDIF            | CLC4IF                  | CLC3IF    | CLC2IF    | CLC1IF    | 00 0000              | 00 0000                   |
| 013h | PIR4                 | SCANIF             | CRCIF                   | SMT2PWAIF          | SMT2PRAIF        | SMT2IF                  | SMT1PWAIF | SMT1PRAIF | SMT1IF    | 0000 0000            | 0000 0000                 |
| 014h | PIR5                 | TMR3GIF            | TMR3IF                  | TMR5GIF            | TMR5IF           |                         | AT1IF     | PID1EIF   | PID1DIF   | 0000 -000            | 0000 -000                 |
| 015h | TMR0                 | Holding Registe    | er for the 8-bit Tir    | mer0 Count         |                  |                         |           |           |           | xxxx xxxx            | uuuu uuuu                 |
| 016h | TMR1L                | Holding Registe    | er for the Least S      | ignificant Byte of | f the 16-bit TMR | 1 Count                 |           |           |           | xxxx xxxx            | uuuu uuuu                 |
| 017h | TMR1H                | Holding Registe    | er for the Most Si      | ignificant Byte of | the 16-bit TMR1  | Count                   |           |           |           | xxxx xxxx            | uuuu uuuu                 |
| 018h | T1CON                | TMR1C              | S<1:0>                  | T1CKP              | S<1:0>           |                         | T1SYNC    | _         | TMR10N    | 0000 -0-0            | uuuu -u-u                 |
| 019h | T1GCON               | TMR1GE             | T1GPOL                  | T1GTM              | T1GSPM           | T <u>1GGO</u> /<br>DONE | T1GVAL    | T1GSS     | S<1:0>    | 0000 0x00            | uuuu uxuu                 |
| 01Ah | TMR2                 | Timer2 Module      | Register                |                    |                  |                         |           |           |           | 0000 0000            | 0000 0000                 |
| 01Bh | PR2                  | Timer2 Period F    | Register                |                    |                  |                         |           |           |           | 1111 1111            | 1111 1111                 |
| 01Ch | T2CON                | ON                 | ON CKPS<2:0> OUTPS<3:0> |                    |                  |                         |           | 0000 0000 | 0000 0000 |                      |                           |
| 01Dh | T2HLT                | PSYNC              | CKPOL                   | CKSYNC             |                  |                         | MODE<4:0> | 0000 0000 | 0000 0000 |                      |                           |
| 01Eh | T2CLKCON             |                    |                         |                    |                  |                         | CS<       | 3:0>      |           | 0000                 | 0000                      |
| 01Fh | T2RST                |                    |                         |                    | _                |                         | RSEL      | <3:0>     |           | 0000                 | 0000                      |

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

Note 1: PIC16F1615/9 only.

2: Unimplemented, read as '1'.

3: PIC16(L)F1615 only.

4: PIC16(L)F1619 only.

| Addr       | Name                | Bit 7                | Bit 6                | Bit 5       | Bit 4           | Bit 3            | Bit 2         | Bit 1  | Bit 0 | Value on<br>POR, BOR | Value on all other Resets |
|------------|---------------------|----------------------|----------------------|-------------|-----------------|------------------|---------------|--------|-------|----------------------|---------------------------|
| Bank       | Bank 4              |                      |                      |             |                 |                  |               |        |       |                      |                           |
| 20Ch       | WPUA                | _                    | _                    | WPUA5       | WPUA4           | WPUA3            | WPUA2         | WPUA1  | WPUA0 | 11 1111              | 11 1111                   |
| 20Dh       | WPUB <sup>(4)</sup> | WPUB7                | WPUB6                | WPUB5       | WPUB4           | _                | —             | —      | —     | 1111                 | 1111                      |
| 20Eh       | WPUC                | WPUC7 <sup>(4)</sup> | WPUC6 <sup>(4)</sup> | WPUC5       | WPUC4           | WPUC3            | WPUC2         | WPUC1  | WPUC0 | 1111 1111            | 111 1111                  |
| 20Fh       | —                   | Unimplemented        |                      |             |                 |                  |               |        |       | —                    | —                         |
| 210h       | —                   | Unimplemented        | Jnimplemented        |             |                 |                  |               |        |       | —                    | —                         |
| 211h       | SSP1BUF             |                      |                      | Synchronous | Serial Port Rec | eive Buffer/Tran | smit Register |        |       | xxxx xxxx            | XXXX XXXX                 |
| 212h       | SSP1ADD             |                      |                      |             | ADD             | <7:0>            |               |        |       | 0000 0000            | 0000 0000                 |
| 213h       | SSP1MSK             |                      |                      |             | MSK             | <7:0>            |               |        |       | 1111 1111            | 1111 1111                 |
| 214h       | SSP1STAT            | SMP                  | CKE                  | D/A         | Р               | S                | R/W           | UA     | BF    | 0000 0000            | 0000 0000                 |
| 215h       | SSP1CON1            | WCOL                 | SSPOV                | SSPEN       | СКР             |                  | SSPM          | 1<3:0> |       | 0000 0000            | 0000 0000                 |
| 216h       | SSP1CON2            | GCEN                 | ACKSTAT              | ACKDT       | ACKEN           | RCEN             | PEN           | RSEN   | SEN   | 0000 0000            | 0000 0000                 |
| 217h       | SSP1CON3            | ACKTIM               | PCIE                 | SCIE        | BOEN            | SDAHT            | SBCDE         | AHEN   | DHEN  | 0000 0000            | 0000 0000                 |
| 218h<br>to | _                   | Unimplemented        |                      |             |                 |                  |               |        |       | _                    | _                         |
| 21Fh       |                     | ep.omontou           |                      |             |                 |                  |               |        |       |                      |                           |

#### TABLE 3-14: SPECIAL FUNCTION REGISTER SUMMARY (CONTINUED)

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

Note 1: PIC16F1615/9 only.

2: Unimplemented, read as '1'.

3: PIC16(L)F1615 only.

4: PIC16(L)F1619 only.

## 5.2.2.7 32 MHz Internal Oscillator Frequency Selection

The Internal Oscillator Block can be used with the 4x PLL associated with the External Oscillator Block to produce a 32 MHz internal system clock source. Either the 8 or 16 MHz internal oscillator settings can be used, with the 16 MHz being divided by two before being input into the PLL. The following settings are required to use the 32 MHz internal clock source:

- The FOSC bits in Configuration Words must be set to use the INTOSC source as the device system clock (FOSC<1:0> = 00).
- The SCS bits in the OSCCON register must be cleared to use the clock determined by FOSC<1:0> in Configuration Words (SCS<1:0> = 00).
- The IRCF bits in the OSCCON register must be set to either the 16 MHz (IRCF<3:0> = 1111) or the 8 MHz HFINTOSC (IRCF<3:0> = 1110).
- The SPLLEN bit in the OSCCON register must be set to enable the 4x PLL, or the PLLEN bit of the Configuration Words must be programmed to a '1'.

Note: When using the PLLEN bit of the Configuration Words, the 4x PLL cannot be disabled by software and the 8/16 MHz HFINTOSC option will no longer be available.

The 4x PLL is not available for use with the internal oscillator when the SCS bits of the OSCCON register are set to '1x'. The SCS bits must be set to '00' to use the 4x PLL with the internal oscillator.

## 5.2.2.8 Internal Oscillator Clock Switch Timing

When switching between the HFINTOSC, MFINTOSC and the LFINTOSC, the new oscillator may already be shut down to save power (see Figure 5-5). If this is the case, there is a delay after the IRCF<3:0> bits of the OSCCON register are modified before the frequency selection takes place. The OSCSTAT register will reflect the current active status of the HFINTOSC, MFINTOSC and LFINTOSC oscillators. The sequence of a frequency selection is as follows:

- 1. IRCF<3:0> bits of the OSCCON register are modified.
- 2. If the new clock is shut down, a clock start-up delay is started.
- 3. Clock switch circuitry waits for a falling edge of the current clock.
- 4. The current clock is held low and the clock switch circuitry waits for a rising edge in the new clock.
- 5. The new clock is now active.
- 6. The OSCSTAT register is updated as required.
- 7. Clock switch is complete.

See Figure 5-5 for more details.

If the internal oscillator speed is switched between two clocks of the same source, there is no start-up delay before the new frequency is selected. Clock switching time delays are shown in Table 5-1.

Start-up delay specifications are located in the oscillator tables of **Section35.0 "Electrical Specifications"**.

# EXAMPLE 10-3: WRITING TO FLASH PROGRAM MEMORY (32 WRITE LATCHES)

| ;      | This           | write rout                | ine assumes the f                    | following:                                                                                 |
|--------|----------------|---------------------------|--------------------------------------|--------------------------------------------------------------------------------------------|
| ;<br>; | 1. 64<br>2. Ea | 4 bytes of<br>ach word of | data are loaded,<br>data to be writt | starting at the address in DATA_ADDR<br>.en is made up of two adjacent bytes in DATA_ADDR, |
| ;      | st<br>3 7      | cored in li               | ttle endian forma                    | t                                                                                          |
| ;      | 4. AI          | DDRH and AD               | DRL are located i                    | n shared data memory 0x70 - 0x7F (common RAM)                                              |
| ,      |                | BCF                       | INTCON,GIE                           | ; Disable ints so required sequences will execute properly                                 |
|        |                | BANKSEL                   | PMADRH                               | ; Bank 3                                                                                   |
|        |                | MOVF                      | ADDRH,W                              | ; Load initial address                                                                     |
|        |                | MOVWF                     | PMADRH                               | ;                                                                                          |
|        |                | MOVF                      | ADDRL,W                              | ;                                                                                          |
|        |                | MOVWF                     | PMADRL                               | ;                                                                                          |
|        |                | MOVLW                     | LOW DATA_ADDR                        | ; Load initial data address                                                                |
|        |                | MOVWF'                    | FSRUL                                | ;<br>. Trad dududa daha addaran                                                            |
|        |                | MOVLW                     | HIGH DATA_ADDR                       | , Load initial data address                                                                |
|        |                | NOVWF                     | PORUNI CECS                          | · Not configuration apage                                                                  |
|        |                | BCF                       | PMCON1, CFGS                         | ; Enable writes                                                                            |
|        |                | BSF                       | PMCON1, LWLO                         | ; Only Load Write Latches                                                                  |
| LC     | OP             | 201                       | 11100111,21120                       |                                                                                            |
|        |                | MOVIW                     | FSR0++                               | ; Load first data byte into lower                                                          |
|        |                | MOVWF                     | PMDATL                               | ;                                                                                          |
|        |                | MOVIW                     | FSR0++                               | ; Load second data byte into upper                                                         |
|        |                | MOVWF                     | PMDATH                               | ;                                                                                          |
|        |                | MOVF                      | PMADRL,W                             | ; Check if lower bits of address are '00000'                                               |
|        |                | XORLW                     | 0x1F                                 | ; Check if we're on the last of 32 addresses                                               |
|        |                | ANDLW                     | 0x1F                                 | ;                                                                                          |
|        |                | BTFSC                     | STATUS , Z                           | ; Exit if last of 32 words,                                                                |
|        |                | GOTO                      | START_WRITE                          | ;                                                                                          |
|        |                | MOVLW                     | 55h                                  | ; Start of required write sequence:                                                        |
|        |                | MOVWF                     | PMCON2                               | ; Write 55h                                                                                |
|        | o ad           | MOVLW                     | AAh                                  | ;                                                                                          |
|        | uire           | MOVWF                     | PMCON2                               | ; Write AAh                                                                                |
|        | seq.           | BSF                       | PMCON1,WR                            | ; Set WR bit to begin write                                                                |
|        | щω             | NOP                       |                                      | ; NOP instructions are forced as processor                                                 |
|        |                | NOP                       |                                      | ; loads program memory write latches<br>;                                                  |
|        |                |                           |                                      |                                                                                            |
|        |                | INCF                      | PMADRL, F                            | ; Still loading latches Increment address                                                  |
|        |                | GOIO                      | TOOL                                 | , write next fatches                                                                       |
| SI     | ART_V          | WRITE                     |                                      |                                                                                            |
|        |                | BCF                       | PMCON1,LWLO                          | ; No more loading latches - Actually start Flash program ; memory write                    |
|        |                | MOVLW                     | 55h                                  | ; Start of required write sequence:                                                        |
|        |                | MOVWF                     | PMCON2                               | ; Write 55h                                                                                |
|        | ъë             | MOVLW                     | AAh                                  | ;                                                                                          |
|        | end            | MOVWF                     | PMCON2                               | ; Write AAh                                                                                |
|        | nba            | BSF                       | PMCON1,WR                            | ; Set WR bit to begin write                                                                |
|        | a s            | NOP                       |                                      | ; NOP instructions are forced as processor writes                                          |
|        |                |                           |                                      | ; all the program memory write latches simultaneously                                      |
|        |                | NOP                       |                                      | ; to program memory.                                                                       |
|        | <u> </u>       |                           |                                      | ; After NOPs, the processor                                                                |
|        |                |                           |                                      | ; stalls until the self-write process in complete                                          |
|        |                | DOE                       |                                      | ; after write processor continues with 3rd instruction                                     |
|        |                | BCF                       | PMCONI, WREN                         | , Disable Writes                                                                           |
|        |                | 100                       | THICON, GIE                          | , ENGATE INCELLADES                                                                        |

#### REGISTER 14-7: IOCCP: INTERRUPT-ON-CHANGE PORTC POSITIVE EDGE REGISTER

| R/W-0/0               | R/W-0/0               | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 |
|-----------------------|-----------------------|---------|---------|---------|---------|---------|---------|
| IOCCP7 <sup>(1)</sup> | IOCCP6 <sup>(1)</sup> | IOCCP5  | IOCCP4  | IOCCP3  | IOCCP2  | IOCCP1  | IOCCP0  |
| 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 |                                                       |

**IOCCP<7:0>:** Interrupt-on-Change PORTC Positive Edge Enable bits(1)

- 1 = Interrupt-on-Change enabled on the pin for a positive going edge. IOCCFx bit and IOCIF flag will be set upon detecting an edge.
- 0 = Interrupt-on-Change disabled for the associated pin.

Note 1: IOCCP<7:6> available on PIC16(L)F1619 only.

## REGISTER 14-8: IOCCN: INTERRUPT-ON-CHANGE PORTC NEGATIVE EDGE REGISTER<sup>(1)</sup>

| R/W-0/0               | R/W-0/0               | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 |
|-----------------------|-----------------------|---------|---------|---------|---------|---------|---------|
| IOCCN7 <sup>(1)</sup> | IOCCN6 <sup>(1)</sup> | IOCCN5  | IOCCN4  | IOCCN3  | IOCCN2  | IOCCN1  | IOCCN0  |
| 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-0

bit 7-0

**IOCCN<7:0>**: Interrupt-on-Change PORTC Negative Edge Enable bits(1)

- 1 = Interrupt-on-Change enabled on the pin for a negative going edge. IOCCFx bit and IOCIF flag will be set upon detecting an edge.
- 0 = Interrupt-on-Change disabled for the associated pin.

Note 1: IOCCN<7:6> available on PIC16(L)F1619 only.

## REGISTER 14-9: IOCCF: INTERRUPT-ON-CHANGE PORTC FLAG REGISTER<sup>(1)</sup>

| R/W/HS-0/0           | R/W/HS-0/0            | R/W/HS-0/0 | R/W/HS-0/0 | R/W/HS-0/0 | R/W/HS-0/0 | R/W/HS-0/0 | R/W/HS-0/0 |
|----------------------|-----------------------|------------|------------|------------|------------|------------|------------|
| IOCCF <sup>(1)</sup> | IOCCF6 <sup>(1)</sup> | IOCCF5     | IOCCF4     | IOCCF3     | IOCCF2     | IOCCF1     | IOCCF0     |
| 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 | HS - Bit is set in hardware                           |

bit 7-0

**IOCCF<7:0>**: Interrupt-on-Change PORTC Flag bits(1)

1 = An enabled change was detected on the associated pin.

- Set when IOCCPx = 1 and a rising edge was detected on RCx, or when IOCCNx = 1 and a falling edge was detected on RCx.
- 0 = No change was detected, or the user cleared the detected change.

Note 1: IOCCF<7:6> available on PIC16(L)F1619 only.

## 22.1 Timer1 Operation

The Timer1 module is a 16-bit incrementing counter which is accessed through the TMR1H:TMR1L register pair. Writes to TMR1H or TMR1L directly update the counter.

When used with an internal clock source, the module is a timer and increments on every instruction cycle. When used with an external clock source, the module can be used as either a timer or counter and increments on every selected edge of the external source.

Timer1 is enabled by configuring the TMR1ON and TMR1GE bits in the T1CON and T1GCON registers, respectively. Table 22-1 displays the Timer1 enable selections.

TABLE 22-1: TIMER1 ENABLE SELECTIONS

| TMR10N | TMR1GE | Timer1<br>Operation |
|--------|--------|---------------------|
| 0      | 0      | Off                 |
| 0      | 1      | Off                 |
| 1      | 0      | Always On           |
| 1      | 1      | Count Enabled       |

## 22.2 Clock Source Selection

The TMR1CS<1:0> bits of the T1CON register are used to select the clock source for Timer1. Table 22-2 displays the clock source selections.

#### 22.2.1 INTERNAL CLOCK SOURCE

When the internal clock source is selected, the TMR1H:TMR1L register pair will increment on multiples of Fosc as determined by the Timer1 prescaler.

When the Fosc internal clock source is selected, the Timer1 register value will increment by four counts every instruction clock cycle. Due to this condition, a 2 LSB error in resolution will occur when reading the Timer1 value. To utilize the full resolution of Timer1, an asynchronous input signal must be used to gate the Timer1 clock input.

The following asynchronous sources may be used:

- Asynchronous event on the T1G pin to Timer1 gate
- C1 or C2 comparator input to Timer1 gate

#### 22.2.2 EXTERNAL CLOCK SOURCE

When the external clock source is selected, the Timer1 module may work as a timer or a counter.

When enabled to count, Timer1 is incremented on the rising edge of the external clock input T1CKI. The external clock source can be synchronized to the microcontroller system clock or it can run asynchronously.

Note: In Counter mode, a falling edge must be registered by the counter prior to the first incrementing rising edge after any one or more of the following conditions:
 •Timer1 enabled after POR

- •Write to TMR1H or TMR1L
- Timer1 is disabled
- •Timer1 is disabled (TMR1ON = 0) when T1CKI is high then Timer1 is enabled (TMR1ON=1) when T1CKI is low.

## TABLE 22-2: CLOCK SOURCE SELECTIONS

| TMR1CS<1:0> | Clock Source                   |
|-------------|--------------------------------|
| 11          | LFINTOSC                       |
| 10          | External Clocking on T1CKI Pin |
| 01          | System Clock (Fosc)            |
| 00          | Instruction Clock (Fosc/4)     |

| FIGURE 22-6:           | TIMER1 GATE SINGL                                          | E-PULSE AND TOGGLE COMBINED MODE                                         |
|------------------------|------------------------------------------------------------|--------------------------------------------------------------------------|
| TMR1GE                 |                                                            |                                                                          |
| T1GPOL                 |                                                            |                                                                          |
| T1GSPM                 |                                                            |                                                                          |
| T1GTM                  |                                                            |                                                                          |
| T1GG <u>O/</u><br>DONE | ← Set by software<br>Counting enabled<br>rising edge of T1 | on<br>G                                                                  |
| тіскі                  |                                                            |                                                                          |
| T1GV <u>AL</u>         |                                                            |                                                                          |
| Timer1                 | Ν                                                          | $\underbrace{N+1} \underbrace{N+2} \underbrace{N+3} \underbrace{N+4}$    |
| TMR1GIF                | <ul> <li>Cleared by software</li> </ul>                    | Set by hardware on Cleared by falling edge of T1GVAL Cleared by software |

#### 23.5.10 LEVEL-TRIGGERED HARDWARE LIMIT ONE-SHOT MODES

The Level-Triggered Hardware Limit One-Shot modes hold the timer in Reset on an external Reset level and start counting when both the ON bit is set and the external signal is not at the Reset level. If one of either the external signal is not in Reset or the ON bit is set then the other signal being set/made active will start the timer. Reset levels are selected as follows:

- Low Reset level (MODE<4:0> = 10110)
- High Reset level (MODE<4:0> = 10111)

When the timer count matches the PRx period count, the timer is reset and the ON bit is cleared. When the ON bit is cleared by either a PRx match or by software control the timer will stay in Reset until both the ON bit is set and the external signal is not at the Reset level.

When Level-Triggered Hardware Limit One-Shot modes are used in conjunction with the CCP PWM operation the PWM drive goes active with either the external signal edge or the setting of the ON bit, which-ever of the two starts the timer.

#### 24.4.5 START CONDITION

The  $I^2C$  specification defines a Start condition as a transition of SDA from a high to a low state while SCL line is high. A Start condition is always generated by the master and signifies the transition of the bus from an Idle to an Active state. Figure 24-12 shows wave forms for Start and Stop conditions.

A bus collision can occur on a Start condition if the module samples the SDA line low before asserting it low. This does not conform to the  $I^2C$  Specification that states no bus collision can occur on a Start.

## 24.4.6 STOP CONDITION

A Stop condition is a transition of the SDA line from low-to-high state while the SCL line is high.

Note: At least one SCL low time must appear before a Stop is valid, therefore, if the SDA line goes low then high again while the SCL line stays high, only the Start condition is detected.

## 24.4.7 RESTART CONDITION

A Restart is valid any time that a Stop would be valid. A master can issue a Restart if it wishes to hold the bus after terminating the current transfer. A Restart has the same effect on the slave that a Start would, resetting all slave logic and preparing it to clock in an address. The master may want to address the same or another slave. Figure 24-13 shows the wave form for a Restart condition.

In 10-bit Addressing Slave mode a Restart is required for the master to clock data out of the addressed slave. Once a slave has been fully addressed, matching both high and low address bytes, the master can issue a Restart and the high address byte with the R/W bit set. The slave logic will then hold the clock and prepare to clock out data.

After a full match with  $R/\overline{W}$  clear in 10-bit mode, a prior match flag is set and maintained until a Stop condition, a high address with  $R/\overline{W}$  clear, or high address match fails.

#### 24.4.8 START/STOP CONDITION INTERRUPT MASKING

The SCIE and PCIE bits of the SSPxCON3 register can enable the generation of an interrupt in Slave modes that do not typically support this function. Slave modes where interrupt on Start and Stop detect are already enabled, these bits will have no effect.







#### 25.1.1.5 TSR Status

The TRMT bit of the TXxSTA register indicates the status of the TSR register. This is a read-only bit. The TRMT bit is set when the TSR register is empty and is cleared when a character is transferred to the TSR register from the TXxREG. The TRMT bit remains clear until all bits have been shifted out of the TSR register. No interrupt logic is tied to this bit, so the user has to poll this bit to determine the TSR status.

| Note: | The TSR register is not mapped in data      |
|-------|---------------------------------------------|
|       | memory, so it is not available to the user. |

#### 25.1.1.6 Transmitting 9-Bit Characters

The EUSART supports 9-bit character transmissions. When the TX9 bit of the TXxSTA register is set, the EUSART will shift nine bits out for each character transmitted. The TX9D bit of the TXxSTA register is the ninth, and Most Significant data bit. When transmitting 9-bit data, the TX9D data bit must be written before writing the eight Least Significant bits into the TXxREG. All nine bits of data will be transferred to the TSR shift register immediately after the TXxREG is written.

A special 9-bit Address mode is available for use with multiple receivers. See **Section 25.1.2.7** "Address **Detection**" for more information on the Address mode.

#### 25.1.1.7 Asynchronous Transmission Set-up:

- Initialize the SPxBRGH, SPxBRGL register pair and the BRGH and BRG16 bits to achieve the desired baud rate (see Section 25.4 "EUSART Baud Rate Generator (BRG)").
- 2. Enable the asynchronous serial port by clearing the SYNC bit and setting the SPEN bit.
- 3. If 9-bit transmission is desired, set the TX9 control bit. A set ninth data bit will indicate that the eight Least Significant data bits are an address when the receiver is set for address detection.
- 4. Set SCKP bit if inverted transmit is desired.
- 5. Enable the transmission by setting the TXEN control bit. This will cause the TXIF interrupt bit to be set.
- If interrupts are desired, set the TXIE interrupt enable bit of the PIE1 register. An interrupt will occur immediately provided that the GIE and PEIE bits of the INTCON register are also set.
- 7. If 9-bit transmission is selected, the ninth bit should be loaded into the TX9D data bit.
- 8. Load 8-bit data into the TXxREG register. This will start the transmission.



## FIGURE 25-4: ASYNCHRONOUS TRANSMISSION (BACK-TO-BACK)



## 27.1 **PWMx Pin Configuration**

All PWM outputs are multiplexed with the PORT data latch. The user must configure the pins as outputs by clearing the associated TRIS bits.

#### 27.1.1 FUNDAMENTAL OPERATION

The PWM module produces a 10-bit resolution output. Timer2 and PR2 set the period of the PWM. The PWMxDCL and PWMxDCH registers configure the duty cycle. The period is common to all PWM modules, whereas the duty cycle is independently controlled.

| Note: | The Timer2 postscaler is not used in the  |
|-------|-------------------------------------------|
|       | determination of the PWM frequency. The   |
|       | postscaler could be used to have a servo  |
|       | update rate at a different frequency than |
|       | the PWM output.                           |

All PWM outputs associated with Timer2 are set when TMR2 is cleared. Each PWMx is cleared when TMR2 is equal to the value specified in the corresponding PWMxDCH (8 MSb) and PWMxDCL<7:6> (2 LSb) registers. When the value is greater than or equal to PR2, the PWM output is never cleared (100% duty cycle).

| Note: | The PWMxDCH and PWMxDCL registers        |
|-------|------------------------------------------|
|       | are double buffered. The buffers are     |
|       | updated when Timer2 matches PR2. Care    |
|       | should be taken to update both registers |
|       | before the timer match occurs.           |

#### 27.1.2 PWM OUTPUT POLARITY

The output polarity is inverted by setting the PWMxPOL bit of the PWMxCON register.

#### 27.1.3 PWM PERIOD

The PWM period is specified by the PR2 register of Timer2. The PWM period can be calculated using the formula of Equation 27-1.

## EQUATION 27-1: PWM PERIOD

 $PWM Period = [(PR2) + 1] \bullet 4 \bullet Tosc \bullet$ (TMR2 Prescale Value)

Note: Tosc = 1/Fosc

When TMR2 is equal to PR2, the following three events occur on the next increment cycle:

- TMR2 is cleared
- The PWM output is active. (Exception: When the PWM duty cycle = 0%, the PWM output will remain inactive.)
- The PWMxDCH and PWMxDCL register values are latched into the buffers.

| Note: | The Timer2 postscaler has no effect on |
|-------|----------------------------------------|
|       | the PWM operation.                     |

## 27.1.4 PWM DUTY CYCLE

The PWM duty cycle is specified by writing a 10-bit value to the PWMxDCH and PWMxDCL register pair. The PWMxDCH register contains the eight MSbs and the PWMxDCL<7:6>, the two LSbs. The PWMxDCH and PWMxDCL registers can be written to at any time.

Equation 27-2 is used to calculate the PWM pulse width.

Equation 27-3 is used to calculate the PWM duty cycle ratio.

## EQUATION 27-2: PULSE WIDTH

 $Pulse Width = (PWMxDCH:PWMxDCL<7:6>) \bullet$ 

TOSC • (TMR2 Prescale Value)

Note: Tosc = 1/Fosc

# EQUATION 27-3: DUTY CYCLE RATIO

$$Duty Cycle Ratio = \frac{(PWMxDCH:PWMxDCL<7:6>)}{4(PR2+1)}$$

The 8-bit timer TMR2 register is concatenated with the two Least Significant bits of 1/Fosc, adjusted by the Timer2 prescaler to create the 10-bit time base. The system clock is used if the Timer2 prescaler is set to 1:1.

Figure 27-2 shows a waveform of the PWM signal when the duty cycle is set for the smallest possible pulse.

## FIGURE 27-2: PWM OUTPUT



| R/W-x/u          | R/W-x/u                                                                                 | R/W-x/u            | R/W-x/u              | R/W-x/u        | R/W-x/u          | R/W-x/u          | R/W-x/u     |
|------------------|-----------------------------------------------------------------------------------------|--------------------|----------------------|----------------|------------------|------------------|-------------|
| LCxG2D4T         | LCxG2D4N                                                                                | LCxG2D3T           | LCxG2D3N             | LCxG2D2T       | LCxG2D2N         | LCxG2D1T         | LCxG2D1N    |
| bit 7            | bit 7                                                                                   |                    |                      |                |                  |                  | bit 0       |
|                  |                                                                                         |                    |                      |                |                  |                  |             |
| Legend:          |                                                                                         |                    |                      |                |                  |                  |             |
| R = Readable     | bit                                                                                     | W = Writable       | bit                  | U = Unimpler   | mented bit, read | as '0'           |             |
| u = Bit is uncha | anged                                                                                   | x = Bit is unknown |                      | -n/n = Value a | at POR and BO    | R/Value at all o | ther Resets |
| '1' = Bit is set |                                                                                         | '0' = Bit is clea  | ared                 |                |                  |                  |             |
|                  |                                                                                         |                    |                      |                |                  |                  |             |
| bit 7            | LCxG2D4T: O                                                                             | Gate 2 Data 4 1    | rue (non-inve        | rted) bit      |                  |                  |             |
|                  | 1 = lcxd4T is                                                                           | gated into lcxg    | j2                   |                |                  |                  |             |
| bit 6            | 0 = 100041 is                                                                           | Tot galed Into     | ICXYZ                | rtad) bit      |                  |                  |             |
| DILO             | $1 = \log d4N$ is                                                                       | dated into Icv     | negaleu (invei<br>12 | neu) bli       |                  |                  |             |
|                  | 0 = lcxd4N is                                                                           | not gated into     | lcxg2                |                |                  |                  |             |
| bit 5            | LCxG2D3T: 0                                                                             | Gate 2 Data 3 1    | rue (non-inve        | rted) bit      |                  |                  |             |
|                  | 1 = Icxd3T is                                                                           | gated into lcxg    | j2                   |                |                  |                  |             |
|                  | 0 = Icxd3T is                                                                           | not gated into     | lcxg2                |                |                  |                  |             |
| bit 4            | 4 LCxG2D3N: Gate 2 Data 3 Negated (inverted) bit                                        |                    |                      |                |                  |                  |             |
|                  | 1 = lcxd3N is                                                                           | gated into loxe    | g2<br>Java2          |                |                  |                  |             |
| hit 2            | 0 = 1cxd3N is not gated into $1cxg2$                                                    |                    |                      |                |                  |                  |             |
| DIL 3            | LCXG2D21: Gate 2 Data 2 True (non-inve                                                  |                    |                      | neu) bii       |                  |                  |             |
|                  | $\perp =  cxu_2 $ is gated into $ cxg_2 $<br>0 = $ cxd_2T $ is not gated into $ cxg_2 $ |                    |                      |                |                  |                  |             |
| bit 2            | LCxG2D2N:                                                                               | Gate 2 Data 2      | Negated (inve        | rted) bit      |                  |                  |             |
|                  | 1 = lcxd2N is gated into lcxg2                                                          |                    |                      |                |                  |                  |             |
|                  | 0 = Icxd2N is not gated into Icxg2                                                      |                    |                      |                |                  |                  |             |
| bit 1            | LCxG2D1T: Gate 2 Data 1 True (non-inverted) bit                                         |                    |                      |                |                  |                  |             |
|                  | 1 = Icxd1T is gated into Icxg2                                                          |                    |                      |                |                  |                  |             |
| <b>h</b> it 0    | 0 = 1000 I is not gated into $1000$                                                     |                    |                      |                |                  |                  |             |
|                  | It U LUXG2D1N: Gate 2 Data 1 Negated (Inverted) bit                                     |                    |                      |                |                  |                  |             |
|                  | 0 = lcxd1N is not gated into lcxg2                                                      |                    |                      |                |                  |                  |             |
|                  |                                                                                         | 0                  | 5                    |                |                  |                  |             |
|                  |                                                                                         |                    |                      |                |                  |                  |             |

## REGISTER 29-8: CLCxGLS1: GATE 2 LOGIC SELECT REGISTER



# FIGURE 30-12: GATED WINDOWED MEASURE MODE REPEAT ACQUISITION TIMING DIAGRAM

PIC16(L)F1615/9



PIC16(L)F1615/9

## REGISTER 32-14: PIDxOUTHL: PID OUTPUT HIGH LOW REGISTER

| R/W-0/0          | R/W-0/0 | R/W-0/0              | R/W-0/0 | R/W-0/0                        | R/W-0/0          | R/W-0/0          | R/W-0/0     |
|------------------|---------|----------------------|---------|--------------------------------|------------------|------------------|-------------|
|                  |         |                      | OUT<    | 23:16>                         |                  |                  |             |
| bit 7            |         |                      |         |                                |                  |                  | bit 0       |
|                  |         |                      |         |                                |                  |                  |             |
| Legend:          |         |                      |         |                                |                  |                  |             |
| R = Readable     | bit     | W = Writable         | bit     | U = Unimpler                   | nented bit, read | as '0'           |             |
| u = Bit is uncha | anged   | x = Bit is unkn      | nown    | -n/n = Value a                 | at POR and BO    | R/Value at all c | ther Resets |
| '1' = Bit is set |         | '0' = Bit is cleared |         | q = Value depends on condition |                  |                  |             |

bit 7-0 **OUT<23:16>** of OUT. OUT is the output value of the PID after completing the designated calculation on the specified inputs.

## REGISTER 32-15: PIDxOUTLH: PID OUTPUT LOW HIGH REGISTER

| R/W-0/0     | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 |
|-------------|---------|---------|---------|---------|---------|---------|---------|
|             |         |         | OUT<    | :15:8>  |         |         |         |
| 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 condition                        |

bit 7-0 **OUT<15:8>:** Bits <15:8> of OUT. OUT is the output value of the PID after completing the designated calculation on the specified inputs.

#### REGISTER 32-16: PIDxOUTLL: PID OUTPUT LOW LOW REGISTER

| R/W-0/0  | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 |
|----------|---------|---------|---------|---------|---------|---------|---------|
| OUT<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 | q = Value depends on condition                        |

bit 7-0 **OUT<7:0>:** Bits <7:0> of OUT. OUT is the output value of the PID after completing the designated calculation on the specified inputs.

Γ.

## REGISTER 32-23: PIDxACCU: PID ACCUMULATOR UPPER REGISTER

| U-0   | U-0 | U-0 | U-0 | U-0 | R/W-0/0 | R/W-0/0    | R/W-0/0 |
|-------|-----|-----|-----|-----|---------|------------|---------|
| —     | _   |     | _   |     |         | ACC<34:32> |         |
| 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 condition                        |

bit 7-3 Unimplemented: Read as '0'

bit 2-0 ACC<34:32>: Bits <34:32> of ACC. ACC is the accumulator register in which all of the multiplier results for the PID are accumulated before being written to the output.

#### REGISTER 32-24: PIDxACCHH: PID ACCUMULATOR HIGH HIGH REGISTER

| R/W-0/0 |
|---------|---------|---------|---------|---------|---------|---------|---------|
|         |         |         | ACC<    | 31:24>  |         |         |         |
| 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 condition                        |

bit 7-0 **ACC<31:24>:** Bits <31:24> of ACC. ACC is the accumulator register in which all of the multiplier results for the PID are accumulated before being written to the output.

## REGISTER 32-25: PIDxACCHL: PID ACCUMULATOR HIGH LOW REGISTER

| R/W-0/0     | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 |
|-------------|---------|---------|---------|---------|---------|---------|---------|
| ACC<23:16>  |         |         |         |         |         |         |         |
| 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 condition                        |

bit 7-0 ACC<23:16>: Bits <23:16> of ACC. ACC is the accumulator register in which all of the multiplier results for the PID are accumulated before being written to the output.

# 35.2 Standard Operating Conditions

The standard operating conditions for any device are defined as:  $V \text{DDMIN} \leq V \text{DD} \leq V \text{DDMAX}$ **Operating Voltage:** Operating Temperature: TA MIN  $\leq$  TA  $\leq$  TA MAX VDD — Operating Supply Voltage<sup>(1)</sup> PIC16LF1615/9 PIC16F1615/9 TA — Operating Ambient Temperature Range Industrial Temperature TA MIN.....--40°C **Extended Temperature** Ta MIN.....--40°C 

Note 1: See Parameter D001, DS Characteristics: Supply Voltage.

## 35.4 AC Characteristics

Timing Parameter Symbology has been created with one of the following formats:

1. TppS2ppS

2. TppS

| Т      |                                       |     |                |
|--------|---------------------------------------|-----|----------------|
| F      | Frequency                             | Т   | Time           |
| Lowerc | case letters (pp) and their meanings: |     |                |
| рр     |                                       |     |                |
| СС     | CCP1                                  | OSC | CLKIN          |
| ck     | CLKOUT                                | rd  | RD             |
| CS     | CS                                    | rw  | RD or WR       |
| di     | SDIx                                  | SC  | SCKx           |
| do     | SDO                                   | SS  | SS             |
| dt     | Data in                               | t0  | TOCKI          |
| io     | I/O PORT                              | t1  | T1CKI          |
| mc     | MCLR                                  | wr  | WR             |
| Upperc | case letters and their meanings:      |     |                |
| S      |                                       |     |                |
| F      | Fall                                  | Р   | Period         |
| Н      | High                                  | R   | Rise           |
| I      | Invalid (High-impedance)              | V   | Valid          |
| L      | Low                                   | Z   | High-impedance |

## FIGURE 35-4: LOAD CONDITIONS



Note the following details of the code protection feature on Microchip devices:

- Microchip products meet the specification contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property.
- Microchip is willing to work with the customer who is concerned about the integrity of their code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as "unbreakable."

Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

Information contained in this publication regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights unless otherwise stated.

Microchip received ISO/TS-16949:2009 certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona; Gresham, Oregon and design centers in California and India. The Company's quality system processes and procedures are for its PIC<sup>®</sup> MCUs and dsPIC<sup>®</sup> DSCs, KEELOQ<sup>®</sup> code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001:2000 certified.

# QUALITY MANAGEMENT SYSTEM CERTIFIED BY DNV = ISO/TS 16949=

#### Trademarks

The Microchip name and logo, the Microchip logo, AnyRate, dsPIC, FlashFlex, flexPWR, Heldo, JukeBlox, KeeLoq, Kee-Loq logo, Kleer, LANCheck, LINK MD, MediaLB, MOST, MOST logo, MPLAB, OptoLyzer, PIC, PICSTART, PIC32 logo, RightTouch, SpyNIC, SST, SST Logo, SuperFlash and UNI/O are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

ClockWorks, The Embedded Control Solutions Company, ETHERSYNCH, Hyper Speed Control, HyperLight Load, Intel-IiMOS, mTouch, Precision Edge, and QUIET-WIRE are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Analog-for-the-Digital Age, Any Capacitor, AnyIn, AnyOut, BodyCom, chipKIT, chipKIT logo, CodeGuard, dsPICDEM, dsPICDEM.net, Dynamic Average Matching, DAM, ECAN, EtherGREEN, In-Circuit Serial Programming, ICSP, Inter-Chip Connectivity, JitterBlocker, KleerNet, KleerNet logo, MiWi, motorBench, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, MultiTRAK, NetDetach, Omniscient Code Generation, PICDEM, PICDEM.net, PICkit, PICtail, PureSilicon, RightTouch logo, REAL ICE, Ripple Blocker, Serial Quad I/O, SQI, SuperSwitcher, SuperSwitcher II, Total Endurance, TSHARC, USBCheck, VariSense, ViewSpan, WiperLock, Wireless DNA, and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

Silicon Storage Technology is a registered trademark of Microchip Technology Inc. in other countries.

GestIC is a registered trademarks of Microchip Technology Germany II GmbH & Co. KG, a subsidiary of Microchip Technology Inc., in other countries.

All other trademarks mentioned herein are property of their respective companies.

 $\textcircled{\mbox{\sc c}}$  2014-2016, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.

ISBN: 978-1-5224-0556-6