

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

E·XFI

| 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              | 12                                                                          |
| Program Memory Size        | 28KB (16K x 14)                                                             |
| Program Memory Type        | FLASH                                                                       |
| EEPROM Size                | 256 x 8                                                                     |
| RAM Size                   | 2K x 8                                                                      |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                                                 |
| Data Converters            | A/D 11x10b; D/A 1x5b                                                        |
| Oscillator Type            | Internal                                                                    |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                           |
| Mounting Type              | Surface Mount                                                               |
| Package / Case             | 14-SOIC (0.154", 3.90mm Width)                                              |
| Supplier Device Package    | 14-SOIC                                                                     |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lf18326-i-sl |
|                            |                                                                             |

Email: info@E-XFL.COM

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

# PIC16(L)F18326/18346





4: For minimum width of INT pulse, refer to AC specifications in Section 35.0 "Electrical Specifications"".

**5:** INTF is enabled to be set any time during the Q4-Q1 cycles.

|                  |                                                                                                                           |                                                           |                 |              | REGISTER 4       |                  |             |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|-----------------|--------------|------------------|------------------|-------------|--|
| 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     |  |
| CWG2IE           | CWG1IE                                                                                                                    | TMR5GIE                                                   | TMR5IE          | CCP4IE       | CCP3IE           | CCP2IE           | CCP1IE      |  |
| bit 7            |                                                                                                                           |                                                           | L.              | 1            |                  |                  | bit (       |  |
|                  |                                                                                                                           |                                                           |                 |              |                  |                  |             |  |
| Legend:          |                                                                                                                           |                                                           |                 |              |                  |                  |             |  |
| R = Readable     | bit                                                                                                                       | W = Writable                                              | bit             | U = Unimplei | mented bit, read | l as '0'         |             |  |
| u = Bit is unch  | anged                                                                                                                     | x = Bit is unknown                                        |                 | -n/n = Value | at POR and BO    | R/Value at all c | ther Resets |  |
| '1' = Bit is set |                                                                                                                           | '0' = Bit is clea                                         | ared            | HS = Hardwa  | are set          |                  |             |  |
| bit 7            | 1 = CWG2 int                                                                                                              | /G 2 Interrupt E<br>terrupt enabled<br>terrupt not enal   |                 |              |                  |                  |             |  |
| bit 6            | CWG1IE: CWG 1 Interrupt Enable bit<br>1 = CWG1 interrupt enabled<br>0 = CWG1 interrupt not enabled                        |                                                           |                 |              |                  |                  |             |  |
| bit 5            | TMR5GIE: Timer5 Gate Interrupt Enable bit<br>1 = TMR5 Gate interrupt is enabled<br>0 = TMR5 Gate interrupt is not enabled |                                                           |                 |              |                  |                  |             |  |
| bit 4            | 1 = TMR5 ove                                                                                                              | R5 Overflow Int<br>erflow interrupt<br>erflow interrupt   | is enabled      |              |                  |                  |             |  |
| bit 3            | 1 = CCP4 inte                                                                                                             | P4 Interrupt Ena<br>errupt is enable<br>errupt is not ena | d               |              |                  |                  |             |  |
| bit 2            | 1 = CCP3 inte                                                                                                             | P3 Interrupt En<br>errupt is enable<br>errupt is not en   | d               |              |                  |                  |             |  |
| bit 1            | 1 = CCP2 in                                                                                                               | P2 Interrupt En<br>Iterrupt is enab<br>Iterrupt is not e  | led             |              |                  |                  |             |  |
| bit 0            | CCP1IE: CCF                                                                                                               | P1 Interrupt En<br>Interrupt is enab                      | able bit<br>led |              |                  |                  |             |  |

#### **REGISTER 8-6: PIE4: PERIPHERAL INTERRUPT ENABLE REGISTER 4**

# 11.0 NONVOLATILE MEMORY (NVM) CONTROL

NVM is separated into two types: Program Flash Memory and Data EEPROM.

NVM is accessible by using both the FSR and INDF registers, or through the NVMREG register interface.

The write time is controlled by an on-chip timer. The write/erase voltages are generated by an on-chip charge pump rated to operate over the operating voltage range of the device.

NVM can be protected in two ways; by either code protection or write protection.

Code protection (CP and CPD bits in Configuration Word 4) disables access, reading and writing, to both the Program Flash Memory and EEPROM via external device programmers. Code protection does not affect the self-write and erase functionality. Code protection can only be Reset by a device programmer performing a Bulk Erase to the device, clearing all nonvolatile memory, Configuration bits, and User IDs.

Write protection prohibits self-write and erase to a portion or all of the Program Flash Memory, as defined by the WRT<1:0> bits of Configuration Word 3. Write protection does not affect a device programmer's ability to read, write, or erase the device.

## 11.1 Program Flash Memory

Program Flash Memory consists of 16,384 14-bit words as user memory, with additional words for User ID information, Configuration Words, and interrupt vectors. Program Flash Memory provides storage locations for:

- User program instructions
- User defined data

Program Flash Memory data can be read and/or written to through:

- CPU instruction fetch (read-only)
- FSR/INDF indirect access (read-only) (Section 11.3 "FSR and INDF Access")
- NVMREG access (Section 11.4 "NVMREG Access"
- In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>)

Read operations return a single word of memory. When write and erase operations are done on a row basis, the row size is defined in Table 11-1. Program Flash Memory will erase to a logic '1' and program to a logic '0'.

#### TABLE 11-1: FLASH MEMORY ORGANIZATION BY DEVICE

| Device         | Row Erase<br>(words) | Write<br>Latches<br>(words) |  |
|----------------|----------------------|-----------------------------|--|
| PIC16(L)F18326 | 32                   | 32                          |  |
| PIC16(L)F18346 | 52                   | 52                          |  |

It is important to understand the Program Flash Memory structure for erase and programming operations. Program Flash Memory is arranged in rows. A row consists of 32 14-bit program memory words. A row is the minimum size that can be erased by user software.

All or a portion of a row can be programmed. Data to be written into the program memory row is written to 14-bit wide data write latches. These latches are not directly accessible to the user, but may be loaded via sequential writes to the NVMDATH:NVMDATL register pair.

| Note: | To modify only a partian of a provinyaly     |
|-------|----------------------------------------------|
| Note: | To modify only a portion of a previously     |
|       | programmed row, then the contents of the     |
|       | entire row must be read and saved in         |
|       | RAM prior to the erase. Then, the new        |
|       | data and retained data can be written into   |
|       | the write latches to reprogram the row of    |
|       | Program Flash Memory. Any                    |
|       | unprogrammed locations can be written        |
|       | without first erasing the row. In this case, |
|       | it is not necessary to save and rewrite the  |
|       | other previously programmed locations        |

#### 11.1.1 PROGRAM MEMORY VOLTAGES

The Program Flash Memory is readable and writable during normal operation over the full VDD range.

#### 11.1.1.1 Programming Externally

The program memory cell and control logic support write and Bulk Erase operations down to the minimum device operating voltage.

#### 11.1.1.2 Self-Programming

The program memory cell and control logic will support write and row erase operations across the entire VDD range. Bulk Erase is not supported when self-programming.

| Name    | Bit 7   | Bit 6   | Bit 5   | Bit 4   | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Register<br>on Page |  |
|---------|---------|---------|---------|---------|-------|-------|-------|-------|---------------------|--|
| PORTB   | RB7     | RB6     | RB5     | RB4     |       | _     | _     |       | 149                 |  |
| TRISB   | TRISB7  | TRISB6  | TRISB5  | TRISB4  | _     |       |       | _     | 149                 |  |
| LATB    | LATB7   | LATB6   | LATB5   | LATB4   | —     | _     | _     | —     | 150                 |  |
| ANSELB  | ANSB7   | ANSB6   | ANSB5   | ANSB4   | —     | _     | _     | —     | 150                 |  |
| WPUB    | WPUB7   | WPU6    | WPUB5   | WPUB4   | _     |       |       | _     | 151                 |  |
| ODCONB  | ODCB7   | ODCB6   | ODCB5   | ODCB4   | —     | _     | _     | _     | 151                 |  |
| SLRCONB | SLRB7   | SLRB6   | SLRB5   | SLRB4   | _     |       | _     | _     | 152                 |  |
| INLVLB  | INLVLB7 | INLVLB6 | INLVLB5 | INLVLB4 | _     |       | _     | _     | 152                 |  |

#### TABLE 12-4: SUMMARY OF REGISTERS ASSOCIATED WITH PORTB

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

| 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 |  |  |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|---------|--------------|-------------------------------------------------------|---------|---------|--|--|
| ODCC7 <sup>(1)</sup> | ODCC6 <sup>(1)</sup>                                                                                                                                                                                                                                           | ODCC5             | ODCC4   | ODCC3        | ODCC2                                                 | ODCC1   | ODCC0   |  |  |
| bit 7                |                                                                                                                                                                                                                                                                |                   |         |              |                                                       |         |         |  |  |
|                      |                                                                                                                                                                                                                                                                |                   |         |              |                                                       |         |         |  |  |
| Legend:              |                                                                                                                                                                                                                                                                |                   |         |              |                                                       |         |         |  |  |
| R = Readable b       | bit                                                                                                                                                                                                                                                            | W = Writable I    | oit     | U = Unimpler | nented bit, read                                      | as '0'  |         |  |  |
| u = Bit is uncha     | 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 clea | ared    |              |                                                       |         |         |  |  |
| bit 7-6<br>bit 5-0   | bit 7-6 <b>ODCC&lt;7:6&gt;</b> : PORTC Open-Drain Enable bits <sup>(1)</sup><br>For RC<7:6> pins, respectively<br>1 = Port pin operates as open-drain drive (sink current only)<br>0 = Port pin operates as standard push-pull drive (source and sink current) |                   |         |              |                                                       |         |         |  |  |

#### REGISTER 12-22: ODCONC: PORTC OPEN-DRAIN CONTROL REGISTER

Note 1: PIC16(L)F18346 only; otherwise read as '0'.

### REGISTER 12-23: SLRCONC: PORTC SLEW RATE CONTROL REGISTER

| R/W-1/1              | R/W-1/1              | R/W-1/1 | R/W-1/1 | R/W-1/1 | R/W-1/1 | R/W-1/1 | R/W-1/1 |
|----------------------|----------------------|---------|---------|---------|---------|---------|---------|
| SLRC7 <sup>(1)</sup> | SLRC6 <sup>(1)</sup> | SLRC5   | SLRC4   | SLRC3   | SLRC2   | SLRC1   | SLRC0   |
| 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-6 | <b>SLRC&lt;7:6&gt;:</b> PORTC Slew Rate Enable bits <sup>(1)</sup><br>For RC<7:6> pins, respectively<br>1 = Port pin slew rate is limited<br>0 = Port pin slews at maximum rate |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 5-0 | SLRC<5:0>: PORTC Slew Rate Enable bits<br>For RC<5:0> pins, respectively<br>1 = Port pin slew rate is limited<br>0 = Port pin slews at maximum rate                             |

Note 1: PIC16(L)F18346 only; otherwise read as '0'.

# 20.11 Register Definitions: CWG Control

| R/W/HC-0/0<br>LD <sup>(1)</sup><br>it<br>nged<br>EN: CWGx E                    | U-0<br>—<br>W = Writable I<br>x = Bit is unkn<br>'0' = Bit is clea                                        | iown                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | R/W-0/0<br>MODE<2:0><br>d as '0'<br>DR/Value at all o                                                                                                                                                                                                                                                                                                                                                                                                           | R/W-0/0<br>bit 0                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| it<br>nged<br><b>EN:</b> CWGx E                                                | x = Bit is unkn<br>'0' = Bit is clea                                                                      | iown                                                                                                                                                                                                                                     | -n/n = Value a                                                                                                                                                                                                                                                                                                         | at POR and BC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | d as '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| nged                                                                           | x = Bit is unkn<br>'0' = Bit is clea                                                                      | iown                                                                                                                                                                                                                                     | -n/n = Value a                                                                                                                                                                                                                                                                                                         | at POR and BC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| nged                                                                           | x = Bit is unkn<br>'0' = Bit is clea                                                                      | iown                                                                                                                                                                                                                                     | -n/n = Value a                                                                                                                                                                                                                                                                                                         | at POR and BC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ther Resets                                                                                                                                                                                                                                                                                                                                                                                                                            |
| nged                                                                           | x = Bit is unkn<br>'0' = Bit is clea                                                                      | iown                                                                                                                                                                                                                                     | -n/n = Value a                                                                                                                                                                                                                                                                                                         | at POR and BC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ther Resets                                                                                                                                                                                                                                                                                                                                                                                                                            |
| EN: CWGx E                                                                     | '0' = Bit is clea                                                                                         |                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | R/Value at all o                                                                                                                                                                                                                                                                                                                                                                                                                                                | ther Resets                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                                                |                                                                                                           | ared                                                                                                                                                                                                                                     | HS/HC = Bit                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                                | nable bit                                                                                                 |                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                        | is set/cleared b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | y hardware                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1 = CWGX is<br>0 = CWGX is                                                     | enabled                                                                                                   |                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1 = Dead-bai<br>this bit is                                                    |                                                                                                           | s to be loade                                                                                                                                                                                                                            | d on CWG dat                                                                                                                                                                                                                                                                                                           | a rising edge fo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ollowing first fall                                                                                                                                                                                                                                                                                                                                                                                                                                             | ing edge afte                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Unimplemen                                                                     | ted: Read as 'o                                                                                           | )'                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 111 = Reser<br>110 = Reser<br>101 = CWG<br>100 = CWG<br>011 = CWG<br>010 = CWG | ved<br>ved<br>outputs operate<br>outputs operate<br>outputs operate<br>outputs operate<br>outputs operate | e in Push-Pull<br>e in Half-Bridg<br>e in Reverse f<br>e in Forward f<br>e in Synchron                                                                                                                                                   | ge mode<br>Full-Bridge mod<br>Full-Bridge mod<br>lous Steering m                                                                                                                                                                                                                                                       | de<br>node                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                                | MODE<2:0>:<br>111 = Reser<br>100 = Reser<br>101 = CWG<br>100 = CWG<br>111 = CWG<br>100 = CWG<br>100 = CWG | MODE<2:0>: CWGx Mode b<br>111 = Reserved<br>100 = Reserved<br>101 = CWG outputs operate<br>100 = CWG outputs operate<br>111 = CWG outputs operate<br>100 = CWG outputs operate<br>100 = CWG outputs operate<br>100 = CWG outputs operate | MODE<2:0>: CWGx Mode bits<br>111 = Reserved<br>100 = Reserved<br>101 = CWG outputs operate in Push-Pul<br>100 = CWG outputs operate in Half-Bridg<br>111 = CWG outputs operate in Reverse<br>101 = CWG outputs operate in Forward I<br>101 = CWG outputs operate in Synchron<br>100 = CWG outputs operate in Asynchron | MODE<2:0>: CWGx Mode bits<br>111 = Reserved<br>100 = Reserved<br>101 = CWG outputs operate in Push-Pull mode<br>100 = CWG outputs operate in Half-Bridge mode<br>111 = CWG outputs operate in Reverse Full-Bridge mode<br>102 = CWG outputs operate in Forward Full-Bridge mode<br>103 = CWG outputs operate in Synchronous Steering mode<br>104 = CWG outputs operate in Asynchronous Steering mode<br>105 = CWG outputs operate in Asynchronous Steering mode<br>106 = CWG outputs operate in Asynchronous Steering mode<br>107 = CWG outputs operate in Asynchronous Steering mode<br>108 = CWG outputs operate in Asynchronous Steering mode<br>109 = CWG outputs operate in Asynchronous Steering mode<br>100 = CWG outputs operate in Asynchronous Steering | MODE<2:0>: CWGx Mode bits<br>111 = Reserved<br>100 = Reserved<br>101 = CWG outputs operate in Push-Pull mode<br>100 = CWG outputs operate in Half-Bridge mode<br>111 = CWG outputs operate in Reverse Full-Bridge mode<br>102 = CWG outputs operate in Forward Full-Bridge mode<br>103 = CWG outputs operate in Synchronous Steering mode<br>104 = CWG outputs operate in Asynchronous Steering mode<br>105 = CWG outputs operate in Asynchronous Steering mode | MODE<2:0>: CWGx Mode bits         11 = Reserved         10 = Reserved         01 = CWG outputs operate in Push-Pull mode         00 = CWG outputs operate in Half-Bridge mode         011 = CWG outputs operate in Reverse Full-Bridge mode         010 = CWG outputs operate in Reverse Full-Bridge mode         010 = CWG outputs operate in Forward Full-Bridge mode         010 = CWG outputs operate in Synchronous Steering mode |

### REGISTER 20-1: CWGxCON0: CWGx CONTROL REGISTER 0

**Note 1:** This bit can only be set after EN = 1; it cannot be set in the same cycle when EN is set.



Note 1: The increment registers are double-buffered to allow for value changes to be made without first disabling the NCO1 module. They are shown for reference only and are not user accessible.

PIC16(L)F18326/18346

|                                                                                | R/W-x/u                                                             | R/W-x/u                                                                                                                                                                         | U-0         | R/W-x/u         | R/W-x/u          | R/W-x/u              | R/W-x/u     |  |  |  |
|--------------------------------------------------------------------------------|---------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------|------------------|----------------------|-------------|--|--|--|
|                                                                                | MDCLPOL                                                             | MDCLSYNC                                                                                                                                                                        | _           |                 | MDCL             | <3:0> <sup>(1)</sup> |             |  |  |  |
| bit 7                                                                          |                                                                     | · · ·                                                                                                                                                                           |             |                 |                  |                      | bit         |  |  |  |
| Legend:                                                                        |                                                                     |                                                                                                                                                                                 |             |                 |                  |                      |             |  |  |  |
| R = Readable                                                                   | e bit                                                               | W = Writable bi                                                                                                                                                                 | t           | U = Unimpler    | nented bit, read | d as '0'             |             |  |  |  |
| u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at a |                                                                     |                                                                                                                                                                                 |             |                 |                  |                      | ther Resets |  |  |  |
| '1' = Bit is set                                                               |                                                                     | '0' = Bit is clear                                                                                                                                                              | ed          |                 |                  |                      |             |  |  |  |
| bit 7                                                                          | Unimplomo                                                           | nted: Read as '0'                                                                                                                                                               |             |                 |                  |                      |             |  |  |  |
| bit 6                                                                          | -                                                                   |                                                                                                                                                                                 | arrior Dola | rity Soloct bit |                  |                      |             |  |  |  |
| DILO                                                                           |                                                                     | Modulator Low Ca                                                                                                                                                                |             |                 |                  |                      |             |  |  |  |
|                                                                                |                                                                     | <ul> <li>1 = Selected low carrier signal is inverted</li> <li>0 = Selected low carrier signal is not inverted</li> </ul>                                                        |             |                 |                  |                      |             |  |  |  |
| bit 5                                                                          |                                                                     | •                                                                                                                                                                               |             |                 | able hit         |                      |             |  |  |  |
| bit 5                                                                          |                                                                     | <b>MDCLSYNC:</b> Modulator Low Carrier Synchronization Enable bit<br>1 = Modulator waits for a falling edge on the low time carrier signal before allowing a switch to the high |             |                 |                  |                      |             |  |  |  |
|                                                                                |                                                                     | time carrier                                                                                                                                                                    |             |                 |                  |                      |             |  |  |  |
|                                                                                |                                                                     | 0 = Modulator output is not synchronized to the low time carrier signal <sup>(1)</sup>                                                                                          |             |                 |                  |                      |             |  |  |  |
| bit 4                                                                          |                                                                     | nted: Read as '0'                                                                                                                                                               |             |                 | 0                |                      |             |  |  |  |
| bit 3-0                                                                        | MDCL<3:0> Modulator Data High Carrier Selection bits <sup>(1)</sup> |                                                                                                                                                                                 |             |                 |                  |                      |             |  |  |  |
|                                                                                |                                                                     | 1111 = CLC4 output                                                                                                                                                              |             |                 |                  |                      |             |  |  |  |
|                                                                                | 1110 = CL(                                                          |                                                                                                                                                                                 |             |                 |                  |                      |             |  |  |  |
|                                                                                | 1101 = CL(                                                          |                                                                                                                                                                                 |             |                 |                  |                      |             |  |  |  |
|                                                                                | 1100 = CLC                                                          | •                                                                                                                                                                               |             |                 |                  |                      |             |  |  |  |
|                                                                                | 1011 = HFI                                                          | NTOSC                                                                                                                                                                           |             |                 |                  |                      |             |  |  |  |
|                                                                                | 1010 = Fos                                                          | SC                                                                                                                                                                              |             |                 |                  |                      |             |  |  |  |
|                                                                                |                                                                     | 1001 = Reserved. No channel connected.                                                                                                                                          |             |                 |                  |                      |             |  |  |  |
|                                                                                |                                                                     | 1000 = NCO1 output                                                                                                                                                              |             |                 |                  |                      |             |  |  |  |
|                                                                                |                                                                     | 0111 = PWM6 output                                                                                                                                                              |             |                 |                  |                      |             |  |  |  |
|                                                                                |                                                                     | 0110 = PWM5 output                                                                                                                                                              |             |                 |                  |                      |             |  |  |  |
|                                                                                |                                                                     | P2 output (PWM (                                                                                                                                                                |             |                 |                  |                      |             |  |  |  |
|                                                                                |                                                                     | P1 output (PWM (<br>erence clock mod                                                                                                                                            |             |                 |                  |                      |             |  |  |  |
|                                                                                | 0011 = Ret                                                          | aranca ciack maa                                                                                                                                                                | uie signal  |                 |                  |                      |             |  |  |  |
|                                                                                |                                                                     |                                                                                                                                                                                 | ale olgital |                 |                  |                      |             |  |  |  |
|                                                                                | 0010 = MD<br>0001 = MD                                              | CIN2PPS                                                                                                                                                                         | ale olgriai |                 |                  |                      |             |  |  |  |

#### REGISTER 25-4: MDCARL: MODULATION LOW CARRIER CONTROL REGISTER

Note 1: Narrowed carrier pulse widths or spurs may occur in the signal stream if the carrier is not synchronized.

# **REGISTER 27-3:** TMRxL<sup>(1)</sup>: TIMERx LOW BYTE REGISTER

| 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 |
|------------------|---------------------------------------------------------------|-------------------|---------|----------------------------------------------------|---------|---------|---------|
|                  |                                                               |                   | TMRx    | L<7:0>                                             |         |         |         |
| bit 7            |                                                               |                   |         |                                                    |         |         | bit 0   |
|                  |                                                               |                   |         |                                                    |         |         |         |
| Legend:          |                                                               |                   |         |                                                    |         |         |         |
| R = Readable     | dable bit W = Writable bit U = Unimplemented bit, read as '0' |                   |         |                                                    |         |         |         |
| u = Bit is unch  | anged                                                         | x = Bit is unkn   | nown    | -n/n = Value at POR and BOR/Value at all other Res |         |         |         |
| '1' = Bit is set |                                                               | '0' = Bit is clea | ared    |                                                    |         |         |         |

bit 7-0 TMRxL<7:0>: TMRx Low Byte bits

Note 1: 'x' refers to either '1', '3' or '5' for the respective Timer1/3/5 registers.

# REGISTER 27-4: TMRxH<sup>(1)</sup>: TIMERx HIGH BYTE REGISTER

| bit 7   |         |         |         |         |         |         | bit 0   |
|---------|---------|---------|---------|---------|---------|---------|---------|
|         |         |         | TMRxH   | 1<7:0>  |         |         |         |
| R/W-x/u |

| 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 TMRxH<7:0>: TMRx High Byte bits

**Note 1:** 'x' refers to either '1', '3' or '5' for the respective Timer1/3/5 registers.

# 28.0 TIMER 2/4/6 MODULE

Timer2/4/6 modules are 8-bit timers that incorporate the following features:

- 8-bit Timer and Period registers (TMR2/4/6 and PR2/4/6, respectively)
- Readable and writable (both registers)
- Software programmable prescaler (1:1, 1:4, 1:16, and 1:64)
- Software programmable postscaler (1:1 to 1:16)
- Interrupt on TMR2/4/6 match with PR2/4/6
- Optional use as the shift clock for the MSSPx module

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

- Note 1: In devices with more than one Timer module, it is very important to pay close attention to the register names used. A number placed after the module acronym is used to distinguish between separate modules. For example, the T2CON and T4CON control the same operational aspects of two completely different Timer modules.
  - 2: Throughout this section, generic references to Timer2 module in any of its operating modes may be interpreted as being equally applicable to Timerx module. Register names, module signals, I/O pins and bit names may use the generic designator 'x' to indicate the use of a numeral to distinguish a particular module, when required.

### FIGURE 28-1: TIMER2/4/6 BLOCK DIAGRAM



#### TABLE 30-2: MSSP CLOCK RATE W/BRG

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

**Note:** Refer to the I/O port electrical specifications in Table 35-4 to ensure the system is designed to support IOL requirements.

-n/n = Value at POR and BOR/Value at all other Resets

#### REGISTER 30-7: SSPxBUF: MSSP BUFFER REGISTER

| 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 |
|----------------|---------|------------------|---------|--------------|------------------|---------|---------|
|                |         |                  | SSPxB   | UF<7:0>      |                  |         |         |
| bit 7          |         |                  |         |              |                  |         | bit 0   |
|                |         |                  |         |              |                  |         |         |
| Legend:        |         |                  |         |              |                  |         |         |
| R = Readable b | it      | W = Writable bit | t       | U = Unimpler | nented bit, read | as '0'  |         |

bit 7-0 **SSPxBUF<7:0>:** MSSP Buffer bits

u = Bit is unchanged

'1' = Bit is set

#### TABLE 30-3: SUMMARY OF REGISTERS ASSOCIATED WITH MSSPx

x = Bit is unknown

'0' = Bit is cleared

| Name                  | Bit 7                  | Bit 6                  | Bit 5   | Bit 4   | Bit 3   | Bit 2     | Bit 1   | Bit 0   | Register<br>on Page |
|-----------------------|------------------------|------------------------|---------|---------|---------|-----------|---------|---------|---------------------|
| TRISA                 | —                      | _                      | TRISA5  | TRISA4  | (3)     | TRISA2    | TRISA1  | TRISA0  | 143                 |
| ANSELA                | _                      | _                      | ANSA5   | ANSA4   | _       | ANSA2     | ANSA1   | ANSA0   | 144                 |
| INLVLA <sup>(1)</sup> | —                      | _                      | INLVLA5 | INLVLA4 | INLVLA3 | INLVLA2   | INLVLA1 | INLVLA0 | 146                 |
| TRISB <sup>(2)</sup>  | TRISB7                 | TRISB6                 | TRISB5  | TRISB4  | _       | _         | _       | _       | 149                 |
| ANSELB <sup>(2)</sup> | ANSB7                  | ANSB6                  | ANSB5   | ANSB4   | _       | _         | _       | _       | 150                 |
| INLVLB <sup>(2)</sup> | INLVLB7                | INLVLB6                | INLVLB5 | INLVLB4 | _       | _         | _       | _       | 152                 |
| TRISC                 | TRISC7 <sup>(2)</sup>  | TRISC6 <sup>(2)</sup>  | TRISC5  | TRISC4  | TRISC3  | TRISC2    | TRISC1  | TRISC0  | 155                 |
| ANSELC                | ANSC7 <sup>(2)</sup>   | ANSC6 <sup>(2)</sup>   | ANSC5   | ANSC4   | ANSC3   | ANSC2     | ANSC1   | ANSC0   | 157                 |
| INLVLC <sup>(1)</sup> | INLVLC7 <sup>(2)</sup> | INLVLC6 <sup>(2)</sup> | INLVLC5 | INLVLC4 | INLVLC3 | INLVLC2   | INLVLC1 | INLVLC0 | 159                 |
| INTCON                | GIE                    | PEIE                   | _       | _       | _       | _         | _       | INTEDG  | 100                 |
| PIR1                  | TMR1GIF                | ADIF                   | RCIF    | TXIF    | SSP1IF  | BCL1IF    | TMR2IF  | TMR1IF  | 107                 |
| PIE1                  | TMR1GIE                | ADIE                   | RCIE    | TXIE    | SSP1IE  | BCL1IE    | TMR2IE  | TMR1IE  | 102                 |
| PIR2                  | TMR6IF                 | C2IF                   | C1IF    | NVMIF   | SSP2IF  | BCL2IF    | TMR4IF  | NCO1IF  | 108                 |
| PIE2                  | TMR6IE                 | C2IE                   | C1IE    | NVMIE   | SSP2IE  | BCL2IE    | TMR4IE  | NCO1IE  | 103                 |
| SSPxSTAT              | SMP                    | CKE                    | D/A     | Р       | S       | R/W       | UA      | BF      | 359                 |
| SSPxCON1              | WCOL                   | SSPOV                  | SSPEN   | CKP     |         | SSPM      | <3:0>   |         | 360                 |
| SSPxCON2              | GCEN                   | ACKSTAT                | ACKDT   | ACKEN   | RCEN    | PEN       | RSEN    | SEN     | 362                 |
| SSPxCON3              | ACKTIM                 | PCIE                   | SCIE    | BOEN    | SDAHT   | SBCDE     | AHEN    | DHEN    | 363                 |
| SSPxMSK               |                        |                        |         | SSPxMS  | K<7:0>  |           |         |         | 364                 |
| SSPxADD               |                        |                        |         | SSPxAD  | D<7:0>  |           |         |         | 364                 |
| SSPxBUF               |                        |                        |         | SSPxBU  | F<7:0>  |           |         |         | 365                 |
| SSPxCLKPPS            | —                      | _                      |         |         | SSP     | xCLKPPS<  | 4:0>    |         | 162                 |
| SSPxDATPPS            | _                      | —                      | _       |         | SSF     | xDATPPS<  | 4:0>    |         | 162                 |
| SSPxSSPPS             | —                      | _                      | _       |         | SSI     | PxSSPPS<4 | :0>     |         | 162                 |

Legend: — = Unimplemented location, read as '0'. Shaded cells are not used by the MSSP module

Note 1: When using designated  $I^2C$  pins, the associated pin values in INLVLx will be ignored.

2: PIC16(L)F18346 only.

3: Unimplemented, read as '1'.

- 31.1.2.8 Asynchronous Reception Setup
- Initialize the SP1BRGH, SP1BRGL register pair and the BRGH and BRG16 bits to achieve the desired baud rate (see Section 31.3 "EUSART1 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 RC1STA 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 RC1REG 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 SP1BRGH, SP1BRGL register pair and the BRGH and BRG16 bits to achieve the desired baud rate (see Section 31.3 "EUSART1 Baud Rate Generator (BRG)").
- 2. Clear the ANSEL bit for the RX pin (if applicable).
- 3. 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 RC1STA 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 RC1REG 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

#### 31.3.5 RECEIVING A BREAK CHARACTER

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

The first method to detect a Break character uses the FERR bit of the RC1STA register and the received data as indicated by RC1REG. The Baud Rate Generator is assumed to have been initialized to the expected baud rate.

A Break character has been received when:

- RCIF bit is set
- FERR bit is set
- RC1REG = 00h

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

Note that following a Break character, the user will typically want to enable the Auto-Baud Detect feature. For both methods, the user can set the ABDEN bit of the BAUD1CON register before placing the EUSART1 in Sleep mode.





# PIC16(L)F18326/18346

| BCF              | Bit Clear f                                                         |
|------------------|---------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ]BCF f,b                                             |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ 0 \leq b \leq 7 \end{array}$ |
| Operation:       | $0 \rightarrow (f \le b >)$                                         |
| Status Affected: | None                                                                |
| Description:     | Bit 'b' in register 'f' is cleared.                                 |

| BTFSC            | Bit Test f, Skip if Clear                                                                                                                                                                                         |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label]BTFSC f,b                                                                                                                                                                                                  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ 0 \leq b \leq 7 \end{array}$                                                                                                                                               |
| Operation:       | skip if (f <b>) = 0</b>                                                                                                                                                                                           |
| Status Affected: | None                                                                                                                                                                                                              |
| Description:     | If bit 'b' in register 'f' is '1', the next instruction is executed.<br>If bit 'b', in register 'f', is '0', the next instruction is discarded, and a NOP is executed instead, making this a 2-cycle instruction. |

| BRA              | Relative Branch                                                                                                                                                                                                                                 | BTFSS      |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| Syntax:          | [ <i>label</i> ]BRA label                                                                                                                                                                                                                       | Syntax:    |
|                  | [ <i>label</i> ]BRA \$+k                                                                                                                                                                                                                        | Operands   |
| Operands:        | -256 $\leq$ label - PC + 1 $\leq$ 255                                                                                                                                                                                                           |            |
|                  | $-256 \le k \le 255$                                                                                                                                                                                                                            | Operation  |
| Operation:       | $(PC) + 1 + k \rightarrow PC$                                                                                                                                                                                                                   | Status Aff |
| Status Affected: | None                                                                                                                                                                                                                                            | Descriptio |
| Description:     | Add the signed 9-bit literal 'k' to the<br>PC. Since the PC will have<br>incremented to fetch the next<br>instruction, the new address will be<br>PC + 1 + k. This instruction is a<br>2-cycle instruction. This branch has a<br>limited range. |            |

| Syntax:          | [ label ] BRW                                                                                                                                                                                                 |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operands:        | None                                                                                                                                                                                                          |
| Operation:       | $(PC) + (W) \to PC$                                                                                                                                                                                           |
| Status Affected: | None                                                                                                                                                                                                          |
| Description:     | Add the contents of W (unsigned) to<br>the PC. Since the PC will have<br>incremented to fetch the next<br>instruction, the new address will be<br>PC + 1 + (W). This instruction is a<br>2-cycle instruction. |

| BSF              | Bit Set f                                                           |
|------------------|---------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ]BSF f,b                                             |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ 0 \leq b \leq 7 \end{array}$ |
| Operation:       | $1 \rightarrow (f \le b >)$                                         |
| Status Affected: | None                                                                |
| Description:     | Bit 'b' in register 'f' is set.                                     |

| c         | [ <i>label</i> ]BTFSS f,b                                                                                                                                                                           |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| nds:      | $\begin{array}{l} 0 \leq f \leq 127 \\ 0 \leq b < 7 \end{array}$                                                                                                                                    |
| tion:     | skip if (f <b>) = 1</b>                                                                                                                                                                             |
| Affected: | None                                                                                                                                                                                                |
| ption:    | If bit 'b' in register 'f' is '0', the next instruction is executed.<br>If bit 'b' is '1', then the next instruction is discarded and a NOP is executed instead, making this a 2-cycle instruction. |

Bit Test f, Skip if Set

### TABLE 35-5: I/O AND CLOCK TIMING SPECIFICATIONS

| Standard                                           | Standard Operating Conditions (unless otherwise stated) |                                                      |          |       |             |       |                                               |
|----------------------------------------------------|---------------------------------------------------------|------------------------------------------------------|----------|-------|-------------|-------|-----------------------------------------------|
| Param.<br>No.                                      | Sym.                                                    | Characteristic                                       | Min.     | Typ.† | Max.        | Units | Conditions                                    |
| High Voltage Entry Programming Mode Specifications |                                                         |                                                      |          |       |             |       |                                               |
| MEM01                                              | Vінн                                                    | Voltage on MCLR/VPP pin to<br>enter Programming mode | 8        | _     | 9           | V     | Note 2                                        |
| MEM02                                              | IPPGM                                                   | Current on MCLR/VPP pin during<br>Programming mode   | —        | _     | 600         | uA    | Note 2                                        |
| Programming Mode Specifications                    |                                                         |                                                      |          |       |             |       |                                               |
| MEM10                                              | VBE                                                     | VDD for Bulk Erase                                   |          | 2.7   | _           | V     |                                               |
| MEM11                                              | IDDPGM                                                  | Supply Current during<br>Programming Operation       | _        | _     | 3           | mA    |                                               |
| Data EEPROM Memory Specifications                  |                                                         |                                                      |          |       |             |       |                                               |
| MEM20                                              | ED                                                      | DataEE Byte Endurance                                | 100k     | _     | —           | E/W   | -40°C ≤ TA ≤ 85°C                             |
| MEM21                                              | TD_RET                                                  | Characteristic Retention                             | _        | 40    | - <         | Year  | Provided no other specifications are violated |
| MEM22                                              | ND_REF                                                  | Total Erase/Write Cycles before<br>Refresh           | _        | _     | 100k        | ÉW    |                                               |
| MEM23                                              | VD_RW                                                   | VDD for Read or Erase/Write<br>Operation             | VDDMIN   |       | VDQMAX      | v     |                                               |
| MEM24                                              | TD_BEW                                                  | Byte Erase and Write Cycle Time                      | —        | 4.0   | 5.0         | ms    |                                               |
| Program                                            | I Flash Me                                              | emory Specifications                                 | $\frown$ |       |             |       |                                               |
| MEM30                                              | Eр                                                      | Flash Memory Cell Endurance                          | 10k      |       | $\searrow$  | E/W   | -40°C ≤ TA ≤ 85°C<br>(Note 1)                 |
| MEM31                                              | EPHEF                                                   | High-Endurance Flash Memory<br>Cell Endurance        | 100K     |       | <u>&gt;</u> | E/W   | TBD                                           |
| MEM32                                              | TP_RET                                                  | Characteristic Retention                             |          | 40    | _           | Year  | Provided no other specifications are violated |
| MEM33                                              | VP_RD                                                   | VDD for Read Operation                               | VODMIN   | —     | VDDMAX      | V     |                                               |
| MEM34                                              | VP_REW                                                  | VDD for Row Erase or Write<br>Operation              | VDDMIN   | _     | VDDMAX      | V     |                                               |
| MEM35                                              | TP_REW                                                  | Self-Timed Row Erase or<br>Self-Timed Write          | _        | 2.0   | 2.5         | ms    |                                               |

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

Note 1: Flash Memory Cell Endurance for the Flash memory is defined as: One Row Erase operation and one Self-Timed Write.

2: Required only if CONFIG3.LVP is disabled.

# PIC16(L)F18326/18346

#### 35.4 **AC Characteristics**





#### FIGURE 35-5: **CLOCK TIMING**



| TABLE 35-9: | PLL CLOCK TIMING SPECIFICATIONS |
|-------------|---------------------------------|
|-------------|---------------------------------|

| Standard Operating Conditions (unless otherwise stated) |         |                                         |       |       |      |       |            |  |
|---------------------------------------------------------|---------|-----------------------------------------|-------|-------|------|-------|------------|--|
| Param.<br>No.                                           | Sym.    | Characteristic                          | Min.  | Тур.† | Max. | Units | Conditions |  |
| PLL01                                                   | Fpllin  | PLL Input Frequency Range               | 4     |       | 8    | MHz   |            |  |
| PLL02                                                   | FPLLOUT | PLL Output Frequency Range              | 16    | —     | 32   | MHz   |            |  |
| PLL03                                                   | TPLLST  | PLL Lock Time from Start-up             | —     | 200   | —    | μs    | η          |  |
| PLL04                                                   | Fplljit | PLL Output Frequency Stability (Jitter) | -0.25 | —     | 0.25 | %     |            |  |

\* These parameters are characterized but not tested.

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







# 37.6 MPLAB X SIM Software Simulator

The MPLAB X SIM Software Simulator allows code development in a PC-hosted environment by simulating the PIC MCUs and dsPIC DSCs on an instruction level. On any given instruction, the data areas can be examined or modified and stimuli can be applied from a comprehensive stimulus controller. Registers can be logged to files for further run-time analysis. The trace buffer and logic analyzer display extend the power of the simulator to record and track program execution, actions on I/O, most peripherals and internal registers.

The MPLAB X SIM Software Simulator fully supports symbolic debugging using the MPLAB XC Compilers, and the MPASM and MPLAB Assemblers. The software simulator offers the flexibility to develop and debug code outside of the hardware laboratory environment, making it an excellent, economical software development tool.

### 37.7 MPLAB REAL ICE In-Circuit Emulator System

The MPLAB REAL ICE In-Circuit Emulator System is Microchip's next generation high-speed emulator for Microchip Flash DSC and MCU devices. It debugs and programs all 8, 16 and 32-bit MCU, and DSC devices with the easy-to-use, powerful graphical user interface of the MPLAB X IDE.

The emulator is connected to the design engineer's PC using a high-speed USB 2.0 interface and is connected to the target with either a connector compatible with in-circuit debugger systems (RJ-11) or with the new high-speed, noise tolerant, Low-Voltage Differential Signal (LVDS) interconnection (CAT5).

The emulator is field upgradeable through future firmware downloads in MPLAB X IDE. MPLAB REAL ICE offers significant advantages over competitive emulators including full-speed emulation, run-time variable watches, trace analysis, complex breakpoints, logic probes, a ruggedized probe interface and long (up to three meters) interconnection cables.

### 37.8 MPLAB ICD 3 In-Circuit Debugger System

The MPLAB ICD 3 In-Circuit Debugger System is Microchip's most cost-effective, high-speed hardware debugger/programmer for Microchip Flash DSC and MCU devices. It debugs and programs PIC Flash microcontrollers and dsPIC DSCs with the powerful, yet easy-to-use graphical user interface of the MPLAB IDE.

The MPLAB ICD 3 In-Circuit Debugger probe is connected to the design engineer's PC using a highspeed USB 2.0 interface and is connected to the target with a connector compatible with the MPLAB ICD 2 or MPLAB REAL ICE systems (RJ-11). MPLAB ICD 3 supports all MPLAB ICD 2 headers.

# 37.9 PICkit 3 In-Circuit Debugger/ Programmer

The MPLAB PICkit 3 allows debugging and programming of PIC and dsPIC Flash microcontrollers at a most affordable price point using the powerful graphical user interface of the MPLAB IDE. The MPLAB PICkit 3 is connected to the design engineer's PC using a fullspeed USB interface and can be connected to the target via a Microchip debug (RJ-11) connector (compatible with MPLAB ICD 3 and MPLAB REAL ICE). The connector uses two device I/O pins and the Reset line to implement in-circuit debugging and In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>).

## 37.10 MPLAB PM3 Device Programmer

The MPLAB PM3 Device Programmer is a universal, CE compliant device programmer with programmable voltage verification at VDDMIN and VDDMAX for maximum reliability. It features a large LCD display (128 x 64) for menus and error messages, and a modular, detachable socket assembly to support various package types. The ICSP cable assembly is included as a standard item. In Stand-Alone mode, the MPLAB PM3 Device Programmer can read, verify and program PIC devices without a PC connection. It can also set code protection in this mode. The MPLAB PM3 connects to the host PC via an RS-232 or USB cable. The MPLAB PM3 has high-speed communications and optimized algorithms for quick programming of large memory devices, and incorporates an MMC card for file storage and data applications.

# 20-Lead Plastic Shrink Small Outline (SS) - 5.30 mm Body [SSOP]

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



## RECOMMENDED LAND PATTERN

|                          | Units  | MILLIMETERS |          |      |  |
|--------------------------|--------|-------------|----------|------|--|
| Dimensior                | Limits | MIN         | NOM      | MAX  |  |
| Contact Pitch            | E      |             | 0.65 BSC |      |  |
| Contact Pad Spacing      | С      |             | 7.20     |      |  |
| Contact Pad Width (X20)  | X1     |             |          | 0.45 |  |
| Contact Pad Length (X20) | Y1     |             |          | 1.75 |  |
| Distance Between Pads    | G      | 0.20        |          |      |  |

Notes:

1. Dimensioning and tolerancing per ASME Y14.5M

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

Microchip Technology Drawing No. C04-2072B