



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Active                                                                       |
|----------------------------|------------------------------------------------------------------------------|
| Core Processor             | PIC                                                                          |
| Core Size                  | 8-Bit                                                                        |
| Speed                      | 48MHz                                                                        |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART, USB                               |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                        |
| Number of I/O              | 22                                                                           |
| 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 10x10b/12b                                                               |
| Oscillator Type            | Internal                                                                     |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                            |
| Mounting Type              | Surface Mount                                                                |
| Package / Case             | 28-VQFN Exposed Pad                                                          |
| Supplier Device Package    | 28-QFN (6x6)                                                                 |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18lf27j53t-i-ml |

Email: info@E-XFL.COM

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

# 1.0 DEVICE OVERVIEW

This document contains device-specific information for the following devices:

- PIC18F26J53 PIC18LF26J53
- PIC18F27J53 PIC18LF27J53
- PIC18F46J53 PIC18LF46J53
- PIC18F47J53 PIC18LF47J53

This family introduces a new line of low-voltage Universal Serial Bus (USB) microcontrollers with the main traditional advantage of all PIC18 microcontrollers, namely, high computational performance and a rich feature set at an extremely competitive price point. These features make the PIC18F47J53 family a logical choice for many high-performance applications, where cost is a primary consideration.

### 1.1 Core Features

#### 1.1.1 XLP TECHNOLOGY

All of the devices in the PIC18F47J53 family incorporate a range of features that can significantly reduce power consumption during operation. Key features are:

- Alternate Run Modes: By clocking the controller from the Timer1 source or the internal RC oscillator, power consumption during code execution can be reduced by as much as 90%.
- **Multiple Idle Modes:** The controller can also run with its CPU core disabled but the peripherals still active. In these states, power consumption can be reduced even further, to as little as 4% of normal operational requirements.
- On-the-Fly Mode Switching: The power-managed modes are invoked by user code during operation, allowing the users to incorporate power-saving ideas into their application's software design.
- **Deep Sleep:** The 2.5V internal core voltage regulator on F parts can be shutdown to cut power consumption to as low as 15 nA (typical). Certain features can remain operating during Deep Sleep, such as the Real-Time Clock Calendar.
- Ultra Low Power Wake-Up: Waking from Sleep or Deep Sleep modes after a period of time can be done without an oscillator/clock source, saving power for applications requiring periodic activity.

#### 1.1.2 UNIVERSAL SERIAL BUS (USB)

Devices in the PIC18F47J53 family incorporate a fully-featured USB communications module with a built-in transceiver that is compliant with the USB Specification Revision 2.0. The module supports both low-speed and full-speed communication for all supported data transfer types.

### 1.1.3 OSCILLATOR OPTIONS AND FEATURES

All of the devices in the PIC18F47J53 family offer five different oscillator options, allowing users a range of choices in developing application hardware. These include:

- Two Crystal modes, using crystals or ceramic resonators.
- Two External Clock modes, offering the option of a divide-by-4 clock output.
- An internal oscillator block, which provides an 8 MHz clock and an INTRC source (approximately 31 kHz, stable over temperature and VDD), as well as a range of six user-selectable clock frequencies, between 125 kHz to 4 MHz, for a total of eight clock frequencies. This option frees an oscillator pin for use as an additional general purpose I/O.
- A Phase Lock Loop (PLL) frequency multiplier available to the high-speed crystal, and external and internal oscillators, providing a clock speed up to 48 MHz.
- Dual clock operation, allowing the USB module to run from a high-frequency oscillator while the rest of the microcontroller is clocked at a different frequency.

The internal oscillator block provides a stable reference source that gives the PIC18F47J53 family additional features for robust operation:

- Fail-Safe Clock Monitor: This option constantly monitors the main clock source against a reference signal provided by the internal oscillator. If a clock failure occurs, the controller is switched to the internal oscillator, allowing for continued low-speed operation or a safe application shutdown.
- **Two-Speed Start-up:** This option allows the internal oscillator to serve as the clock source from Power-on Reset (POR), or wake-up from Sleep mode, until the primary clock source is available.

# 1.1.4 EXPANDED MEMORY

The PIC18F47J53 family provides ample room for application code, from 64 Kbytes to 128 Kbytes of code space. The Flash cells for program memory are rated to last in excess of 10000 erase/write cycles. Data retention without refresh is conservatively estimated to be greater than 20 years.

The Flash program memory is readable and writable during normal operation. The PIC18F47J53 family also provides plenty of room for dynamic application data with up to 3.8 Kbytes of data RAM.

|                 |                                                 |                                       |                 |                            |                    | ,               | ,      |  |
|-----------------|-------------------------------------------------|---------------------------------------|-----------------|----------------------------|--------------------|-----------------|--------|--|
| 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           | DSULP: Ultra                                    | Low-Power W                           | /ake-up Status  | s bit                      |                    |                 |        |  |
|                 | 1 = An ultra l                                  | ow-power wak                          | e-up event oc   | curred during [            | Deep Sleep         |                 |        |  |
|                 | 0 = An ultra le                                 | ow-power wak                          | e-up event dic  | l not occur dur            | ing Deep Sleep     |                 |        |  |
| bit 4           | DSWDT: Dee                                      | p Sleep Watch                         | dog Timer Tin   | ne-out bit                 |                    |                 |        |  |
|                 | 1 = The Deep                                    | o Sleep Watch                         | dog Timer tim   | ed out during [            | Deep Sleep         |                 |        |  |
|                 | 0 = The Deep                                    | o Sleep Watch                         | dog Timer did   | not time out d             | uring Deep Slee    | p               |        |  |
| bit 3           | DSRTC: Real                                     | -Time Clock a                         | nd Calendar A   | larm bit                   |                    |                 |        |  |
|                 | 1 = The Real                                    | -Time Clock/C                         | alendar trigge  | red an alarm d             | luring Deep Slee   | ep              |        |  |
| 1.11.0          |                                                 |                                       | alendar did n   | ot trigger an ai           | arm during Dee     | p Sleep         |        |  |
| bit 2           | DSMCLR: MO                                      |                                       |                 |                            |                    |                 |        |  |
|                 | $1 = \text{Ine } \frac{\text{MCL}}{\text{MCL}}$ | <u>R</u> pin was ass<br>R pin was not | erted during L  | eep Sleep<br>In Deen Sleen |                    |                 |        |  |
| hit 1           | Unimplemented Deed as '0'                       |                                       |                 |                            |                    |                 |        |  |
| bit 0           |                                                 | Inimplemented: 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.0 RESET

The PIC18F47J53 family of devices differentiates among various kinds of Reset:

- a) Power-on Reset (POR)
- b) MCLR Reset during normal operation
- c) MCLR Reset during power-managed modes
- d) Watchdog Timer (WDT) Reset (during execution)
- e) Configuration Mismatch (CM)
- f) Brown-out Reset (BOR)
- g) RESET Instruction
- h) Stack Full Reset
- i) Stack Underflow Reset
- j) Deep Sleep Reset

This section discusses Resets generated by  $\overline{\text{MCLR}}$ , POR and BOR, and covers the operation of the various start-up timers.

For information on WDT Resets, see Section 28.2 "Watchdog Timer (WDT)". For Stack Reset events, see Section 6.1.4.4 "Stack Full and Underflow Resets" and for Deep Sleep mode, see Section 4.6 "Deep Sleep Mode".

Figure 5-1 provides a simplified block diagram of the on-chip Reset circuit.

### 5.1 RCON Register

Device Reset events are tracked through the RCON register (Register 5-1). The lower five bits of the register indicate that a specific Reset event has occurred. In most cases, these bits can only be set by the event and must be cleared by the application after the event. The state of these flag bits, taken together, can be read to indicate the type of Reset that just occurred. This is described in more detail in **Section 5.7 "Reset State of Registers"**.

The RCON register also has a control bit for setting interrupt priority (IPEN). Interrupt priority is discussed in **Section 9.0 "Interrupts"**.

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



2: The VDDCORE monitoring BOR circuit is only implemented on "F" devices. It is always used, except while in Deep Sleep mode. The VDDCORE monitoring BOR circuit has a trip point threshold of VBOR (parameter D005).

| TABLE 3-2.              | . INITIALIZATION CONDITIONS FOR ALL REGISTERS (CONTINUED) |             |                                                                                   |            |                                 |
|-------------------------|-----------------------------------------------------------|-------------|-----------------------------------------------------------------------------------|------------|---------------------------------|
| Register                | Applicable Devices                                        |             | Applicable Devices Power-on Reset,<br>Brown-out Reset,<br>Wake From Deep<br>Sleep |            | Wake-up via WDT<br>or Interrupt |
| TMR3H                   | PIC18F2XJ53                                               | PIC18F4XJ53 | xxxx xxxx                                                                         | uuuu uuuu  | uuuu uuuu                       |
| TMR3L                   | PIC18F2XJ53                                               | PIC18F4XJ53 | xxxx xxxx                                                                         | uuuu uuuu  | uuuu uuuu                       |
| T3CON                   | PIC18F2XJ53                                               | PIC18F4XJ53 | 0000 0000                                                                         | սսսս սսսս  | uuuu uuuu                       |
| TMR4                    | PIC18F2XJ53                                               | PIC18F4XJ53 | 0000 0000                                                                         | սսսս սսսս  | uuuu uuuu                       |
| PR4                     | PIC18F2XJ53                                               | PIC18F4XJ53 | 1111 1111                                                                         | 1111 1111  | uuuu uuuu                       |
| T4CON                   | PIC18F2XJ53                                               | PIC18F4XJ53 | -000 0000                                                                         | -000 0000  | -uuu uuuu                       |
| SSP2BUF                 | PIC18F2XJ53                                               | PIC18F4XJ53 | xxxx xxxx                                                                         | uuuu uuuu  | uuuu uuuu                       |
| SSP2ADD                 | PIC18F2XJ53                                               | PIC18F4XJ53 | 0000 0000                                                                         | 0000 0000  | uuuu uuuu                       |
| SSP2MSK                 | PIC18F2XJ53                                               | PIC18F4XJ53 |                                                                                   | 0000 0000  | uuuu uuuu                       |
| SSP2STAT                | PIC18F2XJ53                                               | PIC18F4XJ53 | 1111 1111                                                                         | 1111 1111  | uuuu uuuu                       |
| SSP2CON1                | PIC18F2XJ53                                               | PIC18F4XJ53 | 0000 0000                                                                         | 0000 0000  | uuuu uuuu                       |
| SSP2CON2                | PIC18F2XJ53                                               | PIC18F4XJ53 | 0000 0000                                                                         | 0000 0000  | uuuu uuuu                       |
| CMSTAT                  | PIC18F2XJ53                                               | PIC18F4XJ53 | 11                                                                                | 11         | uu                              |
| PMADDRH <sup>(5)</sup>  | PIC18F2XJ53                                               | PIC18F4XJ53 | -000 0000                                                                         | -000 0000  | -uuu uuuu                       |
| PMDOUT1H <sup>(5)</sup> | PIC18F2XJ53                                               | PIC18F4XJ53 | 0000 0000                                                                         | 0000 0000  | uuuu uuuu                       |
| PMADDRL                 | PIC18F2XJ53                                               | PIC18F4XJ53 | 0000 0000                                                                         | 0000 0000  | uuuu uuuu                       |
| PMDOUT1L                | PIC18F2XJ53                                               | PIC18F4XJ53 | 0000 0000                                                                         | 0000 0000  | uuuu uuuu                       |
| PMDIN1H                 | PIC18F2XJ53                                               | PIC18F4XJ53 | 0000 0000                                                                         | 0000 0000  | uuuu uuuu                       |
| PMDIN1L                 | PIC18F2XJ53                                               | PIC18F4XJ53 | 0000 0000                                                                         | 0000 0000  | uuuu uuuu                       |
| TXADDRL                 | PIC18F2XJ53                                               | PIC18F4XJ53 | 0000 0000                                                                         | 0000 0000  | uuuu uuuu                       |
| TXADDRH                 | PIC18F2XJ53                                               | PIC18F4XJ53 | 0000                                                                              | 0000       | uuuu                            |
| RXADDRL                 | PIC18F2XJ53                                               | PIC18F4XJ53 | 0000 0000                                                                         | 0000 0000  | uuuu uuuu                       |
| RXADDRH                 | PIC18F2XJ53                                               | PIC18F4XJ53 | 0000                                                                              | 0000       | uuuu                            |
| DMABCL                  | PIC18F2XJ53                                               | PIC18F4XJ53 | 0000 0000                                                                         | 0000 0000  | uuuu uuuu                       |
| DMABCH                  | PIC18F2XJ53                                               | PIC18F4XJ53 | 00                                                                                | 00         | uu                              |
| UCON                    | PIC18F2XJ53                                               | PIC18F4XJ53 | -0x0 000-                                                                         | -0x0 000-  | -uuu uuu-                       |
| USTAT                   | PIC18F2XJ53                                               | PIC18F4XJ53 | -xxx xxx-                                                                         | -xxx xxx-  | -uuu uuu-                       |
| UEIR                    | PIC18F2XJ53                                               | PIC18F4XJ53 | 00 0000                                                                           | 00 0000    | uu uuuu                         |
| UIR                     | PIC18F2XJ53                                               | PIC18F4XJ53 | -000 0000                                                                         | -000 0000  | -uuu uuuu                       |
| UFRMH                   | PIC18F2XJ53                                               | PIC18F4XJ53 | xxx                                                                               | xxx        | uuu                             |
| UFRML                   | PIC18F2XJ53                                               | PIC18F4XJ53 | XXXX XXXX                                                                         | XXXXX XXXX | uuuu uuuu                       |
| PMCONH                  | PIC18F2XJ53                                               | PIC18F4XJ53 | 0-00 0000                                                                         | 0-00 0000  | u-uu uuuu                       |

#### TABLE 5-2: INITIALIZATION CONDITIONS FOR ALL REGISTERS (CONTINUED)

**Legend:** u = unchanged, x = unknown, - = unimplemented bit, read as '0', q = value depends on condition.

**Note 1:** When the wake-up is due to an interrupt and the GIEL or GIEH bit is set, the TOSU, TOSH and TOSL are updated with the current value of the PC. The STKPTR is modified to point to the next location in the hardware stack.

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

3: One or more bits in the INTCONx or PIRx registers will be affected (to cause wake-up).

- 4: See Table 5-1 for Reset value for specific condition.
- 5: Not implemented for PIC18F2XJ53 devices.
- 6: Not implemented for "LF" devices.

#### 10.7.3.2 Output Mapping

In contrast to inputs, the outputs of the PPS options are mapped on the basis of the pin. In this case, a control register associated with a particular pin dictates the peripheral output to be mapped. The RPORx registers are used to control output mapping. The value of the bit field corresponds to one of the peripherals and that peripheral's output is mapped to the pin (see Table 10-14). Because of the mapping technique, the list of peripherals for output mapping also includes a null value of '00000'. This permits any given pin to remain disconnected from the output of any of the pin-selectable peripherals.

## TABLE 10-14: SELECTABLE OUTPUT SOURCES (MAPS FUNCTION TO OUTPUT)

| Function | Output Function<br>Number <sup>(1)</sup> | Output Name                                             |
|----------|------------------------------------------|---------------------------------------------------------|
| NULL     | 0                                        | NULL <sup>(2)</sup>                                     |
| C1OUT    | 1                                        | Comparator 1 Output                                     |
| C2OUT    | 2                                        | Comparator 2 Output                                     |
| C3OUT    | 3                                        | Comparator 3 Output                                     |
| TX2/CK2  | 6                                        | EUSART2 Asynchronous Transmit/Asynchronous Clock Output |
| DT2      | 7                                        | EUSART2 Synchronous Transmit                            |
| SDO2     | 10                                       | SPI2 Data Output                                        |
| SCK2     | 11                                       | SPI2 Clock Output                                       |
| SSDMA    | 12                                       | SPI DMA Slave Select                                    |
| ULPOUT   | 13                                       | Ultra Low-Power Wake-up Event                           |
| CCP1/P1A | 14                                       | ECCP1 Compare or PWM Output Channel A                   |
| P1B      | 15                                       | ECCP1 Enhanced PWM Output, Channel B                    |
| P1C      | 16                                       | ECCP1 Enhanced PWM Output, Channel C                    |
| P1D      | 17                                       | ECCP1 Enhanced PWM Output, Channel D                    |
| CCP2/P2A | 18                                       | ECCP2 Compare or PWM Output                             |
| P2B      | 19                                       | ECCP2 Enhanced PWM Output, Channel B                    |
| P2C      | 20                                       | ECCP2 Enhanced PWM Output, Channel C                    |
| P2D      | 21                                       | ECCP2 Enhanced PWM Output, Channel D                    |
| CCP3/P3A | 22                                       | ECCP3 Compare or PWM Output                             |
| P3B      | 23                                       | ECCP3 Enhanced PWM Output, Channel B                    |
| P3C      | 24                                       | ECCP3 Enhanced PWM Output, Channel C                    |
| P3D      | 25                                       | ECCP3 Enhanced PWM Output, Channel D                    |

**Note 1:** Value assigned to the RP<4:0> pins corresponds to the peripheral output function number.

2: The NULL function is assigned to all RPn outputs at device Reset and disables the RPn output function.

# REGISTER 11-3: PMMODEH: PARALLEL PORT MODE REGISTER HIGH BYTE (BANKED F5Dh)<sup>(1)</sup>

| R-0                                                                                                                                                                                                                                                                                          | R/W-0                                                                                                                                                                                                                                                                                                                                                                                                                                               | R/W-0                                                               | R/W-0                                                            | R/W-0                                                          | R/W-0                                                                                 | R/W-0                                                      | R/W-0             |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|------------------------------------------------------------------|----------------------------------------------------------------|---------------------------------------------------------------------------------------|------------------------------------------------------------|-------------------|
| BUSY                                                                                                                                                                                                                                                                                         | IRQM1                                                                                                                                                                                                                                                                                                                                                                                                                                               | IRQM0                                                               | INCM1                                                            | INCM0                                                          | MODE16                                                                                | MODE1                                                      | MODE0             |
| bit 7                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                     | •                                                                   |                                                                  | -                                                              |                                                                                       |                                                            | bit 0             |
|                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                     |                                                                  |                                                                |                                                                                       |                                                            |                   |
| Legend:                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                     |                                                                  |                                                                |                                                                                       |                                                            |                   |
| R = Readable                                                                                                                                                                                                                                                                                 | e bit                                                                                                                                                                                                                                                                                                                                                                                                                                               | W = Writable                                                        | bit                                                              | U = Unimpler                                                   | nented bit, read                                                                      | d as '0'                                                   |                   |
| -n = Value at                                                                                                                                                                                                                                                                                | POR                                                                                                                                                                                                                                                                                                                                                                                                                                                 | '1' = Bit is set                                                    |                                                                  | '0' = Bit is cle                                               | ared                                                                                  | x = Bit is unkr                                            | nown              |
| bit 7                                                                                                                                                                                                                                                                                        | BUSY: Busy to<br>1 = Port is busy<br>0 = Port is not                                                                                                                                                                                                                                                                                                                                                                                                | bit (Master moo<br>sy<br>t busy                                     | le only)                                                         |                                                                |                                                                                       |                                                            |                   |
| bit 6-5                                                                                                                                                                                                                                                                                      | <ul> <li>it 6-5 IRQM&lt;1:0&gt;: Interrupt Request Mode bits</li> <li>11 = Interrupt generated when Read Buffer 3 is read or Write Buffer 3 is written (Buffered PSP mode or on a read or write operation when PMA&lt;1:0&gt; = 11 (Addressable PSP mode only)</li> <li>10 = No interrupt generated, processor stall activated</li> <li>01 = Interrupt generated at the end of the read/write cycle</li> <li>00 = No interrupt generated</li> </ul> |                                                                     |                                                                  |                                                                |                                                                                       | ed PSP mode)<br>nly)                                       |                   |
| bit 4-3                                                                                                                                                                                                                                                                                      | INCM<1:0>:                                                                                                                                                                                                                                                                                                                                                                                                                                          | ncrement Mode                                                       | e bits                                                           |                                                                |                                                                                       |                                                            |                   |
| <ul> <li>11 = PSP read and write buffers auto-increment (Legacy PSP mode only)</li> <li>10 = Decrement ADDR&lt;15,13:0&gt; by 1 every read/write cycle</li> <li>01 = Increment ADDR&lt;15,13:0&gt; by 1 every read/write cycle</li> <li>00 = No increment or decrement of address</li> </ul> |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                     |                                                                  |                                                                |                                                                                       |                                                            |                   |
| bit 2                                                                                                                                                                                                                                                                                        | MODE16: 8/1                                                                                                                                                                                                                                                                                                                                                                                                                                         | 6-Bit Mode bit                                                      |                                                                  |                                                                |                                                                                       |                                                            |                   |
|                                                                                                                                                                                                                                                                                              | 1 = 16-bit mode: Data register is 16 bits; a read or write to the Data register invokes two 8-bit transfe<br>0 = 8-bit mode: Data register is 8 bits; a read or write to the Data register invokes one 8-bit transfe                                                                                                                                                                                                                                |                                                                     |                                                                  |                                                                |                                                                                       | 8-bit transfers<br>3-bit transfer                          |                   |
| bit 1-0                                                                                                                                                                                                                                                                                      | MODE<1:0>:                                                                                                                                                                                                                                                                                                                                                                                                                                          | Parallel Port N                                                     | lode Select bit                                                  | ts                                                             |                                                                                       |                                                            |                   |
|                                                                                                                                                                                                                                                                                              | 11 = Master M<br>10 = Master M<br>01 = Enhance<br>00 = Legacy F                                                                                                                                                                                                                                                                                                                                                                                     | Aode 1 (PMCS<br>Aode 2 (PMCS<br>ed PSP, control<br>Parallel Slave F | x, PMRD/PMV<br>x, PMRD, PM'<br>signals (PMR<br>Port, control sig | VR, PMENB, Pl<br>WR, PMBE, PM<br>D, PMWR, PM<br>gnals (PMRD, F | MBE, PMA <x:0<br>IA<x:0> and PI<br/>CSx, PMD&lt;7:0<br/>PMWR, PMCS&gt;</x:0></x:0<br> | > and PMD<7:<br>MD<7:0>)<br>> and PMA<1:(<br>< and PMD<7:0 | 0>)<br>0>)<br>)>) |
|                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                     |                                                                  |                                                                |                                                                                       |                                                            |                   |

Note 1: This register is only available on 44-pin devices.

NOTES:

### 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  |
|-------|--------------------------------------|------------|----------|---------|------|------|
|       | ECCPx module will not set the TMR1IF |            |          |         |      | 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

#### 19.2.2 TIMER1/TIMER3 MODE SELECTION

The timers that are to be used with the capture feature (Timer1 and/or Timer3) must be running in Timer mode or Synchronized Counter mode. In Asynchronous Counter mode, the capture operation may not work. The timer to be used with each ECCP module is selected in the CCPTMRS0 register (Register 19-2).

#### 19.2.3 SOFTWARE INTERRUPT

When the Capture mode is changed, a false capture interrupt may be generated. The user should keep the CCPxIE interrupt enable bit clear to avoid false interrupts. The interrupt flag bit, CCPxIF, should also be cleared following any such change in operating mode.

#### 19.2.4 ECCP PRESCALER

There are four prescaler settings in Capture mode; they are specified as part of the operating mode selected by the mode select bits (CCPxM<3:0>). Whenever the

ECCP module is turned off, or Capture mode is disabled, the prescaler counter is cleared. This means that any Reset will clear the prescaler counter.

Switching from one capture prescaler to another may generate an interrupt. Also, the prescaler counter will not be cleared; therefore, the first capture may be from a non-zero prescaler. Example 19-1 provides the recommended method for switching between capture prescalers. This example also clears the prescaler counter and will not generate the "false" interrupt.

#### EXAMPLE 19-1: CHANGING BETWEEN CAPTURE PRESCALERS

| CLRF  | ECCP1CON    | ; | Turn ECCP module off |
|-------|-------------|---|----------------------|
| MOVLW | NEW_CAPT_PS | ; | Load WREG with the   |
|       |             | ; | new prescaler mode   |
|       |             | ; | value and ECCP ON    |
| MOVWF | CCP1CON     | ; | Load ECCP1CON with   |
|       |             | ; | this value           |
|       |             |   |                      |





#### 20.4.4.3 DMABCH and DMABCL

The DMABCH and DMABCL register pair forms a 10-bit Byte Count register, which is used by the SPI DMA module to send/receive up to 1,024 bytes for each DMA transaction. When the DMA module is actively running (DMAEN = 1), the DMA Byte Count register decrements after each byte is transmitted/received. The DMA transaction will halt and the DMAEN bit will be automatically cleared by hardware after the last byte has completed. After a DMA transaction is complete, the DMABC register will read 0x000.

Prior to initiating a DMA transaction by setting the DMAEN bit, user firmware should load the appropriate value into the DMABCH/DMABCL registers. The DMABC is a "base zero" counter, so the actual number of bytes which will be transmitted follows in Equation 20-1.

For example, if user firmware wants to transmit 7 bytes in one transaction, DMABC should be loaded with 006h. Similarly, if user firmware wishes to transmit 1,024 bytes, DMABC should be loaded with 3FFh.

#### EQUATION 20-1: BYTES TRANSMITTED FOR A GIVEN DMABC

Bytes<sub>XMIT</sub>  $\equiv$  (DMABC + 1)

# 20.4.4.4 TXADDRH and TXADDRL

The TXADDRH and TXADDRL registers pair together to form a 12-bit Transmit Source Address Pointer register. In modes that use TXADDR (Full-Duplex and Half-Duplex Transmit), the TXADDR will be incremented after each byte is transmitted. Transmitted data bytes will be taken from the memory location pointed to by the TXADDR register. The contents of the memory locations pointed to by TXADDR will not be modified by the DMA module during a transmission.

The SPI DMA module can read from, and transmit data from, all general purpose memory on the device, including memory used for USB endpoint buffers. The SPI DMA module cannot be used to read from the Special Function Registers (SFRs) contained in Banks 14 and 15.

#### 20.4.4.5 RXADDRH and RXADDRL

The RXADDRH and RXADDRL registers pair together to form a 12-bit Receive Destination Address Pointer. In modes that use RXADDR (Full-Duplex and Half-Duplex Receive), the RXADDR register will be incremented after each byte is received. Received data bytes will be stored at the memory location pointed to by the RXADDR register. The SPI DMA module can write received data to all general purpose memory on the device, including memory used for USB endpoint buffers. The SPI DMA module cannot be used to modify the Special Function Registers contained in Banks 14 and 15.

#### 20.4.5 INTERRUPTS

The SPI DMA module alters the behavior of the SSP2IF interrupt flag. In normal non-DMA modes, the SSP2IF is set once after every single byte is transmitted/received through the MSSP2 module. When MSSP2 is used with the SPI DMA module, the SSP2IF interrupt flag will be set according to the user-selected INTLVL<3:0> value specified in the DMACON2 register. The SSP2IF interrupt condition will also be generated once the SPI DMA transaction has fully completed and the DMAEN bit has been cleared by hardware.

The SSP2IF flag becomes set once the DMA byte count value indicates that the specified INTLVL has been reached. For example, if DMACON2<3:0> = 0101 (16 bytes remaining), the SSP2IF interrupt flag will become set once DMABC reaches 00Fh. If user firmware then clears the SSP2IF interrupt flag, the flag will not be set again by the hardware until after all bytes have been fully transmitted and the DMA transaction is complete.

**Note:** User firmware may modify the INTLVL bits while a DMA transaction is in progress (DMAEN = 1). If an INTLVL value is selected which is higher than the actual remaining number of bytes (indicated by DMABC + 1), the SSP2IF interrupt flag will immediately become set.

For example, if DMABC = 00Fh (implying 16 bytes are remaining) and user firmware writes '1111' to INTLVL<3:0> (interrupt when 576 bytes remaining), the SSP2IF interrupt flag will immediately become set. If user firmware clears this interrupt flag, a new interrupt condition will not be generated until either: user firmware again writes INTLVL with an interrupt level higher than the actual remaining level, or the DMA transaction completes and the DMAEN bit is cleared.

**Note:** If the INTLVL bits are modified while a DMA transaction is in progress, care should be taken to avoid inadvertently changing the DLYCYC<3:0> value.

#### 23.2.5 USB ADDRESS REGISTER (UADDR)

The USB Address register contains the unique USB address that the peripheral will decode when active. UADDR is reset to 00h when a USB Reset is received, indicated by URSTIF, or when a Reset is received from the microcontroller. The USB address must be written by the microcontroller during the USB setup phase (enumeration) as part of the Microchip USB firmware support.

#### 23.2.6 USB FRAME NUMBER REGISTERS (UFRMH:UFRML)

The Frame Number registers contain the 11-bit frame number. The low-order byte is contained in UFRML, while the three high-order bits are contained in UFRMH. The register pair is updated with the current frame number whenever a SOF token is received. For the microcontroller, these registers are read-only. The Frame Number registers are primarily used for isochronous transfers. The contents of the UFRMH and UFRML registers are only valid when the 48 MHz SIE clock is active (i.e., contents are inaccurate when SUSPND (UCON<1>) bit = 1).

# 23.3 USB RAM

USB data moves between the microcontroller core and the SIE through a memory space known as the USB RAM. This is a special dual access memory that is mapped into the normal data memory space in Banks, 0 through 14 (00h to EBFh), for a total of 3.8 Kbytes (Figure 23-4).

Bank 13 (D00h through DFFh) is used specifically for endpoint buffer control, while Banks 0 through 12 and Bank 14 are available for USB data. Depending on the type of buffering being used, all but 8 bytes of Bank 13 may also be available for use as USB buffer space.

Although USB RAM is available to the microcontroller as data memory, the sections that are being accessed by the SIE should not be accessed by the microcontroller. A semaphore mechanism is used to determine the access to a particular buffer at any given time. This is discussed in **Section 23.4.1.1 "Buffer Ownership**".

#### FIGURE 23-4:

#### IMPLEMENTATION OF USB RAM IN DATA MEMORY SPACE



The BDnSTAT byte of the BDT should always be the last byte updated when preparing to arm an endpoint. The SIE will clear the UOWN bit when a transaction has completed.

No hardware mechanism exists to block access when the UOWN bit is set. Thus, unexpected behavior can occur if the microcontroller attempts to modify memory when the SIE owns it. Similarly, reading such memory may produce inaccurate data until the USB peripheral returns ownership to the microcontroller.

#### 23.4.1.2 BDnSTAT Register (CPU Mode)

When UOWN = 0, the microcontroller core owns the BD. At this point, the other seven bits of the register take on control functions.

The Data Toggle Sync Enable bit, DTSEN (BDnSTAT<3>), controls data toggle parity checking. Setting DTSEN enables data toggle synchronization by the SIE. When enabled, it checks the data packet's parity against the value of DTS (BDnSTAT<6>). If a packet arrives with an incorrect synchronization, the data will essentially be ignored. It will not be written to the USB RAM and the USB transfer complete interrupt flag will not be set. The SIE will send an ACK token back to the host to Acknowledge receipt, however. The effects of the DTSEN bit on the SIE are summarized in Table 23-1.

The Buffer Stall bit, BSTALL (BDnSTAT<2>), provides support for control transfers, usually one-time stalls on Endpoint 0. It also provides support for the SET\_FEA-TURE/CLEAR\_FEATURE commands specified in Chapter 9 of the USB Specification; typically, continuous STALLs to any endpoint other than the default control endpoint.

The BSTALL bit enables buffer stalls. Setting BSTALL causes the SIE to return a STALL token to the host if a received token would use the BD in that location. The EPSTALL bit in the corresponding UEPn Control register is set and a STALL interrupt is generated when a STALL is issued to the host. The UOWN bit remains set and the BDs are not changed unless a SETUP token is received. In this case, the STALL condition is cleared and the ownership of the BD is returned to the microcontroller core.

The BCx<9:8> bits (BDnSTAT<1:0>) store the two most significant digits of the SIE byte count. The lower 8 digits are stored in the corresponding BDnCNT register. See **Section 23.4.2 "BD Byte Count"** for more information.

| OUT Packet         | BDnSTAT Settings |     | Device Response after Receiving Packet |      |       |                          |  |
|--------------------|------------------|-----|----------------------------------------|------|-------|--------------------------|--|
| from Host          | DTSEN            | DTS | Handshake                              | UOWN | TRNIF | BDnSTAT and USTAT Status |  |
| DATA0              | 1                | 0   | ACK                                    | 0    | 1     | Updated                  |  |
| DATA1              | 1                | 0   | ACK                                    | 1    | 0     | Not Updated              |  |
| DATA0              | 1                | 1   | ACK                                    | 1    | 0     | Not Updated              |  |
| DATA1              | 1                | 1   | ACK                                    | 0    | 1     | Updated                  |  |
| Either             | 0                | х   | ACK                                    | 0    | 1     | Updated                  |  |
| Either, with error | х                | х   | NAK                                    | 1    | 0     | Not Updated              |  |

# TABLE 23-1: EFFECT OF DTSEN BIT ON ODD/EVEN (DATA0/DATA1) PACKET RECEPTION

**Legend:** x = don't care

#### 23.5.2 USB INTERRUPT ENABLE REGISTER (UIE)

The USB Interrupt Enable (UIE) register (Register 23-8) contains the enable bits for the USB status interrupt sources. Setting any of these bits will enable the respective interrupt source in the UIR register.

The values in this register only affect the propagation of an interrupt condition to the microcontroller's interrupt logic. The flag bits are still set by their interrupt conditions, allowing them to be polled and serviced without actually generating an interrupt.

#### REGISTER 23-8: UIE: USB INTERRUPT ENABLE REGISTER (BANKED F36h)

| U-0   | R/W-0 | R/W-0   | R/W-0  | R/W-0 | R/W-0  | R/W-0  | R/W-0  |
|-------|-------|---------|--------|-------|--------|--------|--------|
| —     | SOFIE | STALLIE | IDLEIE | TRNIE | ACTVIE | UERRIE | URSTIE |
| bit 7 |       |         |        |       |        |        | bit 0  |
| L     |       |         |        |       |        |        |        |

| Legend:           |                  |                             |                    |
|-------------------|------------------|-----------------------------|--------------------|
| 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 6       SOFIE: Start-Of-Frame Token Interrupt Enable bit         1 = Start-Of-Frame token interrupt is enabled       0 = Start-Of-Frame token interrupt is disabled         bit 5       STALLIE: STALL Handshake Interrupt Enable bit         1 = STALL interrupt is enabled       0 = STALL interrupt is enabled         0 = STALL interrupt is disabled       0 = STALL interrupt is disabled         bit 4       IDLEIE: Idle Detect Interrupt Enable bit         1 = Idle detect interrupt is enabled       0 = Idle detect interrupt is disabled         bit 3       TRNIE: Transaction Complete Interrupt Enable bit         1 = Transaction interrupt is disabled       0 = Transaction interrupt is disabled         bit 2       ACTVIE: Bus Activity Detect Interrupt Enable bit         1 = Bus activity detect interrupt is enabled       0 = Bus activity detect interrupt is disabled         bit 1       UERRIE: USB Error Interrupt Enable bit         1 = USB error interrupt is disabled       0 = USB error interrupt is disabled         bit 0       URSTIE: USB Reset Interrupt Enable bit         1 = USB Reset Interrupt is enabled       0 = USB Reset interrupt is enabled         0 = USB Reset interrupt is disabled       0 = USB Reset interrupt is disabled                        | bit 7 | Unimplemented: Read as '0'                                                                                              |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------------------------------------------------------------------------------------------------------------------------|
| 1 = Start-Of-Frame token interrupt is enabled         0 = Start-Of-Frame token interrupt is disabled         bit 5       STALLIE: STALL Handshake Interrupt Enable bit         1 = STALL interrupt is enabled       0 = STALL interrupt is enabled         0 = STALL interrupt is disabled       0 = STALL interrupt is disabled         bit 4       IDLEIE: Idle Detect Interrupt Enable bit         1 = Idle detect interrupt is enabled       0 = Idle detect interrupt is enabled         0 = Idle detect interrupt is enabled       0 = Idle detect interrupt is enabled         bit 3       TRNIE: Transaction Complete Interrupt Enable bit         1 = Transaction interrupt is enabled       0 = Transaction interrupt is enabled         0 = Transaction interrupt is disabled       0 = Transaction interrupt is disabled         bit 2       ACTVIE: Bus Activity Detect Interrupt Enable bit         1 = Bus activity detect interrupt is enabled       0 = Bus activity detect interrupt is disabled         bit 1       UERRIE: USB Error Interrupt Enable bit         1 = USB error interrupt is disabled       0 = USB reror interrupt is disabled         bit 0       URSTIE: USB Reset Interrupt Enable bit         1 = USB Reset interrupt is enabled       0 = USB Reset interrupt is disabled | bit 6 | SOFIE: Start-Of-Frame Token Interrupt Enable bit                                                                        |
| bit 5       STALLIE: STALL Handshake Interrupt Enable bit         1 = STALL interrupt is enabled       0 = STALL interrupt is disabled         bit 4       IDLEIE: Idle Detect Interrupt Enable bit         1 = Idle detect interrupt is enabled       0 = Idle detect interrupt is enabled         0 = Idle detect interrupt is enabled       0 = Idle detect interrupt is disabled         bit 3       TRNIE: Transaction Complete Interrupt Enable bit         1 = Transaction interrupt is enabled       0 = Transaction interrupt is disabled         bit 2       ACTVIE: Bus Activity Detect Interrupt Enable bit         1 = Bus activity detect interrupt is enabled       0 = Bus activity detect interrupt is enabled         0 = Bus activity detect interrupt is disabled       0 = Bus activity detect interrupt is disabled         bit 1       UERRIE: USB Error Interrupt Enable bit         1 = USB error interrupt is enabled       0 = USB error interrupt is disabled         bit 0       URSTIE: USB Reset Interrupt Enable bit         1 = USB Reset interrupt is enabled       0 = USB Reset interrupt is enabled         0 = USB Reset interrupt is enabled       0 = USB Reset interrupt is disabled                                                                                       |       | <ul><li>1 = Start-Of-Frame token interrupt is enabled</li><li>0 = Start-Of-Frame token interrupt is disabled</li></ul>  |
| 1 = STALL interrupt is enabled         0 = STALL interrupt is disabled         bit 4       IDLEIE: Idle Detect Interrupt Enable bit         1 = Idle detect interrupt is enabled       0 = Idle detect interrupt is disabled         bit 3       TRNIE: Transaction Complete Interrupt Enable bit         1 = Transaction interrupt is enabled       0 = Transaction interrupt is disabled         bit 2       ACTVIE: Bus Activity Detect Interrupt Enable bit         1 = Bus activity detect interrupt is enabled       0 = Bus activity detect interrupt is disabled         bit 1       UERRIE: USB Error Interrupt Enable bit         1 = USB error interrupt is disabled       0 = USB reor interrupt is disabled         bit 0       URSTIE: USB Reset Interrupt Enable bit         1 = USB Reset interrupt is enabled       0 = USB Reset interrupt is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                             | bit 5 | STALLIE: STALL Handshake Interrupt Enable bit                                                                           |
| bit 4IDLEIE: Idle Detect Interrupt Enable bit1 = Idle detect interrupt is enabled<br>0 = Idle detect interrupt is disabledbit 3TRNIE: Transaction Complete Interrupt Enable bit<br>1 = Transaction interrupt is enabled<br>0 = Transaction interrupt is disabledbit 2ACTVIE: Bus Activity Detect Interrupt Enable bit<br>1 = Bus activity detect interrupt is enabled<br>0 = Bus activity detect interrupt is disabledbit 1UERRIE: USB Error Interrupt is disabledbit 2UERRIE: USB Error Interrupt Enable bit<br>1 = USB error interrupt is disabledbit 1UERRIE: USB Error Interrupt Enable bit<br>1 = USB Reset Interrupt is disabledbit 0URSTIE: USB Reset Interrupt Enable bit<br>1 = USB Reset interrupt is enabled<br>0 = USB Reset interrupt is disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       | <ul><li>1 = STALL interrupt is enabled</li><li>0 = STALL interrupt is disabled</li></ul>                                |
| 1 = Idle detect interrupt is enabled<br>0 = Idle detect interrupt is disabledbit 3TRNIE: Transaction Complete Interrupt Enable bit<br>1 = Transaction interrupt is enabled<br>0 = Transaction interrupt is disabledbit 2ACTVIE: Bus Activity Detect Interrupt Enable bit<br>1 = Bus activity detect interrupt is enabled<br>0 = Bus activity detect interrupt is disabledbit 1UERRIE: USB Error Interrupt Enable bit<br>1 = USB error interrupt is enabled<br>0 = USB Reset Interrupt is disabledbit 0URSTIE: USB Reset Interrupt Enable bit<br>1 = USB Reset interrupt is enabled<br>0 = USB Reset interrupt is enabled<br>0 = USB Reset interrupt is enabled<br>0 = USB Reset interrupt is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | bit 4 | IDLEIE: Idle Detect Interrupt Enable bit                                                                                |
| bit 3       TRNIE: Transaction Complete Interrupt Enable bit         1 = Transaction interrupt is enabled       0 = Transaction interrupt is disabled         bit 2       ACTVIE: Bus Activity Detect Interrupt Enable bit         1 = Bus activity detect interrupt is enabled       0 = Bus activity detect interrupt is disabled         bit 1       UERRIE: USB Error Interrupt Enable bit         1 = USB error interrupt is enabled       0 = USB error interrupt is disabled         bit 0       URSTIE: USB Reset Interrupt Enable bit         1 = USB Reset interrupt is enabled       0 = USB Reset interrupt is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       | <ul><li>1 = Idle detect interrupt is enabled</li><li>0 = Idle detect interrupt is disabled</li></ul>                    |
| 1 = Transaction interrupt is enabled         0 = Transaction interrupt is disabled         bit 2       ACTVIE: Bus Activity Detect Interrupt Enable bit         1 = Bus activity detect interrupt is enabled         0 = Bus activity detect interrupt is disabled         bit 1       UERRIE: USB Error Interrupt Enable bit         1 = USB error interrupt is enabled         0 = USB error interrupt is disabled         bit 0       URSTIE: USB Reset Interrupt Enable bit         1 = USB Reset interrupt is enabled         0 = USB Reset interrupt is enabled         0 = USB Reset interrupt is enabled         0 = USB Reset interrupt is disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | bit 3 | TRNIE: Transaction Complete Interrupt Enable bit                                                                        |
| bit 2       ACTVIE: Bus Activity Detect Interrupt Enable bit         1 = Bus activity detect interrupt is enabled       0 = Bus activity detect interrupt is disabled         bit 1       UERRIE: USB Error Interrupt Enable bit         1 = USB error interrupt is enabled       0 = USB error interrupt is disabled         bit 0       URSTIE: USB Reset Interrupt Enable bit         1 = USB Reset interrupt is enabled       0 = USB Reset interrupt Enable bit         0 = USB Reset interrupt is disabled       0 = USB Reset interrupt is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       | <ul><li>1 = Transaction interrupt is enabled</li><li>0 = Transaction interrupt is disabled</li></ul>                    |
| 1 = Bus activity detect interrupt is enabled         0 = Bus activity detect interrupt is disabled         bit 1       UERRIE: USB Error Interrupt Enable bit         1 = USB error interrupt is enabled         0 = USB error interrupt is disabled         bit 0       URSTIE: USB Reset Interrupt Enable bit         1 = USB Reset interrupt is enabled         0 = USB Reset interrupt is disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | bit 2 | ACTVIE: Bus Activity Detect Interrupt Enable bit                                                                        |
| bit 1       UERRIE: USB Error Interrupt Enable bit         1 = USB error interrupt is enabled         0 = USB error interrupt is disabled         bit 0       URSTIE: USB Reset Interrupt Enable bit         1 = USB Reset interrupt is enabled         0 = USB Reset interrupt is disabled         0 = USB Reset interrupt is disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       | <ul> <li>1 = Bus activity detect interrupt is enabled</li> <li>0 = Bus activity detect interrupt is disabled</li> </ul> |
| <ul> <li>1 = USB error interrupt is enabled</li> <li>0 = USB error interrupt is disabled</li> <li>bit 0 URSTIE: USB Reset Interrupt Enable bit</li> <li>1 = USB Reset interrupt is enabled</li> <li>0 = USB Reset interrupt is disabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | bit 1 | UERRIE: USB Error Interrupt Enable bit                                                                                  |
| bit 0 URSTIE: USB Reset Interrupt Enable bit<br>1 = USB Reset interrupt is enabled<br>0 = USB Reset interrupt is disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       | <ul> <li>1 = USB error interrupt is enabled</li> <li>0 = USB error interrupt is disabled</li> </ul>                     |
| <ul><li>1 = USB Reset interrupt is enabled</li><li>0 = USB Reset interrupt is disabled</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | bit 0 | URSTIE: USB Reset Interrupt Enable bit                                                                                  |
| 0 = USB Reset interrupt is disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       | 1 = USB Reset interrupt is enabled                                                                                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       | 0 = USB Reset interrupt is disabled                                                                                     |

## 23.7 Oscillator

The USB module has specific clock requirements. For full-speed operation, the clock source must be 48 MHz. Even so, the microcontroller core and other peripherals are not required to run at that clock speed. Available clocking options are described in detail in **Section 3.3** "Oscillator Settings for USB".

### 23.8 USB Firmware and Drivers

Microchip provides a number of application-specific resources, such as USB firmware and driver support. Refer to www.microchip.com for the latest firmware and driver support.

| Name   | Bit 7    | Bit 6     | Bit 5   | Bit 4  | Bit 3    | Bit 2   | Bit 1  | Bit 0   |
|--------|----------|-----------|---------|--------|----------|---------|--------|---------|
| INTCON | GIE/GIEH | PEIE/GIEL | TMR0IE  | INT0IE | RBIE     | TMR0IF  | INT0IF | RBIF    |
| IPR2   | OSCFIP   | CM2IP     | CM1IP   | USBIP  | BCL1IP   | HLVDIP  | TMR3IP | CCP2IP  |
| PIR2   | OSCFIF   | CM2IF     | CM1IF   | USBIF  | BCL1IF   | HLVDIF  | TMR3IF | CCP2IF  |
| PIE2   | OSCFIE   | CM2IE     | CM1IE   | USBIE  | BCL1IE   | HLVDIE  | TMR3IE | CCP2IE  |
| UCON   | _        | PPBRST    | SE0     | PKTDIS | USBEN    | RESUME  | SUSPND | _       |
| UCFG   | UTEYE    | UOEMON    | —       | UPUEN  | UTRDIS   | FSEN    | PPB1   | PPB0    |
| USTAT  | _        | ENDP3     | ENDP2   | ENDP1  | ENDP0    | DIR     | PPBI   | _       |
| UADDR  | _        | ADDR6     | ADDR5   | ADDR4  | ADDR3    | ADDR2   | ADDR1  | ADDR0   |
| UFRML  | FRM7     | FRM6      | FRM5    | FRM4   | FRM3     | FRM2    | FRM1   | FRM0    |
| UFRMH  | _        | _         | _       | —      | —        | FRM10   | FRM9   | FRM8    |
| UIR    | _        | SOFIF     | STALLIF | IDLEIF | TRNIF    | ACTVIF  | UERRIF | URSTIF  |
| UIE    | —        | SOFIE     | STALLIE | IDLEIE | TRNIE    | ACTVIE  | UERRIE | URSTIE  |
| UEIR   | BTSEF    | _         | _       | BTOEF  | DFN8EF   | CRC16EF | CRC5EF | PIDEF   |
| UEIE   | BTSEE    | _         | _       | BTOEE  | DFN8EE   | CRC16EE | CRC5EE | PIDEE   |
| UEP0   | -        |           |         | EPHSHK | EPCONDIS | EPOUTEN | EPINEN | EPSTALL |
| UEP1   | —        | —         | —       | EPHSHK | EPCONDIS | EPOUTEN | EPINEN | EPSTALL |
| UEP2   | _        | _         | _       | EPHSHK | EPCONDIS | EPOUTEN | EPINEN | EPSTALL |
| UEP3   | —        | —         | —       | EPHSHK | EPCONDIS | EPOUTEN | EPINEN | EPSTALL |
| UEP4   | _        | _         | _       | EPHSHK | EPCONDIS | EPOUTEN | EPINEN | EPSTALL |
| UEP5   | _        | _         | _       | EPHSHK | EPCONDIS | EPOUTEN | EPINEN | EPSTALL |
| UEP6   | -        |           |         | EPHSHK | EPCONDIS | EPOUTEN | EPINEN | EPSTALL |
| UEP7   | —        | —         | —       | EPHSHK | EPCONDIS | EPOUTEN | EPINEN | EPSTALL |
| UEP8   | —        | —         | —       | EPHSHK | EPCONDIS | EPOUTEN | EPINEN | EPSTALL |
| UEP9   | -        |           |         | EPHSHK | EPCONDIS | EPOUTEN | EPINEN | EPSTALL |
| UEP10  | —        | —         | —       | EPHSHK | EPCONDIS | EPOUTEN | EPINEN | EPSTALL |
| UEP11  | —        | —         | —       | EPHSHK | EPCONDIS | EPOUTEN | EPINEN | EPSTALL |
| UEP12  | _        | _         | _       | EPHSHK | EPCONDIS | EPOUTEN | EPINEN | EPSTALL |
| UEP13  | —        | —         | _       | EPHSHK | EPCONDIS | EPOUTEN | EPINEN | EPSTALL |
| UEP14  | —        | —         | —       | EPHSHK | EPCONDIS | EPOUTEN | EPINEN | EPSTALL |
| UEP15  | _        | _         | _       | EPHSHK | EPCONDIS | EPOUTEN | EPINEN | EPSTALL |

 TABLE 23-4:
 REGISTERS ASSOCIATED WITH USB MODULE OPERATION<sup>(1)</sup>

**Legend:** — = unimplemented, read as '0'. Shaded cells are not used by the USB module.

**Note 1:** This table includes only those hardware mapped SFRs located in Bank 15 of the data memory space. The Buffer Descriptor registers, which are mapped into Bank 4 and are not true SFRs, are listed separately in Table 23-3.

| SLEEP Enter S |                                        |                                                                                                                            | ep Mode                                                       | SUBFWB                                       |                                                     |
|---------------|----------------------------------------|----------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------|-----------------------------------------------------|
| Syn           | tax:                                   | SLEEP                                                                                                                      |                                                               |                                              | Syntax:                                             |
| Ope           | rands:                                 | None                                                                                                                       |                                                               |                                              | Operands:                                           |
| Ope           | ration:                                | $\begin{array}{l} 00h \rightarrow WE \\ 0 \rightarrow WDT \\ 1 \rightarrow \overline{TO}, \\ 0 \rightarrow PD \end{array}$ | DT,<br>postscaler,                                            |                                              | Operation:<br>Status Affected:                      |
| Stat          | us Affected:                           | TO, PD                                                                                                                     |                                                               |                                              | Encodina:                                           |
| Enc           | oding:                                 | 0000                                                                                                                       | 0000 00                                                       | 00 0011                                      | Description:                                        |
| Des           | cription:                              | The Powe<br>cleared. T<br>is set. The<br>postscaler                                                                        | r-Down status<br>he Time-out s<br>Watchdog Ti<br>are cleared. | bit (PD) is<br>tatus bit (TO)<br>mer and its |                                                     |
|               |                                        | The proce with the os                                                                                                      | ssor is put intescillator stoppe                              | o Sleep mode<br>ed.                          |                                                     |
| Wor           | ds:                                    | 1                                                                                                                          |                                                               |                                              |                                                     |
| Cyc           | es:                                    | 1                                                                                                                          |                                                               |                                              |                                                     |
| QC            | Cycle Activity:                        |                                                                                                                            |                                                               |                                              |                                                     |
|               | Q1                                     | Q2                                                                                                                         | Q3                                                            | Q4                                           |                                                     |
|               | Decode                                 | No<br>operation                                                                                                            | Process<br>Data                                               | Go to<br>Sleep                               |                                                     |
| Exa           | mple:                                  | SLEEP                                                                                                                      |                                                               |                                              | Words:                                              |
|               | Before Instruct<br>$\frac{TO}{PD} =$   | tion<br>?<br>?                                                                                                             |                                                               |                                              | Cycles:<br>Q Cycle Activity:<br>Q1                  |
|               | After Instruction<br>$\frac{TO}{PD} =$ | on<br>1 <b>†</b><br>0                                                                                                      |                                                               |                                              | Decode                                              |
| † 11          | WDT causes v                           | wake-up, this t                                                                                                            | bit is cleared.                                               |                                              | <u>Example 1:</u><br>Before Instru<br>REG<br>W<br>C |

| SUBFWB     |                        | Subtract f from W with Borrow                                                                                                                                                                                                                                                            |                                                                                                                                                                                                    |                                |                   |             |                        |
|------------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|-------------------|-------------|------------------------|
| Synta      | ax:                    | SUBF\                                                                                                                                                                                                                                                                                    | VB f                                                                                                                                                                                               | {,d {,a}}                      | ł                 |             |                        |
| Oper       | ands:                  | $\begin{array}{l} 0\leq f\leq \\ d\in [0,\\ a\in [0,\end{array} \end{array}$                                                                                                                                                                                                             | $0 \le f \le 255$<br>$d \in [0,1]$<br>$a \in [0,1]$                                                                                                                                                |                                |                   |             |                        |
| Oper       | ation:                 | (W) – (                                                                                                                                                                                                                                                                                  | f) – ( <del>C</del>                                                                                                                                                                                | $) \rightarrow des$            | st                |             |                        |
| Statu      | is Affected:           | N, OV,                                                                                                                                                                                                                                                                                   | C, DC                                                                                                                                                                                              | , Z                            |                   |             |                        |
| Enco       | oding:                 | 010                                                                                                                                                                                                                                                                                      | 1                                                                                                                                                                                                  | )1da                           | fff               | f           | ffff                   |
| Desc       | ription:               | Subtra<br>(borrov<br>methoo<br>W. If 'c<br>registe                                                                                                                                                                                                                                       | Subtract register 'f' and Carry flag<br>(borrow) from W (2's complement<br>method). If 'd' is '0', the result is stored in<br>W. If 'd' is '1', the result is stored in<br>register 'f' (default). |                                |                   |             |                        |
|            |                        | lf 'a' is<br>'a' is '1<br>GPR b                                                                                                                                                                                                                                                          | '0', the<br>', the I<br>ank (d                                                                                                                                                                     | Access<br>BSR is u<br>efault). | s Bank<br>used to | is s<br>sel | elected. If<br>ect the |
|            |                        | If 'a' is '0' and the extended instruction<br>set is enabled, this instruction operates in<br>Indexed Literal Offset Addressing mode<br>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. |                                                                                                                                                                                                    |                                |                   |             |                        |
| Word       | ls:                    | 1                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                    |                                |                   |             |                        |
| Cycle      | es:                    | 1                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                    |                                |                   |             |                        |
| QC         | ycle Activity:         |                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                    |                                |                   |             |                        |
|            | Q1                     | Q                                                                                                                                                                                                                                                                                        | 2                                                                                                                                                                                                  | Q                              | 3                 |             | Q4                     |
|            | Decode                 | Rea                                                                                                                                                                                                                                                                                      | d                                                                                                                                                                                                  | Proc                           | ess               | ۷           | Vrite to               |
|            |                        | regist                                                                                                                                                                                                                                                                                   | er 'f'                                                                                                                                                                                             | Da                             | ta                | de          | stination              |
| Exar       | nple 1:                | SUB                                                                                                                                                                                                                                                                                      | FWB                                                                                                                                                                                                | REG,                           | 1, 0              |             |                        |
|            | Before Instruc         | tion                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                    |                                |                   |             |                        |
|            | W                      | = 2                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                    |                                |                   |             |                        |
|            | C<br>After Instructiv  | = 1                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                    |                                |                   |             |                        |
|            | REG                    | رار<br>= F                                                                                                                                                                                                                                                                               | F                                                                                                                                                                                                  |                                |                   |             |                        |
|            | W                      | = 2                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                    |                                |                   |             |                        |
|            | z                      | = 0                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                    |                                |                   |             |                        |
|            | N                      | = 1                                                                                                                                                                                                                                                                                      | ; r                                                                                                                                                                                                | esult is                       | negativ           | /e          |                        |
| Exar       | nple 2:                | SUB                                                                                                                                                                                                                                                                                      | FWB                                                                                                                                                                                                | REG,                           | 0, 0              |             |                        |
|            | Before Instruc         | = 2                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                    |                                |                   |             |                        |
|            | W                      | = 5                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                    |                                |                   |             |                        |
|            | C<br>After Instruction | = 1                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                    |                                |                   |             |                        |
|            | REG                    | = 2                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                    |                                |                   |             |                        |
|            | W                      | = 3                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                    |                                |                   |             |                        |
|            | z                      | = 0                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                    |                                |                   |             |                        |
|            | N                      | = 0                                                                                                                                                                                                                                                                                      | ; r                                                                                                                                                                                                | esult is                       | positiv           | е           |                        |
| Example 3: |                        | SUB                                                                                                                                                                                                                                                                                      | FWB                                                                                                                                                                                                | REG,                           | 1, 0              |             |                        |
|            | Before Instruc         | tion = 1                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                    |                                |                   |             |                        |
|            | W                      | = 2                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                    |                                |                   |             |                        |
|            | C<br>After Instructiv  | = 0                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                    |                                |                   |             |                        |
|            | REG                    | = 0                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                    |                                |                   |             |                        |
|            | Ŵ                      | = 2                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                    |                                |                   |             |                        |
|            | Z                      | = 1<br>= 1                                                                                                                                                                                                                                                                               | ; r                                                                                                                                                                                                | esult is                       | zero              |             |                        |
|            | N                      | = 0                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                    |                                |                   |             |                        |

| MOVSS                                              | Move Indexed to Indexed                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                      |                       |                                        |  |
|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-----------------------|----------------------------------------|--|
| Syntax:                                            | MOVSS                                                                                                                                                                                                                                                                                                                                                                                                                                                      | [z <sub>s</sub> ], [z <sub>d</sub> ] |                       |                                        |  |
| Operands:                                          | $0 \le z_s \le 12$<br>$0 \le z_d \le 12$                                                                                                                                                                                                                                                                                                                                                                                                                   | 27<br>27                             |                       |                                        |  |
| Operation:                                         | ((FSR2) +                                                                                                                                                                                                                                                                                                                                                                                                                                                  | $z_s) \rightarrow ((F$               | SR2) + z <sub>d</sub> | )                                      |  |
| Status Affected:                                   | None                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                      |                       |                                        |  |
| Encoding:<br>1st word (source)<br>2nd word (dest.) | 1110<br>1111                                                                                                                                                                                                                                                                                                                                                                                                                                               | 1011<br>xxxx                         | lzzz<br>xzzz          | zzzz <sub>s</sub><br>zzzz <sub>d</sub> |  |
| Description                                        | The contents of the source register are<br>moved to the destination register. The<br>addresses of the source and destination<br>registers are determined by adding the<br>7-bit literal offsets, 'z <sub>s</sub> ' or 'z <sub>d</sub> ',<br>respectively, to the value of FSR2. Both<br>registers can be located anywhere in<br>the 4096-byte data memory space<br>(000h to FFFh).<br>The MOVSS instruction cannot use the<br>PCL_TOSU_TOSH or TOSL as the |                                      |                       |                                        |  |
|                                                    | If the resultant source address points to<br>an Indirect Addressing register, the<br>value returned will be 00h. If the<br>resultant destination address points to<br>an Indirect Addressing register, the<br>instruction will execute as a NOP                                                                                                                                                                                                            |                                      |                       |                                        |  |
| Words:                                             | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                      |                       |                                        |  |
| Cycles:                                            | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                      |                       |                                        |  |
| Q Cycle Activity:                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                      |                       |                                        |  |

| Q1     | Q2          | Q3          | Q4          |
|--------|-------------|-------------|-------------|
| Decode | Determine   | Determine   | Read        |
|        | source addr | source addr | source reg  |
| Decode | Determine   | Determine   | Write       |
|        | dest addr   | dest addr   | to dest reg |

| Example: | MOVSS | [05h], | [06h] |
|----------|-------|--------|-------|
|          |       |        |       |

| Before Instruction             |   |     |
|--------------------------------|---|-----|
| FSR2                           | = | 80h |
| Contents<br>of 85h<br>Contents | = | 33h |
| of 86h                         | = | 11h |
| After Instruction              |   |     |
| FSR2                           | = | 80h |
| Contents                       |   |     |
| of 85h                         | = | 33h |
| of 86h                         | = | 33h |

| PUSI  | HL             | Store Literal at FSR2, Decrement FSR2                                                                                                 |            |           |                      |  |
|-------|----------------|---------------------------------------------------------------------------------------------------------------------------------------|------------|-----------|----------------------|--|
| Synta | ax:            | PUSHL k                                                                                                                               |            |           |                      |  |
| Oper  | ands:          | $0 \le k \le 255$                                                                                                                     |            |           |                      |  |
| Oper  | ation:         | $k \rightarrow (FSR2),$<br>FSR2 – 1 $\rightarrow$ FSR2                                                                                |            |           |                      |  |
| Statu | s Affected:    | None                                                                                                                                  |            |           |                      |  |
| Enco  | ding:          | 1111                                                                                                                                  | 1010       | kkkk      | kkkk                 |  |
| Desc  | ription:       | The 8-bit literal 'k' is written to the data<br>memory address specified by FSR2.<br>FSR2 is decremented by 1 after the<br>operation. |            |           |                      |  |
|       |                | This instruction allows users to push values onto a software stack.                                                                   |            |           |                      |  |
| Word  | s:             | 1                                                                                                                                     |            |           |                      |  |
| Cycle | es:            | 1                                                                                                                                     |            |           |                      |  |
| QC    | ycle Activity: |                                                                                                                                       |            |           |                      |  |
|       | Q1             | Q2                                                                                                                                    | C          | 3         | Q4                   |  |
|       | Decode         | Read 'k'                                                                                                                              | Proc<br>da | ess<br>ta | Write to destination |  |
| Exam  | nple:          | PUSHL (                                                                                                                               | )8h        |           |                      |  |

| Before Instruction<br>FSR2H:FSR2L<br>Memory (01ECh) | =<br>= | 01ECh<br>00h |
|-----------------------------------------------------|--------|--------------|
| After Instruction<br>FSR2H:FSR2L<br>Memory (01ECh)  | =<br>= | 01EBh<br>08h |

| SUBFSR   |                | Subtract              | Subtract Literal from FSR                    |      |             |  |  |
|----------|----------------|-----------------------|----------------------------------------------|------|-------------|--|--|
| Synta    | ax:            | SUBFSR                | f, k                                         |      |             |  |  |
| Oper     | ands:          | $0 \le k \le 63$      | 5                                            |      |             |  |  |
|          |                | $f \in [0, 1,$        | 2]                                           |      |             |  |  |
| Oper     | ation:         | FSRf – k              | $\rightarrow$ FSRf                           |      |             |  |  |
| Statu    | s Affected:    | None                  |                                              |      |             |  |  |
| Enco     | ding:          | 1110                  | 1001                                         | ffkk | kkkk        |  |  |
| Desc     | ription:       | The 6-bit             | The 6-bit literal 'k' is subtracted from     |      |             |  |  |
|          |                | the conter<br>by 'f'. | the contents of the FSR specified<br>by 'f'. |      |             |  |  |
| Word     | ls:            | 1                     | 1                                            |      |             |  |  |
| Cycle    | es:            | 1                     |                                              |      |             |  |  |
| QC       | ycle Activity: |                       |                                              |      |             |  |  |
|          | Q1             | Q2                    | Q3                                           |      | Q4          |  |  |
|          | Decode         | Read                  | Proce                                        | SS   | Write to    |  |  |
|          |                | register 'f'          | Data                                         | 1    | destination |  |  |
|          |                |                       |                                              |      |             |  |  |
| Example: |                | SUBFSR                | 2, 23h                                       |      |             |  |  |

| Example:           | SUBFSR | 2, | 23h |
|--------------------|--------|----|-----|
| Before Instruction | n      |    |     |
| FSR2 =             | 03FFh  | ı  |     |
| After Instruction  |        |    |     |
| FSR2 =             | 03DC   | h  |     |
|                    |        |    |     |

| SUB                                                                                                                | ULNK                                                                                                                                      | Subtract Li                                                  | teral fron   | n FSR2 a                              | and Return  |  |
|--------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|--------------|---------------------------------------|-------------|--|
| Synta                                                                                                              | ax:                                                                                                                                       | SUBULNK k                                                    |              |                                       |             |  |
| Oper                                                                                                               | ands:                                                                                                                                     | $0 \le k \le 63$                                             |              |                                       |             |  |
| Oper                                                                                                               | ation:                                                                                                                                    | $\begin{array}{l} FSR2-k \\ (TOS) \rightarrow P \end{array}$ | → FSR2,<br>C |                                       |             |  |
| Statu                                                                                                              | s Affected:                                                                                                                               | None                                                         |              |                                       |             |  |
| Enco                                                                                                               | ding:                                                                                                                                     | 1110                                                         | 1001         | 11kk                                  | kkkk        |  |
| Desc                                                                                                               | Description: The 6-bit literal 'k' is subtracted from the contents of the FSR2. A RETURN is ther executed by loading the PC with the TOS. |                                                              |              |                                       |             |  |
|                                                                                                                    | The instruction takes two cycles to execute; a NOP is performed during the second cycle.                                                  |                                                              |              |                                       |             |  |
| This may be thought of as a special<br>of the SUBFSR instruction, where f<br>(binary '11'): it operates only on FS |                                                                                                                                           |                                                              |              | pecial case<br>here f = 3<br>on FSR2. |             |  |
| Word                                                                                                               | ls:                                                                                                                                       | 1                                                            |              |                                       |             |  |
| Cycle                                                                                                              | es:                                                                                                                                       | 2                                                            |              |                                       |             |  |
| QC                                                                                                                 | ycle Activity:                                                                                                                            |                                                              |              |                                       |             |  |
|                                                                                                                    | Q1                                                                                                                                        | Q2                                                           | (            | 23                                    | Q4          |  |
|                                                                                                                    | Decode                                                                                                                                    | Read                                                         | Pro          | cess                                  | Write to    |  |
|                                                                                                                    |                                                                                                                                           | register 'f                                                  | " Da         | ata                                   | destination |  |
|                                                                                                                    | No                                                                                                                                        | No                                                           | N            | lo                                    | No          |  |

Example: SUBULNK 23h

Operation

Operation Operation

Operation

| Before Instruction |   |       |  |
|--------------------|---|-------|--|
| FSR2               | = | 03FFh |  |
| PC                 | = | 0100h |  |

After Instruction FSR2 = 03DCh PC = (TOS)

© 2009-2016 Microchip Technology Inc.









28-Lead Plastic Small Outline (SO) - Wide, 7.50 mm Body [SOIC]

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



# RECOMMENDED LAND PATTERN

|                          | Units | MILLIMETERS |          |      |
|--------------------------|-------|-------------|----------|------|
| Dimension Limits         |       | MIN         | NOM      | MAX  |
| Contact Pitch            | E     |             | 1.27 BSC |      |
| Contact Pad Spacing      | С     |             | 9.40     |      |
| Contact Pad Width (X28)  | Х     |             |          | 0.60 |
| Contact Pad Length (X28) | Y     |             |          | 2.00 |
| Distance Between Pads    | Gx    | 0.67        |          |      |
| Distance Between Pads    | G     | 7.40        |          |      |

Notes:

1. Dimensioning and tolerancing per ASME Y14.5M

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

Microchip Technology Drawing No. C04-2052A

# APPENDIX B: MIGRATION FROM PIC18F46J50 TO PIC18F47J53

Code for the devices in the PIC18F46J50 family can be migrated to the PIC18F47J53 without many changes. The differences between the two device families are listed in Table B-1.

### TABLE B-1: NOTABLE DIFFERENCES BETWEEN PIC18F47J53 AND PIC18F46J50 FAMILIES

| Characteristic                       | PIC18F47J53 Family                                                           | PIC18F46J50 Family                                                          |
|--------------------------------------|------------------------------------------------------------------------------|-----------------------------------------------------------------------------|
| Max Program Memory                   | 128 Kbytes                                                                   | 64 Kbytes                                                                   |
| Oscillator options                   | PLL can be enabled at start-up with<br>Config bit option                     | Requires firmware to set the PLLEN bit at run time                          |
| SOSC Oscillator Options              | Low-power oscillator option for SOSC,<br>with run-time switch                | Low-power oscillator option for SOSC,<br>only via Configuration bit setting |
| T1CKI Clock Input                    | T1CKI can be used as a clock input<br>without enabling the Timer1 oscillator | No                                                                          |
| INTOSC                               | Up to 8 MHz                                                                  | Up to 8 MHz                                                                 |
| Timers                               | 8                                                                            | 5                                                                           |
| ECCP                                 | 3                                                                            | 2                                                                           |
| CCP                                  | 7                                                                            | 0                                                                           |
| SPI Fosc/8 Master Clock<br>Option    | Yes                                                                          | No                                                                          |
| ADC                                  | 13 Channel, 10/12-bit conversion modes with Special Event Trigger option.    | 13 Channel, 10-bit only                                                     |
| Peripheral Module Disable<br>Bits    | Yes, allowing further power reduction                                        | No                                                                          |
| Band Gap Voltage Reference<br>Output | Yes, enabled on pin RA1 by setting the<br>VBGOE bit (WDTCON<4>)              | No                                                                          |
| REPU/RDPU Pull-Up Enable<br>Bits     | Moved to TRISE register (avoids read,<br>modify, write issues)               | Pull-up bits configured in PORTE register                                   |
| Comparators                          | Three, each with four input-pin selections                                   | Two, each with two input-pin selections                                     |
| Increased Output Drive<br>Strength   | RA0 through RA5, RDx and REx                                                 | No                                                                          |