

Welcome to E-XFL.COM

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

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

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

### Details

E·XFI

| Product Status             | Active                                                                       |
|----------------------------|------------------------------------------------------------------------------|
| Core Processor             | PIC                                                                          |
| Core Size                  | 8-Bit                                                                        |
| Speed                      | 48MHz                                                                        |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART, USB                               |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                        |
| Number of I/O              | 34                                                                           |
| Program Memory Size        | 128KB (64K x 16)                                                             |
| Program Memory Type        | FLASH                                                                        |
| EEPROM Size                | -                                                                            |
| RAM Size                   | 3.8K x 8                                                                     |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 2.75V                                                                   |
| Data Converters            | A/D 13x10b/12b                                                               |
| Oscillator Type            | Internal                                                                     |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                            |
| Mounting Type              | Surface Mount                                                                |
| Package / Case             | 44-TQFP                                                                      |
| Supplier Device Package    | 44-TQFP (10x10)                                                              |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18lf47j53t-i-pt |
|                            |                                                                              |

Email: info@E-XFL.COM

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

# 3.2.3 EXTERNAL CLOCK INPUT

The EC and ECPLL Oscillator modes require an external clock source to be connected to the OSC1 pin. There is no oscillator start-up time required after a Power-on Reset (POR) or after an exit from Sleep mode.

In the EC Oscillator mode, the oscillator frequency divided by 4, is available on the OSC2 pin. In the ECPLL Oscillator mode, the PLL output, divided by 4, is available on the OSC2 pin. This signal may be used for test purposes or to synchronize other logic. Figure 3-3 displays the pin connections for the EC Oscillator mode.

### FIGURE 3-3: EXTERNAL CLOCK INPUT OPERATION (EC AND ECPLL CONFIGURATION)



# 3.2.4 PLL FREQUENCY MULTIPLIER

PIC18F47J53 family devices include a PLL circuit. This is provided specifically for USB applications with lower speed oscillators and can also be used as a microcontroller clock source.

The PLL can be enabled in HSPLL, ECPLL, INTOSCPLL and INTOSCPLLO Oscillator modes by setting the PLLEN bit (OSCTUNE<6>). It is designed to produce a fixed 96 MHz reference clock from a fixed 4 MHz input. The output can then be divided and used for both the USB and the microcontroller core clock. Because the PLL has a fixed frequency input and output, there are eight prescaling options to match the oscillator input frequency to the PLL. This prescaler allows the PLL to be used with crystals, resonators and external clocks, which are integer multiple frequencies of 4 MHz. For example, a 12 MHz crystal could be used in a prescaler Divide-by-Three mode to drive the PLL.

There is also a CPU divider, which can be used to derive the microcontroller clock from the PLL. This allows the USB peripheral and microcontroller to use the same oscillator input and still operate at different clock speeds. The CPU divider can reduce the incoming frequency by a factor of 1, 2, 3 or 6.

## 3.2.5 INTERNAL OSCILLATOR BLOCK

The PIC18F47J53 family devices include an internal oscillator block which generates two different clock signals; either can be used as the microcontroller's clock source. The internal oscillator may eliminate the need for external oscillator circuits on the OSC1 and/or OSC2 pins.

The main output (INTOSC) is an 8 MHz clock source which can be used to directly drive the device clock. It also drives the INTOSC postscaler which can provide a range of clock frequencies from 31 kHz to 8 MHz. Additionally, the INTOSC may be used in conjunction with the PLL to generate clock frequencies up to 48 MHz.

The other clock source is the internal RC oscillator (INTRC) which provides a nominal 31 kHz output. INTRC is enabled if it is selected as the device clock source. It is also enabled automatically when any of the following are enabled:

- · Power-up Timer
- Fail-Safe Clock Monitor
- · Watchdog Timer
- · Two-Speed Start-up

These features are discussed in larger detail in **Section 28.0 "Special Features of the CPU"**.

The clock source frequency (INTOSC direct, INTRC direct or INTOSC postscaler) is selected by configuring the IRCF bits of the OSCCON register (page 39).

## 3.6 Reference Clock Output

In addition to the peripheral clock/4 output in certain oscillator modes, the device clock in the PIC18F47J53 family can also be configured to provide a reference clock output signal to a port pin. This feature is available in all oscillator configurations and allows the user to select a greater range of clock submultiples to drive external devices in the application.

This reference clock output is controlled by the REFOCON register (Register 3-4). Setting the ROON bit (REFOCON<7>) makes the clock signal available on the REFO (RB2) pin. The RODIV<3:0> bits enable the selection of 16 different clock divider options.

The ROSSLP and ROSEL bits (REFOCON<5:4>) control the availability of the reference output during Sleep mode. The ROSEL bit determines if the oscillator is on OSC1 and OSC2, or the current system clock source is used for the reference clock output. The ROSSLP bit determines if the reference source is available on RB2 when the device is in Sleep mode.

To use the reference clock output in Sleep mode, both the ROSSLP and ROSEL bits must be set. The device clock must also be configured for an EC or HS mode; otherwise, the oscillator on OSC1 and OSC2 will be powered down when the device enters Sleep mode. Clearing the ROSEL bit allows the reference output frequency to change as the system clock changes during any clock switches.

### REGISTER 3-4: REFOCON: REFERENCE OSCILLATOR CONTROL REGISTER (BANKED F3Dh)

| R/W-0                                                                          | U-0                                  | R/W-0                                | R/W-0           | R/W-0            | R/W-0              | R/W-0             | R/W-0            |  |  |
|--------------------------------------------------------------------------------|--------------------------------------|--------------------------------------|-----------------|------------------|--------------------|-------------------|------------------|--|--|
| ROON                                                                           |                                      | ROSSLP                               | ROSEL           | RODIV3           | RODIV2             | RODIV1            | RODIV0           |  |  |
| bit 7                                                                          |                                      |                                      |                 |                  |                    |                   | bit 0            |  |  |
|                                                                                |                                      |                                      |                 |                  |                    |                   |                  |  |  |
| Legend:                                                                        |                                      |                                      |                 |                  |                    |                   |                  |  |  |
| R = Reada                                                                      |                                      | W = Writable k                       | bit             | -                | nented bit, read   |                   |                  |  |  |
| -n = Value                                                                     | at POR                               | '1' = Bit is set                     |                 | '0' = Bit is cle | ared               | x = Bit is unkr   | nown             |  |  |
| bit 7                                                                          | ROON: Refe                           | rence Oscillator                     | Output Enab     | le bit           |                    |                   |                  |  |  |
|                                                                                |                                      | e oscillator is en                   | -               |                  |                    |                   |                  |  |  |
|                                                                                |                                      | e oscillator is dis                  |                 |                  |                    |                   |                  |  |  |
| bit 6                                                                          | Unimplemen                           | ted: Read as '0                      | ,               |                  |                    |                   |                  |  |  |
| bit 5                                                                          | ROSSLP: Re                           | eference Oscillat                    | or Output Sto   | op in Sleep bit  |                    |                   |                  |  |  |
|                                                                                |                                      | e oscillator cont                    |                 |                  |                    |                   |                  |  |  |
|                                                                                | 0 = Reference                        | e oscillator is dis                  | sabled in Slee  | ер               |                    |                   |                  |  |  |
| bit 4                                                                          |                                      | erence Oscillato                     |                 |                  |                    |                   |                  |  |  |
|                                                                                |                                      | oscillator crystal                   |                 |                  |                    |                   | <i>.</i>         |  |  |
|                                                                                | -                                    | lock (Fosc) is us                    |                 |                  | e clock reflects a | ny clock switchii | ng of the device |  |  |
| bit 3-0                                                                        |                                      | : Reference Osc                      |                 |                  |                    |                   |                  |  |  |
|                                                                                |                                      | clock value divi<br>clock value divi |                 |                  |                    |                   |                  |  |  |
|                                                                                |                                      | clock value divi                     |                 |                  |                    |                   |                  |  |  |
|                                                                                |                                      | clock value divi                     |                 |                  |                    |                   |                  |  |  |
|                                                                                |                                      | clock value divi                     | •               |                  |                    |                   |                  |  |  |
|                                                                                |                                      | clock value divi                     |                 |                  |                    |                   |                  |  |  |
|                                                                                |                                      | clock value divi                     | •               |                  |                    |                   |                  |  |  |
|                                                                                |                                      | clock value divi                     |                 |                  |                    |                   |                  |  |  |
|                                                                                |                                      | clock value divi<br>clock value divi |                 |                  |                    |                   |                  |  |  |
|                                                                                |                                      |                                      | •               |                  |                    |                   |                  |  |  |
| 0101 = Base clock value divided by 32<br>0100 = Base clock value divided by 16 |                                      |                                      |                 |                  |                    |                   |                  |  |  |
|                                                                                |                                      | clock value divi                     |                 |                  |                    |                   |                  |  |  |
|                                                                                | 0010 = Base clock value divided by 4 |                                      |                 |                  |                    |                   |                  |  |  |
|                                                                                | 0001 = Base clock value divided by 2 |                                      |                 |                  |                    |                   |                  |  |  |
|                                                                                | 0000 <b>= Base</b>                   | clock value                          |                 |                  |                    |                   |                  |  |  |
| Note 1                                                                         | The envetel escill                   | ator much ha an                      | المعادمة والمعا |                  | hito, the emistel  | maintaina tha     |                  |  |  |

**Note 1:** The crystal oscillator must be enabled using the FOSC<2:0> bits; the crystal maintains the operation in Sleep mode.

# 5.5 Configuration Mismatch (CM)

The Configuration Mismatch (CM) Reset is designed to detect, and attempt to recover from, random memory corrupting events. These include Electrostatic Discharge (ESD) events, which can cause widespread single bit changes throughout the device and result in catastrophic failure.

In PIC18FXXJ Flash devices, the device Configuration registers (located in the configuration memory space) are continuously monitored during operation by comparing their values to complimentary shadow registers. If a mismatch is detected between the two sets of registers, a CM Reset automatically occurs. These events are captured by the CM bit (RCON<5>). The state of the bit is set to '0' whenever a CM event occurs; it does not change for any other Reset event.

A CM Reset behaves similarly to a MCLR, RESET instruction, WDT time-out or Stack Event Resets. As with all hard and power Reset events, the device Configuration Words are reloaded from the Flash Configuration Words in program memory as the device restarts.

### 5.6 Power-up Timer (PWRT)

PIC18F47J53 family devices incorporate an on-chip PWRT to help regulate the POR process. The PWRT is always enabled. The main function is to ensure that the device voltage is stable before code is executed.

The Power-up Timer (PWRT) of the PIC18F47J53 family devices is a 5-bit counter which uses the INTRC source as the clock input. This yields an approximate time interval of  $32 \times 32 \ \mu s = 1 \ ms$ . While the PWRT is counting, the device is held in Reset.

The power-up time delay depends on the INTRC clock and will vary from chip-to-chip due to temperature and process variation. See DC parameter 33 (TPWRT) for details.

### 5.6.1 TIME-OUT SEQUENCE

The PWRT time-out is invoked after the POR pulse has cleared. The total time-out will vary based on the status of the PWRT. Figure 5-2, Figure 5-3, Figure 5-4 and Figure 5-5 all depict time-out sequences on power-up with the PWRT.

Since the time-outs occur from the POR pulse, if  $\overline{\text{MCLR}}$ is kept low long enough, the PWRT will expire. Bringing  $\overline{\text{MCLR}}$  high will begin execution immediately if a clock source is available (Figure 5-4). This is useful for testing purposes or to synchronize more than one PIC18F device operating in parallel.

# FIGURE 5-2: TIME-OUT SEQUENCE ON POWER-UP (MCLR TIED TO VDD, VDD RISE < TPWRT)



### 6.4.3.2 FSR Registers and POSTINC, POSTDEC, PREINC and PLUSW

In addition to the INDF operand, each FSR register pair also has four additional indirect operands. Like INDF, these are "virtual" registers that cannot be indirectly read or written to. Accessing these registers actually accesses the associated FSR register pair, but also performs a specific action on its stored value. They are:

- POSTDEC: accesses the FSR value, then automatically decrements it by '1' thereafter
- POSTINC: accesses the FSR value, then automatically increments it by '1' thereafter
- PREINC: increments the FSR value by '1', then uses it in the operation
- PLUSW: adds the signed value of the W register (range of 127 to 128) to that of the FSR and uses the new value in the operation

In this context, accessing an INDF register uses the value in the FSR registers without changing them. Similarly, accessing a PLUSW register gives the FSR value offset by the value in the W register; neither value is actually changed in the operation. Accessing the other virtual registers changes the value of the FSR registers.

Operations on the FSRs with POSTDEC, POSTINC and PREINC affect the entire register pair; that is, rollovers of the FSRnL register from FFh to 00h carry over to the FSRnH register. On the other hand, results of these operations do not change the value of any flags in the STATUS register (e.g., Z, N, OV, etc.).

The PLUSW register can be used to implement a form of Indexed Addressing in the data memory space. By manipulating the value in the W register, users can reach addresses that are fixed offsets from pointer addresses. In some applications, this can be used to implement some powerful program control structure, such as software stacks, inside of data memory.

# 6.4.3.3 Operations by FSRs on FSRs

Indirect Addressing operations that target other FSRs or virtual registers represent special cases. For example, using an FSR to point to one of the virtual registers will not result in successful operations. As a specific case, assume that FSR0H:FSR0L contains FE7h, the address of INDF1. Attempts to read the value of the INDF1, using INDF0 as an operand, will return 00h. Attempts to write to INDF1, using INDF0 as the operand, will result in a NOP.

On the other hand, using the virtual registers to write to an FSR pair may not occur as planned. In these cases, the value will be written to the FSR pair but without any incrementing or decrementing. Thus, writing to INDF2 or POSTDEC2 will write the same value to the FSR2H:FSR2L.

Since the FSRs are physical registers mapped in the SFR space, they can be manipulated through all direct operations. Users should proceed cautiously when working on these registers, particularly if their code uses Indirect Addressing.

Similarly, operations by Indirect Addressing are generally permitted on all other SFRs. Users should exercise appropriate caution that they do not inadvertently change settings that might affect the operation of the device.

# 6.5 Program Memory and the Extended Instruction Set

The operation of program memory is unaffected by the use of the extended instruction set.

Enabling the extended instruction set adds five additional two-word commands to the existing PIC18 instruction set: ADDFSR, CALLW, MOVSF, MOVSS and SUBFSR. These instructions are executed as described in Section 6.2.4 "Two-Word Instructions".

# 10.4 PORTC, TRISC and LATC Registers

PORTC is an 8-bit wide, bidirectional port. The corresponding Data Direction register is TRISC. Setting a TRISC bit (= 1) will make the corresponding PORTC pin an input (i.e., put the corresponding output driver in a high-impedance mode). Clearing a TRISC bit (= 0) will make the corresponding PORTC pin an output (i.e., put the contents of the output latch on the selected pin).

The Data Latch register (LATC) is also memory mapped. Read-modify-write operations on the LATC register read and write the latched output value for PORTC.

PORTC is multiplexed with several peripheral functions (see Table ). The pins have Schmitt Trigger input buffers.

When enabling peripheral functions, care should be taken in defining TRIS bits for each PORTC pin. Some peripherals override the TRIS bit to make a pin an output, while other peripherals override the TRIS bit to make a pin an input. The user should refer to the corresponding peripheral section for additional information.

Pins RC4 and RC5 are multiplexed with the USB module. Depending on the configuration of the module, they can serve as the differential data lines for the on-chip USB transceiver, or the data inputs from an external USB transceiver. When used as general purpose inputs, both RC4 and RC5 input buffers depend on the level of the voltage applied to the VUSB pin, instead of VDD like all other general purpose I/O pins. Therefore, if the RC4 or RC5 general purpose input capability will be used, the VUSB pin should not be left floating.

Unlike other PORTC pins, RC4 and RC5 do not have TRISC bits associated with them. As digital ports, they can only function as digital inputs. When configured for USB operation, the data direction is determined by the configuration and status of the USB module at a given time. If an external transceiver is used, RC4 and RC5 always function as inputs from the transceiver. If the onchip transceiver is used, the data direction is determined by the operation being performed by the module at that time. Note: On a Power-on Reset, PORTC pins (except RC2, RC4 and RC5) are configured as digital inputs. RC2 will default as an analog input (controlled by the ANCON1 register). To use pins RC4 and RC5 as digital inputs, the USB module must be disabled (UCON<3> = 0) and the on-chip USB transceiver must be disabled (UCFG<3> = 1). The internal USB transceiver has a POR value of enabled.

The contents of the TRISC register are affected by peripheral overrides. Reading TRISC always returns the current contents, even though a peripheral device may be overriding one or more of the pins.

### EXAMPLE 10-4: INITIALIZING PORTC

| CLRF  | PORTC     | ; Initialize PORTC by      |
|-------|-----------|----------------------------|
|       |           | ; clearing output          |
|       |           | ; data latches             |
| CLRF  | LATC      | ; Alternate method         |
|       |           | ; to clear output          |
|       |           | ; data latches             |
| MOVLW | 0x3F      | ; Value used to            |
|       |           | ; initialize data          |
|       |           | ; direction                |
| MOVWF | TRISC     | ; Set RC<5:0> as inputs    |
|       |           | ; RC<7:6> as outputs       |
| MOVLB | 0x0F      | ; ANCON register is not in |
|       |           | Access Bank                |
| BSF   | ANCON1, P | CFG11                      |
|       |           | ;Configure RC2/AN11 as     |
|       |           | digital input              |
|       |           |                            |

# 13.0 TIMER1 MODULE

The Timer1 timer/counter module incorporates these features:

- Software selectable operation as a 16-bit timer or counter
- Readable and writable 8-bit registers (TMR1H and TMR1L)
- Selectable clock source (internal or external) with device clock or Timer1 oscillator internal options
- Interrupt-on-overflow
- Reset on ECCP Special Event Trigger
- Device clock status flag (SOSCRUN)
- · Timer with gated control

Figure 13-1 displays a simplified block diagram of the Timer1 module.

The module incorporates its own low-power oscillator to provide an additional clocking option. The Timer1 oscillator can also be used as a low-power clock source for the microcontroller in power-managed operation.

Timer1 is controlled through the T1CON Control register (Register 13-1). It also contains the Timer1 Oscillator Enable bit (T1OSCEN). Timer1 can be enabled or disabled by setting or clearing control bit, TMR1ON (T1CON<0>).

The Fosc clock source (TMR1CS<1:0> = 01) should not be used with the ECCP capture/compare features. If the timer will be used with the capture or compare features, always select one of the other timer clocking options.

### REGISTER 13-1: T1CON: TIMER1 CONTROL REGISTER (ACCESS FCDh)

| R/W-0   | R/W-0   | R/W-0   | R/W-0   | R/W-0   | R/W-0  | R/W-0 | R/W-0  |
|---------|---------|---------|---------|---------|--------|-------|--------|
| TMR1CS1 | TMR1CS0 | T1CKPS1 | T1CKPS0 | T1OSCEN | T1SYNC | RD16  | TMR10N |
| bit 7   |         |         |         |         |        |       | bit 0  |

| Legend:          |                                                                            |                                                                                                                                       |                                                                                  |                                 |
|------------------|----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|---------------------------------|
| R = Readable bit |                                                                            | W = Writable bit                                                                                                                      | U = Unimplemented bit,                                                           | read as '0'                     |
| -n = Valu        | e at POR                                                                   | '1' = Bit is set                                                                                                                      | '0' = Bit is cleared                                                             | x = Bit is unknown              |
| bit 7-6          | 10 = Timer<br>01 = Timer                                                   | <b>1:0&gt;:</b> Timer1 Clock Source S<br>1 clock source is the T1OSC<br>1 clock source is the system<br>1 clock source is the instruc | C or T1CKI pin<br>i clock (Fosc) <sup>(1)</sup>                                  |                                 |
| bit 5-4          | 11 = 1:8 P<br>10 = 1:4 P<br>01 = 1:2 P                                     | I:0>: Timer1 Input Clock Pre<br>rescale value<br>rescale value<br>rescale value<br>rescale value<br>rescale value                     | escale Select bits                                                               |                                 |
| bit 3            | <u>When TMF</u><br>1 = Power<br>0 = Timer1<br><u>When TMF</u><br>1 = Power |                                                                                                                                       | elect bit<br>and supply the Timer1 clock fro<br>clock is from the T1CKI input pi |                                 |
| bit 2            | <u>TMR1CS&lt;</u><br>1 = Do not<br>0 = Synchr<br><u>TMR1CS&lt;</u>         | synchronize external clock i<br>onize external clock input<br>1:0> = 0x:                                                              |                                                                                  | > = 0x.                         |
| bit 1            | 1 = Enable                                                                 | Bit Read/Write Mode Enable<br>es register read/write of Time<br>es register read/write of Time                                        | er1 in one 16-bit operation                                                      |                                 |
| bit 0            | <b>TMR1ON:</b><br>1 = Enable<br>0 = Stops                                  |                                                                                                                                       |                                                                                  |                                 |
| Note 1:          | The Fosc cl                                                                | ock source should not be sele                                                                                                         | cted if the timer will be used with                                              | the ECCP capture/compare featur |

2: The Timer1 oscillator crystal driver is powered whenever T1OSCEN (T1CON<3>) or T3OSCEN (T3CON<3>) = 1. The circuit is enabled by the logical OR of these two bits. When disabled, the inverter and feedback resistor are disabled to eliminate power drain. The TMR1ON and TMR3ON bits do not have to be enabled to power up the crystal driver.

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





**EXAMPLE OF** 

### 19.4.6 PROGRAMMABLE DEAD-BAND DELAY MODE

In half-bridge applications, where all power switches are modulated at the PWM frequency, the power switches normally require more time to turn off than to turn on. If both the upper and lower power switches are switched at the same time (one turned on and the other turned off), both switches may be on for a short period until one switch completely turns off. During this brief interval, a very high current (shoot-through current) will flow through both power switches, shorting the bridge supply. To avoid this potentially destructive shoot-through current from flowing during switching, turning on either of the power switches is normally delayed to allow the other switch to completely turn off.

In Half-Bridge mode, a digitally programmable, dead-band delay is available to avoid shoot-through current from destroying the bridge power switches. The delay occurs at the signal transition from the non-active state to the active state. For an illustration, see Figure 19-14. The lower seven bits of the associated ECCPxDEL register (Register 19-5) sets the delay period in terms of microcontroller instruction cycles (TcY or 4 Tosc).

# HALF-BRIDGE PWM OUTPUT

**FIGURE 19-14:** 

# FIGURE 19-15: EXAMPLE OF HALF-BRIDGE APPLICATIONS



# PIC18F47J53

### REGISTER 19-5: ECCPxDEL: ECCP1/2/3 ENHANCED PWM CONTROL REGISTER (1, ACCESS FBDh; 2, FB7h; 3, BANKED F18h)

| R/W-0  | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
|--------|-------|-------|-------|-------|-------|-------|-------|
| PxRSEN | PxDC6 | PxDC5 | PxDC4 | PxDC3 | PxDC2 | PxDC1 | PxDC0 |
| bit 7  |       |       |       |       |       |       | bit 0 |
|        |       |       |       |       |       |       |       |

| 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 7 **PxRSEN:** PWM Restart Enable bit

- 1 = Upon auto-shutdown, the ECCPxASE bit clears automatically once the shutdown event goes away; the PWM restarts automatically
- 0 = Upon auto-shutdown, ECCPxASE must be cleared by software to restart the PWM

bit 6-0 **PxDC<6:0>:** PWM Delay Count bits

PxDCn = Number of Fosc/4 (4 \* Tosc) cycles between the scheduled time when a PWM signal **should** transition active and the **actual** time it transitions active.

## 19.4.7 PULSE STEERING MODE

In Single Output mode, pulse steering allows any of the PWM pins to be the modulated signal. Additionally, the same PWM signal can simultaneously be available on multiple pins.

Once the Single Output mode is selected (CCPxM<3:2> = 11 and PxM<1:0> = 00 of the CCPxCON register), the user firmware can bring out the same PWM signal to one, two, three or four output pins by setting the appropriate STR<D:A> bits (PSTRxCON<3:0>), as provided in Table 19-3.

Note: The associated TRIS bits must be set to output ('0'), to enable the pin output driver, in order to see the PWM signal on the pin.

While the PWM Steering mode is active, the CCPxM<1:0> bits (CCPxCON<1:0>) select the PWM output polarity for the Px<D:A> pins.

The PWM auto-shutdown operation also applies to PWM Steering mode, as described in **Section 19.4.4 "Enhanced PWM Auto-shutdown mode"**. An auto-shutdown event will only affect pins that have PWM outputs enabled.

### 20.3.7 SLAVE MODE

In Slave mode, the data is transmitted and received as the external clock pulses appear on SCKx. When the last bit is latched, the SSPxIF interrupt flag bit is set.

While in Slave mode, the external clock is supplied by the external clock source on the SCKx pin. This external clock must meet the minimum high and low times as specified in the electrical specifications.

While in Sleep mode, the slave can transmit/receive data. When a byte is received, the device can be configured to wake-up from Sleep.

### 20.3.8 SLAVE SELECT SYNCHRONIZATION

The  $\overline{SSx}$  pin allows a Synchronous Slave mode. The SPI must be in Slave mode with the  $\overline{SSx}$  pin control enabled (SSPxCON1<3:0> = 04h). When the  $\overline{SSx}$  pin is low, transmission and reception are enabled and the SDOx pin is driven. When the  $\overline{SSx}$  pin goes high, the SDOx pin is no longer driven, even if in the middle of a

transmitted byte and becomes a floating output. External pull-up/pull-down resistors may be desirable depending on the application.

| Note 1: | When the SPI is in Slave mode                    | with   |
|---------|--------------------------------------------------|--------|
|         | the SSx pin control ena                          | abled  |
|         | (SSPxCON1<3:0> = 0100), the                      | SPI    |
|         | module will reset if the $\overline{SSx}$ pin is | set to |
|         | VDD.                                             |        |
|         |                                                  |        |

2: If the SPI is used in Slave mode with CKE set, then the SSx pin control must be enabled.

When the SPI module resets, the bit counter is forced to '0'. This can be done by either forcing the SSx pin to a high level or clearing the SSPEN bit.

To emulate two-wire communication, the SDOx pin can be connected to the SDIx pin. When the SPI needs to operate as a receiver, the SDOx pin can be configured as an input. This disables transmissions from the SDOx. The SDIx can always be left as an input (SDIx function) since it cannot create a bus conflict.



FIGURE 20-4: SLAVE SYNCHRONIZATION WAVEFORM



# PIC18F47J53



### FIGURE 21-2: BRG OVERFLOW SEQUENCE



# 23.5 USB Interrupts

The USB module can generate multiple interrupt conditions. To accommodate all of these interrupt sources, the module is provided with its own interrupt logic structure, similar to that of the microcontroller. USB interrupts are enabled with one set of control registers and trapped with a separate set of flag registers. All sources are funneled into a single USB interrupt request, USBIF (PIR2<4>), in the microcontroller's interrupt logic. Figure 23-7 provides the interrupt logic for the USB module. There are two layers of interrupt registers in the USB module. The top level consists of overall USB status interrupts; these are enabled and flagged in the UIE and UIR registers, respectively. The second level consists of USB error conditions, which are enabled and flagged in the UEIR and UEIE registers. An interrupt condition in any of these triggers a USB Error Interrupt Flag (UERRIF) in the top level.

Interrupts may be used to trap routine events in a USB transaction. Figure 23-8 provides some common events within a USB frame and its corresponding interrupts.



### FIGURE 23-8: EXAMPLE OF A USB TRANSACTION AND INTERRUPT EVENTS



### REGISTER 24-2: CMSTAT: COMPARATOR STATUS REGISTER (ACCESS F70h)

| U-0                            | U-0       | U-0              | U-0 | U-0               | R-1              | R-1             | R-1   |
|--------------------------------|-----------|------------------|-----|-------------------|------------------|-----------------|-------|
| —                              | _         | -                | _   | —                 | COUT3            | COUT2           | COUT1 |
| bit 7                          |           |                  |     |                   |                  |                 | bit 0 |
|                                |           |                  |     |                   |                  |                 |       |
| Legend:                        |           |                  |     |                   |                  |                 |       |
| R = Readable                   | bit       | W = Writable b   | oit | U = Unimplem      | nented bit, read | l as '0'        |       |
| -n = Value at POR '1' = Bit is |           | '1' = Bit is set |     | '0' = Bit is clea | ared             | x = Bit is unkr | iown  |
|                                |           |                  |     |                   |                  |                 |       |
| bit 7-3                        | Unimpleme | nted: Read as '0 | )'  |                   |                  |                 |       |

bit 2-0 COUT<3:1>: Comparator x Status bits

(For example, COUT3 gives the status for Comparator 3.)

If CPOL (CMxCON<5>) = 0 non-inverted polarity):

1 = Comparator VIN+ > VIN-

0 = Comparator VIN+ < VIN-

If CPOL = 1 (inverted polarity):

1 = Comparator VIN+ < VIN-

0 = Comparator VIN+ > VIN-

### REGISTER 28-8: CONFIG4H: CONFIGURATION REGISTER 4 HIGH (BYTE ADDRESS 300007h)

| U-1         | U-1 | U-1 | U-1 | R/WO-1  | U-0 | R/WO-1 | R/WO-1 |  |
|-------------|-----|-----|-----|---------|-----|--------|--------|--|
| —           | —   | —   | —   | LS48MHZ |     | WPEND  | WPDIS  |  |
| bit 7 bit 0 |     |     |     |         |     |        |        |  |

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

| bit 7-4 | Unimplemented: Program the corresponding Flash Configuration bit to '1'                                                                                                                                                                   |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 3   | LS48MHZ: Low-Speed USB Clock Selection                                                                                                                                                                                                    |
|         | 1 = 48-MHz system clock is expected; divide-by-8 generates low-speed USB clock                                                                                                                                                            |
|         | 0 = 24-MHz system clock is expected; divide-by-4 generates low-speed USB clock                                                                                                                                                            |
| bit 2   | Unimplemented: Read as '0'                                                                                                                                                                                                                |
| bit 1   | WPEND: Write-Protect Disable bit                                                                                                                                                                                                          |
|         | <ul> <li>1 = Flash pages, WPFP&lt;6:0&gt; to (Configuration Words page), are write/erase protected</li> <li>0 = Flash pages 0 to WPFP&lt;6:0&gt; are write/erase-protected</li> </ul>                                                     |
| bit 0   | WPDIS: Write-Protect Disable bit                                                                                                                                                                                                          |
|         | <ul> <li>1 = WPFP&lt;5:0&gt;, WPEND and WPCFG bits are ignored; all Flash memory may be erased or written</li> <li>0 = WPFP&lt;5:0&gt;, WPEND and WPCFG bits enabled; erase/write-protect is active for the selected region(s)</li> </ul> |

# REGISTER 28-9: DEVID1: DEVICE ID REGISTER 1 FOR PIC18F47J53 FAMILY DEVICES (BYTE ADDRESS 3FFFFEh)

| R     | R    | R    | R    | R    | R    | R    | R     |
|-------|------|------|------|------|------|------|-------|
| DEV2  | DEV1 | DEV0 | REV4 | REV3 | REV2 | REV1 | REV0  |
| bit 7 |      |      |      |      |      |      | bit 0 |

| 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 7-5 DEV<2:0>: Device ID bits

These bits are used with DEV<10:3> bits in Device ID Register 2 to identify the part number. See Register 28-10.

bit 4-0 **REV<4:0>:** Revision ID bits These bits are used to indicate the device revision.

# 28.4 Two-Speed Start-up

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

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

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



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

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

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

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

# 28.5 Fail-Safe Clock Monitor

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

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

# PIC18F47J53

| BNO                                                            | v                                                                                      | Branch if N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Branch if Not Overflow                                                                                                                                                                                                   |            |                |  |  |  |
|----------------------------------------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------------|--|--|--|
| Synta                                                          | ax:                                                                                    | BNOV n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | BNOV n                                                                                                                                                                                                                   |            |                |  |  |  |
| Oper                                                           | ands:                                                                                  | -128 ≤ n ≤ 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 127                                                                                                                                                                                                                      |            |                |  |  |  |
| Oper                                                           | ation:                                                                                 | if Overflow<br>(PC) + 2 + 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ,                                                                                                                                                                                                                        |            |                |  |  |  |
| Statu                                                          | s Affected:                                                                            | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                          |            |                |  |  |  |
| Enco                                                           | ding:                                                                                  | 1110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0101                                                                                                                                                                                                                     | nnnn       | nnnn           |  |  |  |
| Desc                                                           | ription:                                                                               | If the Overfiprogram with the second se |                                                                                                                                                                                                                          | )', then t | he             |  |  |  |
|                                                                |                                                                                        | added to the<br>incremented<br>instruction,<br>PC + 2 + 2r                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | The 2's complement number '2n' is<br>added to the PC. Since the PC will have<br>incremented to fetch the next<br>instruction, the new address will be<br>PC + 2 + 2n. This instruction is then a<br>2-cycle instruction. |            |                |  |  |  |
| Word                                                           | ls:                                                                                    | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                          |            |                |  |  |  |
| Cycle                                                          | es:                                                                                    | 1(2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                          |            |                |  |  |  |
| Q C<br>If Ju                                                   | ycle Activity:<br>mp:                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                          |            |                |  |  |  |
|                                                                | Q1                                                                                     | Q2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Q3                                                                                                                                                                                                                       |            | Q4             |  |  |  |
|                                                                | Decode                                                                                 | Read literal<br>'n'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Process<br>Data                                                                                                                                                                                                          | s V        | /rite to<br>PC |  |  |  |
|                                                                | No<br>operation                                                                        | No<br>operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | No<br>operatio                                                                                                                                                                                                           | n op       | No<br>eration  |  |  |  |
| lf No                                                          | o Jump:                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                          |            |                |  |  |  |
|                                                                | Q1                                                                                     | Q2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Q3                                                                                                                                                                                                                       |            | Q4             |  |  |  |
|                                                                | Decode                                                                                 | Read literal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Process                                                                                                                                                                                                                  |            | No             |  |  |  |
|                                                                |                                                                                        | 'n'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Data                                                                                                                                                                                                                     | ορ         | eration        |  |  |  |
| <u>Exan</u>                                                    | nple:                                                                                  | HERE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | BNOV Ju                                                                                                                                                                                                                  | ump        |                |  |  |  |
| Before Instruction<br>PC = address (HERE)<br>After Instruction |                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                          |            |                |  |  |  |
|                                                                | If Overflow = 0;<br>PC = address (Jump)<br>If Overflow = 1;<br>PC = address (HERE + 2) |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                          |            |                |  |  |  |

| BNZ            |                      | Branch if N                                                | Branch if Not Zero                                                                                                                                                                                                       |           |                |  |  |
|----------------|----------------------|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----------------|--|--|
| Syntax         | x:                   | BNZ n                                                      | BNZ n                                                                                                                                                                                                                    |           |                |  |  |
| Opera          | ands:                | -128 ≤ n ≤ 1                                               | 27                                                                                                                                                                                                                       |           |                |  |  |
| Opera          | ation:               | if Zero bit is<br>(PC) + 2 + 2                             | - ,                                                                                                                                                                                                                      |           |                |  |  |
| Status         | Affected:            | None                                                       |                                                                                                                                                                                                                          |           |                |  |  |
| Encod          | ling:                | 1110                                                       | 0001                                                                                                                                                                                                                     | nnnn      | nnnn           |  |  |
| Descri         | iption:              | If the Zero b<br>will branch.                              | oit is '0', t                                                                                                                                                                                                            | hen the p | rogram         |  |  |
|                |                      | added to the<br>incremented<br>instruction,<br>PC + 2 + 2r | The 2's complement number '2n' is<br>added to the PC. Since the PC will have<br>incremented to fetch the next<br>instruction, the new address will be<br>PC + 2 + 2n. This instruction is then a<br>2-cycle instruction. |           |                |  |  |
| Words          | <b>S</b> :           | 1                                                          | 1                                                                                                                                                                                                                        |           |                |  |  |
| Cycles         | S:                   | 1(2)                                                       | 1(2)                                                                                                                                                                                                                     |           |                |  |  |
| Q Cy<br>If Jun | cle Activity:<br>np: |                                                            |                                                                                                                                                                                                                          |           |                |  |  |
|                | Q1                   | Q2                                                         | Q3                                                                                                                                                                                                                       |           | Q4             |  |  |
|                | Decode               | Read literal<br>'n'                                        | Proces<br>Data                                                                                                                                                                                                           | -         | Vrite to<br>PC |  |  |
|                | No                   | No                                                         | No                                                                                                                                                                                                                       |           | No             |  |  |
| L              | operation            | operation                                                  | operati                                                                                                                                                                                                                  | on op     | peration       |  |  |
| lf No          | Jump:                |                                                            |                                                                                                                                                                                                                          |           |                |  |  |
| -              | Q1                   | Q2                                                         | Q3                                                                                                                                                                                                                       |           | Q4             |  |  |
|                | Decode               | Read literal                                               | Proces                                                                                                                                                                                                                   |           | No             |  |  |
| L              |                      | 'n'                                                        | Data                                                                                                                                                                                                                     | op        | peration       |  |  |
| Exam           | <u>ple:</u>          | HERE                                                       | BNZ J                                                                                                                                                                                                                    | ſump      |                |  |  |

| PC<br>After Instruction        | =           | address (HERE)                                   |
|--------------------------------|-------------|--------------------------------------------------|
| If Zero<br>PC<br>If Zero<br>PC | =<br>=<br>= | 0;<br>address (Jump)<br>1;<br>address (HERE + 2) |

| CAL         | LW                                                                                    | Subroutine                                                                                                                           | Subroutine Call Using WREG                                                                                                                                                                                                                                                                                                                                                                      |                 |  |  |  |
|-------------|---------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|--|--|
| Synta       | ax:                                                                                   | CALLW                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                 |                 |  |  |  |
| Oper        | ands:                                                                                 | None                                                                                                                                 | None                                                                                                                                                                                                                                                                                                                                                                                            |                 |  |  |  |
| Oper        | ation:                                                                                | (W) → PCL<br>(PCLATH) -                                                                                                              | $(PC + 2) \rightarrow TOS,$<br>$(W) \rightarrow PCL,$<br>$(PCLATH) \rightarrow PCH,$<br>$(PCLATU) \rightarrow PCU$                                                                                                                                                                                                                                                                              |                 |  |  |  |
| Statu       | s Affected:                                                                           | None                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                 |                 |  |  |  |
| Enco        | ding:                                                                                 | 0000                                                                                                                                 | 0000 000                                                                                                                                                                                                                                                                                                                                                                                        | 01 0100         |  |  |  |
| Desc        | ription                                                                               | pushed ont<br>contents of<br>existing val<br>contents of<br>latched into<br>respectively<br>executed as<br>new next in<br>Unlike CAL | First, the return address (PC + 2) is<br>pushed onto the return stack. Next, the<br>contents of W are written to PCL; the<br>existing value is discarded. Then, the<br>contents of PCLATH and PCLATU are<br>latched into PCH and PCU,<br>respectively. The second cycle is<br>executed as a NOP instruction while the<br>new next instruction is fetched.<br>Unlike CALL, there is no option to |                 |  |  |  |
| Word        | e.                                                                                    | 1                                                                                                                                    | update W, STATUS or BSR.                                                                                                                                                                                                                                                                                                                                                                        |                 |  |  |  |
| Cycle       |                                                                                       | 2                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                 |                 |  |  |  |
|             | ycle Activity:                                                                        | 2                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                 |                 |  |  |  |
| QU          | Q1                                                                                    | Q2                                                                                                                                   | Q3                                                                                                                                                                                                                                                                                                                                                                                              | Q4              |  |  |  |
|             | Decode                                                                                | Read<br>WREG                                                                                                                         | Push PC to<br>stack                                                                                                                                                                                                                                                                                                                                                                             | No<br>operation |  |  |  |
|             | No                                                                                    | No                                                                                                                                   | No                                                                                                                                                                                                                                                                                                                                                                                              | No              |  |  |  |
|             | operation                                                                             | operation                                                                                                                            | operation                                                                                                                                                                                                                                                                                                                                                                                       | operation       |  |  |  |
| <u>Exan</u> | <u>nple:</u><br>Before Instruc                                                        | HERE                                                                                                                                 | CALLW                                                                                                                                                                                                                                                                                                                                                                                           |                 |  |  |  |
|             | PC<br>PCLATH<br>PCLATU<br>W<br>After Instructio<br>PC<br>TOS<br>PCLATH<br>PCLATU<br>W | = 00h<br>= 06h<br>on<br>= 001006<br>= address<br>= 10h                                                                               | h                                                                                                                                                                                                                                                                                                                                                                                               | )               |  |  |  |

| MOV                                                  | SF                                                                                                             | Move Inde                                                                                                                             | Move Indexed to f                                                                                                                                                                                                                                                                                                                                                                                                     |              |                                        |  |  |
|------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----------------------------------------|--|--|
| Synta                                                | ax:                                                                                                            | MOVSF [2                                                                                                                              | MOVSF [z <sub>s</sub> ], f <sub>d</sub>                                                                                                                                                                                                                                                                                                                                                                               |              |                                        |  |  |
| Oper                                                 | ands:                                                                                                          | $0 \le z_s \le 12^{\circ}$<br>$0 \le f_d \le 408^{\circ}$                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                                        |  |  |
| Oner                                                 | ation:                                                                                                         | ((FSR2) + 2                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                                        |  |  |
| •                                                    | s Affected:                                                                                                    | None                                                                                                                                  | -s/ / 'd                                                                                                                                                                                                                                                                                                                                                                                                              |              |                                        |  |  |
|                                                      |                                                                                                                | None                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                                        |  |  |
| Encoding:<br>1st word (source)<br>2nd word (destin.) |                                                                                                                | 1110<br>1111                                                                                                                          | 1011<br>ffff                                                                                                                                                                                                                                                                                                                                                                                                          | Ozzz<br>ffff | zzzz <sub>s</sub><br>ffff <sub>d</sub> |  |  |
| Desc                                                 | ription:                                                                                                       | moved to d<br>actual addr<br>determined<br>offset 'z <sub>s</sub> ', i<br>of FSR2. TI<br>register is s<br>'f <sub>d</sub> ' in the se | The contents of the source register are<br>moved to destination register ' $f_d$ '. The<br>actual address of the source register is<br>determined by adding the 7-bit literal<br>offset ' $z_s$ ', in the first word, to the value<br>of FSR2. The address of the destination<br>register is specified by the 12-bit literal<br>' $f_d$ ' in the second word. Both addresses<br>can be anywhere in the 4096-byte data |              |                                        |  |  |
|                                                      |                                                                                                                | The MOVSF<br>PCL, TOSU                                                                                                                | The MOVSF instruction cannot use the PCL, TOSU, TOSH or TOSL as the destination register.                                                                                                                                                                                                                                                                                                                             |              |                                        |  |  |
|                                                      |                                                                                                                | an Indirect                                                                                                                           | If the resultant source address points to<br>an Indirect Addressing register, the<br>value returned will be 00h.                                                                                                                                                                                                                                                                                                      |              |                                        |  |  |
| Word                                                 | s:                                                                                                             | 2                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                                        |  |  |
| Cycle                                                | es:                                                                                                            | 2                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                                        |  |  |
| QC                                                   | vcle Activity:                                                                                                 |                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                       |              |                                        |  |  |
|                                                      | Q1                                                                                                             | Q2                                                                                                                                    | Q3                                                                                                                                                                                                                                                                                                                                                                                                                    |              | Q4                                     |  |  |
|                                                      | Decode                                                                                                         | Determine source addr                                                                                                                 | Determir source ac                                                                                                                                                                                                                                                                                                                                                                                                    |              | Read<br>urce reg                       |  |  |
|                                                      | Decode                                                                                                         | No<br>operation<br>No dummy<br>read                                                                                                   | No<br>operatio                                                                                                                                                                                                                                                                                                                                                                                                        | n reg        | Write<br>gister 'f'<br>(dest)          |  |  |
| <u>Exan</u>                                          | •                                                                                                              |                                                                                                                                       | [05h], R                                                                                                                                                                                                                                                                                                                                                                                                              | EG2          |                                        |  |  |
|                                                      | Before Instruc<br>FSR2<br>Contents<br>of 85h<br>REG2<br>After Instructio<br>FSR2<br>Contents<br>of 85h<br>REG2 | = 80<br>= 33<br>= 11<br>on<br>= 80                                                                                                    | h<br>h<br>h                                                                                                                                                                                                                                                                                                                                                                                                           |              |                                        |  |  |

# 31.2 DC Characteristics: Power-Down and Supply Current PIC18F47J53 Family (Industrial)

| PIC18LF47J53 Family |                                         |        |            | perating ( |                                              | s (unless otherwise $^{\circ}C \leq TA \leq +85^{\circ}C$ for i |                                   |
|---------------------|-----------------------------------------|--------|------------|------------|----------------------------------------------|-----------------------------------------------------------------|-----------------------------------|
| PIC18F4             |                                         |        | perating C |            | s (unless otherwise<br>°C ≤ TA ≤ +85°C for i |                                                                 |                                   |
| Param.<br>No.       | Device                                  | Тур.   | Max.       | Units      | Conditions                                   |                                                                 |                                   |
|                     | Power-Down Current (IPD) <sup>(1)</sup> | - Slee | p mode     |            |                                              |                                                                 |                                   |
|                     | PIC18LFXXJ53                            | 0.1    | 1.6        | μA         | -40°C                                        |                                                                 |                                   |
|                     |                                         | 0.2    | 1.6        | μΑ         | +25°C                                        | VDD = 2.0V,                                                     |                                   |
|                     |                                         | 0.8    | 7.0        | μA         | +60°C                                        | VDDCORE = 2.0V                                                  |                                   |
|                     |                                         | 2.1    | 11.5       | μA         | +85°C                                        |                                                                 |                                   |
|                     | PIC18LFXXJ53                            | 0.2    | 2.0        | μΑ         | -40°C                                        |                                                                 |                                   |
|                     |                                         | 0.5    | 2.0        | μA         | +25°C                                        | VDD = 2.5V,                                                     |                                   |
|                     |                                         | 1.4    | 9.0        | μA         | +60°C                                        | VDDCORE = 2.5V                                                  |                                   |
|                     |                                         | 3.2    | 15.0       | μA         | +85°C                                        |                                                                 | <b>Sleep mode</b> ,<br>REGSLP = 1 |
|                     | PIC18FXXJ53                             | 3.0    | 6.0        | μΑ         | -40°C                                        |                                                                 |                                   |
|                     |                                         | 3.8    | 6.0        | μA         | +25°C                                        | VDD = 2.15V<br>Vddcore = 10 μF                                  |                                   |
|                     |                                         | 4.7    | 9.0        | μΑ         | +60°C                                        | Capacitor                                                       |                                   |
|                     |                                         | 6.4    | 18.5       | μA         | +85°C                                        |                                                                 |                                   |
|                     | PIC18FXXJ53                             | 3.3    | 9.0        | μΑ         | -40°C                                        |                                                                 |                                   |
|                     |                                         | 4.2    | 9.0        | μA         | +25°C                                        | VDD = 3.3V<br>Vddcore = 10 μF                                   |                                   |
|                     |                                         | 5.5    | 12.0       | μΑ         | +60°C                                        | Capacitor                                                       |                                   |
|                     |                                         | 7.8    | 22.0       | μΑ         | +85°C                                        |                                                                 |                                   |
|                     | Power-Down Current (IPD) <sup>(1)</sup> | – Deep | Sleep      | mode       |                                              |                                                                 |                                   |
|                     | PIC18FXXJ53                             | 2      | 25         | nA         | -40°C                                        |                                                                 |                                   |
|                     |                                         | 9      | 100        | nA         | +25°C                                        | VDD = 2.15V,<br>VDDCORE = 10 μF                                 |                                   |
|                     |                                         | 72     | 250        | nA         | +60°C                                        | Capacitor                                                       |                                   |
|                     |                                         | 0.26   | 1.0        | μA         | +85°C                                        | - apacito.                                                      | Deep Sleep mode                   |
|                     | PIC18FXXJ53                             | 17     | 50         | nA         | -40°C                                        |                                                                 | Deep oleep mode                   |
|                     |                                         | 53     | 150        | nA         | +25°C                                        | VDD = 3.3V,<br>VDDCORE = 10 μF                                  |                                   |
|                     |                                         | 186    | 400        | nA         | +60°C                                        | Capacitor                                                       |                                   |
|                     |                                         | 0.50   | 2.0        | μA         | +85°C                                        |                                                                 |                                   |

**Note 1:** The power-down current in Sleep mode does not depend on the oscillator type. Power-down current is measured with the part in Sleep mode, with all I/O pins in high-impedance state and tied to VDD or VSS and all features that add delta current disabled (such as WDT, Timer1 oscillator, BOR, etc.).

2: The supply current is mainly a function of operating voltage, frequency and mode. Other factors, such as I/O pin loading and switching rate, oscillator type and circuit, internal code execution pattern and temperature, also have an impact on the current consumption. All features that add delta current are disabled (USB module, WDT, etc.). The test conditions for all IDD measurements in active operation mode are:

OSC1 = external square wave, from rail-to-rail; all I/O pins tri-stated, pulled to VDD/Vss;

- MCLR = VDD; WDT disabled unless otherwise specified.
- **3:** Low-power Timer1 with standard, low-cost 32 kHz crystals have an operating temperature range of -10°C to +70°C. Extended temperature crystals are available at a much higher cost.
- 4: This is the module differential current when the USB module is enabled and clocked at 48 MHz, but with no USB cable attached. When the USB cable is attached or data is being transmitted, the current consumption may be much higher (see Section 23.6.4 "USB Transceiver Current Consumption"). During USB Suspend mode (USBEN = 1, SUSPND = 1, bus in Idle state), the USB module current will be dominated by the D+ or D- pull-up resistor. The integrated pull-up resistor use "resistor switching" according to the resistor\_ecn supplement to the USB 2.0 Specifications, and therefore, may be as low as 900Ω during Idle conditions.



# 44-Lead Plastic Quad Flat, No Lead Package (ML) - 8x8 mm Body [QFN or VQFN]

Microchip Technology Drawing C04-103D Sheet 1 of 2