

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                      | 48MHz                                                                       |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART, USB                              |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                       |
| Number of I/O              | 34                                                                          |
| Program Memory Size        | 128KB (64K x 16)                                                            |
| Program Memory Type        | FLASH                                                                       |
| EEPROM Size                | -                                                                           |
| RAM Size                   | 3.8K x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 2.75V                                                                  |
| Data Converters            | A/D 13x10b/12b                                                              |
| Oscillator Type            | Internal                                                                    |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                           |
| Mounting Type              | Surface Mount                                                               |
| Package / Case             | 44-VQFN Exposed Pad                                                         |
| Supplier Device Package    | 44-QFN (8x8)                                                                |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18lf47j53-i-ml |

Email: info@E-XFL.COM

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

|                 |                                                                                                        |                            |                 |                  |                    | ,               | ,      |  |
|-----------------|--------------------------------------------------------------------------------------------------------|----------------------------|-----------------|------------------|--------------------|-----------------|--------|--|
| R/W-0           | U-0                                                                                                    | R/W-0                      | R/W-0           | R/W-0            | R/W-0              | U-0             | R/W-1  |  |
| DSFLT           | —                                                                                                      | DSULP                      | DSWDT           | DSRTC            | DSMCLR             | —               | DSPOR  |  |
| bit 7           |                                                                                                        |                            |                 |                  |                    |                 | bit (  |  |
|                 |                                                                                                        |                            |                 |                  |                    |                 |        |  |
| Legend:         |                                                                                                        |                            |                 |                  |                    |                 |        |  |
| R = Readable I  | bit                                                                                                    | W = Writable               | bit             | U = Unimpler     | mented bit, read   | as '0'          |        |  |
| -n = Value at P | OR                                                                                                     | '1' = Bit is set           |                 | '0' = Bit is cle | ared               | x = Bit is unkr | nown   |  |
| hit 7           |                                                                                                        | Sloop Fault D              | atastad bit     |                  |                    |                 |        |  |
|                 |                                                                                                        | Sleep Fault Mo             | elected bit     | ing Doon Sloo    | <b>.</b>           |                 |        |  |
|                 | 1 = A Deep S<br>0 = A Deep S                                                                           | Sleep Fault was            | s not detected  | during Deep Siee | p<br>Sleep         |                 |        |  |
| bit 6           |                                                                                                        | ted: Read as '             | 0'              | ddinig 200p (    |                    |                 |        |  |
| bit 5           | DSUI P: Ultra Low-Power Wake-up Status bit                                                             |                            |                 |                  |                    |                 |        |  |
|                 | 1 = An ultra low-power wake-up event occurred during Deep Sleep                                        |                            |                 |                  |                    |                 |        |  |
|                 | 0 = An ultra low-power wake-up event did not occur during Deep Sleep                                   |                            |                 |                  |                    |                 |        |  |
| bit 4           | DSWDT: Deep Sleep Watchdog Timer Time-out bit                                                          |                            |                 |                  |                    |                 |        |  |
|                 | 1 = The Deep Sleep Watchdog Timer timed out during Deep Sleep                                          |                            |                 |                  |                    |                 |        |  |
|                 | 0 = The Deep Sleep Watchdog Timer did not time out during Deep Sleep                                   |                            |                 |                  |                    |                 |        |  |
| bit 3           | DSRTC: Real-Time Clock and Calendar Alarm bit                                                          |                            |                 |                  |                    |                 |        |  |
|                 | 1 = The Real-Time Clock/Calendar triggered an alarm during Deep Sleep                                  |                            |                 |                  |                    |                 |        |  |
| 1.11.0          |                                                                                                        |                            | alendar did n   | ot trigger an ai | arm during Dee     | p Sleep         |        |  |
| bit 2           | DSMCLR: MCLR Event bit                                                                                 |                            |                 |                  |                    |                 |        |  |
|                 | 1 = The MCLR pin was asserted during Deep Sleep<br>0 = The MCLR pin was not asserted during Deep Sleep |                            |                 |                  |                    |                 |        |  |
| hit 1           | U = The MOLK pin was not asserted during Deep Sleep                                                    |                            |                 |                  |                    |                 |        |  |
| bit 0           |                                                                                                        | Jnimplemented: Read as '0' |                 |                  |                    |                 |        |  |
|                 |                                                                                                        |                            | venit was activ | a and a POP a    | went was deter     | tod(1)          |        |  |
|                 | 1 = The VDD                                                                                            | supply FOR cli             | cuit was activ  | ctive. or was a  | active, but did no | ot detect a POF | Revent |  |
|                 |                                                                                                        |                            |                 |                  |                    |                 |        |  |

### REGISTER 4-6: DSWAKEL: DEEP SLEEP WAKE LOW BYTE REGISTER (BANKED F4Ah)

**Note 1:** Unlike the other bits in this register, this bit can be set outside of Deep Sleep.

### 5.7 Reset State of Registers

Most registers are unaffected by a Reset. Their status is unknown on POR and unchanged by all other Resets. The other registers are forced to a "Reset state" depending on the type of Reset that occurred.

Most registers are not affected by a WDT wake-up, since this is viewed as the resumption of normal operation. Status bits from the RCON register (CM, RI,

TO, PD, POR and BOR) are set or cleared differently in different Reset situations, as indicated in Table 5-1. These bits are used in software to determine the nature of the Reset.

Table 5-2 describes the Reset states for all of the Special Function Registers. These are categorized by POR and BOR, MCLR and WDT Resets and WDT wake-ups.

| TABLE 5-1: | STATUS BITS, THEIR SIGNIFICANCE AND THE INITIALIZATION CONDITION FOR |
|------------|----------------------------------------------------------------------|
|            | RCON REGISTER                                                        |

| Condition                                                       | Program                | RCON Register STKPTR F |    |    |    |     | Register |        |        |
|-----------------------------------------------------------------|------------------------|------------------------|----|----|----|-----|----------|--------|--------|
| Condition                                                       | Counter <sup>(1)</sup> | CM                     | RI | то | PD | POR | BOR      | STKFUL | STKUNF |
| Power-on Reset                                                  | 0000h                  | 1                      | 1  | 1  | 1  | 0   | 0        | 0      | 0      |
| RESET instruction                                               | 0000h                  | u                      | 0  | u  | u  | u   | u        | u      | u      |
| Brown-out Reset                                                 | 0000h                  | 1                      | 1  | 1  | 1  | u   | 0        | u      | u      |
| Configuration Mismatch Reset                                    | 0000h                  | 0                      | u  | u  | u  | u   | u        | u      | u      |
| MCLR Reset during power-managed Run modes                       | 0000h                  | u                      | u  | 1  | u  | u   | u        | u      | u      |
| MCLR Reset during<br>power-managed Idle modes and<br>Sleep mode | 0000h                  | u                      | u  | 1  | 0  | u   | u        | u      | u      |
| MCLR Reset during full-power execution                          | 0000h                  | u                      | u  | u  | u  | u   | u        | u      | u      |
| Stack Full Reset (STVREN = 1)                                   | 0000h                  | u                      | u  | u  | u  | u   | u        | 1      | u      |
| Stack Underflow Reset<br>(STVREN = 1)                           | 0000h                  | u                      | u  | u  | u  | u   | u        | u      | 1      |
| Stack Underflow Error (not an actual Reset, STVREN = 0)         | 0000h                  | u                      | u  | u  | u  | u   | u        | u      | 1      |
| WDT time-out during full-power<br>or power-managed Run modes    | 0000h                  | u                      | u  | 0  | u  | u   | u        | u      | u      |
| WDT time-out during<br>power-managed Idle or Sleep<br>modes     | PC + 2                 | u                      | u  | 0  | 0  | u   | u        | u      | u      |
| Interrupt exit from<br>power-managed modes                      | PC + 2                 | u                      | u  | u  | 0  | u   | u        | u      | u      |

**Legend:** u = unchanged

**Note 1:** When the wake-up is due to an interrupt and the GIEH or GIEL bit is set, the PC is loaded with the interrupt vector (0008h or 0018h).

### 6.1.1 HARD MEMORY VECTORS

All PIC18 devices have a total of three hard-coded return vectors in their program memory space. The Reset vector address is the default value to which the program counter returns on all device Resets; it is located at 0000h.

PIC18 devices also have two interrupt vector addresses for handling high-priority and low-priority interrupts. The high-priority interrupt vector is located at 0008h and the low-priority interrupt vector at 0018h. Figure 6-2 provides their locations in relation to the program memory map.

### FIGURE 6-2: HARD VECTOR AND CONFIGURATION WORD LOCATIONS FOR PIC18F47J53 FAMILY DEVICES

| Reset Vector                                                                                     | 0000h                                                                                                                                   |
|--------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| High-Priority Interrupt V                                                                        | ector 0008h                                                                                                                             |
| Low-Priority Interrupt V                                                                         | ector 0018h                                                                                                                             |
| On-Chip<br>Program Memory                                                                        |                                                                                                                                         |
| Flash Configuration W                                                                            | ords (Top of Memory-7)<br>(Top of Memory)                                                                                               |
| Read as '0'                                                                                      |                                                                                                                                         |
|                                                                                                  | 1FFFFh                                                                                                                                  |
| Legend: (Top of Memory<br>of on-chip prog<br>Figure 6-1 for o<br>Shaded area re<br>memory. Areas | y) represents upper boundary<br>ram memory space (see<br>levice-specific values).<br>epresents unimplemented<br>are not shown to scale. |

### 6.1.2 FLASH CONFIGURATION WORDS

Because PIC18F47J53 family devices do not have persistent configuration memory, the top four words of on-chip program memory are reserved for configuration information. On Reset, the configuration information is copied into the Configuration registers.

The Configuration Words are stored in their program memory location in numerical order, starting with the lower byte of CONFIG1 at the lowest address and ending with the upper byte of CONFIG4.

Table 6-1 provides the actual addresses of the Flash Configuration Word for devices in the PIC18F47J53 family. Figure 6-2 displays their location in the memory map with other memory vectors.

Additional details on the device Configuration Words are provided in **Section 28.1 "Configuration Bits"**.

# TABLE 6-1: FLASH CONFIGURATION WORD FOR PIC18F47J53 FAMILY DEVICES

| Device      | Program<br>Memory<br>(Kbytes) | Configuration<br>Word Addresses |  |
|-------------|-------------------------------|---------------------------------|--|
| PIC18F26J53 | 64                            | FEE8h to FEEFh                  |  |
| PIC18F46J53 | 04                            |                                 |  |
| PIC18F27J53 | 100                           | 1EEE9b to 1EEEb                 |  |
| PIC18F47J53 | 120                           |                                 |  |

### 6.6.3 MAPPING THE ACCESS BANK IN INDEXED LITERAL OFFSET MODE

The use of Indexed Literal Offset Addressing mode effectively changes how the lower part of Access RAM (00h to 5Fh) is mapped. Rather than containing just the contents of the bottom part of Bank 0, this mode maps the contents from Bank 0 and a user-defined "window" that can be located anywhere in the data memory space. The value of FSR2 establishes the lower boundary of the addresses mapped to the window, while the upper boundary is defined by FSR2 plus 95 (5Fh). Addresses in the Access RAM above 5Fh are mapped as previously described (see **Section 6.3.3** "**Access Bank**"). Figure 6-10 provides an example of Access Bank remapping in this addressing mode.

Remapping of the Access Bank applies *only* to operations using the Indexed Literal Offset mode. Operations that use the BSR (Access RAM bit is '1') will continue to use Direct Addressing as before. Any Indirect or Indexed Addressing operation that explicitly uses any of the indirect file operands (including FSR2) will continue to operate as standard Indirect Addressing. Any instruction that uses the Access Bank, but includes a register address of greater than 05Fh, will use Direct Addressing and the normal Access Bank map.

#### 6.6.4 BSR IN INDEXED LITERAL OFFSET MODE

Although the Access Bank is remapped when the extended instruction set is enabled, the operation of the BSR remains unchanged. Direct Addressing, using the BSR to select the data memory bank, operates in the same manner as previously described.

### FIGURE 6-10: REMAPPING THE ACCESS BANK WITH INDEXED LITERAL OFFSET ADDRESSING



### 7.0 FLASH PROGRAM MEMORY

The Flash program memory is readable, writable and erasable during normal operation over the entire  $V_{\text{DD}}$  range.

A read from program memory is executed on 1 byte at a time. A write to program memory is executed on blocks of 64 bytes at a time or 2 bytes at a time. Program memory is erased in blocks of 1024 bytes at a time. A bulk erase operation may not be issued from user code.

Writing or erasing program memory will cease instruction fetches until the operation is complete. The program memory cannot be accessed during the write or erase, therefore, code cannot execute. An internal programming timer terminates program memory writes and erases.

A value written to program memory does not need to be a valid instruction. Executing a program memory location that forms an invalid instruction results in a NOP.

### 7.1 Table Reads and Table Writes

In order to read and write program memory, there are two operations that allow the processor to move bytes between the program memory space and the data RAM:

- Table Read (TBLRD)
- Table Write (TBLWT)

The program memory space is 16 bits wide, while the data RAM space is 8 bits wide. Table reads and table writes move data between these two memory spaces through an 8-bit register (TABLAT).

Table read operations retrieve data from program memory and place it into the data RAM space. Figure 7-1 illustrates the operation of a table read with program memory and data RAM.

Table write operations store data from the data memory space into holding registers in program memory. The procedure to write the contents of the holding registers into program memory is detailed in **Section 7.5** "**Writing to Flash Program Memory**". Figure 7-2 illustrates the operation of a table write with program memory and data RAM.

Table operations work with byte entities. A table block containing data, rather than program instructions, is not required to be word-aligned. Therefore, a table block can start and end at any byte address. If a table write is being used to write executable code into program memory, program instructions will need to be word-aligned.

### FIGURE 7-1: TABLE READ OPERATION



### 10.7.3.1 Input Mapping

The inputs of the PPS options are mapped on the basis of the peripheral; that is, a control register associated with a peripheral dictates the pin it will be mapped to. The RPINRx registers are used to configure peripheral input mapping (see Register 10-6 through Register 10-23). Each register contains a 5-bit field which is associated with one of the pin selectable peripherals. Programming a given peripheral's bit field with an appropriate 5-bit value maps the RPn pin with that value to that peripheral. For any given device, the valid range of values for any of the bit fields corresponds to the maximum number of Peripheral Pin Selections supported by the device.

| TABLE 10-13: SELECTABLE INPUT SOURCES (MAPS INPUT TO FUNCTION) | TABLE 10-13: | SELECTABLE INPUT SOURCES | (MAPS INPUT TO FUNCTION)( |
|----------------------------------------------------------------|--------------|--------------------------|---------------------------|
|----------------------------------------------------------------|--------------|--------------------------|---------------------------|

| Input Name                                       | Function Name | Register | Configuration<br>Bits |
|--------------------------------------------------|---------------|----------|-----------------------|
| External Interrupt 1                             | INT1          | RPINR1   | INTR1R<4:0>           |
| External Interrupt 2                             | INT2          | RPINR2   | INTR2R<4:0>           |
| External Interrupt 3                             | INT3          | RPINR3   | INTR3R<4:0>           |
| Timer0 External Clock Input                      | TOCKI         | RPINR4   | T0CKR<4:0>            |
| Timer3 External Clock Input                      | T3CKI         | RPINR6   | T3CKR<4:0>            |
| Timer5 External Clock Input                      | T5CKI         | RPINR15  | T5CKR<4:0>            |
| Input Capture 1                                  | CCP1          | RPINR7   | IC1R<4:0>             |
| Input Capture 2                                  | CCP2          | RPINR8   | IC2R<4:0>             |
| Input Capture 3                                  | CCP3          | RPINR9   | IC3R<4:0>             |
| Timer1 Gate Input                                | T1G           | RPINR12  | T1GR<4:0>             |
| Timer3 Gate Input                                | T3G           | RPINR13  | T3GR<4:0>             |
| Timer5 Gate Input                                | T5G           | RPINR14  | T5GR<4:0>             |
| EUSART2 Asynchronous Receive/Synchronous Receive | RX2/DT2       | RPINR16  | RX2DT2R<4:0>          |
| EUSART2 Asynchronous Clock Input                 | CK2           | RPINR17  | CK2R<4:0>             |
| SPI2 Data Input                                  | SDI2          | RPINR21  | SDI2R<4:0>            |
| SPI2 Clock Input                                 | SCK2IN        | RPINR22  | SCK2R<4:0>            |
| SPI2 Slave Select Input                          | SS2IN         | RPINR23  | SS2R<4:0>             |
| PWM Fault Input                                  | FLT0          | RPINR24  | OCFAR<4:0>            |

**Note 1:** Unless otherwise noted, all inputs use the Schmitt Trigger input buffers.

### 11.2.5.2 WRITE TO SLAVE PORT

When chip select is active and a write strobe occurs (PMCSx = 1 and PMWR = 1), the data from PMD<7:0> is captured into one of the four input buffer bytes. Which byte is written depends on the 2-bit address placed on ADDRL<1:0>.

Table 11-1 provides the corresponding input registers and their associated address.

When an input buffer is written, the corresponding IBxF bit is set. The IBF flag bit is set when all the buffers are written. If any buffer is already written (IBxF = 1), the next write strobe to that buffer will generate an OBUF event and the byte will be discarded.



### FIGURE 11-8: PARALLEL SLAVE PORT WRITE WAVEFORMS

### 11.4 Application Examples

This section introduces some potential applications for the  $\ensuremath{\mathsf{PMP}}$  module.

### 11.4.1 MULTIPLEXED MEMORY OR PERIPHERAL

Figure 11-27 demonstrates the hookup of a memory or another addressable peripheral in Full Multiplex mode. Consequently, this mode achieves the best pin saving from the microcontroller perspective. However, for this configuration, there needs to be some external latches to maintain the address.

### FIGURE 11-27: MULTIPLEXED ADDRESSING APPLICATION EXAMPLE



### 11.4.2 PARTIALLY MULTIPLEXED MEMORY OR PERIPHERAL

Partial multiplexing implies using more pins; however, for a few extra pins, some extra performance can be achieved. Figure 11-28 provides an example of a memory or peripheral that is partially multiplexed with an external latch. If the peripheral has internal latches, as displayed in Figure 11-29, then no extra circuitry is required except for the peripheral itself.

### FIGURE 11-28: EXAMPLE OF A PARTIALLY MULTIPLEXED ADDRESSING APPLICATION



### FIGURE 11-29: EXAMPLE OF AN 8-BIT MULTIPLEXED ADDRESS AND DATA APPLICATION



### 13.7 Resetting Timer1 Using the ECCP Special Event Trigger

If ECCP1 or ECCP2 is configured to use Timer1 and to generate a Special Event Trigger in Compare mode (CCPxM<3:0> = 1011), this signal will reset Timer3. The trigger from ECCP2 will also start an A/D conversion if the A/D module is enabled (see **Section 19.3.4** "**Special Event Trigger**" for more information).

The module must be configured as either a timer or a synchronous counter to take advantage of this feature. When used this way, the CCPRxH:CCPRxL register pair effectively becomes a period register for Timer1.

If Timer1 is running in Asynchronous Counter mode, this Reset operation may not work.

In the event that a write to Timer1 coincides with a Special Event Trigger, the write operation will take precedence.

| Note: | The    | Special    | Event     | Trigger   | from  | the  |
|-------|--------|------------|-----------|-----------|-------|------|
|       | ECC    | Px modu    | le will r | ot set th | e TMF | R1IF |
|       | interr | upt flag b | it (PIR1  | <0>).     |       |      |

### 13.8 Timer1 Gate

The Timer1 can be configured to count freely or the count can be enabled and disabled using the Timer1 gate circuitry. This is also referred to as Timer1 gate count enable.

The Timer1 gate can also be driven by multiple selectable sources.

### 13.8.1 TIMER1 GATE COUNT ENABLE

The Timer1 Gate Enable mode is enabled by setting the TMR1GE bit of the T1GCON register. The polarity of the Timer1 Gate Enable mode is configured using the T1GPOL bit of the T1GCON register.

When Timer1 Gate Enable mode is enabled, Timer1 will increment on the rising edge of the Timer1 clock source. When Timer1 Gate Enable mode is disabled, no incrementing will occur and Timer1 will hold the current count. See Figure 13-4 for timing details.

### TABLE 13-3: TIMER1 GATE ENABLE SELECTIONS

| T1CLK      | T1GPOL | T1G | Timer1 Operation |
|------------|--------|-----|------------------|
| $\uparrow$ | 0      | 0   | Counts           |
| $\uparrow$ | 0      | 1   | Holds Count      |
| $\uparrow$ | 1      | 0   | Holds Count      |
| $\uparrow$ | 1      | 1   | Counts           |

### 

### FIGURE 13-4: TIMER1 GATE COUNT ENABLE MODE

### 17.1.3 ALRMVALH AND ALRMVALL REGISTER MAPPINGS

### REGISTER 17-14: ALRMMNTH: ALARM MONTH VALUE REGISTER<sup>(1)</sup>

| U-0      | U-0 | U-0 | R/W-x   | R/W-x   | R/W-x   | R/W-x   | R/W-x   |
|----------|-----|-----|---------|---------|---------|---------|---------|
| —        | —   | —   | MTHTEN0 | MTHONE3 | MTHONE2 | MTHONE1 | MTHONE0 |
| bit 7    |     |     |         |         |         |         | bit 0   |
|          |     |     |         |         |         |         |         |
| l egend: |     |     |         |         |         |         |         |

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

| bit 7-5 | Unimplemented: Read as '0'                                                                                    |
|---------|---------------------------------------------------------------------------------------------------------------|
| bit 4   | <b>MTHTEN0:</b> Binary Coded Decimal Value of Month's Tens Digit bit Contains a value of 0 or 1.              |
| bit 3-0 | <b>MTHONE&lt;3:0&gt;:</b> Binary Coded Decimal Value of Month's Ones Digit bits Contains a value from 0 to 9. |

**Note 1:** A write to this register is only allowed when RTCWREN = 1.

### **REGISTER 17-15: ALRMDAY: ALARM DAY VALUE REGISTER<sup>(1)</sup>**

| U-0   | U-0 | R/W-x   | R/W-x   | R/W-x   | R/W-x   | R/W-x   | R/W-x   |
|-------|-----|---------|---------|---------|---------|---------|---------|
| —     | —   | DAYTEN1 | DAYTEN0 | DAYONE3 | DAYONE2 | DAYONE1 | DAYONE0 |
| bit 7 |     |         |         |         |         |         | bit 0   |

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

| bit 7-6 | Unimplemented: Read as '0' |
|---------|----------------------------|
|---------|----------------------------|

| bit 5-4 | <b>DAYTEN&lt;1:0&gt;:</b> Binary Coded Decimal Value of Day's Tens Digit bits |
|---------|-------------------------------------------------------------------------------|
|         | Contains a value from 0 to 3.                                                 |

bit 3-0 **DAYONE<3:0>:** Binary Coded Decimal Value of Day's Ones Digit bits Contains a value from 0 to 9.

**Note 1:** A write to this register is only allowed when RTCWREN = 1.

### 21.2.2 EUSART ASYNCHRONOUS RECEIVER

The receiver block diagram is displayed in Figure 21-6. The data is received on the RXx pin and drives the data recovery block. The data recovery block is actually a high-speed shifter, operating at x16 times the baud rate, whereas the main receive serial shifter operates at the bit rate or at Fosc. This mode would typically be used in RS-232 systems.

To set up an Asynchronous Reception:

- 1. Initialize the SPBRGHx:SPBRGx registers for the appropriate baud rate. Set or clear the BRGH and BRG16 bits, as required, to achieve the desired baud rate.
- 2. Enable the asynchronous serial port by clearing bit, SYNC, and setting bit, SPEN.
- 3. If interrupts are desired, set enable bit, RCxIE.
- 4. If 9-bit reception is desired, set bit, RX9.
- 5. Enable the reception by setting bit, CREN.
- Flag bit, RCxIF, will be set when reception is complete and an interrupt will be generated if enable bit, RCxIE, was set.
- Read the RCSTAx register to get the ninth bit (if enabled) and determine if any error occurred during reception.
- 8. Read the 8-bit received data by reading the RCREGx register.
- 9. If any error occurred, clear the error by clearing enable bit, CREN.
- 10. If using interrupts, ensure that the GIE and PEIE bits in the INTCON register (INTCON<7:6>) are set.

### 21.2.3 SETTING UP 9-BIT MODE WITH ADDRESS DETECT

This mode would typically be used in RS-485 systems. To set up an Asynchronous Reception with Address Detect Enable:

- 1. Initialize the SPBRGHx:SPBRGx registers for the appropriate baud rate. Set or clear the BRGH and BRG16 bits, as required, to achieve the desired baud rate.
- 2. Enable the asynchronous serial port by clearing the SYNC bit and setting the SPEN bit.
- 3. If interrupts are required, set the RCEN bit and select the desired priority level with the RCxIP bit.
- 4. Set the RX9 bit to enable 9-bit reception.
- 5. Set the ADDEN bit to enable address detect.
- 6. Enable reception by setting the CREN bit.
- 7. The RCxIF bit will be set when reception is complete. The interrupt will be Acknowledged if the RCxIE and GIE bits are set.
- 8. Read the RCSTAx register to determine if any error occurred during reception, as well as read bit 9 of data (if applicable).
- 9. Read RCREGx to determine if the device is being addressed.
- 10. If any error occurred, clear the CREN bit.
- 11. If the device has been addressed, clear the ADDEN bit to allow all received data into the receive buffer and interrupt the CPU.





### 23.4.4 PING-PONG BUFFERING

An endpoint is defined to have a ping-pong buffer when it has two sets of BD entries: one set for an Even transfer and one set for an Odd transfer. This allows the CPU to process one BD while the SIE is processing the other BD. Double-buffering BDs in this way allows for maximum throughput to/from the USB.

The USB module supports four modes of operation:

- · No ping-pong support
- Ping-pong buffer support for OUT Endpoint 0 only
- · Ping-pong buffer support for all endpoints
- Ping-pong buffer support for all other endpoints except Endpoint 0

The ping-pong buffer settings are configured using the PPB<1:0> bits in the UCFG register.

The USB module keeps track of the Ping-Pong Pointer individually for each endpoint. All pointers are initially reset to the Even BD when the module is enabled. After the completion of a transaction (UOWN cleared by the SIE), the pointer is toggled to the Odd BD. After the completion of the next transaction, the pointer is toggled back to the Even BD and so on.

The Even/Odd status of the last transaction is stored in the PPBI bit of the USTAT register. The user can reset all Ping-Pong Pointers to Even using the PPBRST bit.

Figure 23-6 shows the four different modes of operation and how USB RAM is filled with the BDs.

BDs have a fixed relationship to a particular endpoint, depending on the buffering configuration. Table 23-2 provides the mapping of BDs to endpoints. This relationship also means that gaps may occur in the BDT if endpoints are not enabled contiguously. This, theoretically, means that the BDs for disabled endpoints could be used as buffer space. In practice, users should avoid using such spaces in the BDT unless a method of validating BD addresses is implemented.



#### FIGURE 23-6: BUFFER DESCRIPTOR TABLE MAPPING FOR BUFFERING MODES

### 24.2 Comparator Operation

A single comparator is shown in Figure 24-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 24-2 represent the uncertainty due to input offsets and response time.

FIGURE 24-2: SINGLE COMPARATOR



### 24.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 31.0 "Electrical Characteristics"**).

### 24.4 Analog Input Connection Considerations

Figure 24-3 provides a simplified circuit for an analog input. 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 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.





### 24.6 Comparator Interrupts

The comparator interrupt flag is set whenever any of the following occurs:

- · Low-to-high transition of the comparator output
- High-to-low transition of the comparator output
- Any change in the comparator output

The comparator interrupt selection is done by the EVPOL<1:0> bits in the CMxCON register (CMxCON<4:3>).

In order to provide maximum flexibility, the output of the comparator may be inverted using the CPOL bit in the CMxCON register (CMxCON<5>). This is functionally identical to reversing the inverting and non-inverting inputs of the comparator for a particular mode.

An interrupt is generated on the low-to-high or high-tolow transition of the comparator output. This mode of interrupt generation is dependent on EVPOL<1:0> in the CMxCON register. When EVPOL<1:0> = 01 or 10, the interrupt is generated on a low-to-high or high-tolow transition of the comparator output. Once the interrupt is generated, it is required to clear the interrupt flag by software. When EVPOL<1:0> = 11, the comparator interrupt flag is set whenever there is a change in the output value of either comparator. Software will need to maintain information about the status of the output bits, as read from CMSTAT<1:0>, to determine the actual change that occurred. The CMxIF bits (PIR2<6:5>) are the Comparator x Interrupt Flags. The CMxIF bits must be reset by clearing them. Since it is also possible to write a '1' to this register, a simulated interrupt may be initiated.

Table 24-2 provides the interrupt generation corresponding to comparator input voltages and EVPOL bit settings.

Both the CMxIE bits (PIE2<6:5>) and the PEIE bit (INTCON<6>) must be set to enable the interrupt. In addition, the GIE bit (INTCON<7>) must also be set. If any of these bits are clear, the interrupt is not enabled, though the CMxIF bits will still be set if an interrupt condition occurs.

Figure 24-3 provides a simplified diagram of the interrupt section.

| CPOL | EVPOL<1:0> | Comparator<br>Input Change | COUTx Transition        | Interrupt<br>Generated |
|------|------------|----------------------------|-------------------------|------------------------|
|      | 0.0        | VIN+ > VIN-                | Low-to-High             | No                     |
|      | 00         | VIN+ < VIN-                | High-to-Low             | No                     |
|      | 0.1        | VIN+ > VIN-                | Low-to-High             | Yes                    |
| 0    | UΤ         | VIN+ < VIN-                | High-to-Low             | No                     |
| U    | 1.0        | VIN+ > VIN-                | Low-to-High             | No                     |
|      | TO         | VIN+ < VIN-                | High-to-Low             | Yes                    |
|      | 11         | VIN+ > VIN-                | VIN+ > VIN- Low-to-High |                        |
|      |            | VIN+ < VIN-                | High-to-Low             | Yes                    |
|      | 0.0        | VIN+ > VIN-                | High-to-Low             | No                     |
|      | 00         | VIN+ < VIN-                | Low-to-High             | No                     |
|      | 01         | VIN+ > VIN-                | High-to-Low             | No                     |
| 1    | UL         | VIN+ < VIN-                | Low-to-High             | Yes                    |
| T    | 1.0        | VIN+ > VIN-                | High-to-Low             | Yes                    |
|      | TO         | VIN+ < VIN-                | Low-to-High             | No                     |
|      | 11         | VIN+ > VIN-                | High-to-Low             | Yes                    |
|      | 11         | VIN+ < VIN-                | Low-to-High             | Yes                    |

### TABLE 24-2: COMPARATOR INTERRUPT GENERATION

### 26.1 Operation

When the HLVD module is enabled, a comparator uses an internally generated reference voltage as the set point. The set point is compared with the trip point, where each node in the resistor divider represents a trip point voltage. The "trip point" voltage is the voltage level at which the device detects a high or low-voltage event, depending on the configuration of the module.

When the supply voltage is equal to the trip point, the voltage tapped off of the resistor array is equal to the internal reference voltage generated by the voltage reference module. The comparator then generates an interrupt signal by setting the HLVDIF bit.

The trip point voltage is software programmable to any one of 16 values. The trip point is selected by programming the HLVDL<3:0> bits (HLVDCON<3:0>).

Additionally, the HLVD module allows the user to supply the trip voltage to the module from an external source. This mode is enabled when bits, HLVDL<3:0>, are set to '1111'. In this state, the comparator input is multiplexed from the external input pin, HLVDIN. This gives users flexibility because it allows them to configure the HLVD interrupt to occur at any voltage in the valid operating range.





### 28.4 Two-Speed Start-up

The Two-Speed Start-up feature helps to minimize the latency period, from oscillator start-up to code execution, by allowing the microcontroller to use the INTRC oscillator as a clock source until the primary clock source is available. It is enabled by setting the IESO Configuration bit.

Two-Speed Start-up should be enabled only if the primary oscillator mode is HS or HSPLL (Crystal-Based) modes. Since the EC and ECPLL modes do not require an Oscillator Start-up Timer (OST) delay, Two-Speed Start-up should be disabled. When enabled, Resets and wake-ups from Sleep mode cause the device to configure itself to run from the internal oscillator block as the clock source, following the time-out of the Power-up Timer after a Power-on Reset is enabled. This allows almost immediate code execution while the primary oscillator starts and the OST is running. Once the OST times out, the device automatically switches to PRI\_RUN mode.

In all other power-managed modes, Two-Speed Start-up is not used. The device will be clocked by the currently selected clock source until the primary clock source becomes available. The setting of the IESO bit is ignored.



FIGURE 28-3: TIMING TRANSITION FOR TWO-SPEED START-UP (INTRC TO HSPLL)

### 28.4.1 SPECIAL CONSIDERATIONS FOR USING TWO-SPEED START-UP

While using the INTRC oscillator in Two-Speed Start-up, the device still obeys the normal command sequences for entering power-managed modes, including serial SLEEP instructions (refer to **Section 4.1.4 "Multiple Sleep Commands"**). In practice, this means that user code can change the SCS<1:0> bit settings or issue SLEEP instructions before the OST times out. This would allow an application to briefly wake-up, perform routine "housekeeping" tasks and return to Sleep before the device starts to operate from the primary oscillator.

User code can also check if the primary clock source is currently providing the device clocking by checking the status of the OSTS bit (OSCCON<3>). If the bit is set, the primary oscillator is providing the clock. Otherwise, the internal oscillator block is providing the clock during wake-up from Reset or Sleep mode.

### 28.5 Fail-Safe Clock Monitor

The Fail-Safe Clock Monitor (FSCM) allows the microcontroller to continue operation in the event of an external oscillator failure by automatically switching the device clock to the internal oscillator block. The FSCM function is enabled by setting the FCMEN Configuration bit.

When FSCM is enabled, the INTRC oscillator runs at all times to monitor clocks to peripherals and provide a backup clock in the event of a clock failure. Clock monitoring (shown in Figure 28-4) is accomplished by creating a sample clock signal, which is the INTRC output divided by 64. This allows ample time between FSCM sample clocks for a peripheral clock edge to occur. The peripheral device clock and the sample clock are presented as inputs to the clock monitor latch. The clock monitor is set on the falling edge of the device clock source but cleared on the rising edge of the sample clock.

| COMF              | Complement f CPFSEQ                                                                                                                                                                                                                                                                      |                                                                                                                    |                                                          | Compare f with W, Skip if f = W |                                     |                                                                                                                                                                      |                                                   |                                       |  |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|---------------------------------|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|---------------------------------------|--|
| Syntax:           | COMF f {,d {,a}}                                                                                                                                                                                                                                                                         |                                                                                                                    | Syntax:                                                  |                                 | CPFSEQ                              |                                                                                                                                                                      |                                                   |                                       |  |
| Operands:         | 0 ≤ f ≤ 255<br>d ∈ [0,1]                                                                                                                                                                                                                                                                 |                                                                                                                    |                                                          | Operands                        | <b>3</b> :                          | 0 ≤ f ≤ 255<br>a ∈ [0,1]                                                                                                                                             |                                                   |                                       |  |
|                   | a ∈ [0,1]                                                                                                                                                                                                                                                                                |                                                                                                                    |                                                          | Operation                       | n:                                  | (f) – (W),                                                                                                                                                           |                                                   |                                       |  |
| Operation:        | $\overline{f} \rightarrow dest$                                                                                                                                                                                                                                                          |                                                                                                                    |                                                          |                                 |                                     | skip if (f) = (                                                                                                                                                      | (W)<br>comparison)                                |                                       |  |
| Status Affected:  | ected: N, Z                                                                                                                                                                                                                                                                              |                                                                                                                    | Status Af                                                | fected <sup>.</sup>             | None                                | ompanoony                                                                                                                                                            |                                                   |                                       |  |
| Encoding:         | 0001                                                                                                                                                                                                                                                                                     | 11da ff                                                                                                            | ff ffff                                                  | Encoding                        | :                                   | 0110                                                                                                                                                                 | 001a fff                                          | f fff                                 |  |
| Description:      | The conten<br>complemer<br>stored in W<br>stored back                                                                                                                                                                                                                                    | ts of register 'f<br>nted. If 'd' is '0<br>/. If 'd' is '1', th<br>< in register 'f'                               | f' are<br>d', the result is<br>e result is<br>(default). | Descriptio                      | on:                                 | Compares t<br>location 'f' to<br>performing                                                                                                                          | he contents of<br>o the contents<br>an unsigned s | data memory<br>of W by<br>ubtraction. |  |
|                   | If 'a' is '0', t<br>If 'a' is '1', t<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 (default). |                                                          |                                 |                                     | discarded a<br>instead, ma<br>instruction.                                                                                                                           | nd a NOP is ex<br>king this a 2-c                 | ycle                                  |  |
|                   | If 'a' is '0' and the extended instruction<br>set is enabled, this instruction operates<br>in Indexed Literal Offset Addressing<br>mode whenever $f \le 95$ (5Fh). See<br>Section 29.2.3 "Byte-Oriented and<br>Bit-Oriented Instructions in Indexed<br>Literal Offset Mode" for details. |                                                                                                                    |                                                          |                                 |                                     | lf 'a' is '0', tl<br>If 'a' is '1', tl<br>GPR bank (                                                                                                                 | he Access Bar<br>he BSR is use<br>(default).      | nk is selected.<br>d to select the    |  |
|                   |                                                                                                                                                                                                                                                                                          |                                                                                                                    |                                                          |                                 |                                     | If 'a' is '0' and the extended instruction<br>set is enabled, this instruction operates<br>in Indexed Literal Offset Addressing<br>mode whenever $f < 95$ (5Fb). See |                                                   |                                       |  |
| Words:            | 1                                                                                                                                                                                                                                                                                        |                                                                                                                    |                                                          |                                 | Section 29                          | .2.3 "Byte-Ori                                                                                                                                                       | ented and                                         |                                       |  |
| Cycles:           | 1                                                                                                                                                                                                                                                                                        |                                                                                                                    |                                                          |                                 |                                     | Bit-Oriente                                                                                                                                                          | d Instruction                                     | s in Indexed                          |  |
| Q Cycle Activity: |                                                                                                                                                                                                                                                                                          |                                                                                                                    |                                                          | \M/ordo                         |                                     |                                                                                                                                                                      | Set MODe TOP                                      | details.                              |  |
| Q1                | Q2                                                                                                                                                                                                                                                                                       | Q3                                                                                                                 | Q4                                                       | words.                          |                                     | 1(2)                                                                                                                                                                 |                                                   |                                       |  |
| Decode            | Read<br>register 'f'                                                                                                                                                                                                                                                                     | Process<br>Data                                                                                                    | Write to destination                                     | Cycles.                         |                                     | <b>Note:</b> 3 cycles if skip and followed by a 2-word instruction.                                                                                                  |                                                   |                                       |  |
| Example:          | COME                                                                                                                                                                                                                                                                                     |                                                                                                                    |                                                          | Q Cycle                         | Activity:                           |                                                                                                                                                                      |                                                   |                                       |  |
| Roforo Instruc    | tion                                                                                                                                                                                                                                                                                     | REG, 0, 0                                                                                                          |                                                          |                                 | Q1                                  | Q2                                                                                                                                                                   | Q3                                                | Q4                                    |  |
| REG               | = 13h                                                                                                                                                                                                                                                                                    |                                                                                                                    |                                                          | D                               | ecode                               | Read                                                                                                                                                                 | Process                                           | No                                    |  |
| After Instruction | on                                                                                                                                                                                                                                                                                       |                                                                                                                    |                                                          | lf skip:                        |                                     | Tegister T                                                                                                                                                           | Data                                              | operation                             |  |
| REG<br>W          | = 13h<br>= FCh                                                                                                                                                                                                                                                                           |                                                                                                                    |                                                          | - 1                             | Q1                                  | Q2                                                                                                                                                                   | Q3                                                | Q4                                    |  |
|                   | Lon                                                                                                                                                                                                                                                                                      |                                                                                                                    |                                                          |                                 | No                                  | No                                                                                                                                                                   | No                                                | No                                    |  |
|                   |                                                                                                                                                                                                                                                                                          |                                                                                                                    |                                                          | op                              | eration                             | operation                                                                                                                                                            | operation                                         | operation                             |  |
|                   |                                                                                                                                                                                                                                                                                          |                                                                                                                    |                                                          | if skip ar                      |                                     | a by 2-word in:<br>O2                                                                                                                                                |                                                   | 04                                    |  |
|                   |                                                                                                                                                                                                                                                                                          |                                                                                                                    |                                                          |                                 | No                                  | No                                                                                                                                                                   | No                                                | No                                    |  |
|                   |                                                                                                                                                                                                                                                                                          |                                                                                                                    |                                                          | ор                              | eration                             | operation                                                                                                                                                            | operation                                         | operation                             |  |
|                   |                                                                                                                                                                                                                                                                                          |                                                                                                                    |                                                          |                                 | No                                  | No                                                                                                                                                                   | No                                                | No                                    |  |
|                   |                                                                                                                                                                                                                                                                                          |                                                                                                                    |                                                          | ор                              | eration                             | operation                                                                                                                                                            | operation                                         | operation                             |  |
|                   |                                                                                                                                                                                                                                                                                          |                                                                                                                    |                                                          | Example:                        |                                     | HERE<br>NEQUAL<br>EOUAL                                                                                                                                              | CPFSEQ REG<br>:                                   | , 0                                   |  |
|                   |                                                                                                                                                                                                                                                                                          |                                                                                                                    |                                                          | Befc                            | ore Instruc<br>PC Addre<br>W<br>REG | tion<br>ess = HE<br>= ?<br>= ?                                                                                                                                       | RE                                                |                                       |  |

W; Address (EQUAL) W; Address (NEQUAL)

After Instruction If REG PC If REG PC

= = ≠

| MULLW                        | Multiply Li                                                                                                                                                                                                               | iteral with W         |                                             | MULWF                     | Multiply W w                                                                                                                                                                                                                     | ith f                                                                                                                          |                                                                                    |  |  |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|---------------------------------------------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|--|--|
| Syntax:                      | MULLW                                                                                                                                                                                                                     | k                     |                                             | Syntax:                   | MULWF f{                                                                                                                                                                                                                         | a}                                                                                                                             |                                                                                    |  |  |
| Operands:                    | $0 \le k \le 255$                                                                                                                                                                                                         | 5                     |                                             | Operands:                 | $0 \leq f \leq 255$                                                                                                                                                                                                              |                                                                                                                                |                                                                                    |  |  |
| Operation:                   | (W) x k $\rightarrow$                                                                                                                                                                                                     | PRODH:PRO             | DL                                          |                           | a ∈ [0,1]                                                                                                                                                                                                                        |                                                                                                                                |                                                                                    |  |  |
| Status Affected:             | None                                                                                                                                                                                                                      |                       |                                             | Operation:                | (W) x (f) $\rightarrow$ PI                                                                                                                                                                                                       | (W) x (f) $\rightarrow$ PRODH:PRODL                                                                                            |                                                                                    |  |  |
| Encoding:                    | 0000                                                                                                                                                                                                                      | 1101 kk               | kk kkkk                                     | Status Affected:          | None                                                                                                                                                                                                                             |                                                                                                                                |                                                                                    |  |  |
| Description:                 | An unsigned multiplication is carried<br>out between the contents of W and the<br>8-bit literal 'k'. The 16-bit result is<br>placed in the PRODH:PRODL register<br>pair. PRODH contains the high byte.<br>W is unchanged. |                       |                                             | Encoding:<br>Description: | 0000 001a ffff fff<br>An unsigned multiplication is carried o<br>between the contents of W and the<br>register file location 'f'. The 16-bit resu<br>stored in the PRODH:PRODL register<br>pair. PRODH contains the high byte. B |                                                                                                                                |                                                                                    |  |  |
|                              | None of the                                                                                                                                                                                                               | e Status flags        | are affected.                               |                           | None of the Status flags are affected.                                                                                                                                                                                           |                                                                                                                                |                                                                                    |  |  |
|                              | Note that neither Overflow nor Carry is possible in this operation. A Zero result is possible but not detected.                                                                                                           |                       |                                             |                           | Note that neither Overflow nor Carry is possible in this operation. A Zero result is possible but not detected.                                                                                                                  |                                                                                                                                |                                                                                    |  |  |
| Words:                       | 1                                                                                                                                                                                                                         |                       |                                             |                           | If 'a' is '0' the                                                                                                                                                                                                                | Access Bank                                                                                                                    | is selected. If                                                                    |  |  |
| Cycles:<br>Q Cycle Activity: | 1                                                                                                                                                                                                                         |                       |                                             |                           | 'a' is '1', the E<br>GPR bank (de                                                                                                                                                                                                | SR is used to<br>efault).                                                                                                      | select the                                                                         |  |  |
| Q1<br>Decode                 | Q2<br>Read<br>literal 'k'                                                                                                                                                                                                 | Q3<br>Process<br>Data | Q4<br>Write<br>registers<br>PRODH:<br>PRODL |                           | If 'a' is '0' and<br>is enabled, th<br>Indexed Litera<br>whenever f ≤<br>Section 29.2.<br>Bit-Oriented<br>Literal Offset                                                                                                         | the extended<br>is instruction of<br>al Offset Addre<br>95 (5Fh). See<br><b>3 "Byte-Orie</b><br>Instructions<br>t Mode" for de | instruction set<br>operates in<br>essing mode<br>nted and<br>in Indexed<br>etails. |  |  |
| Example:                     | MULLW                                                                                                                                                                                                                     | 0C4h                  |                                             | Words:                    | 1                                                                                                                                                                                                                                |                                                                                                                                |                                                                                    |  |  |
| Before Instruct              | ion = E2                                                                                                                                                                                                                  | 2h                    |                                             | Cycles:                   | 1                                                                                                                                                                                                                                |                                                                                                                                |                                                                                    |  |  |
| PRODH                        | = ?                                                                                                                                                                                                                       | -11                   |                                             | Q Cycle Activity          |                                                                                                                                                                                                                                  |                                                                                                                                |                                                                                    |  |  |
| PRODL<br>After Instructio    | n = ?                                                                                                                                                                                                                     |                       |                                             | Q1                        | Q2                                                                                                                                                                                                                               | Q3                                                                                                                             | Q4                                                                                 |  |  |
| W<br>PRODH<br>PRODL          | = E2<br>= AI<br>= 08                                                                                                                                                                                                      | 2h<br>Dh<br>Ih        |                                             | Decode                    | Read<br>register 'f'                                                                                                                                                                                                             | Process<br>Data                                                                                                                | Write<br>registers<br>PRODH:<br>PRODL                                              |  |  |
|                              |                                                                                                                                                                                                                           |                       |                                             | Example:                  | MULWF                                                                                                                                                                                                                            | REG, 1                                                                                                                         |                                                                                    |  |  |

 Before Instruction

 W
 =
 C4h

 REG
 =
 B5h

 PRODH
 =
 ?

 PRODL
 =
 ?

 After Instruction
 W
 =
 C4h

 REG
 =
 B5h

 PRODH
 =
 24h

 PRODH
 =
 8Ah

 PRODH
 =
 94h









### TABLE 31-31: 10-BIT A/D CONVERSION REQUIREMENTS

| Param.<br>No. | Symbol | Characteristic                                                     | Min. | Min. Max.           |     | Conditions                   |
|---------------|--------|--------------------------------------------------------------------|------|---------------------|-----|------------------------------|
| 130           | Tad    | A/D Clock Period                                                   | 0.7  | 25.0 <sup>(1)</sup> | μS  | Tosc based, VREF $\geq$ 3.0V |
| 131           | TCNV   | Conversion Time<br>(not including acquisition time) <sup>(2)</sup> | 11   | 12                  | Tad |                              |
| 132           | TACQ   | Acquisition Time <sup>(3)</sup>                                    | 1.4  | —                   | μS  | -40°C to +85°C               |
| 135           | Tswc   | Switching Time from Convert $\rightarrow$ Sample                   | —    | (Note 4)            |     |                              |
| 137           | TDIS   | Discharge Time                                                     | 0.2  | —                   | μS  |                              |

**Note 1:** The time of the A/D clock period is dependent on the device frequency and the TAD clock divider.

2: ADRES registers may be read on the following TCY cycle.

**3:** The time for the holding capacitor to acquire the "New" input voltage when the voltage changes full scale after the conversion (VDD to Vss or Vss to VDD). The source impedance (Rs) on the input channels is 50W.

4: On the following cycle of the device clock.

### TABLE 31-32: 12-BIT A/D CONVERSION REQUIREMENTS

| Param.<br>No. | Symbol | Characteristic                                                     |     | Max.                | Units | Conditions                   |
|---------------|--------|--------------------------------------------------------------------|-----|---------------------|-------|------------------------------|
| 130           | TAD    | A/D Clock Period                                                   | 0.8 | 12.5 <sup>(1)</sup> | μS    | Tosc based, VREF $\geq$ 3.0V |
| 131           | TCNV   | Conversion Time<br>(not including acquisition time) <sup>(2)</sup> | 13  | 14                  | Tad   |                              |
| 132           | TACQ   | Acquisition Time <sup>(3)</sup>                                    | 1.4 | —                   | μS    |                              |
| 135           | Tswc   | Switching Time from Convert $\rightarrow$ Sample                   |     | (Note 4)            |       |                              |
| 137           | TDIS   | Discharge Time                                                     | 0.2 | _                   | μS    |                              |

Note 1: The time of the A/D clock period is dependent on the device frequency and the TAD clock divider.

**2:** ADRES registers may be read on the following TCY cycle.

**3:** The time for the holding capacitor to acquire the "New" input voltage when the voltage changes full scale after the conversion (VDD to Vss or Vss to VDD). The source impedance (Rs) on the input channels is 50Ω.

4: On the following cycle of the device clock.