



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Active                                                                    |
|----------------------------|---------------------------------------------------------------------------|
| Core Processor             | PIC                                                                       |
| Core Size                  | 8-Bit                                                                     |
| Speed                      | 32MHz                                                                     |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                         |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                     |
| Number of I/O              | 16                                                                        |
| Program Memory Size        | 7KB (4K x 14)                                                             |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | 256 x 8                                                                   |
| RAM Size                   | 384 x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 5.5V                                                               |
| 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/pic16f1827-i-ss |

Email: info@E-XFL.COM

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

# TO OUR VALUED CUSTOMERS

It is our intention to provide our valued customers with the best documentation possible to ensure successful use of your Microchip products. To this end, we will continue to improve our publications to better suit your needs. Our publications will be refined and enhanced as new volumes and updates are introduced.

If you have any questions or comments regarding this publication, please contact the Marketing Communications Department via E-mail at **docerrors@microchip.com** or fax the **Reader Response Form** in the back of this data sheet to (480) 792-4150. We welcome your feedback.

#### **Most Current Data Sheet**

To obtain the most up-to-date version of this data sheet, please register at our Worldwide Web site at:

#### http://www.microchip.com

You can determine the version of a data sheet by examining its literature number found on the bottom outside corner of any page. The last character of the literature number is the version number, (e.g., DS30000A is version A of document DS30000).

#### Errata

An errata sheet, describing minor operational differences from the data sheet and recommended workarounds, may exist for current devices. As device/documentation issues become known to us, we will publish an errata sheet. The errata will specify the revision of silicon and revision of document to which it applies.

To determine if an errata sheet exists for a particular device, please check with one of the following:

- Microchip's Worldwide Web site; http://www.microchip.com
- Your local Microchip sales office (see last page)

When contacting a sales office, please specify which device, revision of silicon and data sheet (include literature number) you are using.

#### **Customer Notification System**

Register on our web site at www.microchip.com to receive the most current information on all of our products.

# TABLE 3-3:PIC16(L)F1826/27 MEMORY MAP (CONTINUED)

|              | BANK16                                |              | BANK17                                |              | BANK18                                |              | BANK19                                |              | BANK20                                |              | BANK21                                |              | BANK22                                |              | BANK23                                |
|--------------|---------------------------------------|--------------|---------------------------------------|--------------|---------------------------------------|--------------|---------------------------------------|--------------|---------------------------------------|--------------|---------------------------------------|--------------|---------------------------------------|--------------|---------------------------------------|
| 800h         | Core Registers<br>(Table 3-2)         | 880h         | Core Registers<br>(Table 3-2)         | 900h         | Core Registers<br>(Table 3-2)         | 980h         | Core Registers<br>(Table 3-2)         | A00h         | Core Registers<br>(Table 3-2)         | A80h         | Core Registers<br>(Table 3-2)         | B00h         | Core Registers<br>(Table 3-2)         | B80h         | Core Registers<br>(Table 3-2)         |
| 80Bh         | ( ,                                   | 88Bh         | ( ,                                   | 90Bh         | ( ,                                   | 98Bh         | ( ••••• )                             | A0Bh         | (                                     | A8Bh         | ( ••••• )                             | B0Bh         | ( ••••• )                             | B8Bh         | ( ,                                   |
| 80Ch         |                                       | 88Ch         |                                       | 90Ch         |                                       | 98Ch         |                                       | A0Ch         |                                       | A8Ch         |                                       | B0Ch         |                                       | B8Ch         |                                       |
|              | Unimplemented<br>Read as '0'          |
| 86Fh         |                                       | 8EFh         |                                       | 96Fh         |                                       | 9EFh         |                                       | A6Fh         |                                       | AEFh         |                                       | B6Fh         |                                       | BEFh         |                                       |
| 870h<br>87Fh | Common RAM<br>(Accesses<br>70h – 7Fh) | 8F0h<br>8FFh | Common RAM<br>(Accesses<br>70h – 7Fh) | 970h<br>97Fh | Common RAM<br>(Accesses<br>70h – 7Fh) | 9F0h<br>9FFh | Common RAM<br>(Accesses<br>70h – 7Fh) | A70h<br>A7Fh | Common RAM<br>(Accesses<br>70h – 7Fh) | AF0h<br>AFFh | Common RAM<br>(Accesses<br>70h – 7Fh) | B70h<br>B7Fh | Common RAM<br>(Accesses<br>70h – 7Fh) | BF0h<br>BFFh | Common RAM<br>(Accesses<br>70h – 7Fh) |

|      | BANK 24                       |      | BANK 25                       |      | BANK 26                       |      | BANK 27                       |      | BANK 28                       |      | BANK 29                       |      | BANK 30                               |              | BANK 31                               |
|------|-------------------------------|------|-------------------------------|------|-------------------------------|------|-------------------------------|------|-------------------------------|------|-------------------------------|------|---------------------------------------|--------------|---------------------------------------|
| C00h | Core Registers<br>(Table 3-2) | C80h | Core Registers<br>(Table 3-2) | D00h | Core Registers<br>(Table 3-2) | D80h | Core Registers<br>(Table 3-2) | E00h | Core Registers<br>(Table 3-2) | E80h | Core Registers<br>(Table 3-2) | F00h | Core Registers<br>(Table 3-2)         | F80h         | Core Registers<br>(Table 3-2)         |
| C0Bh |                               | C8Bh |                               | D0Bh |                               | D8Bh |                               | E0Bh |                               | E8Bh |                               | F0Bh |                                       | F8Bh         |                                       |
| C0Ch |                               | C8Ch |                               | D0Ch |                               | D8Ch |                               | E0Ch |                               | E8Ch |                               | F0Ch |                                       | F8Ch         |                                       |
|      | Unimplemented<br>Read as '0'          | F9Fh         | Read as '0'                           |
| C6Fh |                               | CEFh |                               | D6Fh |                               | DEFh |                               | E6Fh |                               | EEFh |                               | F6Fh |                                       | FA0h<br>FEFh | See Table 3-4 for more information    |
| C70h | Accesses<br>70h – 7Fh         | CF0h | Accesses<br>70h – 7Fh         | D70h | Accesses<br>70h – 7Fh         | DF0h | Accesses<br>70h – 7Fh         | E70h | Accesses<br>70h – 7Fh         | EF0h | Accesses<br>70h – 7Fh         | F70h | Common RAM<br>(Accesses<br>70h – 7Fh) | FF0h         | Common RAM<br>(Accesses<br>70h – 7Fh) |
| C7Fh |                               | CFFh |                               | D7Fh |                               | DFFh |                               | E7Fh |                               | EFFh |                               | F7Fh |                                       | FFFh         |                                       |

Legend: = Unimplemented data memory locations, read as '0'

# 7.0 RESETS

There are multiple ways to reset this device:

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

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

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

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



# 9.0 POWER-DOWN MODE (SLEEP)

The Power-Down mode is entered by executing a SLEEP instruction.

Upon entering Sleep mode, the following conditions exist:

- 1. WDT will be cleared but keeps running, if enabled for operation during Sleep.
- 2. PD bit of the STATUS register is cleared.
- 3.  $\overline{\text{TO}}$  bit of the STATUS register is set.
- 4. CPU clock is disabled.
- 5. 31 kHz LFINTOSC is unaffected and peripherals that operate from it may continue operation in Sleep.
- 6. Timer1 oscillator is unaffected and peripherals that operate from it may continue operation in Sleep.
- 7. ADC is unaffected, if the dedicated FRC clock is selected.
- 8. Capacitive Sensing oscillator is unaffected.
- I/O ports maintain the status they had before SLEEP was executed (driving high, low or highimpedance).
- 10. Resets other than WDT are not affected by Sleep mode.

Refer to individual chapters for more details on peripheral operation during Sleep.

To minimize current consumption, the following conditions should be considered:

- I/O pins should not be floating
- External circuitry sinking current from I/O pins
- · Internal circuitry sourcing current from I/O pins
- · Current draw from pins with internal weak pull-ups
- Modules using 31 kHz LFINTOSC
- Modules using Timer1 oscillator

I/O pins that are high-impedance inputs should be pulled to VDD or Vss externally to avoid switching currents caused by floating inputs.

Examples of internal circuitry that might be sourcing current include modules such as the DAC and FVR modules. See Section 17.0 "Digital-to-Analog Converter (DAC) Module" and Section 14.0 "Fixed Voltage Reference (FVR)" for more information on these modules.

#### 9.1 Wake-up from Sleep

The device can wake-up from Sleep through one of the following events:

- 1. External Reset input on MCLR pin, if enabled
- 2. BOR Reset, if enabled
- 3. POR Reset
- 4. Watchdog Timer, if enabled
- 5. Any external interrupt
- 6. Interrupts by peripherals capable of running during Sleep (see individual peripheral for more information)

The first three events will cause a device Reset. The last three events are considered a continuation of program execution. To determine whether a device Reset or wake-up event occurred, refer to **Section 7.10 "Determining the Cause of a Reset"**.

When the SLEEP instruction is being executed, the next instruction (PC + 1) is prefetched. For the device to wake-up through an interrupt event, the corresponding interrupt enable bit must be enabled. Wake-up will occur regardless of the state of the GIE bit. If the GIE bit is disabled, the device continues execution at the instruction after the SLEEP instruction. If the GIE bit is enabled, the device executes the instruction after the SLEEP instruction, the device will then call the Interrupt Service Routine. In cases where the execution of the instruction following SLEEP is not desirable, the user should have a NOP after the SLEEP instruction.

The WDT is cleared when the device wakes up from Sleep, regardless of the source of wake-up.

# 11.7 EEPROM and Flash Control Registers

## REGISTER 11-1: EEDATL: EEPROM LOW BYTE DATA 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     |
|------------------|---------|-----------------|---------|----------------|------------------|------------------|-------------|
|                  |         |                 | EEDA    | T<7:0>         |                  |                  |             |
| bit 7            |         |                 |         |                |                  |                  | bit 0       |
|                  |         |                 |         |                |                  |                  |             |
| Legend:          |         |                 |         |                |                  |                  |             |
| R = Readable     | bit     | W = Writable    | bit     | U = Unimpler   | mented bit, read | as '0'           |             |
| u = Bit is uncha | anged   | x = Bit is unkr | nown    | -n/n = Value : | at POR and BO    | R/Value at all o | ther Resets |

bit 7-0 EEDAT<7:0>: Read/write value for EEPROM data byte or Least Significant bits of program memory

#### REGISTER 11-2: EEDATH: EEPROM DATA HIGH BYTE REGISTER

'0' = Bit is cleared

| U-0   | U-0 | R/W-x/u | R/W-x/u | R/W-x/u | R/W-x/u | R/W-x/u | R/W-x/u |
|-------|-----|---------|---------|---------|---------|---------|---------|
| —     | —   |         |         | EEDA    | T<13:8> |         |         |
| bit 7 |     |         |         |         |         |         | bit 0   |

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

bit 7-6 Unimplemented: Read as '0'

'1' = Bit is set

bit 5-0 **EEDAT<13:8>**: Read/write value for Most Significant bits of program memory

#### REGISTER 11-3: EEADRL: EEPROM ADDRESS REGISTER

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

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

bit 7-0 EEADR<7:0>: Specifies the Least Significant bits for program memory address or EEPROM address

### 16.4 A/D Acquisition Requirements

For the ADC to meet its specified accuracy, the charge holding capacitor (CHOLD) must be allowed to fully charge to the input channel voltage level. The Analog Input model is shown in Figure 16-4. The source impedance (Rs) and the internal sampling switch (Rss) impedance directly affect the time required to charge the capacitor CHOLD. The sampling switch (Rss) impedance varies over the device voltage (VDD), refer to Figure 16-4. The maximum recommended impedance for analog sources is 10 k $\Omega$ . As the

source impedance is decreased, the acquisition time may be decreased. After the analog input channel is selected (or changed), an A/D acquisition must be done before the conversion can be started. To calculate the minimum acquisition time, Equation 16-1 may be used. This equation assumes that 1/2 LSb error is used (1,024 steps for the ADC). The 1/2 LSb error is the maximum error allowed for the ADC to meet its specified resolution.

#### EQUATION 16-1: ACQUISITION TIME EXAMPLE

Assumptions: Temperature = 
$$50^{\circ}C$$
 and external impedance of  $10k\Omega 5.0V$  VDD  
 $TACQ = Amplifier Settling Time + Hold Capacitor Charging Time + Temperature Coefficient$   
 $= TAMP + TC + TCOFF$   
 $= 2\mu s + TC + [(Temperature - 25^{\circ}C)(0.05\mu s/^{\circ}C)]$ 

*The value for TC can be approximated with the following equations:* 

$$V_{APPLIED}\left(1 - \frac{1}{(2^{n+1}) - 1}\right) = V_{CHOLD} \qquad ;[1] V_{CHOLD} charged to within 1/2 lsb$$

$$V_{APPLIED}\left(1 - e^{\frac{-Tc}{RC}}\right) = V_{CHOLD} \qquad ;[2] V_{CHOLD} charge response to V_{APPLIED} \\V_{APPLIED}\left(1 - e^{\frac{-Tc}{RC}}\right) = V_{APPLIED}\left(1 - \frac{1}{(2^{n+1}) - 1}\right) \quad ;combining [1] and [2]$$

*Note:* Where n = number of bits of the ADC.

Solving for TC:

$$Tc = -CHOLD(RIC + RSS + RS) ln(1/511)$$
  
= -10pF(1k\Omega + 7k\Omega + 10k\Omega) ln(0.001957)  
= 1.12\mus

Therefore:

$$TACQ = 2\mu s + 1.12\mu s + [(50^{\circ}C - 25^{\circ}C)(0.05\mu s/^{\circ}C)]$$
  
= 4.42\mu s

**Note 1:** The reference voltage (VREF) has no effect on the equation, since it cancels itself out.

- 2: The charge holding capacitor (CHOLD) is not discharged after each conversion.
- **3:** The maximum recommended impedance for analog sources is  $10 \text{ k}\Omega$ . This is required to meet the pin leakage specification.

### 17.4 Low-Power Voltage State

In order for the DAC module to consume the least amount of power, one of the two voltage reference input sources to the resistor ladder must be disconnected. Either the positive voltage source, (VSOURCE+), or the negative voltage source, (VSOURCE-) can be disabled.

The negative voltage source is disabled by setting the DACLPS bit in the DACCON0 register. Clearing the DACLPS bit in the DACCON0 register disables the positive voltage source.

#### 17.4.1 OUTPUT CLAMPED TO POSITIVE VOLTAGE SOURCE

The DAC output voltage can be set to VSOURCE+ with the least amount of power consumption by performing the following:

- · Clearing the DACEN bit in the DACCON0 register.
- Setting the DACLPS bit in the DACCON0 register.
- Configuring the DACPSS bits to the proper positive source.
- Configuring the DACR<4:0> bits to '11111' in the DACCON1 register.

This is also the method used to output the voltage level from the FVR to an output pin. See **Section 17.5** "**Operation During Sleep**" for more information.

Reference Figure 17-3 for output clamping examples.

# 17.4.2 OUTPUT CLAMPED TO NEGATIVE VOLTAGE SOURCE

The DAC output voltage can be set to VSOURCE- with the least amount of power consumption by performing the following:

- · Clearing the DACEN bit in the DACCON0 register.
- Clearing the DACLPS bit in the DACCON0 register.
- Configuring the DACNSS bits to the proper negative source.
- Configuring the DACR<4:0> bits to '00000' in the DACCON1 register.

This allows the comparator to detect a zero-crossing while not consuming additional current through the DAC module.

Reference Figure 17-3 for output clamping examples.

#### FIGURE 17-3: OUTPUT VOLTAGE CLAMPING EXAMPLES



#### 17.5 Operation During Sleep

When the device wakes up from Sleep through an interrupt or a Watchdog Timer time-out, the contents of the DACCON0 register are not affected. To minimize current consumption in Sleep mode, the voltage reference should be disabled.

## 17.6 Effects of a Reset

A device Reset affects the following:

- DAC is disabled.
- DAC output voltage is removed from the DACOUT pin.
- The DACR<4:0> range select bits are cleared.
- © 2011 Microchip Technology Inc.

# PIC16(L)F1826/27

| 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      |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|-----------------------------------------------------|--------------------------------------|--------------------------|------------------|--------------|--|--|
| SRSPE                                                                                                                                                                                              | SRSCKE                                                                                                                                                                                                           | SRSC2E                                                 | SRSC1E                                              | SRRPE                                | SRRCKE                   | SRRC2E           | SRRC1E       |  |  |
| bit 7                                                                                                                                                                                              |                                                                                                                                                                                                                  |                                                        |                                                     |                                      |                          |                  | bit 0        |  |  |
|                                                                                                                                                                                                    |                                                                                                                                                                                                                  |                                                        |                                                     |                                      |                          |                  |              |  |  |
| Legend:                                                                                                                                                                                            |                                                                                                                                                                                                                  |                                                        |                                                     |                                      |                          |                  |              |  |  |
| R = Readable                                                                                                                                                                                       | bit                                                                                                                                                                                                              | W = Writable                                           | bit                                                 | U = Unimplemented bit, read as '0'   |                          |                  |              |  |  |
| u = Bit is uncha                                                                                                                                                                                   | anged                                                                                                                                                                                                            | x = Bit is unkr                                        | nown                                                | -n/n = Value a                       | at POR and BO            | R/Value at all o | other Resets |  |  |
| '1' = Bit is set                                                                                                                                                                                   |                                                                                                                                                                                                                  | '0' = Bit is cle                                       | ared                                                |                                      |                          |                  |              |  |  |
| bit 7 SRSPE: SR Latch Peripheral Set Enable bit<br>1 = SR Latch is set when the SRI pin is high.                                                                                                   |                                                                                                                                                                                                                  |                                                        |                                                     |                                      |                          |                  |              |  |  |
| <ul> <li>bit 6</li> <li>SRSCKE: SR Latch Set Clock Enable bit</li> <li>1 = Set input of SR Latch is pulsed with SRCLK</li> <li>0 = SRCLK has no effect on the set input of the SR Latch</li> </ul> |                                                                                                                                                                                                                  |                                                        |                                                     |                                      |                          |                  |              |  |  |
| bit 5                                                                                                                                                                                              | SRSC2E: SR<br>1 = SR Latch<br>0 = C2 Comp                                                                                                                                                                        | Latch C2 Set<br>is set when th<br>parator output I     | Enable bit<br>le C2 Compara<br>nas no effect o      | ator output is hi<br>n the set input | gh<br>of the SR Latch    | 1                |              |  |  |
| bit 4                                                                                                                                                                                              | <b>SRSC1E:</b> SR<br>1 = SR Latch<br>0 = C1 Comp                                                                                                                                                                 | Latch C1 Set<br>is set when th<br>parator output h     | Enable bit<br>le C1 Compara<br>nas no effect o      | ator output is hi<br>n the set input | gh<br>of the SR Latch    | 1                |              |  |  |
| bit 3                                                                                                                                                                                              | <b>SRRPE:</b> SR I<br>1 = SR Latch<br>0 = SRI pin h                                                                                                                                                              | Latch Periphera<br>i is reset when<br>nas no effect or | al Reset Enabl<br>the SRI pin is<br>hthe reset inpu | e bit<br>high.<br>ut of the SR Lat   | tch                      |                  |              |  |  |
| bit 2                                                                                                                                                                                              | bit 2 SRRCKE: SR Latch Reset Clock Enable bit<br>1 = Reset input of SR Latch is pulsed with SRCLK<br>0 = SRCLK has no effect on the reset input of the SR Latch                                                  |                                                        |                                                     |                                      |                          |                  |              |  |  |
| bit 1                                                                                                                                                                                              | <ul> <li>SRRC2E: SR Latch C2 Reset Enable bit</li> <li>1 = SR Latch is reset when the C2 Comparator output is high</li> <li>0 = C2 Comparator output has no effect on the reset input of the SR Latch</li> </ul> |                                                        |                                                     |                                      |                          |                  |              |  |  |
| bit 0                                                                                                                                                                                              | <b>SRRC1E:</b> SR<br>1 = SR Latch<br>0 = C1 Comp                                                                                                                                                                 | Latch C1 Res<br>is reset when<br>parator output h      | et Enable bit<br>the C1 Compa<br>nas no effect o    | arator output is<br>n the reset inpu | high<br>ut of the SR Lat | tch              |              |  |  |

#### REGISTER 18-2: SRCON1: SR LATCH CONTROL 1 REGISTER

#### 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.

# PIC16(L)F1826/27



# PIC16(L)F1826/27



# FIGURE 21-4: TIMER1 GATE TOGGLE MODE



| PxM< | 1:0>                      | Signal        | 0 ◀ Pulse<br>Width | <b>→</b> | PRx+1                                 |
|------|---------------------------|---------------|--------------------|----------|---------------------------------------|
|      |                           |               | -                  | Period — |                                       |
| 00   | (Single Output)           | PxA Modulated |                    |          |                                       |
|      |                           | PxA Modulated |                    | Delay    |                                       |
| 10   | (Half-Bridge)             | PxB Modulated |                    |          |                                       |
|      |                           | PxA Active    | _                  |          | · · · · · · · · · · · · · · · · · · · |
| 01   | (Full-Bridge,<br>Forward) | PxB Inactive  | - :                |          |                                       |
|      | ,                         | PxC Inactive  |                    |          |                                       |
|      |                           | PxD Modulated |                    |          |                                       |
|      |                           | PxA Inactive  |                    |          |                                       |
| 11   | (Full-Bridge,             | PxB Modulated |                    | [        |                                       |
|      | Reverse)                  | PxC Active    |                    |          |                                       |
|      |                           | PxD Inactive  | -                  |          |                                       |
|      |                           |               |                    |          |                                       |

#### EXAMPLE ENHANCED PWM OUTPUT RELATIONSHIPS (ACTIVE-LOW STATE) FIGURE 24-7.

Pulse Width = Tosc \* (CCPRxL<7:0>:CCPxCON<5:4>) \* (TMRx Prescale Value)
Delay = 4 \* Tosc \* (PWMxCON<6:0>)

#### 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.6.2 CLOCK ARBITRATION

Clock arbitration occurs when the master, during any receive, transmit or Repeated Start/Stop condition, releases the SCLx pin (SCLx allowed to float high). When the SCLx pin is allowed to float high, the Baud Rate Generator (BRG) is suspended from counting until the SCLx pin is actually sampled high. When the SCLx pin is sampled high, the Baud Rate Generator is reloaded with the contents of SSPxADD<7:0> and begins counting. This ensures that the SCLx high time will always be at least one BRG rollover count in the event that the clock is held low by an external device (Figure 25-25).

![](_page_15_Figure_3.jpeg)

![](_page_15_Figure_4.jpeg)

#### 25.6.3 WCOL STATUS FLAG

If the user writes the SSPxBUF when a Start, Restart, Stop, Receive or Transmit sequence is in progress, the WCOL is set and the contents of the buffer are unchanged (the write does not occur). Any time the WCOL bit is set it indicates that an action on SSPxBUF was attempted while the module was not Idle.

| Note: | Because queueing of events is not       |
|-------|-----------------------------------------|
|       | allowed, writing to the lower 5 bits of |
|       | SSPxCON2 is disabled until the Start    |
|       | condition is complete.                  |

#### 25.6.5 I<sup>2</sup>C MASTER MODE REPEATED START CONDITION TIMING

A Repeated Start condition occurs when the RSEN bit of the SSPxCON2 register is programmed high and the Master state machine is no longer active. When the RSEN bit is set, the SCLx pin is asserted low. When the SCLx pin is sampled low, the Baud Rate Generator is loaded and begins counting. The SDAx pin is released (brought high) for one Baud Rate Generator count (TBRG). When the Baud Rate Generator times out, if SDAx is sampled high, the SCLx pin will be deasserted (brought high). When SCLx is sampled high, the Baud Rate Generator is reloaded and begins counting. SDAx and SCLx must be sampled high for one TBRG. This action is then followed by assertion of the SDAx pin (SDAx = 0) for one TBRG while SCLx is high. SCLx is asserted low. Following this, the RSEN bit of the SSPxCON2 register will be automatically cleared and the Baud Rate Generator will not be reloaded, leaving the SDAx pin held low. As soon as a Start condition is detected on the SDAx and SCLx pins, the S bit of the SSPxSTAT register will be set. The SSPxIF bit will not be set until the Baud Rate Generator has timed out.

- **Note 1:** If RSEN is programmed while any other event is in progress, it will not take effect.
  - **2:** A bus collision during the Repeated Start condition occurs if:
    - SDAx is sampled low when SCLx goes from low-to-high.
    - SCLx goes low before SDAx is asserted low. This may indicate that another master is attempting to transmit a data '1'.

#### FIGURE 25-27: REPEAT START CONDITION WAVEFORM

![](_page_16_Figure_9.jpeg)

#### 25.6.13.3 Bus Collision During a Stop Condition

Bus collision occurs during a Stop condition if:

- a) After the SDAx pin has been deasserted and allowed to float high, SDAx is sampled low after the BRG has timed out.
- b) After the SCLx pin is deasserted, SCLx is sampled low before SDAx goes high.

The Stop condition begins with SDAx asserted low. When SDAx is sampled low, the SCLx pin is allowed to float. When the pin is sampled high (clock arbitration), the Baud Rate Generator is loaded with SSPxADD and counts down to 0. After the BRG times out, SDAx is sampled. If SDAx is sampled low, a bus collision has occurred. This is due to another master attempting to drive a data '0' (Figure 25-37). If the SCLx pin is sampled low before SDAx is allowed to float high, a bus collision occurs. This is another case of another master attempting to drive a data '0' (Figure 25-38).

#### FIGURE 25-38: BUS COLLISION DURING A STOP CONDITION (CASE 1)

![](_page_17_Figure_7.jpeg)

#### FIGURE 25-39: BUS COLLISION DURING A STOP CONDITION (CASE 2)

![](_page_17_Figure_9.jpeg)

### 32.11 PICkit 2 Development Programmer/Debugger and PICkit 2 Debug Express

The PICkit<sup>™</sup> 2 Development Programmer/Debugger is a low-cost development tool with an easy to use interface for programming and debugging Microchip's Flash families of microcontrollers. The full featured Windows® programming interface supports baseline (PIC10F, PIC12F5xx, PIC16F5xx), midrange (PIC12F6xx, PIC16F), PIC18F, PIC24, dsPIC30, dsPIC33, and PIC32 families of 8-bit, 16-bit, and 32-bit microcontrollers, and many Microchip Serial EEPROM products. With Microchip's powerful MPLAB Integrated Development Environment (IDE) the PICkit<sup>™</sup> 2 enables in-circuit debugging on most PIC<sup>®</sup> microcontrollers. In-Circuit-Debugging runs, halts and single steps the program while the PIC microcontroller is embedded in the application. When halted at a breakpoint, the file registers can be examined and modified.

The PICkit 2 Debug Express include the PICkit 2, demo board and microcontroller, hookup cables and CDROM with user's guide, lessons, tutorial, compiler and MPLAB IDE software.

#### 32.12 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.

## 32.13 Demonstration/Development Boards, Evaluation Kits, and Starter Kits

A wide variety of demonstration, development and evaluation boards for various PIC MCUs and dsPIC DSCs allows quick application development on fully functional systems. Most boards include prototyping areas for adding custom circuitry and provide application firmware and source code for examination and modification.

The boards support a variety of features, including LEDs, temperature sensors, switches, speakers, RS-232 interfaces, LCD displays, potentiometers and additional EEPROM memory.

The demonstration and development boards can be used in teaching environments, for prototyping custom circuits and for learning about various microcontroller applications.

In addition to the PICDEM<sup>™</sup> and dsPICDEM<sup>™</sup> demonstration/development board series of circuits, Microchip has a line of evaluation kits and demonstration software for analog filter design, KEELOQ<sup>®</sup> security ICs, CAN, IrDA<sup>®</sup>, PowerSmart battery management, SEEVAL<sup>®</sup> evaluation system, Sigma-Delta ADC, flow rate sensing, plus many more.

Also available are starter kits that contain everything needed to experience the specified device. This usually includes a single application and debug capability, all on one board.

Check the Microchip web page (www.microchip.com) for the complete list of demonstration, development and evaluation kits.

# PIC16(L)F1826/27

| Enhanced Universal Synchronous Asynchronous       |       |
|---------------------------------------------------|-------|
| Receiver Transmitter (EUSART)                     | 285   |
| Errata                                            | 8     |
| EUSART                                            | . 285 |
| Associated Registers                              |       |
| Baud Rate Generator                               | .298  |
| Asynchronous Mode                                 | .287  |
| 12-bit Break Transmit and Receive                 | 305   |
| Associated Registers                              | 000   |
|                                                   | .293  |
| i ransmit                                         | .289  |
| Auto-wake-up on Break                             | . 303 |
| Baud Rate Generator (BRG)                         | . 297 |
| Clock Accuracy                                    | .294  |
| Receiver                                          | 290   |
| Setting up 9-bit Mode with Address Detect         | . 292 |
| I ransmitter                                      | . 287 |
| Baud Rate Generator (BRG)                         | 200   |
| Auto Baud Rate Detect                             | . 302 |
| Baud Rate Error, Calculating                      | . 297 |
| Baud Rates, Asynchronous Modes                    | 299   |
| Formulas                                          | . 298 |
| High Baud Rate Select (BRGH Bit)                  | . 297 |
| Synchronous Master Mode                           | 311   |
|                                                   | 210   |
| Tranomit                                          | 200   |
| Percention                                        | 200   |
| Tronomission                                      | 208   |
| Synchronous Slove Mede                            | . 300 |
|                                                   |       |
| Receive                                           | 310   |
| Transmit                                          | 211   |
| Recention                                         | 312   |
| Transmission                                      | 311   |
| Extended Instruction Set                          | 511   |
|                                                   | 320   |
|                                                   | 020   |
| F                                                 |       |
| Fail-Safe Clock Monitor                           | 63    |
| Fail-Safe Condition Clearing                      | 63    |
| Fail-Safe Detection                               | 63    |
| Fail-Safe Operation                               | 63    |
| Reset or Wake-up from Sleep                       | 63    |
| Firmware Instructions                             | . 325 |
| Fixed Voltage Reference (FVR)                     |       |
| Associated Registers                              | . 136 |
| Flash Program Memory                              | . 101 |
| Erasing                                           | . 107 |
| Modifying                                         | . 111 |
| Writing                                           | . 107 |
| FSR Register                                      | 27    |
| FVRCON (Fixed Voltage Reference Control) Register | . 136 |

#### | |<sup>2</sup>(

| C Mode (MSSPx)                    |          |
|-----------------------------------|----------|
| Acknowledge Sequence Timing       |          |
| Bus Collision                     |          |
| During a Repeated Start Condition |          |
| During a Stop Condition           |          |
| Effects of a Reset                | 271      |
| I <sup>2</sup> C Clock Rate w/BRG |          |
| Master Mode                       |          |
| Operation                         |          |
| Reception                         |          |
| Start Condition Timing            | 264, 265 |
|                                   |          |

| Transmission                                  | 266      |
|-----------------------------------------------|----------|
| Multi Master Communication, Bug Colligion and | 200      |
| Multi-Master Communication, Bus Comsion and   | 074      |
| Arbitration                                   | 271      |
| Multi-Master Mode                             | 271      |
| Read/Write Bit Information (R/W Bit)          | 247      |
| Slave Mode                                    |          |
| Transmission                                  | 252      |
| Sleep Operation                               | 271      |
| Stop Condition Timing                         | 270      |
|                                               | 27       |
| Indiract Addressing                           | 21<br>20 |
|                                               | 39       |
| Instruction Format                            | 326      |
| Instruction Set                               | 325      |
| ADDLW                                         | 329      |
| ADDWF                                         | 329      |
| ADDWFC                                        | 329      |
| ANDLW.                                        | 329      |
|                                               | 329      |
| RDA                                           | 330      |
|                                               | 000      |
|                                               | 331      |
| CALLW                                         | 331      |
| LSLF                                          | 333      |
| LSRF                                          | 333      |
| MOVF                                          | 333      |
| MOVIW                                         | 334      |
| MOVIB                                         | 334      |
| MOV/WI                                        | 335      |
|                                               | 225      |
|                                               | 335      |
| RESEI                                         | 335      |
| SUBWFB                                        | 337      |
| TRIS                                          | 338      |
| BCF                                           | 330      |
| BSF                                           | 330      |
| BTESC                                         | 330      |
| BTESS                                         | 330      |
|                                               | 221      |
|                                               | 221      |
|                                               | 331      |
| CLRW                                          | 331      |
| CLRWDT                                        | 331      |
| COMF                                          | 331      |
| DECF                                          | 331      |
| DECFSZ                                        | 332      |
| GOTO                                          | 332      |
| INCE                                          | 332      |
|                                               | 222      |
|                                               | 332      |
|                                               | 332      |
| IORWF                                         | 332      |
| MOVLW                                         | 334      |
| MOVWF                                         | 334      |
| NOP                                           | 335      |
| RETFIE                                        | 336      |
| RETI W                                        | 336      |
|                                               | 336      |
|                                               | 330      |
| RLF                                           | 336      |
| RRF                                           | 337      |
| SLEEP                                         | 337      |
| SUBLW                                         | 337      |
| SUBWF                                         | 337      |
| SWAPF                                         | 338      |
| XORLW                                         | 338      |
| XORWE                                         | 335      |
|                                               | 000      |
| Internal Opeillator Black                     | 00       |
|                                               |          |
|                                               | 0        |
| Specifications                                | 355      |

| TRISB                         | 125 |
|-------------------------------|-----|
| TRISB Register                |     |
| Two-Speed Clock Start-up Mode | 61  |
| TXCON (Timer2/4/6) Register   |     |
| TXREG                         |     |
| TXREG Register                |     |
| TXSTA Register                |     |
| BRGH Bit                      |     |

# U

#### USART

| . 364 |
|-------|
| . 364 |
| . 364 |
| . 364 |
|       |

#### ۷

VREF. SEE ADC Reference Voltage

#### W

| Wake-up on Break                 |                    |
|----------------------------------|--------------------|
| Wake-up Using Interrupts         |                    |
| Watchdog Timer (WDT)             | 76                 |
| Associated Registers             |                    |
| Configuration Word w/ Watchdog T | ïmer 100           |
| Modes                            |                    |
| Specifications                   |                    |
| WCOL                             | 263, 266, 268, 270 |
| WCOL Status Flag                 | 263, 266, 268, 270 |
| WDTCON Register                  |                    |
| WPUB Register                    | 123, 128           |
| Write Protection                 |                    |
| WWW Address                      |                    |
| WWW, On-Line Support             | 8                  |
|                                  |                    |