



Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| Product Status             | Active                                                                     |
|----------------------------|----------------------------------------------------------------------------|
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 32MHz                                                                      |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                          |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                      |
| Number of I/O              | 16                                                                         |
| Program Memory Size        | 3.5KB (2K x 14)                                                            |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | 256 x 8                                                                    |
| RAM Size                   | 256 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                                                |
| Data Converters            | A/D 12x10b                                                                 |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 20-SSOP (0.209", 5.30mm Width)                                             |
| Supplier Device Package    | 20-SSOP                                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lf1826-i-ss |

Email: info@E-XFL.COM

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

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

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

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

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

## QUALITY MANAGEMENT SYSTEM CERTIFIED BY DNV ISO/TS 16949:2002

#### Trademarks

The Microchip name and logo, the Microchip logo, dsPIC, KEELOQ, KEELOQ logo, MPLAB, PIC, PICmicro, PICSTART, PIC<sup>32</sup> logo, rfPIC and UNI/O are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

FilterLab, Hampshire, HI-TECH C, Linear Active Thermistor, MXDEV, MXLAB, SEEVAL and The Embedded Control Solutions Company are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Analog-for-the-Digital Age, Application Maestro, CodeGuard, dsPICDEM, dsPICDEM.net, dsPICworks, dsSPEAK, ECAN, ECONOMONITOR, FanSense, HI-TIDE, In-Circuit Serial Programming, ICSP, Mindi, MiWi, MPASM, MPLAB Certified logo, MPLIB, MPLINK, mTouch, Omniscient Code Generation, PICC, PICC-18, PICDEM, PICDEM.net, PICkit, PICtail, REAL ICE, rfLAB, Select Mode, Total Endurance, TSHARC, UniWinDriver, WiperLock and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

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

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

© 2011, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.

Printed on recycled paper.

#### ISBN: 978-1-61341-124-7

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

#### 3.2.1.1 STATUS Register

The STATUS register, shown in Register 3-1, contains:

- the arithmetic status of the ALU
- · the Reset status

'1' = Bit is set

The STATUS register can be the destination for any instruction, like any other register. If the STATUS register is the destination for an instruction that affects the Z, DC or C bits, then the write to these three bits is disabled. These bits are set or cleared according to the device logic. Furthermore, the TO and PD bits are not writable. Therefore, the result of an instruction with the STATUS register as destination may be different than intended.

#### REGISTER 3-1: STATUS: STATUS REGISTER

'0' = Bit is cleared

For example, CLRF STATUS will clear the upper three bits and set the Z bit. This leaves the STATUS register as '000u uluu' (where u = unchanged).

It is recommended, therefore, that only BCF, BSF, SWAPF and MOVWF instructions are used to alter the STATUS register, because these instructions do not affect any Status bits. For other instructions not affecting any Status bits (Refer to Section 29.0 "Instruction Set Summary").

**Note 1:** The <u>C and DC</u> bits operate as Borrow and Digit Borrow out bits, respectively, in subtraction.

| U-0                                     | U-0 | U-0 | R-1/q                              | R-1/q                                                 | R/W-0/u | R/W-0/u           | R/W-0/u          |  |  |
|-----------------------------------------|-----|-----|------------------------------------|-------------------------------------------------------|---------|-------------------|------------------|--|--|
| _                                       | —   | _   | TO                                 | PD                                                    | Z       | DC <sup>(1)</sup> | C <sup>(1)</sup> |  |  |
| 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 |         |                   |                  |  |  |

q = Value depends on condition

| bit 7-5 | Unimplemented: Read as '0'                                                                                                                                                                                           |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 4   | TO: Time-out bit                                                                                                                                                                                                     |
|         | 1 = After power-up, CLRWDT instruction or SLEEP instruction<br>0 = A WDT time-out occurred                                                                                                                           |
| bit 3   | PD: Power-down bit                                                                                                                                                                                                   |
|         | 1 = After power-up or by the CLRWDT instruction                                                                                                                                                                      |
|         | 0 = By execution of the SLEEP instruction                                                                                                                                                                            |
| bit 2   | Z: Zero bit                                                                                                                                                                                                          |
|         | <ul> <li>1 = The result of an arithmetic or logic operation is zero</li> <li>0 = The result of an arithmetic or logic operation is not zero</li> </ul>                                                               |
| bit 1   | DC: Digit Carry/Digit Borrow bit (ADDWF, ADDLW, SUBLW, SUBWF instructions) <sup>(1)</sup>                                                                                                                            |
|         | <ul> <li>1 = A carry-out from the 4th low-order bit of the result occurred</li> <li>0 = No carry-out from the 4th low-order bit of the result</li> </ul>                                                             |
| bit 0   | C: Carry/Borrow bit <sup>(1)</sup> (ADDWF, ADDLW, SUBLW, SUBWF instructions) <sup>(1)</sup>                                                                                                                          |
|         | 1 = A carry-out from the Most Significant bit of the result occurred                                                                                                                                                 |
|         | 0 = No carry-out from the Most Significant bit of the result occurred                                                                                                                                                |
| Note 1: | For Borrow, the polarity is reversed. A subtraction is executed by adding the two's complement of the second operand. For rotate (RRF, RLF) instructions, this bit is loaded with either the high-order or low-order |

bit of the source register.

|         |                      | -                      |               |          |          |          | -      | /       |           |                      |                                 |
|---------|----------------------|------------------------|---------------|----------|----------|----------|--------|---------|-----------|----------------------|---------------------------------|
| Address | Name                 | Bit 7                  | Bit 6         | Bit 5    | Bit 4    | Bit 3    | Bit 2  | Bit 1   | Bit 0     | Value on<br>POR, BOR | Value on all<br>other<br>Resets |
| Bank 8  |                      |                        |               |          |          |          |        |         |           |                      |                                 |
| 40Ch    | —                    | Unimplemen             | Jnimplemented |          |          |          |        |         |           |                      |                                 |
| 40Dh    | —                    | Unimplement            | ted           |          |          |          |        |         |           | _                    | _                               |
| 40Eh    | —                    | Unimplemen             | ted           |          |          |          |        |         |           | _                    | _                               |
| 40Fh    | —                    | Unimplemen             | ted           |          |          |          |        |         |           | _                    | _                               |
| 410h    | —                    | Unimplemen             | ted           |          |          |          |        |         |           | _                    | _                               |
| 411h    | —                    | Unimplemen             | ted           |          |          |          |        |         |           | _                    | _                               |
| 412h    | —                    | Unimplemen             | ted           |          |          |          |        |         |           | _                    | _                               |
| 413h    | —                    | Unimplemen             | Unimplemented |          |          |          |        |         |           |                      | _                               |
| 414h    | —                    | Unimplemen             | ted           |          |          |          |        |         |           | _                    | _                               |
| 415h    | TMR4 <sup>(1)</sup>  | Timer4 Modu            | ile Register  |          |          |          |        |         |           | 0000 0000            | 0000 0000                       |
| 416h    | PR4 <sup>(1)</sup>   | Timer4 Perio           | d Register    |          |          |          |        |         |           | 1111 1111            | 1111 1111                       |
| 417h    | T4CON <sup>(1)</sup> | _                      | T4OUTPS3      | T4OUTPS2 | T4OUTPS1 | T4OUTPS0 | TMR4ON | T4CKPS1 | T4CKPS0   | -000 0000            | -000 0000                       |
| 418h    | —                    | Unimplemen             | ted           |          |          |          |        |         |           | _                    | _                               |
| 419h    | —                    | Unimplemen             | ted           |          |          |          |        |         |           | _                    | _                               |
| 41Ah    | —                    | Unimplemented          |               |          |          |          |        |         | _         | _                    |                                 |
| 41Bh    | —                    | Unimplemented          |               |          |          |          |        | _       | _         |                      |                                 |
| 41Ch    | TMR6 <sup>(1)</sup>  | Timer6 Module Register |               |          |          |          |        |         | 0000 0000 | 0000 0000            |                                 |
| 41Dh    | PR6 <sup>(1)</sup>   | Timer6 Period Register |               |          |          |          |        |         |           | 1111 1111            | 1111 1111                       |
| 41Eh    | T6CON <sup>(1)</sup> |                        | T6OUTPS3      | T6OUTPS2 | T6OUTPS1 | T6OUTPS0 | TMR6ON | T6CKPS1 | T6CKPS0   | -000 0000            | -000 0000                       |
| 41Fh    | _                    | Unimplement            | ted           | •        | •        | -        |        | •       |           | _                    | _                               |

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

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

Note 1: PIC16(L)F1827 only.

#### 5.2.1.5 TIMER1 Oscillator

The Timer1 Oscillator is a separate crystal oscillator that is associated with the Timer1 peripheral. It is optimized for timekeeping operations with a 32.768 kHz crystal connected between the T1OSO and T1OSI device pins.

The Timer1 Oscillator can be used as an alternate system clock source and can be selected during run-time using clock switching. Refer to **Section 5.3 "Clock Switching"** for more information.

#### FIGURE 5-5: QUARTZ CRYSTAL OPERATION (TIMER1 OSCILLATOR)



- Note 1: Quartz crystal characteristics vary according to type, package and manufacturer. The user should consult the manufacturer data sheets for specifications and recommended application.
  - 2: Always verify oscillator performance over the VDD and temperature range that is expected for the application.
  - **3:** For oscillator design assistance, reference the following Microchip Applications Notes:
    - AN826, "Crystal Oscillator Basics and Crystal Selection for rfPIC<sup>®</sup> and PIC<sup>®</sup> Devices" (DS00826)
    - AN849, "Basic PIC<sup>®</sup> Oscillator Design" (DS00849)
    - AN943, "Practical PIC<sup>®</sup> Oscillator Analysis and Design" (DS00943)
    - AN949, "Making Your Oscillator Work" (DS00949)
    - TB097, "Interfacing a Micro Crystal MS1V-T1K 32.768 kHz Tuning Fork Crystal to a PIC16F690/SS" (DS91097)
    - AN1288, "Design Practices for Low-Power External Oscillators" (DS01288)

## 5.2.1.6 External RC Mode

The external Resistor-Capacitor (RC) modes support the use of an external RC circuit. This allows the designer maximum flexibility in frequency choice while keeping costs to a minimum when clock accuracy is not required.

The RC circuit connects to OSC1. OSC2/CLKOUT is available for general purpose I/O or CLKOUT. The function of the OSC2/CLKOUT pin is determined by the state of the CLKOUTEN bit in Configuration Word 1.

Figure 5-6 shows the external RC mode connections.



The RC oscillator frequency is a function of the supply voltage, the resistor (REXT) and capacitor (CEXT) values and the operating temperature. Other factors affecting the oscillator frequency are:

- threshold voltage variation
- component tolerances
- · packaging variations in capacitance

The user also needs to take into account variation due to tolerance of external RC components used.



FIGURE 7-3: RESET START-UP SEQUENCE

| R/W-0/0          | R/W-0/0                        | R/W-0/0            | R/W/HC-0/0             | R/W-x/q                             | R/W-0/0              | R/S/HC-0/0                            | R/S/HC-0/0       |
|------------------|--------------------------------|--------------------|------------------------|-------------------------------------|----------------------|---------------------------------------|------------------|
| EEPGD            | CFGS                           | LWLO               | FREE                   | WRERR                               | WREN                 | WR                                    | RD               |
| bit 7            |                                |                    |                        |                                     |                      | •                                     | bit 0            |
|                  |                                |                    |                        |                                     |                      |                                       |                  |
| Legend:          |                                |                    |                        |                                     |                      |                                       |                  |
| R = Readable     | bit                            | W = Writable       | bit                    | U = Unimple                         | mented bit, read     | l as '0'                              |                  |
| S = Bit can onl  | y be set                       | x = Bit is unki    | nown                   | -n/n = Value                        | at POR and BO        | R/Value at all o                      | ther Resets      |
| '1' = Bit is set |                                | '0' = Bit is cle   | ared                   | HC = Bit is c                       | leared by hardw      | are                                   |                  |
| b:# 7            |                                |                    |                        |                                     | <b>b</b> :4          |                                       |                  |
| DIL 7            | $1 = \Delta ccesses$           | s program space    | e Flash memo           | ernory Select                       | DIL                  |                                       |                  |
|                  | 0 = Accesses                   | s data EEPRO       | M memory               | , y                                 |                      |                                       |                  |
| bit 6            | CFGS: Flash                    | Program/Data       | EEPROM or C            | Configuration                       | Select bit           |                                       |                  |
|                  | 1 = Accesses                   | s Configuration    | , User ID and          | Device ID Re                        | gisters              |                                       |                  |
| 1.1. E           | 0 = Accesses                   | s Flash Progra     | m or data EEP          | ROM Memor                           | у                    |                                       |                  |
| bit 5            | LWLO: Load                     | Write Latches      | Only bit               | 2S = 0 and E                        | EDCD = 1 (prog       | rom Elech);                           |                  |
|                  | 1 = The                        | next WR com        | mand does not          | ot initiate a v                     | vrite: only the p    | rogram memoi                          | rv latches are   |
|                  | upda                           | ated.              |                        |                                     |                      |                                       | <i>y</i>         |
|                  | 0 = The                        | next WR comn       | hand writes a v        | alue from EE                        | DATH:EEDATL          | into program m                        | emory latches    |
|                  | anu                            | initiates a write  | or all the data        | stored in the                       | program memo         | ry latenes.                           |                  |
|                  | <u> If CFGS = 0 a</u>          | and EEPGD =        | <u>o:</u> (Accessing o | data EEPRON                         | Л)                   |                                       |                  |
|                  | LWLO is igno                   | red. The next \    | VR command             | initiates a wri                     | te to the data EE    | EPROM.                                |                  |
| bit 4            | FREE: Progra                   | am Flash Erase     | e Enable bit           | $20 - 0$ and $\Gamma$               |                      | rom Floob);                           |                  |
|                  | $\frac{  CFGS =   }{1 = Perf}$ | Conliguration s    | operation on t         | <u>55 = 0 anu E</u><br>he nevt WR c | $EPGD = \perp (prog$ | <u>ram Flasn)</u> :<br>ad by bardware | after comple-    |
|                  | tion                           | of erase).         | operation on t         |                                     |                      |                                       |                  |
|                  | 0 = Perf                       | orms a write op    | peration on the        | next WR cor                         | nmand.               |                                       |                  |
|                  | If EEPGD = 0                   | and CFGS =         | o: (Accessing (        | data EEPRON                         | A)                   |                                       |                  |
|                  | FREE is ignor                  | red. The next V    | VR command             | will initiate bo                    | h a erase cycle      | and a write cyc                       | le.              |
| bit 3            | WRERR: EE                      | PROM Error FI      | ag bit                 |                                     |                      |                                       |                  |
|                  | 1 = Condition                  | n indicates an     | improper prog          | ram or erase                        | sequence atter       | mpt or termination                    | tion (bit is set |
|                  | 0 = The prog                   | ram or erase c     | peration comp          | e ⊥) or the w                       | ν.                   |                                       |                  |
| bit 2            | WREN: Prog                     | ,<br>ram/Erase Ena | ble bit                |                                     | ,                    |                                       |                  |
|                  | 1 = Allows pr                  | rogram/erase c     | ycles                  |                                     |                      |                                       |                  |
|                  | 0 = Inhibits p                 | orogramming/er     | asing of progra        | am Flash and                        | data EEPROM          |                                       |                  |
| bit 1            | WR: Write Co                   | ontrol bit         |                        |                                     |                      |                                       |                  |
|                  | 1 = Initiates a                | a program Flas     | h or data EEP          | ROM progran                         | n/erase operatio     | n.<br>operation is co                 | mnlete           |
|                  | The WR                         | bit can only be    | set (not cleare        | ed) in software                     | e.                   |                                       | inpiete.         |
|                  | 0 = Program                    | /erase operatio    | n to the Flash         | or data EEPF                        | ROM is complete      | e and inactive.                       |                  |
| bit 0            | RD: Read Co                    | ntrol bit          |                        |                                     |                      |                                       |                  |
|                  | 1 = Initiates                  | an program F       | lash or data E         | EPROM rea                           | d. Read takes        | one cycle. RD                         | is cleared in    |
|                  | 0 = Does not                   | t initiate a prog  | ram Flash or d         | ata EEPROM                          | data read.           |                                       |                  |
|                  |                                |                    |                        |                                     |                      |                                       |                  |

### REGISTER 11-5: EECON1: EEPROM CONTROL 1 REGISTER

### 12.1 Alternate Pin Function

The Alternate Pin Function Control (APFCON0 and APFCON1) registers are used to steer specific peripheral input and output functions between different pins. The APFCON0 and APFCON1 registers are shown in Register 12-1 and Register 12-2. For this device family, the following functions can be moved between different pins.

- RX/DT
- SDO1
- SS1 (Slave Select 1)
- P2B
- CCP2/P2A
- P1D
- P1C
- CCP1/P1A
- TX/CK

These bits have no effect on the values of any TRIS register. PORT and TRIS overrides will be routed to the correct pin. The unselected pin will be unaffected.

#### 19.7 Comparator Negative Input Selection

The CxNCH<1:0> bits of the CMxCON0 register direct one of four analog pins to the comparator inverting input.

| Note: | To use CxIN+ and CxINx- pins as analog     |
|-------|--------------------------------------------|
|       | input, the appropriate bits must be set in |
|       | the ANSEL register and the correspond-     |
|       | ing TRIS bits must also be set to disable  |
|       | the output drivers.                        |

## 19.8 Comparator Response Time

The comparator output is indeterminate for a period of time after the change of an input source or the selection of a new reference voltage. This period is referred to as the response time. The response time of the comparator differs from the settling time of the voltage reference. Therefore, both of these times must be considered when determining the total response time to a comparator input change. See the Comparator and Voltage Reference Specifications in Section 29.0 "Electrical Specifications" for more details.

## 19.9 Interaction with ECCP Logic

The C1 and C2 comparators can be used as general purpose comparators. Their outputs can be brought out to the C1OUT and C2OUT pins. When the ECCP Auto-Shutdown is active it can use one or both comparator signals. If auto-restart is also enabled, the comparators can be configured as a closed loop analog feedback to the ECCP, thereby, creating an analog controlled PWM.

**Note:** When the comparator module is first initialized the output state is unknown. Upon initialization, the user should verify the output state of the comparator prior to relying on the result, primarily when using the result in connection with other peripheral features, such as the ECCP Auto-Shutdown mode.

#### 19.10 Analog Input Connection Considerations

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

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

Note 1: When reading a PORT register, all pins configured as analog inputs will read as a '0'. Pins configured as digital inputs will convert as an analog input, according to the input specification.

> Analog levels on any pin defined as a digital input, may cause the input buffer to consume more current than is specified.

## 21.11 Timer1 Control Register

The Timer1 Control register (T1CON), shown in Register 21-1, is used to control Timer1 and select the various features of the Timer1 module.

#### REGISTER 21-1: T1CON: TIMER1 CONTROL REGISTER

| R/W-0/u      | R/W-0/u | R/W-0/u      | R/W-0/u | R/W-0/u                            | R/W-0/u | U-0 | R/W-0/u |  |
|--------------|---------|--------------|---------|------------------------------------|---------|-----|---------|--|
| TMR1CS<1:0>  |         | T1CKP        | S<1:0>  | T1OSCEN                            | T1SYNC  | —   | TMR10N  |  |
| bit 7        |         |              |         |                                    |         |     | bit 0   |  |
|              |         |              |         |                                    |         |     |         |  |
| Legend:      |         |              |         |                                    |         |     |         |  |
| R = Readable | bit     | W = Writable | bit     | U = Unimplemented bit, read as '0' |         |     |         |  |

| u = Bit is unch  | anged 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          | TMR1CS<1:0>: Timer1 Clock So                                                                                                                                                                                                                                             | urce Select bits                                                                                                                   |
|                  | 11 = Timer1 clock source is Capa<br>10 = Timer1 clock source is pin or<br><u>If T1OSCEN = 0</u> :<br>External clock from T1CKI pi<br><u>If T1OSCEN = 1</u> :<br>Crystal oscillator on T1OSI/T<br>01 = Timer1 clock source is syste<br>00 = Timer1 clock source is instru | citive Sensing Oscillator (CAPOSC)<br>oscillator:<br>n (on the rising edge)<br>10SO pins<br>m clock (Fosc)<br>ction clock (Fosc/4) |
| bit 5-4          | <b>T1CKPS&lt;1:0&gt;:</b> Timer1 Input Cloc<br>11 = 1:8 Prescale value<br>10 = 1:4 Prescale value<br>01 = 1:2 Prescale value<br>00 = 1:1 Prescale value                                                                                                                  | k Prescale Select bits                                                                                                             |
| bit 3            | <b>TIOSCEN:</b> LP Oscillator Enable (<br>1 = Dedicated Timer1 oscillator c<br>0 = Dedicated Timer1 oscillator c                                                                                                                                                         | Control bit<br>ircuit enabled<br>ircuit disabled                                                                                   |
| bit 2            | <b>T1SYNC:</b> Timer1 External Clock I<br><u>TMR1CS&lt;1:0&gt; = 1X:</u><br>1 = Do not synchronize external of<br>0 = Synchronize external clock in                                                                                                                      | nput Synchronization Control bit<br>clock input<br>put with system clock (Fosc)                                                    |
|                  | <u>TMR1CS&lt;1:0&gt; = 0x:</u><br>This bit is ignored.                                                                                                                                                                                                                   |                                                                                                                                    |
| bit 1            | Unimplemented: Read as '0'                                                                                                                                                                                                                                               |                                                                                                                                    |
| bit 0            | TMR1ON: Timer1 On bit<br>1 = Enables Timer1<br>0 = Stops Timer1<br>Clears Timer1 gate flip-flop                                                                                                                                                                          |                                                                                                                                    |

| FIGURE 23-4:                 | CARRIER LOW SYNCHRONIZATION (MDSHSYNC = 0, MDCLSYNC = 1) |
|------------------------------|----------------------------------------------------------|
| Carrier High (CARH)          |                                                          |
| Carrier Low (CARL)           |                                                          |
| Modulator (MOD)              |                                                          |
| MDCHSYNC = 0<br>MDCLSYNC = 1 |                                                          |
| Active Carrier<br>State -    |                                                          |
|                              |                                                          |



#### 24.3.6 PWM RESOLUTION

The resolution determines the number of available duty cycles for a given period. For example, a 10-bit resolution will result in 1024 discrete duty cycles, whereas an 8-bit resolution will result in 256 discrete duty cycles.

The maximum PWM resolution is 10 bits when PRx is 255. The resolution is a function of the PRx register value as shown by Equation 24-4.

#### EQUATION 24-4: PWM RESOLUTION

Resolution = 
$$\frac{\log[4(PRx+1)]}{\log(2)}$$
 bits

Note: If the pulse width value is greater than the period the assigned PWM pin(s) will remain unchanged.

#### TABLE 24-5: EXAMPLE PWM FREQUENCIES AND RESOLUTIONS (Fosc = 32 MHz)

| PWM Frequency             | 1.95 kHz | 7.81 kHz | 31.25 kHz | 125 kHz | 250 kHz | 333.3 kHz |
|---------------------------|----------|----------|-----------|---------|---------|-----------|
| Timer Prescale (1, 4, 16) | 16       | 4        | 1         | 1       | 1       | 1         |
| PRx Value                 | 0xFF     | 0xFF     | 0xFF      | 0x3F    | 0x1F    | 0x17      |
| Maximum Resolution (bits) | 10       | 10       | 10        | 8       | 7       | 6.6       |

#### TABLE 24-6: EXAMPLE PWM FREQUENCIES AND RESOLUTIONS (Fosc = 20 MHz)

| PWM Frequency             | 1.22 kHz | 4.88 kHz | 19.53 kHz | 78.12 kHz | 156.3 kHz | 208.3 kHz |
|---------------------------|----------|----------|-----------|-----------|-----------|-----------|
| Timer Prescale (1, 4, 16) | 16       | 4        | 1         | 1         | 1         | 1         |
| PRx Value                 | 0xFF     | 0xFF     | 0xFF      | 0x3F      | 0x1F      | 0x17      |
| Maximum Resolution (bits) | 10       | 10       | 10        | 8         | 7         | 6.6       |

#### TABLE 24-7: EXAMPLE PWM FREQUENCIES AND RESOLUTIONS (Fosc = 8 MHz)

| PWM Frequency             | 1.22 kHz | 4.90 kHz | 19.61 kHz | 76.92 kHz | 153.85 kHz | 200.0 kHz |
|---------------------------|----------|----------|-----------|-----------|------------|-----------|
| Timer Prescale (1, 4, 16) | 16       | 4        | 1         | 1         | 1          | 1         |
| PRx Value                 | 0x65     | 0x65     | 0x65      | 0x19      | 0x0C       | 0x09      |
| Maximum Resolution (bits) | 8        | 8        | 8         | 6         | 5          | 5         |

#### 25.2.2 SPI MODE OPERATION

When initializing the SPI, several options need to be specified. This is done by programming the appropriate control bits (SSPxCON1<5:0> and SSPxSTAT<7:6>). These control bits allow the following to be specified:

- · Master mode (SCKx is the clock output)
- · Slave mode (SCKx is the clock input)
- Clock Polarity (Idle state of SCKx)
- Data Input Sample Phase (middle or end of data output time)
- Clock Edge (output data on rising/falling edge of SCKx)
- Clock Rate (Master mode only)
- · Slave Select mode (Slave mode only)

To enable the serial port, SSPx Enable bit, SSPxEN of the SSPxCON1 register, must be set. To reset or reconfigure SPI mode, clear the SSPxEN bit, re-initialize the SSPxCONx registers and then set the SSPxEN bit. This configures the SDIx, SDOx, SCKx and SSx pins as serial port pins. For the pins to behave as the serial port function, some must have their data direction bits (in the TRIS register) appropriately programmed as follows:

- · SDIx must have corresponding TRIS bit set
- · SDOx must have corresponding TRIS bit cleared
- SCKx (Master mode) must have corresponding TRIS bit cleared
- SCKx (Slave mode) must have corresponding
   TRIS bit set
- SSx must have corresponding TRIS bit set

Any serial port function that is not desired may be overridden by programming the corresponding data direction (TRIS) register to the opposite value.

The MSSPx consists of a transmit/receive shift register (SSPxSR) and a buffer register (SSPxBUF). The SSPxSR shifts the data in and out of the device, MSb first. The SSPxBUF holds the data that was written to the SSPxSR until the received data is ready. Once the 8 bits of data have been received, that byte is moved to the SSPxBUF register. Then, the Buffer Full Detect bit, BF of the SSPxSTAT register, and the interrupt flag bit, SSPxIF, are set. This double-buffering of the received data (SSPxBUF) allows the next byte to start reception before reading the data that was just received. Any write to the **SSPxBUF** reaister durina transmission/reception of data will be ignored and the write collision detect bit WCOL of the SSPxCON1 register, will be set. User software must clear the WCOL bit to allow the following write(s) to the SSPxBUF register to complete successfully.

When the application software is expecting to receive valid data, the SSPxBUF should be read before the next byte of data to transfer is written to the SSPxBUF. The Buffer Full bit, BF of the SSPxSTAT register, indicates when SSPxBUF has been loaded with the received data (transmission is complete). When the SSPxBUF is read, the BF bit is cleared. This data may be irrelevant if the SPI is only a transmitter. Generally, the MSSPx interrupt is used to determine when the transmission/reception has completed. If the interrupt method is not going to be used, then software polling can be done to ensure that a write collision does not occur.



#### FIGURE 25-5: SPI MASTER/SLAVE CONNECTION

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

## 25.3.1 CLOCK STRETCHING

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

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

## 25.3.2 ARBITRATION

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

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

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

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

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

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

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

#### 25.5.2 SLAVE RECEPTION

When the  $R/\overline{W}$  bit of a matching received address byte is clear, the  $R/\overline{W}$  bit of the SSPxSTAT register is cleared. The received address is loaded into the SSPx-BUF register and acknowledged.

When the overflow condition exists for a received address, then not Acknowledge is given. An overflow condition is defined as either bit BF of the SSPxSTAT register is set, or bit SSPxOV of the SSPxCON1 register is set. The BOEN bit of the SSPxCON3 register modifies this operation. For more information see Register 25-4.

An MSSPx interrupt is generated for each transferred data byte. Flag bit, SSPxIF, must be cleared by software.

When the SEN bit of the SSPxCON2 register is set, SCLx will be held low (clock stretch) following each received byte. The clock must be released by setting the CKP bit of the SSPxCON1 register, except sometimes in 10-bit mode. See Section 25.2.3 "SPI Master Mode" for more detail.

#### 25.5.2.1 7-bit Addressing Reception

This section describes a standard sequence of events for the MSSPx module configured as an  $I^2C$  Slave in 7-bit Addressing mode. All decisions made by hardware or software and their effect on reception. Figure 25-13 and Figure 25-14 is used as a visual reference for this description.

This is a step by step process of what typically must be done to accomplish  $I^2C$  communication.

- 1. Start bit detected.
- 2. S bit of SSPxSTAT is set; SSPxIF is set if interrupt on Start detect is enabled.
- 3. Matching address with  $R/\overline{W}$  bit clear is received.
- 4. The slave pulls SDAx low sending an ACK to the master, and sets SSPxIF bit.
- 5. Software clears the SSPxIF bit.
- 6. Software reads received address from SSPx-BUF clearing the BF flag.
- 7. If SEN = 1; Slave software sets CKP bit to release the SCLx line.
- 8. The master clocks out a data byte.
- 9. Slave drives SDAx low sending an ACK to the master, and sets SSPxIF bit.
- 10. Software clears SSPxIF.
- 11. Software reads the received byte from SSPx-BUF clearing BF.
- 12. Steps 8-12 are repeated for all received bytes from the Master.
- 13. Master sends Stop condition, setting P bit of SSPxSTAT, and the bus goes Idle.

#### 25.5.2.2 7-bit Reception with AHEN and DHEN

Slave device reception with AHEN and DHEN set operate the same as without these options with extra interrupts and clock stretching added after the 8th falling edge of SCLx. These additional interrupts allow the slave software to decide whether it wants to ACK the receive address or data byte, rather than the hardware. This functionality adds support for PMBus<sup>™</sup> that was not present on previous versions of this module.

This list describes the steps that need to be taken by slave software to use these options for  $I^2C$  communcation. Figure 25-15 displays a module using both address and data holding. Figure 25-16 includes the operation with the SEN bit of the SSPxCON2 register set.

- 1. S bit of SSPxSTAT is set; SSPxIF is set if interrupt on Start detect is enabled.
- Matching address with R/W bit clear is clocked in. SSPxIF is set and CKP cleared after the 8th falling edge of SCLx.
- 3. Slave clears the SSPxIF.
- Slave can look at the ACKTIM bit of the SSPxCON3 register to determine if the SSPxIF was after or before the ACK.
- 5. Slave reads the address value from SSPxBUF, clearing the BF flag.
- 6. Slave sets ACK value clocked out to the master by setting ACKDT.
- 7. Slave releases the clock by setting CKP.
- 8. SSPxIF is set after an ACK, not after a NACK.
- 9. If SEN = 1 the slave hardware will stretch the clock after the ACK.

10. Slave clears SSPxIF.

Note: SSPxIF is still set after the 9th falling edge of SCLx even if there is no clock stretching and BF has been cleared. Only if NACK is sent to Master is SSPxIF not set

- 11. SSPxIF set and CKP cleared after 8th falling edge of SCLx for a received data byte.
- 12. Slave looks at ACKTIM bit of SSPxCON3 to determine the source of the interrupt.
- 13. Slave reads the received data from SSPxBUF clearing BF.
- 14. Steps 7-14 are the same for each received data byte.
- 15. Communication is ended by either the slave sending an ACK = 1, or the master sending a Stop condition. If a Stop is sent and Interrupt on Stop Detect is disabled, the slave will only know by polling the P bit of the SSTSTAT register.

| Name                | Bit 7                                  | Bit 6   | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0                 | Reset<br>Values on<br>Page: |
|---------------------|----------------------------------------|---------|--------|--------|--------|--------|--------|-----------------------|-----------------------------|
| INTCON              | GIE                                    | PEIE    | TMR0IE | INTE   | IOCIE  | TMR0IF | INTF   | IOCIF                 | 86                          |
| PIE1                | TMR1GIE                                | ADIE    | RCIE   | TXIE   | SSP1IE | CCP1IE | TMR2IE | TMR1IE                | 87                          |
| PIE2                | OSFIE                                  | C2IE    | C1IE   | EEIE   | BCL1IE | —      | _      | CCP2IE <sup>(1)</sup> | 88                          |
| PIE4 <sup>(1)</sup> | —                                      | _       | _      | _      | _      | —      | BCL2IE | SSP2IE                | 90                          |
| PIR1                | TMR1GIF                                | ADIF    | RCIF   | TXIF   | SSP1IF | CCP1IF | TMR2IF | TMR1IF                | 91                          |
| PIR2                | OSFIF                                  | C2IF    | C1IF   | EEIF   | BCL1IF | _      | _      | CCP2IF <sup>(1)</sup> | 92                          |
| PIR4 <sup>(1)</sup> | —                                      | _       | —      | _      | —      | —      | BCL2IF | SSP2IF                | 94                          |
| TRISA               | TRISA7                                 | TRISA6  | TRISA5 | TRISA4 | TRISA3 | TRISA2 | TRISA1 | TRISA0                | 122                         |
| TRISB               | TRISB7                                 | TRISB6  | TRISB5 | TRISB4 | TRISB3 | TRISB2 | TRISB1 | TRISB0                | 127                         |
| SSPxADD             | ADD7                                   | ADD6    | ADD5   | ADD4   | ADD3   | ADD2   | ADD1   | ADD0                  | 283                         |
| SSPxBUF             | MSSPx Receive Buffer/Transmit Register |         |        |        |        | 235*   |        |                       |                             |
| SSPxCON1            | WCOL                                   | SSPOV   | SSPEN  | CKP    | SSPM3  | SSPM2  | SSPM1  | SSPM0                 | 280                         |
| SSPxCON2            | GCEN                                   | ACKSTAT | ACKDT  | ACKEN  | RCEN   | PEN    | RSEN   | SEN                   | 281                         |
| SSPxCON3            | ACKTIM                                 | PCIE    | SCIE   | BOEN   | SDAHT  | SBCDE  | AHEN   | DHEN                  | 282                         |
| SSPxMSK             | MSK7                                   | MSK6    | MSK5   | MSK4   | MSK3   | MSK2   | MSK1   | MSK0                  | 283                         |
| SSPxSTAT            | SMP                                    | CKE     | D/A    | Р      | S      | R/W    | UA     | BF                    | 279                         |

## TABLE 25-3: SUMMARY OF REGISTERS ASSOCIATED WITH I<sup>2</sup>C<sup>™</sup> OPERATION

Legend: -= unimplemented, read as '0'. Shaded cells are not used by the MSSP module in I<sup>2</sup>C<sup>™</sup> mode. \* Page provides register information.

Note 1: PIC16(L)F1827 only.

## 28.0 IN-CIRCUIT SERIAL PROGRAMMING<sup>™</sup> (ICSP<sup>™</sup>)

ICSP<sup>™</sup> programming allows customers to manufacture circuit boards with unprogrammed devices. Programming can be done after the assembly process allowing the device to be programmed with the most recent firmware or a custom firmware. Five pins are needed for ICSP<sup>™</sup> programming:

- ICSPCLK
- ICSPDAT
- MCLR/VPP
- VDD
- Vss

In Program/Verify mode the Program Memory, User IDs and the Configuration Words are programmed through serial communications. The ICSPDAT pin is a bidirectional I/O used for transferring the serial data and the ICSPCLK pin is the clock input. For more information on ICSP<sup>TM</sup> refer to the "PIC16(L)F182X/PIC12(L)F1822 Memory Programming Specification" (DS41390).

## 28.1 High-Voltage Programming Entry Mode

The device is placed into High-Voltage Programming Entry mode by holding the ICSPCLK and ICSPDAT pins low then raising the voltage on MCLR/VPP to VIHH.

Some programmers produce VPP greater than VIHH (9.0V), an external circuit is required to limit the VPP voltage. See Figure 28-1 for example circuit.



FIGURE 28-1: VPP LIMITER EXAMPLE CIRCUIT

PIC16(L)F1826/27.

## 29.0 INSTRUCTION SET SUMMARY

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

- Byte Oriented
- · Bit Oriented
- Literal and Control

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

Table 29-3 lists the instructions recognized by the MPASM<sup>TM</sup> assembler.

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

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

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

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

## 29.1 Read-Modify-Write Operations

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

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

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

#### TABLE 29-2: ABBREVIATION DESCRIPTIONS

| Field | Description     |  |  |
|-------|-----------------|--|--|
| PC    | Program Counter |  |  |
| TO    | Time-out bit    |  |  |
| С     | Carry bit       |  |  |
| DC    | Digit carry bit |  |  |
| Z     | Zero bit        |  |  |
| PD    | Power-down bit  |  |  |

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

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

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

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

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

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

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

is

## 30.1 DC Characteristics: PIC16(L)F1826/27-I/E (Industrial, Extended)

| PIC16LF1826/27                                      |         |                                                           | $\begin{array}{ll} \mbox{Standard Operating Conditions (unless otherwise stated)} \\ \mbox{Operating temperature} & -40^\circ C \leq TA \leq +85^\circ C \mbox{ for industrial} \\ -40^\circ C \leq TA \leq +125^\circ C \mbox{ for extended} \end{array}$ |                                                      |            |        |                                                        |  |
|-----------------------------------------------------|---------|-----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|------------|--------|--------------------------------------------------------|--|
| PIC16F1826/27                                       |         |                                                           |                                                                                                                                                                                                                                                            | $\begin{array}{llllllllllllllllllllllllllllllllllll$ |            |        |                                                        |  |
| Param. Sym. Characteristic<br>No.                   |         |                                                           | Min.                                                                                                                                                                                                                                                       | Тур†                                                 | Max.       | Units  | Conditions                                             |  |
| D001                                                | Vdd     | Supply Voltage                                            |                                                                                                                                                                                                                                                            |                                                      |            |        |                                                        |  |
|                                                     |         | PIC16LF1826/27                                            | 1.8<br>2.5                                                                                                                                                                                                                                                 | -                                                    | 3.6<br>3.6 | V<br>V | Fosc ≤ 16 MHz:<br>Fosc ≤ 32 MHz ( <b>NOTE 2</b> )      |  |
| D001                                                |         | PIC16F1826/27                                             | 1.8<br>2.5                                                                                                                                                                                                                                                 | -                                                    | 5.5<br>5.5 | V<br>V | Fosc ≤ 16 MHz:<br>Fosc ≤ 32 MHz ( <b>NOTE 2</b> )      |  |
| D002* VDR RAM Data Retention Voltage <sup>(1)</sup> |         |                                                           |                                                                                                                                                                                                                                                            |                                                      |            |        |                                                        |  |
|                                                     |         | PIC16LF1826/27                                            | 1.5                                                                                                                                                                                                                                                        | -                                                    | _          | V      | Device in Sleep mode                                   |  |
| D002*                                               |         | PIC16F1826/27                                             | 1.7                                                                                                                                                                                                                                                        |                                                      |            | V      | Device in Sleep mode                                   |  |
|                                                     | VPOR*   | Power-on Reset Release Voltage                            |                                                                                                                                                                                                                                                            | 1.6                                                  | —          | V      |                                                        |  |
|                                                     | VPORR*  | Power-on Reset Rearm Voltage                              | -                                                                                                                                                                                                                                                          |                                                      |            |        |                                                        |  |
|                                                     |         | PIC16LF1826/27                                            | _                                                                                                                                                                                                                                                          | 0.8                                                  | —          | V      | Device in Sleep mode                                   |  |
|                                                     |         | PIC16F1826/27                                             |                                                                                                                                                                                                                                                            | 1.7                                                  | —          | V      | Device in Sleep mode                                   |  |
| D003                                                | VADFVR  | Fixed Voltage Reference Voltage for                       | -8                                                                                                                                                                                                                                                         | —                                                    | 6          | %      | 1.024V, VDD $\geq$ 2.5V                                |  |
|                                                     |         | ADC                                                       | -8                                                                                                                                                                                                                                                         | —                                                    | 6          |        | $2.048V, VDD \ge 2.5V$                                 |  |
| D0034                                               |         | Fixed Voltage Reference Voltage for                       | -0                                                                                                                                                                                                                                                         |                                                      | 7          | 0/.    | $4.096V, VDD \ge 4.75$                                 |  |
| DUUSA                                               | VCDAFVR | Comparator and DAC                                        | -11                                                                                                                                                                                                                                                        | _                                                    | 7          | 70     | $2.048V. VDD \ge 2.5V$                                 |  |
|                                                     |         | • • • • • • •                                             | -11                                                                                                                                                                                                                                                        | _                                                    | 7          |        | $4.096V, VDD \ge 4.75$                                 |  |
| D004*                                               | SVDD    | VDD Rise Rate to ensure internal<br>Power-on Reset signal | 0.05                                                                                                                                                                                                                                                       | -                                                    | -          | V/ms   | See Section 7.1 "Power-on Reset<br>(POR)" for details. |  |

These parameters are characterized but not tested.

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

Note 1: This is the limit to which VDD can be lowered in Sleep mode without losing RAM data.

2: PLL required for 32 MHz operation.

\*



FIGURE 31-3: VOH VS. IOH OVER TEMPERATURE (VDD = 3.0V)



