

Welcome to E-XFL.COM

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

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

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

#### Details

E·XFI

| Product Status             | Active                                                                     |
|----------------------------|----------------------------------------------------------------------------|
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 64MHz                                                                      |
| Connectivity               | I <sup>2</sup> C, IrDA, LINbus, SPI, UART/USART, USB                       |
| Peripherals                | Brown-out Detect/Reset, HLVD, LCD, POR, PWM, WDT                           |
| Number of I/O              | 86                                                                         |
| Program Memory Size        | 32KB (16K x 16)                                                            |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | -                                                                          |
| RAM Size                   | 4K x 8                                                                     |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 3.6V                                                                  |
| Data Converters            | A/D 24x12b                                                                 |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 100-TQFP                                                                   |
| Supplier Device Package    | 100-TQFP (12x12)                                                           |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18f95j94-i-pt |

Email: info@E-XFL.COM

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

#### 3.3.2 OSCCON3 – CLOCK DIVIDER REGISTER (IRCF<2:0> BITS)

This option is described in more detail in Section 3.10.2 "FRC Postscaler Mode (FRCDIV)" and Section 3.10.3 "FRC Oscillator with PLL Mode (FRCPLL)".

The IRCFx bits (OSCCON3<2:0>) select the postscaler option for the FRC Oscillator output, allowing users to choose a lower clock frequency than the nominal 8 MHz.

#### REGISTER 3-3: OSCCON3: OSCILLATOR CONTROL REGISTER 3

| U-0   | U-0 | U-0 | U-0 | U-0 | R/W-0                | R/W-0                | R/W-1                |
|-------|-----|-----|-----|-----|----------------------|----------------------|----------------------|
| —     | —   | —   | —   | —   | IRCF2 <sup>(1)</sup> | IRCF1 <sup>(1)</sup> | IRCF0 <sup>(1)</sup> |
| bit 7 |     |     |     |     |                      |                      | bit 0                |

| Legena.           |                  |                             |                    |
|-------------------|------------------|-----------------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit, read | d as '0'           |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared        | x = Bit is unknown |

#### bit 7-3 Unimplemented: Read as '0'

bit 2-0 **IRCF<2:0>:** Reference Clock Divider bits<sup>(1)</sup>

000 = FRC divide-by-1 001 = FRC divide-by-2 (default) 010 = FRC divide-by-4 011 = FRC divide-by-8 100 = FRC divide-by-16 101 = FRC divide-by-32 110 = FRC divide-by-64 111 = FRC divide-by-256

**Note 1:** The default FRC divide-by setting on an 8-bit device corresponds to 1 MIPS operation.

### REGISTER 3-4: OSCCON4: OSCILLATOR CONTROL REGISTER 4

| R/W-0  | R/W-0  | R/W-0 | U-0 | U-0 | U-0 | U-0 | U-0   |
|--------|--------|-------|-----|-----|-----|-----|-------|
| CPDIV1 | CPDIV0 | PLLEN |     | —   | —   | —   | —     |
| bit 7  |        |       |     |     |     |     | bit 0 |

| Legend:           |                  |                             |                    |
|-------------------|------------------|-----------------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit, read | d as '0'           |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared        | x = Bit is unknown |

bit 7-6 CPDIV<1:0>: USB System Clock Select bits (postscaler select from 64 MHz clock branch) 00 = Input clock/1 01 = Input clock/2 10 = Input clock/4 11 = Input clock/8 bit 5 PLLEN: PLL Enable bit 1 = PLL is enabled even though it is not requested by the CPU; provides ability to "warm-up" the PLL and keep it running to avoid the PLL start-up time. This setting will force the PLL and associated clock source to stay active in Sleep. 0 = PLL is disabled; PLL will be automatically turned on when SRC1 is selected, or when REFO1 or REFO2 is enabled and using the PLL clock as its source. In either case, the PLL will require a start-up time. bit 4-0 Unimplemented: Read as '0'

#### © 2012-2016 Microchip Technology Inc.

#### 3.5.1 SELECTING A PRIMARY OSCILLATOR MODE

The main difference between the MS and HS modes is the gain of the internal inverter of the oscillator circuit, which allows the different frequency ranges. The MS mode is a medium power, medium frequency mode. HS mode provides the highest oscillator frequencies with a crystal. OSC2 provides crystal feedback in both HS and MS Oscillator modes.

The EC and HS modes that use the PLL circuit provide the highest device operating frequencies. The oscillator circuit will consume the most current in these modes because the PLL is enabled to multiply the frequency of the oscillator.

In general, users should select the oscillator option with the lowest possible gain that still meets their specifications. This will result in lower dynamic currents (IDD). The frequency range of each oscillator mode is the recommended frequency cutoff, but the selection of a different gain mode is acceptable as long as a thorough validation is performed (voltage, temperature and component variations, such as resistor, capacitor and internal oscillator circuitry).

The oscillator feedback circuit is disabled in all EC modes. The OSC1 pin is a high-impedance input and can be driven by a CMOS driver.

If the Primary Oscillator is configured for an external clock input, the OSC2 pin is not required to support the oscillator function. For these modes, the OSC2 pin can be used as an additional device I/O pin or a clock output pin. When the OSC2 pin is used as a clock output pin, the output frequency is Fosc/4.

## 3.6 Crystal Oscillators and Ceramic Resonators

In MS and HS modes, a crystal or ceramic resonator is connected to the OSC1 and OSC2 pins to establish oscillation (Figure 3-3). The PIC18F oscillator design requires the use of a parallel cut crystal. Using a series cut crystal may give a frequency out of the crystal manufacturer's specifications.

#### 3.6.1 OSCILLATOR/RESONATOR START-UP

As the device voltage increases from Vss, the oscillator will start its oscillations. The time required for the oscillator to start oscillating depends on many factors, including:

- Crystal/resonator frequency
- · Capacitor values used
- · Series resistor, if used, and its value and type
- Device VDD rise time
- System temperature
- Oscillator mode selection of device (selects the gain of the internal oscillator inverter)
- · Crystal quality
- Oscillator circuit layout
- System noise

The course of a typical crystal or resonator start-up is shown in Figure 3-4. Notice that the time to achieve stable oscillation is not instantaneous.

### FIGURE 3-4: EXAMPLE OSCILLATOR/RESONATOR START-UP CHARACTERISTICS



## 6.0 MEMORY ORGANIZATION

PIC18FXXJ94 devices have these types of memory:

- Program Memory
- Data RAM

As Harvard architecture devices, the data and program memories use separate buses. This enables concurrent access of the two memory spaces.

Additional detailed information on the operation of the Flash program memory is provided in **Section 7.0 "Flash Program Memory"**.



## 10.6 PIE Registers

The PIE registers contain the individual enable bits for the peripheral interrupts. Due to the number of peripheral interrupt sources, there are six Peripheral Interrupt Enable registers (PIE1 through PIE6). When IPEN (RCON<7>) = 0, the PEIE bit must be set to enable any of these peripheral interrupts.

### REGISTER 10-10: PIE1: PERIPHERAL INTERRUPT ENABLE REGISTER 1

| N/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0  | R/W-0   | R/W-0  | R/W-0  |
|-------|-------|-------|-------|--------|---------|--------|--------|
| PSPIE | ADIE  | RC1IE | TX1IE | SSP1IE | TMR1GIE | TMR2IE | TMR1IE |
| bit 7 |       |       |       |        |         |        | bit 0  |

| Legend:           |                  |                             |                    |
|-------------------|------------------|-----------------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit, read | d as '0'           |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared        | x = Bit is unknown |

| bit 7 | PSPIE: Parallel Slave Port Read/Write Interrupt Enable bit    |
|-------|---------------------------------------------------------------|
|       | 1 = Enables the PSP read/write interrupt                      |
|       | 0 = Disables the PSP read/write interrupt                     |
| bit 6 | ADIE: A/D Converter Interrupt Enable bit                      |
|       | 1 = Enables the A/D interrupt                                 |
|       | 0 = Disables the A/D interrupt                                |
| bit 5 | RC1IE: EUSART1 Receive Interrupt Enable bit                   |
|       | 1 = Enables the EUSART1 receive interrupt                     |
|       | 0 = Disables the EUSART1 receive interrupt                    |
| bit 4 | TX1IE: EUSART1 Transmit Interrupt Enable bit                  |
|       | 1 = Enables the EUSART1 transmit interrupt                    |
|       | 0 = Disables the EUSART1 transmit interrupt                   |
| bit 3 | SSP1IE: Master Synchronous Serial Port 1 Interrupt Enable bit |
|       | 1 = Enables the MSSP1 interrupt                               |
|       | 0 = Disables the MSSP1 interrupt                              |
| bit 2 | TMR1GIE: TMR1 Gate Interrupt Enable bit                       |
|       | 1 = Enables the gate                                          |
|       | 0 = Disables the gate                                         |
| bit 1 | TMR2IE: TMR2 to PR2 Match Interrupt Enable bit                |
|       | 1 = Enables the TMR2 to PR2 match interrupt                   |
|       | 0 = Disables the TMR2 to PR2 match interrupt                  |
| bit 0 | TMR1IE: TMR1 Overflow Interrupt Enable bit                    |
|       | 1 = Enables the TMR1 overflow interrupt                       |
|       | 0 = Disables the TMR1 overflow interrupt                      |
|       |                                                               |

| Pin Name      | Function | TRIS<br>Setting | I/O | l/O<br>Type      | Description                                                                               |
|---------------|----------|-----------------|-----|------------------|-------------------------------------------------------------------------------------------|
| RD3/PSP3/     | RD3      | 0               | 0   | DIG              | LATD<3> data output.                                                                      |
| RP23/SEG3/AD3 |          | 1               | I   | ST               | PORTD<3> data input.                                                                      |
|               | PSP3     | x               | I/O | ST/DIG           | Parallel Slave Port Data Bus Bit 3.                                                       |
|               | RP23     | x               | х   | DIG              | Reconfigurable Pin 23 for PPS-Lite; TRIS must be set to match input/<br>output of module. |
|               | SEG3     | 0               | 0   | ANA              | LCD Segment 3 output; disables all other pin functions.                                   |
|               | AD3      | x               | I/O | ST/DIG           | External Memory Bus Address Line 3.                                                       |
| RD4/PSP4/     | RD4      | 0               | 0   | DIG              | LATD<4> data output.                                                                      |
| RP24/SEG4/AD4 |          | 1               | I   | ST               | PORTD<4> data input.                                                                      |
|               | PSP4     | x               | I/O | ST/DIG           | Parallel Slave Port Data Bus Bit 4.                                                       |
|               | RP24     | х               | х   | DIG              | Reconfigurable Pin 24 for PPS-Lite; TRIS must be set to match input/<br>output of module. |
|               | SEG4     | 0               | 0   | ANA              | LCD Segment 4 output; disables all other pin functions.                                   |
|               | AD4      | x               | I/O | ST/DIG           | External Memory Bus Address Line 4.                                                       |
| RD5/PSP5/     | RD5      | 0               | 0   | DIG              | LATD<5> data output.                                                                      |
| RP25/SDA2/    |          | 1               | Ι   | ST               | PORTD<5> data input.                                                                      |
| SEG5/AD5      | PSP5     | x               | I/O | ST/DIG           | Parallel Slave Port Data Bus Bit 5.                                                       |
|               | RP25     | x               | x   | DIG              | Reconfigurable Pin 25 for PPS-Lite; TRIS must be set to match input/<br>output of module. |
|               | SDA2     | x               | I/O | ST/DIG           | I <sup>2</sup> C mode data I/O.                                                           |
|               | SEG5     | 0               | 0   | ANA              | LCD Segment 5 output; disables all other pin functions.                                   |
|               | AD5      | x               | I/O | ST/DIG           | External Memory Bus Address Line 5.                                                       |
| RD6/PSP6/     | RD6      | 0               | 0   | DIG              | LATD<6> data output.                                                                      |
| RP26/SCL2/    |          | 1               | I   | ST               | PORTD<6> data input.                                                                      |
| SEG0/AD0      | PSP6     | x               | I/O | ST/DIG           | Parallel Slave Port Data Bus Bit 6.                                                       |
|               | RP26     | х               | х   | DIG              | Reconfigurable Pin 26 for PPS-Lite; TRIS must be set to match input/<br>output of module. |
|               | SCL2     | x               | I/O | l <sup>2</sup> C | Synchronous serial clock input/output for I <sup>2</sup> C mode.                          |
|               | SEG6     | 0               | 0   | ANA              | LCD Segment 6 output; disables all other pin functions.                                   |
|               | AD6      | x               | I/O | ST/DIG           | External Memory Bus Address Line 6.                                                       |
| RD7/PSP7/     | RD7      | 0               | 0   | DIG              | LATD<7> data output.                                                                      |
| RP27/REFO2/   |          | 1               | Ι   | ST               | PORTD<7> data input.                                                                      |
| SEG//AD/      | PSP7     | x               | I/O | ST/DIG           | Parallel Slave Port Data Bus Bit 7.                                                       |
|               | RP27     | х               | x   | DIG              | Reconfigurable Pin 27 for PPS-Lite; TRIS must be set to match input/<br>output of module. |
|               | REFO2    | 0               | 0   | DIG              | Reference Clock 2 output.                                                                 |
|               | SEG7     | 0               | 0   | ANA              | LCD Segment 7 output; disables all other pin functions.                                   |
|               | AD7      | x               | I/O | ST/DIG           | External Memory Bus Address Line 7.                                                       |

TABLE 11-4: PORTD FUNCTIONS (CONTINUED)

**Legend:** O = Output, I = Input, ANA = Analog Signal, DIG = Digital Output, ST = Schmitt Trigger Buffer Input,  $I^2C = I^2C/SMBus$ , x = Don't care (TRIS bit does not affect port direction or is overridden for this option).

| Pin Name        | Function | TRIS<br>Setting | I/O | l/O<br>Type | Description                                                                               |
|-----------------|----------|-----------------|-----|-------------|-------------------------------------------------------------------------------------------|
| RF6/RP40/C1INA/ | RF6      | 0               | 0   | DIG         | LATF<6> data output.                                                                      |
| AN11/SEG24      |          | 1               | I   | ST          | PORTF<6> data input.                                                                      |
|                 | RP40     | x               | х   | DIG         | Reconfigurable Pin 40 for PPS-Lite; TRIS must be set to match input/<br>output of module. |
|                 | C1INA    | 1               | I   | ANA         | Comparator 1 Input A.                                                                     |
|                 | AN11     | 1               | I   | ANA         | A/D Input Channel 11. Default input configuration on POR; does not affect digital output. |
|                 | SEG24    | 0               | 0   | ANA         | LCD Segment 24 output; disables all other pin functions.                                  |
| RF7/RP38/AN5/   | RF7      | 0               | 0   | DIG         | LATF<7> data output.                                                                      |
| SEG25           |          | 1               | I   | ST          | PORTF<7> data input.                                                                      |
|                 | RP38     | х               | x   | DIG         | Reconfigurable Pin 38 for PPS-Lite; TRIS must be set to match input/<br>output of module. |
|                 | AN5      | 1               | I   | ANA         | A/D Input Channel 5. Default input configuration on POR; does not affect digital output.  |
|                 | SEG25    | 0               | 0   | ANA         | LCD Segment 25 output; disables all other pin functions.                                  |

#### TABLE 11-6: PORTF FUNCTIONS (CONTINUED)

Legend: O = Output, I = Input, ANA = Analog Signal, DIG = Digital Output, ST = Schmitt Trigger Buffer Input,

XCVR = USB Transceiver, x = Don't care (TRIS bit does not affect port direction or is overridden for this option).

PPS-Lite Input Peripheral Group 4n + 3

| PPS-Lite Inp           | PPS-Lite Input Peripheral Group 4n + 2 |  |  |  |  |  |  |
|------------------------|----------------------------------------|--|--|--|--|--|--|
| (1) To Map this Signal | (4) to the Associated RPIN Register    |  |  |  |  |  |  |
| <u>SS1</u>             | RPINR10 11<3:0>                        |  |  |  |  |  |  |
| INT2                   |                                        |  |  |  |  |  |  |
| IOC2                   |                                        |  |  |  |  |  |  |
| IOC6                   |                                        |  |  |  |  |  |  |
| MDMIN                  | RPINR28_29<7:4>                        |  |  |  |  |  |  |
| U1TX                   | RPINR0_1<7:4>                          |  |  |  |  |  |  |
| U2RX                   | RPINR2_3<3:0>                          |  |  |  |  |  |  |
| SCK2                   | RPINR10_11<7:4>                        |  |  |  |  |  |  |
| ECCP3                  | RPINR16_17<7:4>                        |  |  |  |  |  |  |
| CCP6                   | RPINR34_35<3:0>                        |  |  |  |  |  |  |
| CCP10                  | RPINR38_39<3:0>                        |  |  |  |  |  |  |
| RVP2                   | RPINR48_49<3:0>                        |  |  |  |  |  |  |
| RVP6                   | RPINR52_53<3:0>                        |  |  |  |  |  |  |
| (2) with this RPn Pin  | (3) Write this Corresponding Value     |  |  |  |  |  |  |
|                        | (3) White this corresponding value     |  |  |  |  |  |  |
| DD6                    | h'1                                    |  |  |  |  |  |  |
|                        | h'2                                    |  |  |  |  |  |  |
|                        | h'3                                    |  |  |  |  |  |  |
| RP18                   | h'4                                    |  |  |  |  |  |  |
| RP22                   | h'5                                    |  |  |  |  |  |  |
|                        | h'6                                    |  |  |  |  |  |  |
| RP30                   | h'7                                    |  |  |  |  |  |  |
| RP34                   | h'8                                    |  |  |  |  |  |  |
| RP38                   | h'9                                    |  |  |  |  |  |  |
| RP42                   | h'A                                    |  |  |  |  |  |  |
| RP46                   | h'B                                    |  |  |  |  |  |  |
| _                      | h'C                                    |  |  |  |  |  |  |
| _                      | h'D                                    |  |  |  |  |  |  |
| _                      | h'E                                    |  |  |  |  |  |  |
|                        |                                        |  |  |  |  |  |  |

#### TABLE 11-13: RPIN REGISTERS AND AVAILABLE FUNCTIONS (CONTINUED)

#### (1) To Map this Signal (4) to the Associated RPIN Register SS2 RPINR12 13<7:4> INT3 RPINR28 29<3:0> IOC3 RPINR20 21<7:4> IOC7 RPINR24 25<7:4> U1RX RPINR0\_1<3:0> U2TX RPINR2 3<7:4> SCK1 RPINR8 9<3:0> ECCP1 RPINR14\_15<7:4> ECCP2 RPINR16\_17<3:0> CCP4 RPINR32 33<3:0> RPINR48\_49<7:4> RVP3 RVP7 RPINR52\_53<7:4> (2) with this RPn Pin (3) Write this Corresponding Value RP3 h'0 RP7 h'1 **RP11** h'2 **RP15** h'3 **RP19** h'4 RP23 h'5 **RP27** h'6 **RP31** h'7 RP35 h'8 **RP39** h'9 RP43 h'A h'B h'C h'D \_\_\_\_ h'E Vss h'F

## 11.15.3.2 Output Mapping

In contrast to the inputs, the outputs of the Peripheral Pin Select options are mapped on the basis of the pin. In this case, a bit field associated with a particular pin dictates the peripheral output to be mapped. The RPORx registers contain sets of 4-bit fields, with each associated with one RPn pin (see Register 11-5). The value of the bit field corresponds to one of the peripherals and that peripheral's output is mapped to the pin. Each pin has a limited set of peripherals to choose from.

The PPS-Lite peripheral outputs and associated RPn pins have been organized into four groups. It is not possible to map a peripheral to an RPn pin which is outside of its group. To map a peripheral output signal to

an RPn pin, use the 4-step process, as indicated in Table 11-14. Choose the RPn pin and the signal; the column on the right shows which value to write to the associated RPORx register.

The peripheral outputs that support Peripheral Pin Selection have no default pins. Since the RPORx registers reset to all '0's, the outputs are all disconnected in the device's default (Reset) state.

The list of peripherals for output mapping also includes a null value of b'0000' because of the mapping technique. This allows unused peripherals to not be connected to a pin. Not all peripherals are available on all pins. For example, the "SDO2" signal is only available on RP0, RP4, RP8, etc. The "SDO2" signal is not available on RP1.



## FIGURE 13-11: TYPE-B WAVEFORMS IN 1/2 MUX, 1/2 BIAS DRIVE

## 15.3 Timer1/3/5 16-Bit Read/Write Mode

Timer1/3/5 can be configured for 16-bit reads and writes (see Figure 15-3). When the RD16 control bit (TxCON<1>) is set, the address for TMRxH is mapped to a buffer register for the high byte of Timer1/3/5. A read from TMRxL will load the contents of the high byte of Timer1/3/5 into the Timerx High Byte Buffer register. This provides users with the ability to accurately read all 16 bits of Timer1/3/5 without having to determine whether a read of the high byte, followed by a read of the low byte, has become invalid due to a rollover between reads.

A write to the high byte of Timer1/3/5 must also take place through the TMRxH Buffer register. The Timer1/3/5 high byte is updated with the contents of TMRxH when a write occurs to TMRxL. This allows users to write all 16 bits to both the high and low bytes of Timer1/3/5 at once.

The high byte of Timer1/3/5 is not directly readable or writable in this mode. All reads and writes must take place through the Timerx High Byte Buffer register.

Writes to TMRxH do not clear the Timer1/3/5 prescaler. The prescaler is only cleared on writes to TMRxL.

### 15.4 Using the SOSC Oscillator as the Timer1/3/5 Clock Source

The SOSC Internal Oscillator may be used as the clock source for Timer1/3/5. It can be enabled in one of these ways:

- Setting the SOSCEN bit in either of the TxCON registers (TxCON<3>)
- Setting the SOSCGO bit in the OSCCON2 register (OSCCON2<1>)
- Setting the NOSC bits to secondary clock source in the OSCCON register (OSCCON<2:0> = 100)

The SOSCGO bit is used to warm up the SOSC so that it is ready before any peripheral requests it.

To use it as the Timer3 clock source, the TMR3CSx bits must also be set. As previously noted, this also configures Timer3 to increment on every rising edge of the oscillator source.

The SOSC Oscillator is described in Section 15.4 "Using the SOSC Oscillator as the Timer1/3/5 Clock Source".

Calibration of the crystal can be done through this module to yield an error of 3 seconds or less per month.

(For further details, see Section 17.2.9 "Calibration".)

## 17.2.2 CLOCK SOURCE

As mentioned earlier, the RTCC module is intended to be clocked by an external Real-Time Clock (RTC) crystal, oscillating at 32.768 kHz, but an internal oscillator can be used. The RTCC clock selection is decided by the RTCOSC bit (CONFIG3L<0>).

#### FIGURE 17-4: CLOCK SOURCE MULTIPLEXING



#### 17.2.2.1 Real-Time Clock Enable

The RTCC module can be clocked by an external, 32.768 kHz crystal (SOSC Oscillator) or the LF-INTOSC Oscillator, which can be selected in CONFIG3L<0>.

If the external clock is used, the SOSC Oscillator should be enabled. If LF-INTOSC is providing the clock, the INTOSC clock can be brought out to the RTCC pin by the RTSECSEL<1:0> bits (RTCCON2<1:0>).

#### 17.2.3 DIGIT CARRY RULES

This section explains which timer values are affected when there is a rollover:

- Time of Day: From 23:59:59 to 00:00:00 with a carry to the Day field
- Month: From 12/31 to 01/01 with a carry to the Year field
- Day of Week: From 6 to 0 with no carry (see Table 17-1)
- Year Carry: From 99 to 00; this also surpasses the use of the RTCC

For the day-to-month rollover schedule, see Table 17-2.

Because the following values are in BCD format, the carry to the upper BCD digit occurs at the count of 10, not 16 (SECONDS, MINUTES, HOURS, WEEKDAY, DAYS and MONTHS).

#### TABLE 17-1: DAY OF WEEK SCHEDULE

| Day of Week |   |  |  |  |  |
|-------------|---|--|--|--|--|
| Sunday      | 0 |  |  |  |  |
| Monday      | 1 |  |  |  |  |
| Tuesday     | 2 |  |  |  |  |
| Wednesday   | 3 |  |  |  |  |
| Thursday    | 4 |  |  |  |  |
| Friday      | 5 |  |  |  |  |
| Saturday    | 6 |  |  |  |  |

#### TABLE 17-2: DAY TO MONTH ROLLOVER SCHEDULE

| Month          | Maximum Day Field       |  |  |  |
|----------------|-------------------------|--|--|--|
| 01 (January)   | 31                      |  |  |  |
| 02 (February)  | 28 or 29 <sup>(1)</sup> |  |  |  |
| 03 (March)     | 31                      |  |  |  |
| 04 (April)     | 30                      |  |  |  |
| 05 (May)       | 31                      |  |  |  |
| 06 (June)      | 30                      |  |  |  |
| 07 (July)      | 31                      |  |  |  |
| 08 (August)    | 31                      |  |  |  |
| 09 (September) | 30                      |  |  |  |
| 10 (October)   | 31                      |  |  |  |
| 11 (November)  | 30                      |  |  |  |
| 12 (December)  | 31                      |  |  |  |

Note 1: See Section 17.2.4 "Leap Year".

| U-0             | U-0                                    | U-0                      | R/W-0         | U-0              | R/W-0            | R/W-0           | R/W-0   |  |
|-----------------|----------------------------------------|--------------------------|---------------|------------------|------------------|-----------------|---------|--|
| —               | _                                      | —                        | C10TSEL0      | —                | C9TSEL0          | C8TSEL1         | C8TSEL0 |  |
| bit 7           |                                        |                          |               |                  |                  |                 | bit 0   |  |
|                 |                                        |                          |               |                  |                  |                 |         |  |
| Legend:         |                                        |                          |               |                  |                  |                 |         |  |
| R = Readable    | bit                                    | W = Writable             | bit           | U = Unimpler     | mented bit, read | l as '0'        |         |  |
| -n = Value at I | POR                                    | '1' = Bit is set         | t             | '0' = Bit is cle | ared             | x = Bit is unkr | nown    |  |
|                 |                                        |                          |               |                  |                  |                 |         |  |
| bit 7-5         | Unimplemen                             | ted: Read as '           | 0'            |                  |                  |                 |         |  |
| bit 4           | C10TSEL0: C                            | CP10 Timer S             | Selection bit |                  |                  |                 |         |  |
|                 | 0 = CCP10 is                           | s based off of TMR1/TMR2 |               |                  |                  |                 |         |  |
|                 | 1 = CCP10 is                           | s based off of           | TMR5/TMR2     |                  |                  |                 |         |  |
| bit 3           | Unimplemen                             | ted: Read as '           | 0'            |                  |                  |                 |         |  |
| bit 2           | C9TSEL0: CO                            | CP9 Timer Sel            | ection bit    |                  |                  |                 |         |  |
|                 | 0 = CCP9 is                            | based off of TI          | MR1/TMR2      |                  |                  |                 |         |  |
|                 | 1 = CCP9 is                            | based off of TI          | MR5/TMR4      |                  |                  |                 |         |  |
| bit 1-0         | C8TSEL<1:0>: CCP8 Timer Selection bits |                          |               |                  |                  |                 |         |  |
|                 | 00 =CCP8 is                            | based off of T           | MR1/TMR2      |                  |                  |                 |         |  |
|                 | 01 =CCP8 is                            | based off of T           | MR3/TMR4      |                  |                  |                 |         |  |
|                 | 10 =CCP8 is                            | based off of 1           | MR3/TMR6      |                  |                  |                 |         |  |

#### REGISTER 19-3: CCPTMRS2: CCP TIMER SELECT REGISTER 2

11 =Reserved; do not use

## 19.4 PWM Mode

In Pulse-Width Modulation (PWM) mode, the CCP4 pin produces up to a 10-bit resolution PWM output. Since the CCP4 pin is multiplexed with a PORTC or PORTE data latch, the appropriate TRIS bit must be cleared to make the CCP4 pin an output.

| Note: | Clearing the CCPxCON register will force    |
|-------|---------------------------------------------|
|       | the CCPx compare output latch (depend-      |
|       | ing on device configuration) to the default |
|       | low level. This is not the PORTx I/O data   |
|       | latch.                                      |

Figure 19-3 shows a simplified block diagram of the CCP4 module in PWM mode.

For a step-by-step procedure on how to set up the CCP module for PWM operation, see **Section 19.4.3** "Setup for PWM Operation".

### FIGURE 19-3: SIMPLIFIED PWM BLOCK DIAGRAM



Note 1: The 8-bit TMR2 value is concatenated with the 2-bit internal Q clock, or 2 bits of the prescaler, to create the 10-bit time base.

 CCP4 and its appropriate timers are used as an example. For details on all of the CCP modules and their timer assignments, see Table 19-2 and Table 19-3. A PWM output (Figure 19-4) has a time base (period) and a time that the output stays high (duty cycle). The frequency of the PWM is the inverse of the period (1/ period).

#### FIGURE 19-4: PWM OUTPUT



### 19.4.1 PWM PERIOD

The PWM period is specified by writing to the PR2 register. The PWM period can be calculated using the following formula:

#### EQUATION 19-1: PWM PERIOD CALCULATION

| PWM Period | =[(PR2) + 1] • 4 • Tosc • |
|------------|---------------------------|
|            | (TMR2 Prescale Value)     |

PWM frequency is defined as 1/[PWM period].

When TMR2 is equal to PR2, the following three events occur on the next increment cycle:

- TMR2 is cleared
- The CCP4 pin is set
  - (An exception: If PWM Duty Cycle = 0%, the CCP4 pin will not be set)
- The PWM duty cycle is latched from CCPR4L into CCPR4H

| Note: | The       | Time   | r2    | postsca    | lers    | (see      |
|-------|-----------|--------|-------|------------|---------|-----------|
|       | Section   | 16.0   | "Ti   | mer2/4/6/8 | Moc     | lules")   |
|       | are not   | used   | in tl | ne determi | nation  | of the    |
|       | PWM fre   | equen  | су    | The postsc | aler co | ould be   |
|       | used to   | have a | a se  | rvo update | rate a  | at a dif- |
|       | ferent fr | equen  | cy tl | han the PV | /M out  | tput.     |

| EXAMPLE 22-3: A/D INIT    | IALIZATION CODE EXAMPLE                                         |
|---------------------------|-----------------------------------------------------------------|
| ADCON1H = 0x22;           | // Configure sample clock source                                |
| ADCON1L = $0 \times 00$ ; | // and conversion trigger mode.                                 |
|                           | <pre>// Unsigned Fraction format (FORM&lt;1:0&gt;=10),</pre>    |
|                           | <pre>// Manual conversion trigger (SSRC&lt;3:0&gt;=0000),</pre> |
|                           | // Manual start of sampling (ASAM=0),                           |
|                           | // S/H in Sample (SAMP = 1)                                     |
| ADCON2H = 0;              | // Configure A/D voltage reference                              |
| ADCON2L = 0;              | // and buffer fill modes.                                       |
|                           | // Vr+ and Vr- from AVdd and AVss(PVCFG<1:0>=00, NVCFG=0),      |
|                           | // Inputs are not scanned,                                      |
|                           | // Interrupt after every sample                                 |
| ADCON3H = 0;              | // Configure sample time = 1Tad,                                |
| ADCON3L = 0;              | // A/D conversion clock as Tcy                                  |
|                           |                                                                 |
| ADCHSOH = $0;$            | // Configure input channels,                                    |
| ADCHSOL = 0;              | // S/H+ input is ANO,                                           |
|                           | // S/H- input is Vr- (AVss).                                    |
| ADCSSOL = 0;              | // No inputs are scanned.                                       |
| ADCSSOH = 0;              | // No inputs are scanned.                                       |
| PIR1bits.ADIF = 0;        | // Clear A/D conversion interrupt.                              |
|                           |                                                                 |
| // Configure A/D interr   | upt priority bits (ADIP) here, if                               |
| // required. Default pr   | iority level is high.                                           |
|                           |                                                                 |
| PIE1bits.ADIE = 1;        | // Enable A/D conversion interrupt                              |
| ADCON1Hbits.ADON = 1;     | // Turn on A/D                                                  |
| ADCON1Lbits.SAMP = 1;     | // Start sampling the input                                     |
| Delay();                  | // Ensure the correct sampling time has elapsed                 |
|                           | // before starting conversion.                                  |
| ADCON1Lbits.SAMP = 0;     | // End A/D sampling and start conversion                        |
|                           |                                                                 |
| // Example code for A/D   | ISR:                                                            |
| #pragma interrupt _ADC1   | Interrupt                                                       |
| void _ADC1Interrupt(voi   | d)                                                              |
| {                         |                                                                 |
| PIR1bits.ADIF = 0;        |                                                                 |
| }                         |                                                                 |
|                           |                                                                 |
|                           |                                                                 |

| REGISTER 23-2: CMST | AT: COMPARATOR | STATUS REGISTER |
|---------------------|----------------|-----------------|
|---------------------|----------------|-----------------|

| U-0     | U-0 | U-0 | U-0 | U-0 | R-x   | R-x   | R-x   |
|---------|-----|-----|-----|-----|-------|-------|-------|
|         | —   | _   | —   | —   | C3OUT | C2OUT | C1OUT |
| bit 7   |     |     |     |     |       |       | bit 0 |
|         |     |     |     |     |       |       |       |
| Lonondi |     |     |     |     |       |       |       |

| Legena.           |                  |                             |                    |
|-------------------|------------------|-----------------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit, read | d as '0'           |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared        | x = Bit is unknown |

bit 7-3 Unimplemented: Read as '0'

| bit 2-0 | C3OUT:C1OUT: Comparator x Status bits           |
|---------|-------------------------------------------------|
|         | If CPOL (CMxCON<5>)= 0 (non-inverted polarity): |
|         |                                                 |

1 = Comparator x's VIN+ > VIN-

0 = Comparator x's VIN+ < VIN-

CPOL = 1 (inverted polarity):

1 = Comparator x's VIN+ < VIN-

0 = Comparator x's VIN + > VIN

## 23.2 Comparator Operation

A single comparator is shown in Figure 23-2, along with the relationship between the analog input levels and the digital output. When the analog input at VIN+ is less than the analog input, VIN-, the output of the comparator is a digital low level. When the analog input at VIN+ is greater than the analog input, VIN-, the output of the comparator is a digital high level. The shaded areas of the output of the comparator in Figure 23-2 represent the uncertainty due to input offsets and response time.

FIGURE 23-2: SINGLE COMPARATOR



## 23.3 Comparator Response Time

Response time is the minimum time, after selecting a new reference voltage or input source, before the comparator output has a valid level. The response time of the comparator differs from the settling time of the voltage reference. Therefore, both of these times must be considered when determining the total response to a comparator input change. Otherwise, the maximum delay of the comparators should be used (see **Section 30.0 "Electrical Specifications"**).

## 23.4 Analog Input Connection Considerations

A simplified circuit for an analog input is shown in Figure 23-3. Since the analog pins are connected to a digital output, they have reverse biased diodes to VDD and VSs. The analog input, therefore, must be between VSs and VDD. If the input voltage deviates from this range by more than 0.6V in either direction, one of the diodes is forward biased and a latch-up condition may occur.

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

## REGISTER 27-2: UCFG: USB CONFIGURATION REGISTER

| R/W-0      | R/W-0                           | U-0                                   | R/W-0                                | R/W-0                                 | R/W-0                               | R/W-0                          | R/W-0        |
|------------|---------------------------------|---------------------------------------|--------------------------------------|---------------------------------------|-------------------------------------|--------------------------------|--------------|
| UTEYE      | E UOEMON                        |                                       | UPUEN <sup>(1,2)</sup>               | UTRDIS <sup>(1,3)</sup>               | FSEN <sup>(1)</sup>                 | PPB1                           | PPB0         |
| oit 7      |                                 |                                       |                                      |                                       |                                     |                                | bit          |
|            |                                 |                                       |                                      |                                       |                                     |                                |              |
| Legend:    |                                 |                                       |                                      |                                       |                                     |                                |              |
| R = Reada  | able bit                        | W = Writable                          | e bit                                | U = Unimplem                          | iented bit, read                    | as '0'                         |              |
| -n = Value | at POR                          | '1' = Bit is se                       | t                                    | '0' = Bit is clea                     | ared                                | x = Bit is unkr                | nown         |
|            |                                 |                                       | <b>.</b>                             |                                       |                                     |                                |              |
| DIT /      | UIEYE: US                       | B Eye Pattern                         |                                      |                                       |                                     |                                |              |
|            | $\perp$ = Eye pat               | tern test is ena<br>tern test is disa | bled                                 |                                       |                                     |                                |              |
| bit 6      |                                 | JSB OF Monite                         | or Enable bit                        |                                       |                                     |                                |              |
|            | $1 = \overline{\text{UOE}}$ sid | anal is active. in                    | ndicating interva                    | als during which                      | n the D+/D- line                    | es are driving                 |              |
|            | 0 = UOE sig                     | gnal is inactive                      | jj                                   |                                       |                                     |                                |              |
| oit 5      | Unimpleme                       | nted: Read as                         | <b>'</b> 0 <b>'</b>                  |                                       |                                     |                                |              |
| oit 4      | UPUEN: US                       | B On-Chip Pul                         | -up Enable bit <sup>(</sup>          | 1,2)                                  |                                     |                                |              |
|            | 1 = On-chip<br>0 = On-chip      | pull-up is enab<br>pull-up is disat   | led (pull-up on<br>bled              | D+ with FSEN                          | = 1 or D- with I                    | <b>SEN =</b> 0)                |              |
| bit 3      | UTRDIS: Or                      | n-Chip Transce                        | iver Disable bit                     | (1,3)                                 |                                     |                                |              |
|            | 1 = On-chip                     | transceiver is o                      | lisabled                             |                                       |                                     |                                |              |
|            | 0 = On-chip                     | transceiver is a                      | active                               |                                       |                                     |                                |              |
| oit 2      | FSEN: Full-S                    | Speed Enable I                        | oit <sup>(1)</sup>                   |                                       |                                     |                                |              |
|            | 1 = Full-spe<br>0 = Low-spe     | ed device: Con<br>ed device: Cor      | trols transceive<br>trols transceive | r edge rates; re<br>er edge rates; re | equires input cl<br>equires input c | ock at 48 MHz<br>lock at 6 MHz |              |
| oit 1-0    | PPB<1:0>:                       | Ping-Pong Buff                        | ers Configurati                      | on bits                               |                                     |                                |              |
|            | 11 = Even/C                     | dd ping-pong                          | ouffers are enal                     | bled for Endpoi                       | nts 1 to 15                         |                                |              |
|            | 10 = Even/C                     | dd ping-pong l                        | ouffers are enal                     | bled for all endp                     | points                              |                                |              |
|            | 01 = Even/C                     | ad ping-pong i<br>dd ping-pong i      | ouffers are enab                     | led for OUT En<br>bled                | apoint U                            |                                |              |
|            |                                 | aa ping-pong i                        |                                      | bicd                                  |                                     |                                |              |
| Note 1:    | The UPUEN, UTF values must be p | RDIS and FSEI<br>reconfigured pr      | N bits should ne<br>ior to enabling  | ever be change<br>the module.         | d while the US                      | B module is en                 | abled. These |
| 2:         | This bit is only val            | id when the on                        | -chip transceive                     | r is active (UTR                      | DIS = 0); other                     | wise, it is ignor              | ed.          |

**3:** If UTRDIS is set, the UOE signal will be active, independent of the UOEMON bit setting.

## 27.6 USB Power Modes

Many USB applications will likely have several different sets of power requirements and configuration. The most common power modes encountered are Bus Power Only, Self-Power Only and Dual Power with Self-Power Dominance. The most common cases are presented here. Also provided is a means of estimating the current consumption of the USB transceiver.

### 27.6.1 BUS POWER ONLY

In Bus Power Only mode, all power for the application is drawn from the USB (Figure 27-9). This is effectively the simplest power method for the device.

In order to meet the inrush current requirements of the "USB 2.0 Specification", the total effective capacitance appearing across VBUs and ground must be no more than 10  $\mu$ F. If not, some kind of inrush timing is required. For more details, see **Section 7.2.4 of the** "**USB 2.0 Specification**".

According to the "USB 2.0 Specification", all USB devices must also support a Low-Power Suspend mode. In the USB Suspend mode, devices must consume no more than 2.5 mA from the 5V VBUS line of the USB cable.

The host signals the USB device to enter the Suspend mode by stopping all USB traffic to that device for more than 3 ms. This condition will cause the IDLEIF bit in the UIR register to become set.

During the USB Suspend mode, the D+ or D- pull-up resistor must remain active, which will consume some of the allowed suspend current: 2.5 mA budget.

## FIGURE 27-9: BUS POWER ONLY



## 27.6.2 SELF-POWER ONLY

In Self-Power Only mode, the USB application provides its own power, with very little power being pulled from the USB. See Figure 27-10 for an example.

Note that an attach indication is added to indicate when the USB has been connected and the host is actively powering VBUS.

In order to meet compliance specifications, the USB module (and the D+ or D- pull-up resistor) should not be enabled until the host actively drives VBUS high. One of the 5.5V tolerant I/O pins may be used for this purpose.

The application should never source any current onto the 5V VBUS pin of the USB cable.

#### FIGURE 27-10: SELF-POWER ONLY



### 27.6.3 DUAL POWER WITH SELF-POWER DOMINANCE

Some applications may require a dual power option. This allows the application to use internal power primarily, but switch to power from the USB when no internal power is available. See Figure 27-11 for a simple Dual Power with Self-Power Dominance mode example, which automatically switches between Self-Power Only and USB Bus Power Only modes.

Dual power devices must also meet all of the special requirements for inrush current and Suspend mode current, and must not enable the USB module until VBUS is driven high. See Section 27.6.1 "Bus Power Only" and Section 27.6.2 "Self-Power Only" for descriptions of those requirements. Additionally, dual power devices must never source current onto the 5V VBUS pin of the USB cable.

#### FIGURE 27-11: DUAL POWER WITH SELF-POWER DOMINANCE



Note: Users should keep in mind the limits for devices drawing power from the USB. According to USB Specification 2.0, this cannot exceed 100 mA per low-power device or 500 mA per high-power device.

| ADDWFC       |                                                                                                                                                                                                                                                                                    | ADD W a                                                      | ADD W and Carry bit to f                                                                                                                                                |               |                       |  |  |  |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-----------------------|--|--|--|
| Synta        | x:                                                                                                                                                                                                                                                                                 | ADDWFC                                                       | f {,d {,;                                                                                                                                                               | a}}           |                       |  |  |  |
| Opera        | ands:                                                                                                                                                                                                                                                                              | $0 \le f \le 255$<br>$d \in [0,1]$<br>$a \in [0,1]$          | 5                                                                                                                                                                       |               |                       |  |  |  |
| Opera        | ation:                                                                                                                                                                                                                                                                             | (W) + (f) +                                                  | $(C) \rightarrow de$                                                                                                                                                    | st            |                       |  |  |  |
| Status       | Affected:                                                                                                                                                                                                                                                                          | N,OV, C, I                                                   | N,OV, C, DC, Z                                                                                                                                                          |               |                       |  |  |  |
| Enco         | ding:                                                                                                                                                                                                                                                                              | 0010                                                         | 00da                                                                                                                                                                    | ffff          | ffff                  |  |  |  |
| Description: |                                                                                                                                                                                                                                                                                    | Add W, the<br>location 'f'<br>placed in v<br>placed in v     | Add W, the Carry flag and data memory<br>location 'f'. If 'd' is '0', the result is<br>placed in W. If 'd' is '1', the result is<br>placed in data memory location 'f'. |               |                       |  |  |  |
|              |                                                                                                                                                                                                                                                                                    | lf 'a' is '0',<br>lf 'a' is '1',<br>GPR bank                 | If 'a' is '0', the Access Bank is selected.<br>If 'a' is '1', the BSR is used to select the<br>GPR bank.                                                                |               |                       |  |  |  |
|              | If 'a' is '0' and the extended instruction<br>set is enabled, this instruction operate<br>in Indexed Literal Offset Addressing<br>mode whenever f ≤ 95 (5Fh). See<br>Section 29.2.3 "Byte-Oriented and<br>Bit-Oriented Instructions in Indexed<br>Literal Offset Mode" for details |                                                              |                                                                                                                                                                         |               |                       |  |  |  |
| Words        | 6:                                                                                                                                                                                                                                                                                 | 1                                                            |                                                                                                                                                                         |               |                       |  |  |  |
| Cycle        | S:                                                                                                                                                                                                                                                                                 | 1                                                            |                                                                                                                                                                         |               |                       |  |  |  |
| Q Cy         | cle Activity:                                                                                                                                                                                                                                                                      |                                                              |                                                                                                                                                                         |               |                       |  |  |  |
| F            | Q1                                                                                                                                                                                                                                                                                 | Q2                                                           | Q3                                                                                                                                                                      |               | Q4                    |  |  |  |
|              | Decode                                                                                                                                                                                                                                                                             | Read<br>register 'f'                                         | Proce:<br>Data                                                                                                                                                          | ss V<br>a des | /rite to<br>stination |  |  |  |
| Example:     |                                                                                                                                                                                                                                                                                    | ADDWFC                                                       | REG,                                                                                                                                                                    | 0, 1          |                       |  |  |  |
| E<br>/       | Before Instruc<br>Carry bit<br>REG<br>W<br>After Instructio<br>Carry bit<br>REG<br>W                                                                                                                                                                                               | tion<br>= 1<br>= 02h<br>= 4Dh<br>on<br>= 0<br>= 02h<br>= 50h |                                                                                                                                                                         |               |                       |  |  |  |

| ANDLW        |                                         | AND Liter                   | AND Literal with W                                                                 |          |   |               |  |  |  |
|--------------|-----------------------------------------|-----------------------------|------------------------------------------------------------------------------------|----------|---|---------------|--|--|--|
| Syntax:      |                                         | ANDLW                       | k                                                                                  |          |   |               |  |  |  |
| Operands:    |                                         | $0 \le k \le 25$            | $0 \leq k \leq 255$                                                                |          |   |               |  |  |  |
| Opera        | ation:                                  | (W) .AND.                   | (W) .AND. $k \rightarrow W$                                                        |          |   |               |  |  |  |
| Statu        | s Affected:                             | N, Z                        | N, Z                                                                               |          |   |               |  |  |  |
| Enco         | ding:                                   | 0000                        | 1011                                                                               | kkk.     | k | kkkk          |  |  |  |
| Description: |                                         | The conter<br>8-bit literal | The contents of W are ANDed with the 8-bit literal 'k'. The result is placed in W. |          |   |               |  |  |  |
| Word         | s:                                      | 1                           |                                                                                    |          |   |               |  |  |  |
| Cycle        | S:                                      | 1                           |                                                                                    |          |   |               |  |  |  |
| QC           | cle Activity:                           |                             |                                                                                    |          |   |               |  |  |  |
| _            | Q1                                      | Q2                          | Q3                                                                                 | 5        |   | Q4            |  |  |  |
|              | Decode                                  | Read literal<br>'k'         | Proce<br>Data                                                                      | ess<br>a | W | /rite to<br>W |  |  |  |
| Exam         | iple:                                   | ANDLW                       | 05Fh                                                                               |          |   |               |  |  |  |
| l            | Before Instruc<br>W<br>After Instructic | tion<br>= A3h<br>on         |                                                                                    |          |   |               |  |  |  |
|              | W                                       | = 03h                       |                                                                                    |          |   |               |  |  |  |
|              |                                         |                             |                                                                                    |          |   |               |  |  |  |

| TBL                                                                               | RD             | Table Read                                                                                                                                                                                                                                                                                                                                                                           |    |                                                                                                                                                                                                         |            |    |                                           |  |
|-----------------------------------------------------------------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----|-------------------------------------------|--|
| Synta                                                                             | ax:            | TBLRD ( *; *+; *-; +*)                                                                                                                                                                                                                                                                                                                                                               |    |                                                                                                                                                                                                         |            |    |                                           |  |
| Oper                                                                              | ands:          | None                                                                                                                                                                                                                                                                                                                                                                                 |    |                                                                                                                                                                                                         |            |    |                                           |  |
| Oper                                                                              | ation:         | if TBLRD *,<br>(Prog Mem (TBLPTR)) $\rightarrow$ TABLAT;<br>TBLPTR – No Change<br>if TBLRD *+,<br>(Prog Mem (TBLPTR)) $\rightarrow$ TABLAT;<br>(TBLPTR) + 1 $\rightarrow$ TBLPTR<br>if TBLRD *-,<br>(Prog Mem (TBLPTR)) $\rightarrow$ TABLAT;<br>(TBLPTR) – 1 $\rightarrow$ TBLPTR<br>if TBLRD +*,<br>(TBLPTR) + 1 $\rightarrow$ TBLPTR;<br>(Prog Mem (TBLPTR)) $\rightarrow$ TABLAT |    |                                                                                                                                                                                                         |            |    |                                           |  |
| Statu                                                                             | s Affected:    | None                                                                                                                                                                                                                                                                                                                                                                                 |    |                                                                                                                                                                                                         |            |    |                                           |  |
| Enco                                                                              | ding:          | 0000                                                                                                                                                                                                                                                                                                                                                                                 | 00 | 000                                                                                                                                                                                                     | 000        | 00 | 10nn<br>nn=0 *<br>=1 *+<br>=2 *-<br>=3 +* |  |
| Description: This instruct<br>of Program<br>program m<br>Pointer (TE<br>The TBLPT |                |                                                                                                                                                                                                                                                                                                                                                                                      |    | struction is used to read the contents<br>ram Memory (P.M.). To address the<br>n memory, a pointer called Table<br>(TBLPTR) is used.<br>LPTR (a 21-bit pointer) points to<br>the program memory TBL PTR |            |    |                                           |  |
|                                                                                   | has a 2-Mby    | a 2-Mbyte address range.                                                                                                                                                                                                                                                                                                                                                             |    |                                                                                                                                                                                                         |            |    |                                           |  |
|                                                                                   |                | TBLPTR<0> = 0:Least Significant Byte of<br>Program Memory Word                                                                                                                                                                                                                                                                                                                       |    |                                                                                                                                                                                                         |            |    |                                           |  |
|                                                                                   |                | Program Memory Word                                                                                                                                                                                                                                                                                                                                                                  |    |                                                                                                                                                                                                         |            |    |                                           |  |
|                                                                                   |                | The TBLRD instruction can modify the value of TBLPTR as follows:                                                                                                                                                                                                                                                                                                                     |    |                                                                                                                                                                                                         |            |    |                                           |  |
|                                                                                   |                | no change                                                                                                                                                                                                                                                                                                                                                                            |    |                                                                                                                                                                                                         |            |    |                                           |  |
|                                                                                   |                | post-increment                                                                                                                                                                                                                                                                                                                                                                       |    |                                                                                                                                                                                                         |            |    |                                           |  |
|                                                                                   |                | post-decrement                                                                                                                                                                                                                                                                                                                                                                       |    |                                                                                                                                                                                                         |            |    |                                           |  |
|                                                                                   |                | • pre-increment                                                                                                                                                                                                                                                                                                                                                                      |    |                                                                                                                                                                                                         |            |    |                                           |  |
| Words:                                                                            |                | 1                                                                                                                                                                                                                                                                                                                                                                                    |    |                                                                                                                                                                                                         |            |    |                                           |  |
| Cycles:                                                                           |                | 2                                                                                                                                                                                                                                                                                                                                                                                    |    |                                                                                                                                                                                                         |            |    |                                           |  |
| QC                                                                                | ycle Activity: | :                                                                                                                                                                                                                                                                                                                                                                                    |    |                                                                                                                                                                                                         |            |    |                                           |  |
|                                                                                   | Q1             | Q2                                                                                                                                                                                                                                                                                                                                                                                   |    | C                                                                                                                                                                                                       | 13         |    | Q4                                        |  |
|                                                                                   | Decode         | No<br>operation                                                                                                                                                                                                                                                                                                                                                                      |    | N<br>opera                                                                                                                                                                                              | o<br>ation | ор | No<br>eration                             |  |

No operation (Write TABLAT)

| TBLRD                                                                        | Table Re  | ad | (Con        | tinued)                      |
|------------------------------------------------------------------------------|-----------|----|-------------|------------------------------|
| Example 1:                                                                   | TBLRD     | *+ | ;           |                              |
| Before Instruction                                                           | on        |    |             |                              |
| TABLAT<br>TBLPTR<br>MEMORY(                                                  | (00A356h) | )  | =<br>=<br>= | 55h<br>00A356h<br>34h        |
| After Instruction<br>TABLAT<br>TBLPTR                                        |           |    | =<br>=      | 34h<br>00A357h               |
| Example 2:                                                                   | TBLRD     | +* | ;           |                              |
| Before Instruction<br>TABLAT<br>TBLPTR<br>MEMORY(01A357h)<br>MEMORY(01A358h) |           |    |             | AAh<br>01A357h<br>12h<br>34h |
| TABLAT                                                                       |           |    | =           | 34h<br>01A358h               |

No operation (Read Program

Memory)

No

operation

No

operation

## 31.2 MPLAB XC Compilers

The MPLAB XC Compilers are complete ANSI C compilers for all of Microchip's 8, 16, and 32-bit MCU and DSC devices. These compilers provide powerful integration capabilities, superior code optimization and ease of use. MPLAB XC Compilers run on Windows, Linux or MAC OS X.

For easy source level debugging, the compilers provide debug information that is optimized to the MPLAB X IDE.

The free MPLAB XC Compiler editions support all devices and commands, with no time or memory restrictions, and offer sufficient code optimization for most applications.

MPLAB XC Compilers include an assembler, linker and utilities. The assembler generates relocatable object files that can then be archived or linked with other relocatable object files and archives to create an executable file. MPLAB XC Compiler uses the assembler to produce its object file. Notable features of the assembler include:

- · Support for the entire device instruction set
- · Support for fixed-point and floating-point data
- Command-line interface
- · Rich directive set
- · Flexible macro language
- MPLAB X IDE compatibility

## 31.3 MPASM Assembler

The MPASM Assembler is a full-featured, universal macro assembler for PIC10/12/16/18 MCUs.

The MPASM Assembler generates relocatable object files for the MPLINK Object Linker, Intel<sup>®</sup> standard HEX files, MAP files to detail memory usage and symbol reference, absolute LST files that contain source lines and generated machine code, and COFF files for debugging.

The MPASM Assembler features include:

- Integration into MPLAB X IDE projects
- User-defined macros to streamline assembly code
- Conditional assembly for multipurpose source files
- Directives that allow complete control over the assembly process

## 31.4 MPLINK Object Linker/ MPLIB Object Librarian

The MPLINK Object Linker combines relocatable objects created by the MPASM Assembler. It can link relocatable objects from precompiled libraries, using directives from a linker script.

The MPLIB Object Librarian manages the creation and modification of library files of precompiled code. When a routine from a library is called from a source file, only the modules that contain that routine will be linked in with the application. This allows large libraries to be used efficiently in many different applications.

The object linker/library features include:

- Efficient linking of single libraries instead of many smaller files
- Enhanced code maintainability by grouping related modules together
- Flexible creation of libraries with easy module listing, replacement, deletion and extraction

## 31.5 MPLAB Assembler, Linker and Librarian for Various Device Families

MPLAB Assembler produces relocatable machine code from symbolic assembly language for PIC24, PIC32 and dsPIC DSC devices. MPLAB XC Compiler uses the assembler to produce its object file. The assembler generates relocatable object files that can then be archived or linked with other relocatable object files and archives to create an executable file. Notable features of the assembler include:

- · Support for the entire device instruction set
- · Support for fixed-point and floating-point data
- Command-line interface
- Rich directive set
- Flexible macro language
- MPLAB X IDE compatibility

80-Lead Plastic Thin Quad Flatpack (PT)-12x12x1mm Body, 2.00 mm Footprint [TQFP]

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



RECOMMENDED LAND PATTERN

|                          |                | -    |       |      |
|--------------------------|----------------|------|-------|------|
|                          | MILLIMETERS    |      |       |      |
| Dimension Limits         |                | MIN  | NOM   | MAX  |
| Contact Pitch            | ich E 0.50 BSC |      |       | -    |
| Contact Pad Spacing      | C1             |      | 13.40 |      |
| Contact Pad Spacing      | C2             |      | 13.40 |      |
| Contact Pad Width (X80)  | X1             |      |       | 0.30 |
| Contact Pad Length (X80) | Y1             |      |       | 1.50 |
| Distance Between Pads    | G              | 0.20 |       |      |

Notes:

1. Dimensioning and tolerancing per ASME Y14.5M

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

Microchip Technology Drawing No. C04-2092B