



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

| Details                    |                                                                            |
|----------------------------|----------------------------------------------------------------------------|
| Product Status             | Active                                                                     |
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 32MHz                                                                      |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART                                  |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                      |
| Number of I/O              | 17                                                                         |
| 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) | 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-VFQFN Exposed Pad                                                       |
| Supplier Device Package    | 20-QFN (4x4)                                                               |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f1829t-i-ml |
|                            |                                                                            |

Email: info@E-XFL.COM

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

## 5.2 Clock Source Types

Clock sources can be classified as external or internal.

External clock sources rely on external circuitry for the clock source to function. Examples are: oscillator modules (EC mode), quartz crystal resonators or ceramic resonators (LP, XT and HS modes) and Resistor-Capacitor (RC) mode circuits.

Internal clock sources are contained internally within the oscillator module. The internal oscillator block has two internal oscillators and a dedicated Phase-Lock Loop (HFPLL) that are used to generate three internal system clock sources: the 16 MHz High-Frequency Internal Oscillator (HFINTOSC), 500 kHz (MFINTOSC) and the 31 kHz Low-Frequency Internal Oscillator (LFINTOSC).

The system clock can be selected between external or internal clock sources via the System Clock Select (SCS) bits in the OSCCON register. See **Section 5.3 "Clock Switching"** for additional information.

## 5.2.1 EXTERNAL CLOCK SOURCES

An external clock source can be used as the device system clock by performing one of the following actions:

- Program the FOSC<2:0> bits in the Configuration Word 1 to select an external clock source that will be used as the default system clock upon a device Reset.
- Write the SCS<1:0> bits in the OSCCON register to switch the system clock source to:
  - Timer1 Oscillator during run-time, or
  - An external clock source determined by the value of the FOSC bits.

See **Section 5.3 "Clock Switching**" for more information.

## 5.2.1.1 EC Mode

The External Clock (EC) mode allows an externally generated logic level signal to be the system clock source. When operating in this mode, an external clock source is connected to the OSC1 input. OSC2/CLKOUT is available for general purpose I/O or CLKOUT. Figure 5-2 shows the pin connections for EC mode.

EC mode has three power modes to select from through Configuration Word 1:

- High power, 4-32 MHz (FOSC = 111)
- Medium power, 0.5-4 MHz (FOSC = 110)
- Low power, 0-0.5 MHz (FOSC = 101)

The Oscillator Start-up Timer (OST) is disabled when EC mode is selected. Therefore, there is no delay in operation after a Power-on Reset (POR) or wake-up from Sleep. Because the PIC<sup>®</sup> MCU design is fully static, stopping the external clock input will have the effect of halting the device while leaving all data intact. Upon restarting the external clock, the device will resume operation as if no time had elapsed.

FIGURE 5-2:

### EXTERNAL CLOCK (EC) MODE OPERATION



## 5.2.1.2 LP, XT, HS Modes

The LP, XT and HS modes support the use of quartz crystal resonators or ceramic resonators connected to OSC1 and OSC2 (Figure 5-3). The three modes select a low, medium or high gain setting of the internal inverter-amplifier to support various resonator types and speed.

**LP** Oscillator mode selects the lowest gain setting of the internal inverter-amplifier. LP mode current consumption is the least of the three modes. This mode is designed to drive only 32.768 kHz tuning-fork type crystals (watch crystals).

**XT** Oscillator mode selects the intermediate gain setting of the internal inverter-amplifier. XT mode current consumption is the medium of the three modes. This mode is best suited to drive resonators with a medium drive level specification.

**HS** Oscillator mode selects the highest gain setting of the internal inverter-amplifier. HS mode current consumption is the highest of the three modes. This mode is best suited for resonators that require a high drive setting.

Figure 5-3 and Figure 5-4 show typical circuits for quartz crystal and ceramic resonators, respectively.

### 5.2.2.7 Internal Oscillator Clock Switch Timing

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

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

See Figure 5-7 for more details.

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

Start-up delay specifications are located in the oscillator tables of **Section 30.0** "**Electrical Specifications**"

### 7.10 Determining the Cause of a Reset

Upon any Reset, multiple bits in the STATUS and PCON register are updated to indicate the cause of the Reset. Table 7-3 and Table 7-4 show the Reset conditions of these registers.

| STKOVF | STKUNF | RMCLR | RI | POR | BOR | то | PD | Condition                                                         |
|--------|--------|-------|----|-----|-----|----|----|-------------------------------------------------------------------|
| 0      | 0      | 1     | 1  | 0   | x   | 1  | 1  | Power-on Reset                                                    |
| 0      | 0      | 1     | 1  | 0   | x   | 0  | x  | Illegal, $\overline{\text{TO}}$ is set on $\overline{\text{POR}}$ |
| 0      | 0      | 1     | 1  | 0   | x   | x  | 0  | Illegal, PD is set on POR                                         |
| 0      | 0      | 1     | 1  | u   | 0   | 1  | 1  | Brown-out Reset                                                   |
| u      | u      | u     | u  | u   | u   | 0  | u  | WDT Reset                                                         |
| u      | u      | u     | u  | u   | u   | 0  | 0  | WDT Wake-up from Sleep                                            |
| u      | u      | u     | u  | u   | u   | 1  | 0  | Interrupt Wake-up from Sleep                                      |
| u      | u      | 0     | u  | u   | u   | u  | u  | MCLR Reset during normal operation                                |
| u      | u      | 0     | u  | u   | u   | 1  | 0  | MCLR Reset during Sleep                                           |
| u      | u      | u     | 0  | u   | u   | u  | u  | RESET Instruction Executed                                        |
| 1      | u      | u     | u  | u   | u   | u  | u  | Stack Overflow Reset (STVREN = 1)                                 |
| u      | 1      | u     | u  | u   | u   | u  | u  | Stack Underflow Reset (STVREN = 1)                                |

TABLE 7-3: RESET STATUS BITS AND THEIR SIGNIFICANCE

## TABLE 7-4: RESET CONDITION FOR SPECIAL REGISTERS<sup>(2)</sup>

| Condition                          | Program<br>Counter    | STATUS<br>Register | PCON<br>Register |
|------------------------------------|-----------------------|--------------------|------------------|
| Power-on Reset                     | 0000h                 | 1 1000             | 00 110x          |
| MCLR Reset during normal operation | 0000h                 | u uuuu             | uu Ouuu          |
| MCLR Reset during Sleep            | 0000h                 | 1 Ouuu             | uu Ouuu          |
| WDT Reset                          | 0000h                 | 0 uuuu             | uu uuuu          |
| WDT Wake-up from Sleep             | PC + 1                | 0 Ouuu             | uu uuuu          |
| Brown-out Reset                    | 0000h                 | 1 luuu             | 00 11u0          |
| Interrupt Wake-up from Sleep       | PC + 1 <sup>(1)</sup> | 1 Ouuu             | uu uuuu          |
| RESET Instruction Executed         | 0000h                 | u uuuu             | uu u0uu          |
| Stack Overflow Reset (STVREN = 1)  | 0000h                 | u uuuu             | lu uuuu          |
| Stack Underflow Reset (STVREN = 1) | 0000h                 | u uuuu             | ul uuuu          |

**Legend:** u = unchanged, x = unknown, - = unimplemented bit, reads as '0'.

**Note 1:** When the wake-up is due to an interrupt and Global Enable bit (GIE) is set, the return address is pushed on the stack and PC is loaded with the interrupt vector (0004h) after execution of PC + 1.

2: If a Status bit is not implemented, that bit will be read as '0'.



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

### 8.6.8 PIR3 REGISTER

The PIR3 register contains the interrupt flag bits, as shown in Register 8-8.

1 = Interrupt is pending0 = Interrupt is not pending

1 = Interrupt is pending0 = Interrupt is not pending

1 = Interrupt is pending0 = Interrupt is not pending

Unimplemented: Read as '0'

Unimplemented: Read as '0'

TMR6IF: TMR6 to PR6 Match Interrupt Flag bit

TMR4IF: TMR4 to PR4 Match Interrupt Flag bit

Note 1: Interrupt flag bits are set when an interrupt condition occurs, regardless of the state of its corresponding enable bit or the Global Enable bit, GIE, of the INTCON register. User software should ensure the appropriate interrupt flag bits are clear prior to enabling an interrupt.

### REGISTER 8-8: PIR3: PERIPHERAL INTERRUPT REQUEST REGISTER 3

| U-0   | U-0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | U-0 | R/W-0/0 | U-0   |
|-------|-----|---------|---------|---------|-----|---------|-------|
| —     |     | CCP4IF  | CCP3IF  | TMR6IF  | —   | TMR4IF  | —     |
| bit 7 |     |         |         |         |     |         | bit 0 |

| Legend:                               | Legend:     |                        |                                                       |  |  |  |  |  |  |
|---------------------------------------|-------------|------------------------|-------------------------------------------------------|--|--|--|--|--|--|
| R = Readable bit W = Writable 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 |             | '0' = Bit is cleared   |                                                       |  |  |  |  |  |  |
|                                       |             |                        |                                                       |  |  |  |  |  |  |
| bit 7-6                               | Unimplem    | nented: Read as '0'    |                                                       |  |  |  |  |  |  |
| bit 5                                 | CCP4IF: C   | CP4 Interrupt Flag bit |                                                       |  |  |  |  |  |  |
|                                       |             | pt is pending          |                                                       |  |  |  |  |  |  |
|                                       | 0 = Interru | pt is not pending      |                                                       |  |  |  |  |  |  |
| bit 4                                 | CCP3IF: C   | CP3 Interrupt Flag bit |                                                       |  |  |  |  |  |  |

bit 3

bit 2

bit 1

bit 0

## 9.0 POWER-DOWN MODE (SLEEP)

The Power-Down mode is entered by executing a  $\ensuremath{\mathtt{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. 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 high-impedance).
- 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.

## 9.1.1 WAKE-UP USING INTERRUPTS

When global interrupts are disabled (GIE cleared) and any interrupt source has both its interrupt enable bit and interrupt flag bit set, one of the following will occur:

- If the interrupt occurs **before** the execution of a SLEEP instruction
  - SLEEP instruction will execute as a NOP.
  - WDT and WDT prescaler will not be cleared
  - TO bit of the STATUS register will not be set
  - PD bit of the STATUS register will not be cleared.
- If the interrupt occurs **during or after** the execution of a **SLEEP** instruction
  - SLEEP instruction will be completely executed
  - Device will immediately wake-up from Sleep
  - WDT and WDT prescaler will be cleared
  - TO bit of the STATUS register will be set
  - PD bit of the STATUS register will be cleared.

### 12.2.2 PORTA FUNCTIONS AND OUTPUT PRIORITIES

Each PORTA pin is multiplexed with other functions. The pins, their combined functions and their output priorities are briefly described here. For additional information, refer to the appropriate section in this data sheet.

When multiple outputs are enabled, the actual pin control goes to the peripheral with the lowest number in the following lists.

Analog input functions, such as ADC, comparator and Cap Sense inputs, are not shown in the priority lists. These inputs are active when the I/O pin is set for Analog mode using the ANSELx registers. Digital output functions may control the pin when it is in Analog mode with the priority shown below.

| Pin Name | Function Priority <sup>(1)</sup>                                     |
|----------|----------------------------------------------------------------------|
| RA0      | ICSPDAT<br>ICDDAT<br>DACOUT                                          |
| RA1      | ICSPCLK<br>ICDCLK<br>RX/DT <sup>(2)</sup>                            |
| RA2      | SRQ<br>C1OUT<br>CCP3                                                 |
| RA3      | None (input only)                                                    |
| RA4      | CLKOUT<br>T1OSO<br>CLKR<br>SDO1<br>P2B <sup>(2)</sup>                |
| RA5      | SDO2 (PIC16(L)F1829 only)<br>CCP2 <sup>(2)</sup> /P2A <sup>(2)</sup> |

### TABLE 12-2: PORTA OUTPUT PRIORITY

**Note 1:** Priority listed from highest to lowest.

2: Pin function is selectable via the APFCON0 or APFCON1 register.

## 17.7 DAC Control Registers

### REGISTER 17-1: DACCONO: VOLTAGE REFERENCE CONTROL REGISTER 0

|                  |                              |                     | -              |                |                  | -              |              |
|------------------|------------------------------|---------------------|----------------|----------------|------------------|----------------|--------------|
| R/W-0/0          | R/W-0/0                      | R/W-0/0             | U-0            | R/W-0/0        | R/W-0/0          | U-0            | R/W-0/0      |
| DACEN            | DACLPS                       | DACOE               |                | DACP           | SS<1:0>          | _              | DACNSS       |
| bit 7            |                              |                     |                |                |                  |                | bit 0        |
|                  |                              |                     |                |                |                  |                |              |
| Legend:          |                              |                     |                |                |                  |                |              |
| R = Readable     | bit                          | W = Writable        | bit            | U = Unimpler   | nented bit, read | as '0'         |              |
| u = Bit is unch  | nanged                       | x = Bit is unkr     | nown           | -n/n = Value a | at POR and BOF   | R/Value at all | other Resets |
| '1' = Bit is set |                              | '0' = Bit is cle    | ared           |                |                  |                |              |
|                  |                              |                     |                |                |                  |                |              |
| bit 7            | DACEN: DAG                   |                     |                |                |                  |                |              |
|                  | 1 = DAC is e<br>0 = DAC is c |                     |                |                |                  |                |              |
| bit 6            |                              | AC Low-Power        | Voltage State  | Select hit     |                  |                |              |
| bit 0            |                              | sitive reference    | •              |                |                  |                |              |
|                  |                              | gative reference    |                |                |                  |                |              |
| bit 5            | DACOE: DAG                   | -<br>C Voltage Outp | ut Enable bit  |                |                  |                |              |
|                  |                              | tage level is als   |                |                |                  |                |              |
|                  |                              | tage level is dis   |                | om the DACOU   | T pin            |                |              |
| bit 4            | Unimplemer                   | ted: Read as '      | 0'             |                |                  |                |              |
| bit 3-2          |                              | 0>: DAC Positiv     | ve Source Sel  | ect bits       |                  |                |              |
|                  | 00 = VDD<br>01 = VREF+       |                     |                |                |                  |                |              |
|                  | 10 = FVR B                   | uffer2 output       |                |                |                  |                |              |
|                  |                              | ed, do not use      |                |                |                  |                |              |
| bit 1            | Unimplemer                   | ted: Read as '      | 0'             |                |                  |                |              |
| bit 0            | DACNSS: D/                   | AC Negative So      | ource Select b | its            |                  |                |              |
|                  | 1 = VREF-                    |                     |                |                |                  |                |              |
|                  | 0 = Vss                      |                     |                |                |                  |                |              |
|                  |                              |                     |                |                |                  |                |              |

## REGISTER 17-2: DACCON1: VOLTAGE REFERENCE CONTROL REGISTER 1

| U-0   | U-0 | U-0 | R/W-0/0 | R/W-0/0 | R/W-0/0   | R/W-0/0 | R/W-0/0 |
|-------|-----|-----|---------|---------|-----------|---------|---------|
| —     | —   | —   |         |         | DACR<4: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-5 <b>l</b> | Inimplemented: Read as '0' |
|------------------|----------------------------|
|------------------|----------------------------|

```
bit 4-0 DACR<4:0>: DAC Voltage Output Select bits
```

Vout = ((Vsrc+) - (Vsrc-))\*(DACR<4:0>/(2<sup>5</sup>)) + Vsrc-

**Note 1:** The output select bits are always right justified to ensure that any number of bits can be used without affecting the register layout



## FIGURE 21-4: TIMER1 GATE TOGGLE MODE



| 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                 |
| CCP1CON | P1M•           | <1:0>            | DC1B             | <1:0>             |                         | CCP1N   | 1<3:0>  |         | 224                 |
| CCP2CON | P2M            | <1:0>            | DC2B             | <1:0>             |                         | CCP2N   | 1<3:0>  |         | 224                 |
| INLVLA  | _              | _                | INLVLA5          | INLVLA4           | INLVLA3                 | INLVLA2 | INLVLA1 | INLVLA0 | 124                 |
| INTCON  | GIE            | PEIE             | TMR0IE           | INTE              | IOCIE                   | TMR0IF  | INTF    | IOCIF   | 87                  |
| PIE1    | TMR1GIE        | ADIE             | RCIE             | TXIE              | SSP1IE                  | CCP1IE  | TMR2IE  | TMR1IE  | 88                  |
| PIR1    | TMR1GIF        | ADIF             | RCIF             | TXIF              | SSP1IF                  | CCP1IF  | TMR2IF  | TMR1IF  | 92                  |
| TMR1H   | Holding Regist | er for the Most  | Significant Byte | of the 16-bit T   | MR1 Register            |         |         |         | 181*                |
| TMR1L   | Holding Regist | er for the Least | Significant Byte | e of the 16-bit ⊺ | FMR1 Register           |         |         |         | 181*                |
| TRISA   | —              | —                | TRISA5           | TRISA4            | TRISA3                  | TRISA2  | TRISA1  | TRISA0  | 122                 |
| T1CON   | TMR1C          | S<1:0>           | T1CKPS<1:0>      |                   | T1OSCEN                 | T1SYNC  | _       | TMR10N  | 185                 |
| T1GCON  | TMR1GE         | T1GPOL           | T1GTM            | T1GSPM            | T <u>1GGO</u> /<br>DONE | T1GVAL  | T1GS    | 186     |                     |

 Unimplemented location, read as '0'. Shaded cells are not used by the Timer1 module.
 \* Page provides register information. Legend:

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



## 24.3.6 PWM RESOLUTION

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

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

### EQUATION 24-4: PWM RESOLUTION

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

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

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

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

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

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

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

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





## 26.1 EUSART Asynchronous Mode

The EUSART transmits and receives data using the standard non-return-to-zero (NRZ) format. NRZ is implemented with two levels: a VOH mark state which represents a '1' data bit, and a VOL space state which represents a '0' data bit. NRZ refers to the fact that consecutively transmitted data bits of the same value stay at the output level of that bit without returning to a neutral level between each bit transmission. An NRZ transmission port idles in the mark state. Each character transmission consists of one Start bit followed by eight or nine data bits and is always terminated by one or more Stop bits. The Start bit is always a space and the Stop bits are always marks. The most common data format is eight bits. Each transmitted bit persists for a period of 1/(Baud Rate). An on-chip dedicated 8-bit/16-bit Baud Rate Generator is used to derive standard baud rate frequencies from the system oscillator. See Table 26-5 for examples of baud rate configurations.

The EUSART transmits and receives the LSb first. The EUSART's transmitter and receiver are functionally independent, but share the same data format and baud rate. Parity is not supported by the hardware, but can be implemented in software and stored as the ninth data bit.

### 26.1.1 EUSART ASYNCHRONOUS TRANSMITTER

The EUSART transmitter block diagram is shown in Figure 26-1. The heart of the transmitter is the serial Transmit Shift Register (TSR), which is not directly accessible by software. The TSR obtains its data from the transmit buffer, which is the TXREG register.

### 26.1.1.1 Enabling the Transmitter

The EUSART transmitter is enabled for asynchronous operations by configuring the following three control bits:

- TXEN = 1
- SYNC = 0
- SPEN = 1

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

Setting the TXEN bit of the TXSTA register enables the transmitter 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 and automatically configures the TX/CK I/O pin as an output. If the TX/CK pin is shared with an analog peripheral, the analog I/O function must be disabled by clearing the corresponding ANSEL bit.

**Note 1:** The TXIF Transmitter Interrupt flag is set when the TXEN enable bit is set.

## 26.1.1.2 Transmitting Data

A transmission is initiated by writing a character to the TXREG register. If this is the first character, or the previous character has been completely flushed from the TSR, the data in the TXREG is immediately transferred to the TSR register. If the TSR still contains all or part of a previous character, the new character data is held in the TXREG until the Stop bit of the previous character has been transmitted. The pending character in the TXREG is then transferred to the TSR in one TCY immediately following the Stop bit sequence commences immediately following the transfer of the data to the TSR from the TXREG.

### 26.1.1.3 Transmit Data Polarity

The polarity of the transmit data can be controlled with the SCKP bit of the BAUDCON register. The default state of this bit is '0' which selects high true transmit idle and data bits. Setting the SCKP bit to '1' will invert the transmit data resulting in low true idle and data bits. The SCKP bit controls transmit data polarity in Asynchronous mode only. In Synchronous mode, the SCKP bit has a different function. See **Section 26.4.1.2 "Clock Polarity"**.

### 26.1.1.4 Transmit Interrupt Flag

The TXIF interrupt flag bit of the PIR1 register is set whenever the EUSART transmitter is enabled and no character is being held for transmission in the TXREG. In other words, the TXIF bit is only clear when the TSR is busy with a character and a new character has been queued for transmission in the TXREG. The TXIF flag bit is not cleared immediately upon writing TXREG. TXIF becomes valid in the second instruction cycle following the write execution. Polling TXIF immediately following the TXREG write will return invalid results. The TXIF bit is read-only, it cannot be set or cleared by software.

The TXIF interrupt can be enabled by setting the TXIE interrupt enable bit of the PIE1 register. However, the TXIF flag bit will be set whenever the TXREG is empty, regardless of the state of TXIE enable bit.

To use interrupts when transmitting data, set the TXIE bit only when there is more data to send. Clear the TXIE interrupt enable bit upon writing the last character of the transmission to the TXREG.

| R-0/0            | R-1/1                           | U-0                                         | R/W-0/0              | R/W-0/0                                              | U-0             | R/W-0/0          | R/W-0/0       |  |
|------------------|---------------------------------|---------------------------------------------|----------------------|------------------------------------------------------|-----------------|------------------|---------------|--|
| ABDOVF           | RCIDL                           |                                             | SCKP                 | BRG16                                                |                 | WUE              | ABDEN         |  |
| bit 7            |                                 |                                             |                      |                                                      |                 |                  | bit 0         |  |
|                  |                                 |                                             |                      |                                                      |                 |                  |               |  |
| Legend:          |                                 |                                             |                      |                                                      |                 |                  |               |  |
| R = Readable     | e bit                           | W = Writable                                | e bit                | U = Unimpler                                         | mented bit, rea | id as '0'        |               |  |
| u = Bit is uncl  | hanged                          | x = Bit is unk                              | nown                 | -n/n = Value at POR and BOR/Value at all other Reset |                 |                  |               |  |
| '1' = Bit is set | t                               | '0' = Bit is cle                            | '0' = Bit is cleared |                                                      |                 |                  |               |  |
| bit 7            |                                 | uto-Baud Dete                               | ct Overflow bit      |                                                      |                 |                  |               |  |
| bit i            | Asynchrono                      |                                             |                      |                                                      |                 |                  |               |  |
|                  |                                 | ud timer overflo                            | wed                  |                                                      |                 |                  |               |  |
|                  |                                 | ud timer did not                            | overflow             |                                                      |                 |                  |               |  |
|                  | <u>Synchronou</u><br>Don't care | <u>s mode</u> :                             |                      |                                                      |                 |                  |               |  |
| bit 6            |                                 | eive Idle Flag b                            | oit                  |                                                      |                 |                  |               |  |
|                  | Asynchrono                      | -                                           |                      |                                                      |                 |                  |               |  |
|                  | 1 = Receive                     |                                             |                      |                                                      |                 |                  |               |  |
|                  |                                 | has been recei                              | ved and the re       | ceiver is receiv                                     | ring            |                  |               |  |
|                  | <u>Synchronou</u><br>Don't care | <u>s mode</u> .                             |                      |                                                      |                 |                  |               |  |
| bit 5            | Unimpleme                       | nted: Read as                               | <b>'</b> 0'          |                                                      |                 |                  |               |  |
| bit 4            | -                               | SCKP: Synchronous Clock Polarity Select bit |                      |                                                      |                 |                  |               |  |
|                  | Asynchronous mode:              |                                             |                      |                                                      |                 |                  |               |  |
|                  |                                 | t inverted data<br>t non-inverted c         | •                    |                                                      |                 |                  |               |  |
|                  | <u>Synchronou</u>               |                                             |                      |                                                      |                 |                  |               |  |
|                  |                                 | clocked on risin<br>clocked on fallir       |                      |                                                      |                 |                  |               |  |
| bit 3            | <b>BRG16:</b> 16-               | bit Baud Rate (                             | Generator bit        |                                                      |                 |                  |               |  |
|                  |                                 | aud Rate Gene<br>ud Rate Gener              |                      |                                                      |                 |                  |               |  |
| bit 2            | Unimpleme                       | nted: Read as                               | ʻ0'                  |                                                      |                 |                  |               |  |
| bit 1            | WUE: Wake                       | -up Enable bit                              |                      |                                                      |                 |                  |               |  |
|                  | Asynchrono                      |                                             |                      |                                                      |                 |                  |               |  |
|                  |                                 | r is waiting for<br>matically clear a       |                      |                                                      | will be receive | d, byte RCIF wil | I be set. WUE |  |
|                  |                                 | r is operating n                            | ormally              |                                                      |                 |                  |               |  |
|                  | Synchronou                      | <u>s mode</u> :                             |                      |                                                      |                 |                  |               |  |
| hit 0            | Don't care                      | to-Baud Detect                              | Enable bit           |                                                      |                 |                  |               |  |
| bit 0            |                                 |                                             | Enable bit           |                                                      |                 |                  |               |  |
|                  | Asynchrono                      | aud Detect mod                              | le is enabled (c     | lears when au                                        | to-baud is com  | nplete)          |               |  |
|                  |                                 | aud Detect mod                              |                      | acti s which du                                      |                 |                  |               |  |
|                  | <u>Synchronou</u>               |                                             |                      |                                                      |                 |                  |               |  |
|                  | Don't care                      |                                             |                      |                                                      |                 |                  |               |  |

## REGISTER 26-3: BAUDCON: BAUD RATE CONTROL REGISTER

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

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

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

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

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

| TFSS           | Bit Test f, Skip if Set                                                                                                                                                                                         |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| yntax:         | [label]BTFSS f,b                                                                                                                                                                                                |
| perands:       | $\begin{array}{l} 0 \leq f \leq 127 \\ 0 \leq b < 7 \end{array}$                                                                                                                                                |
| peration:      | skip if (f <b>) = 1</b>                                                                                                                                                                                         |
| atus Affected: | None                                                                                                                                                                                                            |
| escription:    | If bit 'b' in register 'f' is '0', the next<br>instruction is executed.<br>If bit 'b' is '1', then the next<br>instruction is discarded and a NOP is<br>executed instead, making this a<br>2-cycle instruction. |

| LSLF                             | Logical Left Shift                                                                                                                                                                                                                                                 | MOVF             | Move f                                                                                                                                                                                                                                                                            |
|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                          | [ <i>label</i> ]LSLF f{,d}                                                                                                                                                                                                                                         | Syntax:          | [ <i>label</i> ] MOVF f,d                                                                                                                                                                                                                                                         |
| Operands:                        | $0 \le f \le 127$<br>d $\in [0,1]$                                                                                                                                                                                                                                 | Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                                                                                                |
| Operation:                       | $(f < 7 >) \rightarrow C$                                                                                                                                                                                                                                          | Operation:       | $(f) \rightarrow (dest)$                                                                                                                                                                                                                                                          |
|                                  | $(f<6:0>) \rightarrow dest<7:1>$<br>0 $\rightarrow dest<0>$                                                                                                                                                                                                        | Status Affected: | Z                                                                                                                                                                                                                                                                                 |
| Status Affected:<br>Description: | <ul> <li>C, Z</li> <li>The contents of register 'f' are shifted one bit to the left through the Carry flag.</li> <li>A '0' is shifted into the LSb. If 'd' is '0', the result is placed in W. If 'd' is '1', the result is stored back in register 'f'.</li> </ul> | Description:     | The contents of register f is moved to<br>a destination dependent upon the<br>status of d. If $d = 0$ ,<br>destination is W register. If $d = 1$ , the<br>destination is file register f itself. $d = 1$<br>is useful to test a file register since<br>status flag Z is affected. |
|                                  | C                                                                                                                                                                                                                                                                  | Words:           | 1                                                                                                                                                                                                                                                                                 |
|                                  |                                                                                                                                                                                                                                                                    | Cycles:          | 1                                                                                                                                                                                                                                                                                 |
|                                  |                                                                                                                                                                                                                                                                    | Example:         | MOVF FSR, 0                                                                                                                                                                                                                                                                       |
| LSRF                             | Logical Right Shift                                                                                                                                                                                                                                                |                  | After Instruction<br>W = value in FSR register                                                                                                                                                                                                                                    |
| Syntax:                          | [ <i>label</i> ]LSRF f{,d}                                                                                                                                                                                                                                         |                  | Z = 1                                                                                                                                                                                                                                                                             |

| Syntax:          | [label]LSRF f{,d}                                                                                                                                                                                                                    |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d  \in \left[ 0,1 \right] \end{array}$                                                                                                                                                        |
| Operation:       | $\begin{array}{l} 0 \rightarrow dest < 7 > \\ (f < 7:1 >) \rightarrow dest < 6:0 >, \\ (f < 0 >) \rightarrow C, \end{array}$                                                                                                         |
| Status Affected: | C, Z                                                                                                                                                                                                                                 |
| Description:     | The contents of register 'f' are shifted<br>one bit to the right through the Carry<br>flag. A '0' is shifted into the MSb. If 'd' is<br>'0', the result is placed in W. If 'd' is '1',<br>the result is stored back in register 'f'. |
|                  |                                                                                                                                                                                                                                      |

| 0→ | register f | ►C |
|----|------------|----|
|    | 9          |    |

| RETFIE           | Return from Interrupt                                                                                                                                                                                           |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Syntax:          | [label] RETFIE                                                                                                                                                                                                  |  |
| Operands:        | None                                                                                                                                                                                                            |  |
| Operation:       | $\begin{array}{l} TOS \to PC, \\ 1 \to GIE \end{array}$                                                                                                                                                         |  |
| Status Affected: | None                                                                                                                                                                                                            |  |
| Description:     | Return from Interrupt. Stack is POPed<br>and Top-of-Stack (TOS) is loaded in<br>the PC. Interrupts are enabled by<br>setting Global Interrupt Enable bit,<br>GIE (INTCON<7>). This is a 2-cycle<br>instruction. |  |
| Words:           | 1                                                                                                                                                                                                               |  |
| Cycles:          | 2                                                                                                                                                                                                               |  |
| Example:         | RETFIE                                                                                                                                                                                                          |  |
|                  | After Interrupt<br>PC = TOS<br>GIE = 1                                                                                                                                                                          |  |

| RETURN           | Return from Subroutine                                                                                                                                |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] RETURN                                                                                                                                        |
| Operands:        | None                                                                                                                                                  |
| Operation:       | $TOS \to PC$                                                                                                                                          |
| Status Affected: | None                                                                                                                                                  |
| Description:     | Return from subroutine. The stack is<br>POPed and the top of the stack (TOS)<br>is loaded into the program counter.<br>This is a 2-cycle instruction. |

| RETLW            | Return with literal in W                                                                                                           |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------|------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] RETLW k                                                                                                           | RLF              | Rotate Left f through Carry                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Operands:        | $0 \le k \le 255$                                                                                                                  | Syntax:          | [ <i>label</i> ] RLF f,d                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Operation:       | $k \rightarrow (W);$<br>TOS $\rightarrow$ PC                                                                                       | Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Status Affected: | None                                                                                                                               | Operation:       | See description below                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Description:     | The W register is loaded with the 8-bit                                                                                            | Status Affected: | С                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Description.     | literal 'k'. The program counter is<br>loaded from the top of the stack (the<br>return address). This is a 2-cycle<br>instruction. | Description:     | The contents of register 'f' are rotated<br>one bit to the left through the Carry<br>flag. If 'd' is '0', the result is placed in<br>the W register. If 'd' is '1', the result is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Words:           | 1                                                                                                                                  |                  | stored back in register 'f'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Cycles:          | 2                                                                                                                                  |                  | ← C ← Register f ←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Example:         | CALL TABLE;W contains table                                                                                                        | Words:           | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                  | <pre>;offset value , W now has table value</pre>                                                                                   | Cycles:          | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| TABLE            | •                                                                                                                                  | Example:         | RLF REG1,0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  | •<br>ADDWF PC ;W = offset<br>RETLW k1 ;Begin table<br>RETLW k2 ;<br>•<br>•<br>RETLW kn ; End of table                              |                  | Before Instruction         REG1         =         1110         0110           C         =         0         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         - |
|                  | Before Instruction<br>W = 0x07<br>After Instruction<br>W = value of k8                                                             |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |





