# E·XFL



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Active                                                                        |
|----------------------------|-------------------------------------------------------------------------------|
| Core Processor             | PIC                                                                           |
| Core Size                  | 8-Bit                                                                         |
| Speed                      | 32MHz                                                                         |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART                                     |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT, IBT LIN/J2602                          |
| Number of I/O              | 12                                                                            |
| Program Memory Size        | 14KB (8K x 14)                                                                |
| Program Memory Type        | FLASH                                                                         |
| EEPROM Size                | 256 x 8                                                                       |
| RAM Size                   | 1K x 8                                                                        |
| Voltage - Supply (Vcc/Vdd) | 2.3V ~ 5.5V                                                                   |
| Data Converters            | A/D 9x10b                                                                     |
| Oscillator Type            | Internal                                                                      |
| Operating Temperature      | -40°C ~ 125°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/pic16f1829lint-i-ss |

Email: info@E-XFL.COM

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

FIGURE 3-5: ACCESSING THE STACK EXAMPLE 2



#### **REGISTER 4-1: CONFIGURATION WORD 1 (CONTINUED)**

- bit 2-0 FOSC<2:0>: Oscillator Selection bits
  - 111 = ECH: External Clock, High-Power mode (4-32 MHz): device clock supplied to CLKIN pin
  - 110 = ECM: External Clock, Medium-Power mode (0.5-4 MHz): device clock supplied to CLKIN pin
    - 101 = ECL: External Clock, Low-Power mode (0-0.5 MHz): device clock supplied to CLKIN pin
    - 100 = INTOSC oscillator: I/O function on CLKIN pin
    - 011 = EXTRC oscillator: External RC circuit connected to CLKIN pin
    - 010 = HS oscillator: High-speed crystal/resonator connected between OSC1 and OSC2 pins
    - 001 = XT oscillator: Crystal/resonator connected between OSC1 and OSC2 pins
    - 000 = LP oscillator: Low-power crystal connected between OSC1 and OSC2 pins
- **Note 1:** Enabling Brown-out Reset does not automatically enable Power-up Timer.
  - 2: The entire data EEPROM will be erased when the code protection is turned off during an erase.
  - 3: The entire program memory will be erased when the code protection is turned off.

| Name   | Bit 7  | Bit 6  | Bit 5      | Bit 4 | Bit 3 | Bit 2 | Bit 1  | Bit 0  | Register<br>on Page |
|--------|--------|--------|------------|-------|-------|-------|--------|--------|---------------------|
| BORCON | SBOREN |        |            |       |       |       |        | BORRDY | 76                  |
| PCON   | STKOVF | STKUNF |            | _     | RMCLR | RI    | POR    | BOR    | 80                  |
| STATUS | _      | _      |            | TO    | PD    | Z     | DC     | С      | 22                  |
| WDTCON |        |        | WDTPS<4:0> |       |       |       | SWDTEN | 100    |                     |

TABLE 7-5: SUMMARY OF REGISTERS ASSOCIATED WITH RESETS

Legend: — Unimplemented bit, reads as '0'. Shaded cells are not used by Resets.

#### 11.3.2 ERASING FLASH PROGRAM MEMORY

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

- 1. Load the EEADRH:EEADRL register pair with the address of new row to be erased.
- 2. Clear the CFGS bit of the EECON1 register.
- 3. Set the EEPGD, FREE, and WREN bits of the EECON1 register.
- 4. Write 55h, then AAh, to EECON2 (Flash programming unlock sequence).
- 5. Set control bit WR of the EECON1 register to begin the erase operation.
- 6. Poll the FREE bit in the EECON1 register to determine when the row erase has completed.

#### See Example 11-4.

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

# 11.3.3 WRITING TO FLASH PROGRAM MEMORY

Program memory is programmed using the following steps:

- 1. Load the starting address of the word(s) to be programmed.
- 2. Load the write latches with data.
- 3. Initiate a programming operation.
- 4. Repeat steps 1 through 3 until all data is written.

Before writing to program memory, the word(s) to be written must be erased or previously unwritten. Program memory can only be erased one row at a time. No automatic erase occurs upon the initiation of the write.

Program memory can be written one or more words at a time. The maximum number of words written at one time is equal to the number of write latches. See Figure 11-2 for more details. The write latches are aligned to the address boundary defined by EEADRL as shown in Table 11-1. Write operations do not cross these boundaries. At the completion of a program memory write operation, the write latches are reset to contain 0x3FFF. The following steps should be completed to load the write latches and program a block of program memory. These steps are divided into two parts. First, all write latches are loaded with data except for the last program memory location. Then, the last write latch is loaded and the programming sequence is initiated. A special unlock sequence is required to load a write latch with data or initiate a Flash programming operation. This unlock sequence should not be interrupted.

- 1. Set the EEPGD and WREN bits of the EECON1 register.
- 2. Clear the CFGS bit of the EECON1 register.
- Set the LWLO bit of the EECON1 register. When the LWLO bit of the EECON1 register is '1', the write sequence will only load the write latches and will not initiate the write to Flash program memory.
- 4. Load the EEADRH:EEADRL register pair with the address of the location to be written.
- 5. Load the EEDATH:EEDATL register pair with the program memory data to be written.
- Write 55h, then AAh, to EECON2, then set the WR bit of the EECON1 register (Flash programming unlock sequence). The write latch is now loaded.
- 7. Increment the EEADRH:EEADRL register pair to point to the next location.
- 8. Repeat steps 5 through 7 until all but the last write latch has been loaded.
- Clear the LWLO bit of the EECON1 register. When the LWLO bit of the EECON1 register is '0', the write sequence will initiate the write to Flash program memory.
- 10. Load the EEDATH:EEDATL register pair with the program memory data to be written.
- 11. Write 55h, then AAh, to EECON2, then set the WR bit of the EECON1 register (Flash programming unlock sequence). The entire latch block is now written to Flash program memory.

It is not necessary to load the entire write latch block with user program data. However, the entire write latch block will be written to program memory.

An example of the complete write sequence for eight words is shown in Example 11-5. The initial address is loaded into the EEADRH:EEADRL register pair; the eight words of data are loaded using indirect addressing.

### REGISTER 12-9: PORTB: PORTB REGISTER

| R/W-x/u                           | R/W-x/u | R/W-x/u           | R/W-x/u | U-0                                              | U-0 | U-0         | U-0   |  |
|-----------------------------------|---------|-------------------|---------|--------------------------------------------------|-----|-------------|-------|--|
| RB7                               | RB6     | RB5               | RB4     |                                                  | —   |             | _     |  |
| bit 7                             |         |                   |         |                                                  |     |             | bit 0 |  |
|                                   |         |                   |         |                                                  |     |             |       |  |
| Legend:                           |         |                   |         |                                                  |     |             |       |  |
| R = Readable bit W = Writable bit |         |                   | bit     | U = Unimplemented bit, read as '0'               |     |             |       |  |
| u = Bit is uncha                  | anged   | x = Bit is unkn   | nown    | -n/n = Value at POR and BOR/Value at all other R |     | ther Resets |       |  |
| '1' = Bit is set                  |         | '0' = Bit is clea | ared    |                                                  |     |             |       |  |
|                                   |         |                   |         |                                                  |     |             |       |  |

| bit 7-4 | <b>RB&lt;7:4&gt;</b> : PORTB General Purpose I/O Pin bits |
|---------|-----------------------------------------------------------|
|         | 1 = Port pin is <u>&gt;</u> Vін                           |
|         | 0 <b>= Port pin is <u>&lt;</u> VI</b> ∟                   |
| bit 3-0 | Unimplemented: Read as '0'                                |

### REGISTER 12-10: TRISB: PORTB TRI-STATE REGISTER

| R/W-1/1     | R/W-1/1 | R/W-1/1 | R/W-1/1 | U-0 | U-0 | U-0 | U-0 |
|-------------|---------|---------|---------|-----|-----|-----|-----|
| TRISB7      | TRISB6  | TRISB5  | TRISB4  | —   | —   | —   | —   |
| 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-4 **TRISB<7:4>:** PORTB Tri-State Control bits 1 = PORTB pin configured as an input (tri-stated) 0 = PORTB pin configured as an output

bit 3-0 Unimplemented: Read as '0'

### REGISTER 12-11: LATB: PORTB DATA LATCH REGISTER

| R/W-x/u | R/W-x/u | R/W-x/u | R/W-x/u | U-0 | U-0 | U-0 | U-0   |
|---------|---------|---------|---------|-----|-----|-----|-------|
| LATB7   | LATB6   | LATB5   | LATB4   | —   | —   | —   | —     |
| 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-4 LATB<7:4>: PORTB Output Latch Value bits<sup>(1)</sup>

bit 3-0 Unimplemented: Read as '0'

**Note 1:** Writes to PORTB are actually written to corresponding LATB register. Reads from PORTB register is return of actual I/O pin values.

| REGISTER 12-18: | ANSELC: PORTC ANALOG SELECT REGISTER |  |
|-----------------|--------------------------------------|--|
|                 |                                      |  |

| R/W-1/1                                                                                                                                                                                                                                                                                                      | R/W-1/1                                                                                                                                                                                                                                                                                                           | U-0               | U-0  | R/W-1/1        | R/W-1/1          | R/W-1/1          | R/W-1/1      |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|------|----------------|------------------|------------------|--------------|
| ANSC7 <sup>(2)</sup>                                                                                                                                                                                                                                                                                         | ANSC6 <sup>(2)</sup>                                                                                                                                                                                                                                                                                              | _                 | _    | ANSC3          | ANSC2            | ANSC1            | ANSC0        |
| bit 7                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                   |                   |      |                |                  |                  | bit 0        |
|                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                   |                   |      |                |                  |                  |              |
| Legend:                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                   |                   |      |                |                  |                  |              |
| R = Readable                                                                                                                                                                                                                                                                                                 | bit                                                                                                                                                                                                                                                                                                               | W = Writable      | bit  | U = Unimpler   | nented bit, read | l as '0'         |              |
| u = Bit is unch                                                                                                                                                                                                                                                                                              | 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 clea | ared |                |                  |                  |              |
| bit 7-6 <b>ANSC&lt;7:6&gt;</b> : Analog Select between Analog or Digital Function on pins RC<7:6>, respectively <sup>(2)</sup><br>0 = Digital I/O. Pin is assigned to port or digital special function.<br>1 = Analog input. Pin is assigned as analog input <sup>(1)</sup> . Digital input buffer disabled. |                                                                                                                                                                                                                                                                                                                   |                   |      |                |                  |                  |              |
| bit 2 0                                                                                                                                                                                                                                                                                                      | bit 2.0 ANCC -2.0 Analog Calest between Analog or Digital Eurotian on pine DC-220 respectively                                                                                                                                                                                                                    |                   |      |                |                  |                  |              |
| DIL 3-U                                                                                                                                                                                                                                                                                                      | <ul> <li>ANSC&lt;3:0&gt;: Analog Select between Analog or Digital Function on pins RC&lt;3:0&gt;, respectively</li> <li>0 = Digital I/O. Pin is assigned to port or digital special function.</li> <li>1 = Analog input. Pin is assigned as analog input<sup>(1)</sup>. Digital input buffer disabled.</li> </ul> |                   |      |                |                  | ecuvery          |              |

- **Note 1:** When setting a pin to an analog input, the corresponding TRIS bit must be set to Input mode in order to allow external control of the voltage on the pin.
  - 2: ANSELC<7:6> available on PIC16(L)F1829 only. Otherwise, they are unimplemented and read as '0'.

# REGISTER 12-19: WPUC: WEAK PULL-UP PORTC REGISTER

| R/W-1/1              | R/W-1/1              | R/W-1/1 | R/W-1/1 | R/W-1/1 | R/W-1/1 | R/W-1/1 | R/W-1/1 |
|----------------------|----------------------|---------|---------|---------|---------|---------|---------|
| WPUC7 <sup>(3)</sup> | WPUC6 <sup>(3)</sup> | WPUC5   | WPUC4   | WPUC3   | WPUC2   | WPUC1   | WPUC0   |
| 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 WPUC<7:0>: Weak Pull-up Register bits<sup>(1, 2)</sup> 1 = Pull-up enabled 0 = Pull-up disabled

**Note 1:** Global WPUEN bit of the OPTION\_REG register must be cleared for individual pull-ups to be enabled.

- 2: The weak pull-up device is automatically disabled if the pin is in configured as an output.
- 3: WPUC<7:6> available on PIC16(L)F1829 only. Otherwise, they are unimplemented and read as '0'.

# 17.0 DIGITAL-TO-ANALOG CONVERTER (DAC) MODULE

The Digital-to-Analog Converter supplies a variable voltage reference, ratiometric with the input source, with 32 selectable output levels.

The input of the DAC can be connected to:

- External VREF pins
- VDD supply voltage
- FVR Buffer2

The output of the DAC can be configured to supply a reference voltage to the following:

- Comparator positive input
- ADC input channel
- DACOUT pin
- · Capacitive Sensing module (CPS)

The Digital-to-Analog Converter (DAC) can be enabled by setting the DACEN bit of the DACCON0 register.

# EQUATION 17-1: DAC OUTPUT VOLTAGE

# <u>**IF DACEN = 1**</u> $VOUT = \left( (VSOURCE - VSOURCE -) \times \frac{DACR[4:0]}{2^5} \right) + VSOURCE -$

IF DACEN = 0 and DACLPS = 1 and DACR[4:0] = 11111

VOUT = VSOURCE +

#### IF DACEN = 0 and DACLPS = 0 and DACR[4:0] = 00000

VOUT = VSOURCE -

VSOURCE+ = VDD, VREF, or FVR BUFFER 2

VSOURCE - = VSS

# 17.2 Ratiometric Output Level

The DAC output value is derived using a resistor ladder with each end of the ladder tied to a positive and negative voltage reference input source. If the voltage of either input source fluctuates, a similar fluctuation will result in the DAC output value.

The value of the individual resistors within the ladder can be found in **Section 30.0** "**Electrical Specifications**".

# 17.1 Output Voltage Selection

The DAC has 32 voltage level ranges. The 32 levels are set with the DACR<4:0> bits of the DACCON1 register.

The DAC output voltage is determined by the following equations:

# 17.3 DAC Voltage Reference Output

The DAC can be output to the DACOUT pin by setting the DACOE bit of the DACCON0 register to '1'. Selecting the DAC reference voltage for output on the DACOUT pin automatically overrides the digital output buffer and digital input threshold detector functions of that pin. Reading the DACOUT pin when it has been configured for DAC reference voltage output will always return a '0'.

Due to the limited current drive capability, a buffer must be used on the DAC voltage reference output for external connections to DACOUT. Figure 17.5 shows an example buffering technique.

# 19.2 Comparator Control

Each comparator has two control registers: CMxCON0 and CMxCON1.

The CMxCON0 registers (see Register 19-1) contain Control and Status bits for the following:

- Enable
- · Output selection
- Output polarity
- · Speed/Power selection
- · Hysteresis enable
- · Output synchronization

The CMxCON1 registers (see Register 19-2) contain Control bits for the following:

- · Interrupt enable
- · Interrupt edge polarity
- · Positive input channel selection
- Negative input channel selection

#### 19.2.1 COMPARATOR ENABLE

Setting the CxON bit of the CMxCON0 register enables the comparator for operation. Clearing the CxON bit disables the comparator resulting in minimum current consumption.

#### 19.2.2 COMPARATOR OUTPUT SELECTION

The output of the comparator can be monitored by reading either the CxOUT bit of the CMxCON0 register or the MCxOUT bit of the CMOUT register. In order to make the output available for an external connection, the following conditions must be true:

- · CxOE bit of the CMxCON0 register must be set
- · Corresponding TRIS bit must be cleared
- · CxON bit of the CMxCON0 register must be set

| Note 1: | The CxOE bit of the CMxCON0 register   |
|---------|----------------------------------------|
|         | overrides the PORT data latch. Setting |
|         | the CxON bit of the CMxCON0 register   |
|         | has no impact on the port override.    |

2: The internal output of the comparator is latched with each instruction cycle. Unless otherwise specified, external outputs are not latched.

#### 19.2.3 COMPARATOR OUTPUT POLARITY

Inverting the output of the comparator is functionally equivalent to swapping the comparator inputs. The polarity of the comparator output can be inverted by setting the CxPOL bit of the CMxCON0 register. Clearing the CxPOL bit results in a non-inverted output.

Table 19-1 shows the output state versus input conditions, including polarity control.

#### TABLE 19-1: COMPARATOR OUTPUT STATE VS. INPUT CONDITIONS

| Input Condition | CxPOL | CxOUT |
|-----------------|-------|-------|
| CxVN > CxVP     | 0     | 0     |
| CxVN < CxVP     | 0     | 1     |
| CxVN > CxVP     | 1     | 1     |
| CxVN < CxVP     | 1     | 0     |

### 19.2.4 COMPARATOR SPEED/POWER SELECTION

The trade-off between speed or power can be optimized during program execution with the CxSP control bit. The default state for this bit is '1' which selects the Normal Speed mode. Device power consumption can be optimized at the cost of slower comparator propagation delay by clearing the CxSP bit to '0'.

### 19.3 Comparator Hysteresis

A selectable amount of separation voltage can be added to the input pins of each comparator to provide a hysteresis function to the overall operation. Hysteresis is enabled by setting the CxHYS bit of the CMxCON0 register.

See **Section 30.0 "Electrical Specifications"** for more information.

| FIGURE 21-5:           | TIMER1 GATE SINGLE-PULSE MODE                                     |
|------------------------|-------------------------------------------------------------------|
|                        |                                                                   |
| TMR1GE                 |                                                                   |
| T1GPOL                 |                                                                   |
| T1GSPM                 |                                                                   |
| T1GG <u>O/</u><br>DONE | Cleared by hardware on falling edge of T1GVAL Counting enabled on |
| T1G_IN                 | rising edge of T1G                                                |
| т1скі                  |                                                                   |
| T1GV <u>AL</u>         |                                                                   |
| Timer1                 | N N + 1 N + 2                                                     |
| TMR1GIF                | Cleared by software Cleared by hardware on falling edge of T1GVAL |

| Name    | Bit 7      | Bit 6          | Bit 5        | Bit 4      | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Register<br>on Page |
|---------|------------|----------------|--------------|------------|--------|--------|--------|--------|---------------------|
| CCP2CON | P2M∙       | <1:0>          | DC2B         | <1:0>      |        | CCP2   | V<3:0> |        | 224                 |
| CCP4CON | _          | _              | DC4B         | <1:0>      |        | CCP4   | V<3:0> |        | 224                 |
| CCP6CON | _          |                | DC6B         | <1:0>      |        | CCP6   | V<3:0> |        | 224                 |
| INTCON  | GIE        | PEIE           | TMR0IE       | INTE       | IOCIE  | TMR0IF | INTF   | IOCIF  | 87                  |
| PIE1    | TMR1GIE    | ADIE           | RCIE         | TXIE       | SSP1IE | CCP1IE | TMR2IE | TMR1IE | 88                  |
| PIE3    | _          | _              | CCP4IE       | CCP3IE     | TMR6IE | —      | TMR4IE | —      | 90                  |
| PIR1    | TMR1GIF    | ADIF           | RCIF         | TXIF       | SSP1IF | CCP1IF | TMR2IF | TMR1IF | 92                  |
| PIR3    | _          | —              | CCP4IF       | CCP3IF     | TMR6IF | —      | TMR4IF | —      | 94                  |
| PR2     | Timer2 Mod | dule Period    | Register     |            |        |        |        |        | 188*                |
| PR4     | Timer4 Mod | dule Period    | Register     |            |        |        |        |        | 188*                |
| PR6     | Timer6 Mod | dule Period    | Register     |            |        |        |        |        | 188*                |
| T2CON   | _          |                | T2OUTF       | PS<3:0>    |        | TMR2ON | T2CKP  | S<1:0> | 190                 |
| T4CON   | _          |                | T4OUTF       | PS<3:0>    |        | TMR4ON | T4CKP  | S<1:0> | 190                 |
| T6CON   | _          |                | T6OUTF       | PS<3:0>    |        | TMR6ON | T6CKP  | S<1:0> | 190                 |
| TMR2    | Holding Re | gister for the | e 8-bit TMR2 | 2 Register |        |        |        |        | 188*                |
| TMR4    | Holding Re | gister for the | e 8-bit TMR4 | 1 Register |        |        |        |        | 188*                |
| TMR6    | Holding Re | gister for the | e 8-bit TMR  | 8 Register |        |        |        |        | 188*                |

TABLE 22-1: SUMMARY OF REGISTERS ASSOCIATED WITH TIMER2/4/6

**Legend:** — Unimplemented location, read as '0'. Shaded cells are not used for Timer2/4/6 module.

\* Page provides register information.

## 24.3 PWM Overview

Pulse-Width Modulation (PWM) is a scheme that provides power to a load by switching quickly between fully on and fully off states. The PWM signal resembles a square wave where the high portion of the signal is considered the on state and the low portion of the signal is considered the off state. The high portion, also known as the pulse width, can vary in time and is defined in steps. A larger number of steps applied, which lengthens the pulse width, also supplies more power to the load. Lowering the number of steps applied, which shortens the pulse width, supplies less power. The PWM period is defined as the duration of one complete cycle or the total amount of on and off time combined.

PWM resolution defines the maximum number of steps that can be present in a single PWM period. A higher resolution allows for more precise control of the pulse width time and in turn the power that is applied to the load.

The term duty cycle describes the proportion of the on time to the off time and is expressed in percentages, where 0% is fully off and 100% is fully on. A lower duty cycle corresponds to less power applied and a higher duty cycle corresponds to more power applied.

Figure 24-3 shows a typical waveform of the PWM signal.

#### 24.3.1 STANDARD PWM OPERATION

The standard PWM function described in this section is available and identical for CCP modules ECCP1, ECCP2, CCP3 and CCP4.

The standard PWM mode generates a Pulse-Width Modulation (PWM) signal on the CCPx pin with up to 10 bits of resolution. The period, duty cycle, and resolution are controlled by the following registers:

- PRx registers
- TxCON registers
- · CCPRxL registers
- · CCPxCON registers

Figure 24-4 shows a simplified block diagram of PWM operation.

- Note 1: The corresponding TRIS bit must be cleared to enable the PWM output on the CCPx pin.
  - 2: Clearing the CCPxCON register will relinquish control of the CCPx pin.

#### FIGURE 24-3: CCP PWM OUTPUT SIGNAL





SIMPLIFIED PWM BLOCK DIAGRAM



|              | SDI MODE WAVEEODM   |                           |   |
|--------------|---------------------|---------------------------|---|
| FIGURE 23-9. | SFI WODE WAVEFORING | (SLAVE WODE WITH CRE = 0) | 1 |

|                               | 1<br>1<br>1<br>1<br>1                 |                                       |                                                 |                                       |                   |                                         |                                       |                       |                                       |             |                       |
|-------------------------------|---------------------------------------|---------------------------------------|-------------------------------------------------|---------------------------------------|-------------------|-----------------------------------------|---------------------------------------|-----------------------|---------------------------------------|-------------|-----------------------|
|                               |                                       |                                       |                                                 |                                       |                   |                                         |                                       |                       |                                       |             |                       |
| - Č≪E, ≈ 03                   | :                                     | ; •••••••<br>• :<br>•                 | ;                                               | (                                     | ; <i>********</i> | ; ·····;<br>; ·                         | ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; | , /<br>,<br>,         |                                       | :<br>:<br>: | (<br>(<br>(           |
| 80%)<br>(CXP1# 5<br>(CXE1# 5) |                                       |                                       | 4                                               |                                       |                   |                                         |                                       | ,                     |                                       |             | 5<br>5<br>5<br>5<br>5 |
| 90000 00<br>SBRX814F<br>VisBM | ,<br>,<br>,<br>,                      | ·<br>·                                | :<br>; · · · ·<br>; · · · · · · · · · · · · · · | (                                     | •                 | <pre>&lt;</pre>                         | c                                     | •<br>•<br>•<br>•<br>• | , , , , , , , , , , , , , , , , , , , |             | 5<br>5<br>5<br>5      |
| - 8920x                       |                                       | X 68.7                                |                                                 | X 68 8 [                              | N 58 4            |                                         | Xazz                                  | X 68 -                | X                                     |             | 485<br>197            |
| - SERS                        | · · · · · · · · · · · · · · · · · · · |                                       |                                                 |                                       |                   |                                         |                                       | ;<br>                 |                                       |             | 7<br>3<br>7<br>7      |
| input<br>Sampia               |                                       | 4                                     | , 4<br>, 4                                      |                                       |                   | : · · · · · · · · · · · · · · · · · · · | · · · · · · · · · · · · · · · · · · · | :<br>                 |                                       |             |                       |
| SASSENSEE<br>Enternasia       | ۰<br>۰<br>۰<br>۶                      | · · · · · · · · · · · · · · · · · · · | · · · · · · · · · · · · · · · · · · ·           | · · · · · · · · · · · · · · · · · · · | ·<br>·<br>·       | ζ                                       | ,<br>2 ;<br>2 ;<br>2 ;<br>2 ;<br>2 ;  | ,<br>,<br>,           | · · · · · · · · · · · · · · · · · · · |             |                       |
| ***9<br>SSR2SR &:<br>SSR2SR : | : ;<br>; ;<br>; ;                     | · · · · · · · · · · · · · · · · · · · | ; · · · · · · · · · · · · · · · · · · ·         | :                                     |                   | s · · · · · · · · · · · · · · · · · · · | s -<br>s -<br>s -                     | :<br>;<br>;<br>;      | · :<br>· :<br>· :                     | ġ.          |                       |
| Write Collinear               |                                       |                                       |                                                 |                                       |                   |                                         |                                       |                       |                                       |             |                       |
| deteción activo               |                                       |                                       |                                                 |                                       |                   |                                         |                                       |                       |                                       |             |                       |

## FIGURE 25-10: SPI MODE WAVEFORM (SLAVE MODE WITH CKE = 1)

| SSx<br>SCKx<br>(CKP = 0<br>CKE = 1)<br>SCKx<br>(CKP = 1<br>CKE = 1)<br>Write to |             |                                     |             |                          |             |
|---------------------------------------------------------------------------------|-------------|-------------------------------------|-------------|--------------------------|-------------|
| SSPxBUF                                                                         |             | 1 1 1<br>1 1 1<br>1 1 1<br>111      |             |                          |             |
| SDOX                                                                            | bit 7 bit 6 | bit 5 bit 4                         | bit 3 bit 2 | bit 1 bit 0              |             |
| SDIx                                                                            | bit 7       |                                     | $\sim$      | bit 0                    |             |
| Input<br>Sample                                                                 | <u> </u>    | <u>↑</u> ↑                          | <u>†</u> †  | <u>†</u> †               | ·<br>·<br>· |
| SSPxIF<br>Interrupt<br>Flag                                                     |             |                                     |             |                          |             |
| SSPxSR to<br>SSPxBUF                                                            |             | 1 1 1<br>1 1 1<br>1 1<br>1 1<br>1 1 |             | 1 I<br>1 I<br>1 I<br>1 I | -           |
| Write Collisies                                                                 |             |                                     | •           |                          | •           |





#### 25.5.3 SLAVE MODE 10-BIT ADDRESS RECEPTION

This section describes a standard sequence of events for the MSSPx module configured as an  $I^2C$  Slave in 10-bit Addressing mode.

Figure 25-20 is used as a visual reference for this description.

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

- 1. Bus starts Idle.
- 2. Master sends Start condition; S bit of SSPxSTAT is set; SSPxIF is set if interrupt on Start detect is enabled.
- 3. Master sends matching high address with the  $R/\overline{W}$  bit clear; UA bit of the SSPxSTAT register is set.
- 4. Slave sends ACK and SSPxIF is set.
- 5. Software clears the SSPxIF bit.
- 6. Software reads received address from SSPxBUF clearing the BF flag.
- 7. Slave loads low address into SSPxADD, releasing SCLx.
- 8. Master sends matching low address byte to the slave; UA bit is set.

**Note:** Updates to the SSPxADD register are not allowed until after the ACK sequence.

9. Slave sends ACK and SSPxIF is set.

**Note:** If the low address does not match, SSPxIF and UA are still set so that the slave software can set SSPxADD back to the high address. BF is not set because there is no match. CKP is unaffected.

- 10. Slave clears SSPxIF.
- 11. Slave reads the received matching address from SSPxBUF clearing BF.
- 12. Slave loads high address into SSPxADD.
- 13. Master clocks a data byte to the slave and clocks out the slaves ACK on the ninth SCLx pulse; SSPxIF is set.
- 14. If SEN bit of SSPxCON2 is set, CKP is cleared by hardware and the clock is stretched.
- 15. Slave clears SSPxIF.
- 16. Slave reads the received byte from SSPxBUF clearing BF.
- 17. If SEN is set the slave sets CKP to release the SCLx.
- 18. Steps 13-17 repeat for each received byte.
- 19. Master sends Stop to end the transmission.

### 25.5.4 10-BIT ADDRESSING WITH ADDRESS OR DATA HOLD

Reception using 10-bit addressing with AHEN or DHEN set is the same as with 7-bit modes. The only difference is the need to update the SSPxADD register using the UA bit. All functionality, specifically when the CKP bit is cleared and SCLx line is held low are the same. Figure 25-21 can be used as a reference of a slave in 10-bit addressing with AHEN set.

Figure 25-22 shows a standard waveform for a slave transmitter in 10-bit Addressing mode.

#### 25.6.13.1 Bus Collision During a Start Condition

During a Start condition, a bus collision occurs if:

- a) SDAx or SCLx are sampled low at the beginning of the Start condition (Figure 25-33).
- b) SCLx is sampled low before SDAx is asserted low (Figure 25-34).

During a Start condition, both the SDAx and the SCLx pins are monitored.

If the SDAx pin is already low, or the SCLx pin is already low, then all of the following occur:

- · the Start condition is aborted,
- · the BCLxIF flag is set and
- the MSSPx module is reset to its Idle state (Figure 25-33).

The Start condition begins with the SDAx and SCLx pins deasserted. When the SDAx pin is sampled high, the Baud Rate Generator is loaded and counts down. If the SCLx pin is sampled low while SDAx is high, a bus collision occurs because it is assumed that another master is attempting to drive a data '1' during the Start condition.

If the SDAx pin is sampled low during this count, the BRG is reset and the SDAx line is asserted early (Figure 25-35). If, however, a '1' is sampled on the

SDAx pin, the SDAx pin is asserted low at the end of the BRG count. The Baud Rate Generator is then reloaded and counts down to zero; if the SCLx pin is sampled as '0' during this time, a bus collision does not occur. At the end of the BRG count, the SCLx pin is asserted low.

Note: The reason that bus collision is not a factor during a Start condition is that no two bus masters can assert a Start condition at the exact same time. Therefore, one master will always assert SDAx before the other. This condition does not cause a bus collision because the two masters must be allowed to arbitrate the first address following the Start condition. If the address is the same, arbitration must be allowed to continue into the data portion, Repeated Start or Stop conditions.





#### 26.1.2 EUSART ASYNCHRONOUS RECEIVER

The Asynchronous mode is typically used in RS-232 systems. The receiver block diagram is shown in Figure 26-2. The data is received on the RX/DT pin and drives the data recovery block. The data recovery block is actually a high-speed shifter operating at 16 times the baud rate, whereas the serial Receive Shift Register (RSR) operates at the bit rate. When all eight or nine bits of the character have been shifted in, they are immediately transferred to a two character First-In-First-Out (FIFO) memory. The FIFO buffering allows reception of two complete characters and the start of a third character before software must start servicing the EUSART receiver. The FIFO and RSR registers are not directly accessible by software. Access to the received data is via the RCREG register.

#### 26.1.2.1 Enabling the Receiver

The EUSART receiver is enabled for asynchronous operation by configuring the following three control bits:

- CREN = 1
- SYNC = 0
- SPEN = 1

All other EUSART control bits are assumed to be in their default state.

Setting the CREN bit of the RCSTA register enables the receiver circuitry of the EUSART. Clearing the SYNC bit of the TXSTA register configures the EUSART for asynchronous operation. Setting the SPEN bit of the RCSTA register enables the EUSART. The programmer must set the corresponding TRIS bit to configure the RX/DT I/O pin as an input.

**Note 1:** If the RX/DT function is on an analog pin, the corresponding ANSEL bit must be cleared for the receiver to function.

# 26.1.2.2 Receiving Data

The receiver data recovery circuit initiates character reception on the falling edge of the first bit. The first bit, also known as the Start bit, is always a zero. The data recovery circuit counts one-half bit time to the center of the Start bit and verifies that the bit is still a zero. If it is not a zero then the data recovery circuit aborts character reception, without generating an error, and resumes looking for the falling edge of the Start bit. If the Start bit zero verification succeeds then the data recovery circuit counts a full bit time to the center of the next bit. The bit is then sampled by a majority detect circuit and the resulting '0' or '1' is shifted into the RSR. This repeats until all data bits have been sampled and shifted into the RSR. One final bit time is measured and the level sampled. This is the Stop bit, which is always a '1'. If the data recovery circuit samples a '0' in the Stop bit position then a framing error is set for this character, otherwise the framing error is cleared for this character. See Section 26.1.2.4 "Receive Framing Error"" for more information on framing errors.

Immediately after all data bits and the Stop bit have been received, the character in the RSR is transferred to the EUSART receive FIFO and the RCIF interrupt flag bit of the PIR1 register is set. The top character in the FIFO is transferred out of the FIFO by reading the RCREG register.

| Note: | If the receive FIFO is overrun, no additional characters will be received until the overrun |  |  |  |  |  |  |
|-------|---------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|       | condition is cleared. See Section 26.1.2.5                                                  |  |  |  |  |  |  |
|       | "Receive Overrun Error" for more                                                            |  |  |  |  |  |  |
|       | information on overrun errors.                                                              |  |  |  |  |  |  |

### 26.1.2.3 Receive Interrupts

The RCIF interrupt flag bit of the PIR1 register is set whenever the EUSART receiver is enabled and there is an unread character in the receive FIFO. The RCIF interrupt flag bit is read-only, it cannot be set or cleared by software.

RCIF interrupts are enabled by setting all of the following bits:

- · RCIE interrupt enable bit of the PIE1 register
- PEIE Peripheral Interrupt Enable bit of the INTCON register
- GIE Global Interrupt Enable bit of the INTCON register

The RCIF interrupt flag bit will be set when there is an unread character in the FIFO, regardless of the state of interrupt enable bits.

| U-0               | U-0                  | U-0               | U-0           | R/W-0/0 <sup>(1)</sup> | R/W-0/0           | R/W-0/0           | R/W-0/0   |
|-------------------|----------------------|-------------------|---------------|------------------------|-------------------|-------------------|-----------|
| —                 | _                    | —                 | —             |                        | CPSC              | H<3:0>            |           |
| bit 7             |                      |                   |               | ·                      |                   |                   | bit 0     |
|                   |                      |                   |               |                        |                   |                   |           |
| Legend:           |                      |                   |               |                        |                   |                   |           |
| R = Readable bit  |                      | W = Writable b    | it            | U = Unimpleme          | ented bit, read a | as '0'            |           |
| u = Bit is unchan | ged                  | x = Bit is unkno  | own           | -n/n = Value at        | POR and BOR       | /Value at all oth | er Resets |
| '1' = Bit is set  |                      | '0' = Bit is clea | red           |                        |                   |                   |           |
|                   |                      |                   |               |                        |                   |                   |           |
| bit 7-4           | Unimplement          | ed: Read as '0'   |               |                        |                   |                   |           |
| bit 3-0           | CPSCH<3:0>           | : Capacitive Sen  | sing Channe   | el Select bits         |                   |                   |           |
| <u> </u>          | <u> If CPSON = 0</u> | :                 | -             |                        |                   |                   |           |
|                   | These bit            | s are ignored. N  | o channel is  | selected.              |                   |                   |           |
| <u> </u>          | <u> If CPSON = 1</u> |                   |               |                        |                   |                   |           |
|                   | 0000 =               | channel 0, (CPS   | 50)           |                        |                   |                   |           |
|                   | 0001 =               | channel 1, (CPS   | 51)           |                        |                   |                   |           |
|                   | 0010 =               | channel 2, (CPS   | 52)           |                        |                   |                   |           |
|                   | 0011 =               | channel 3, (CPS   | 53)           |                        |                   |                   |           |
|                   | 0100 =               | channel 4, (CPS   | 54)           |                        |                   |                   |           |
|                   | 0101 =               | channel 5, (CPS   | 55)           |                        |                   |                   |           |
|                   | 0110 =               | channel 6, (CPS   | 56)           |                        |                   |                   |           |
|                   | 0111 =               | channel 7, (CPS   | 57)<br>50)(1) |                        |                   |                   |           |
|                   | 1000 =               | channel 8, (CP:   | $58)^{(1)}$   |                        |                   |                   |           |
|                   | 1001 =               | channel 9, (CPS   | $59)^{(1)}$   |                        |                   |                   |           |
|                   | 1010 =               | channel 10, (CF   | -510, (1)     |                        |                   |                   |           |
|                   | 1011 =               | Channel II, (CF   | ·SII)(·)      |                        |                   |                   |           |
|                   | 1100 =               | Reserved. Do n    | ot use.       |                        |                   |                   |           |
|                   | •                    |                   |               |                        |                   |                   |           |
|                   | •                    |                   |               |                        |                   |                   |           |
|                   | •                    | Received Do n     | otuse         |                        |                   |                   |           |
|                   |                      | Neserveu. DO II   | 01 050.       |                        |                   |                   |           |

**Note 1:** These channels are only implemented on the PIC16(L)F1829.

| TABLE 27-3: | SUMM | ARY OF R | REGISTER | S ASSOC | IATED WI | TH CAPA | CITIVE SE | NSING |  |
|-------------|------|----------|----------|---------|----------|---------|-----------|-------|--|
|             |      |          |          |         |          |         |           |       |  |

| Name                  | Bit 7                  | Bit 6                  | Bit 5   | Bit 4   | Bit 3   | Bit 2      | Bit 1   | Bit 0   | Register on<br>Page |
|-----------------------|------------------------|------------------------|---------|---------|---------|------------|---------|---------|---------------------|
| ANSELA                | —                      | —                      | —       | ANSA4   | —       | ANSA2      | ANSA1   | ANSA0   | 123                 |
| ANSELC                | ANSC7 <sup>(1)</sup>   | ANSC6 <sup>(1)</sup>   | —       | -       | ANSC3   | ANSC2      | ANSC1   | ANSC0   | 134                 |
| CPSCON0               | CPSON                  | CPSRM                  | —       | _       | CPSRN   | IG<1:0>    | CPSOUT  | T0XCS   | 315                 |
| CPSCON1               | —                      | —                      | —       | -       |         | CPSCH<3:0> |         |         | 316                 |
| INLVLA                | _                      | _                      | INLVLA5 | INLVLA4 | INLVLA3 | INLVLA2    | INLVLA1 | INLVLA0 | 124                 |
| INLVLB <sup>(1)</sup> | INLVLB7                | INLVLB6                | INLVLB5 | INLVLB4 | _       | _          | _       | _       | 129                 |
| INLVLC                | INLVLC7 <sup>(1)</sup> | INLVLC6 <sup>(1)</sup> | INLVLC5 | INLVLC4 | INLVLC3 | INLVLC2    | INLVLC1 | INLVLC0 | 135                 |
| INTCON                | GIE                    | PEIE                   | TMR0IE  | INTE    | IOCIE   | TMR0IF     | INTF    | IOCIF   | 87                  |
| OPTION_REG            | WPUEN                  | INTEDG                 | TMR0CS  | TMR0SE  | PSA     | PS2        | PS1     | PS0     | 176                 |
| T1CON                 | TMR1CS1                | TMR1CS0                | T1CKPS1 | T1CKPS0 | T1OSCEN | T1SYNC     | —       | TMR10N  | 185                 |
| TRISA                 | —                      | —                      | TRISA5  | TRISA4  | TRISA3  | TRISA2     | TRISA1  | TRISA0  | 122                 |
| TRISB <sup>(1)</sup>  | TRISB7                 | TRISB6                 | TRISB5  | TRISB4  | —       | —          | —       | —       | 128                 |
| TRISC                 | TRISC7 <sup>(1)</sup>  | TRISC6 <sup>(1)</sup>  | TRISC5  | TRISC4  | TRISC3  | TRISC2     | TRISC1  | TRISC0  | 133                 |

Legend: — Unimplemented locations, read as '0'. Shaded cells are not used by the CPS module. Note 1: PIC16(L)F1829 only.

FIGURE 31-33: IPD, CAPACITIVE SENSING (CPS) MODULE, MEDIUM-CURRENT RANGE, CPSRM = 0, PIC16LF1825/9 ONLY



FIGURE 31-34: IPD, CAPACITIVE SENSING (CPS) MODULE, MEDIUM-CURRENT RANGE, CPSRM = 0, PIC16F1825/9 ONLY



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

# 32.12 Third-Party Development Tools

Microchip also offers a great collection of tools from third-party vendors. These tools are carefully selected to offer good value and unique functionality.

- Device Programmers and Gang Programmers from companies, such as SoftLog and CCS
- Software Tools from companies, such as Gimpel and Trace Systems
- Protocol Analyzers from companies, such as Saleae and Total Phase
- Demonstration Boards from companies, such as MikroElektronika, Digilent<sup>®</sup> and Olimex
- Embedded Ethernet Solutions from companies, such as EZ Web Lynx, WIZnet and IPLogika<sup>®</sup>