

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

| Details                    |                                                                             |
|----------------------------|-----------------------------------------------------------------------------|
| Product Status             | Active                                                                      |
| Core Processor             | PIC                                                                         |
| Core Size                  | 8-Bit                                                                       |
| Speed                      | 64MHz                                                                       |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART                                   |
| Peripherals                | Brown-out Detect/Reset, DMA, HLVD, POR, PWM, WDT                            |
| Number of I/O              | 25                                                                          |
| Program Memory Size        | 64KB (32K x 16)                                                             |
| Program Memory Type        | FLASH                                                                       |
| EEPROM Size                | 1K x 8                                                                      |
| RAM Size                   | 4K x 8                                                                      |
| Voltage - Supply (Vcc/Vdd) | 2.3V ~ 5.5V                                                                 |
| Data Converters            | A/D 24x12b; D/A 1x5b                                                        |
| Oscillator Type            | Internal                                                                    |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                           |
| Mounting Type              | Surface Mount                                                               |
| Package / Case             | 28-SOIC (0.295", 7.50mm Width)                                              |
| Supplier Device Package    | 28-SOIC                                                                     |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18f26k42t-i-so |
|                            |                                                                             |

Email: info@E-XFL.COM

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

#### 4.5.5 STATUS REGISTER

The STATUS register, shown in Register 4-2, contains the arithmetic status of the ALU. As with any other SFR, it can be the operand for any instruction.

If the STATUS register is the destination for an instruction that affects the Z, DC, C, OV or N bits, the results of the instruction are not written; instead, the STATUS register is updated according to the instruction performed. Therefore, the result of an instruction with the STATUS register as its destination may be different than intended. As an example, CLRF STATUS will set the Z bit and leave the remaining Status bits unchanged ('0uuu u1uu').

It is recommended that only BCF, BSF, SWAPF, MOVFF, MOVWF and MOVFFL instructions are used to alter the STATUS register, because these instructions do not affect the Z, C, DC, OV or N bits in the STATUS register.

For other instructions that do not affect Status bits, see the instruction set summaries in **Section 41.2 "Extended Instruction Set**" and Table 41-3.

**Note:** The C and DC bits operate as the borrow and digit borrow bits, respectively, in subtraction.

#### 4.5.6 CALL SHADOW REGISTER

When CALL, CALLW, RCALL instructions are used, the WREG, BSR and STATUS are automatically saved in hardware and can be accessed using the WREG\_C-SHAD, BSR\_CSHAD and STATUS\_CSHAD registers. The contents of these registers should be handled correctly to avoid erroneous code execution.

#### FIGURE 4-7: COMPARING ADDRESSING OPTIONS FOR BIT-ORIENTED AND BYTE-ORIENTED INSTRUCTIONS (EXTENDED INSTRUCTION SET ENABLED)

**EXAMPLE INSTRUCTION:** ADDWF, f, d, a (Opcode: 0010 01da ffff ffff)

#### When 'a' = 0 and $f \ge 60h$ :

The instruction executes in Direct Forced mode. 'f' is interpreted as a location in the Access RAM between 060h and 0FFh. This is the same as locations 3F60h to 3FFFh (Bank 63) of data memory.

Locations below 60h are not available in this Addressing mode.



#### When 'a' = 0 and $f \le 5Fh$ :

The instruction executes in Indexed Literal Offset mode. 'f' is interpreted as an offset to the address value in FSR2. The two are added together to obtain the address of the target register for the instruction. The address can be anywhere in the data memory space.

Note that in this mode, the correct syntax is now: ADDWF [k], d where 'k' is the same as 'f'.

#### When 'a' = 1 (all values of f):

The instruction executes in Direct mode (also known as Direct Long mode). 'f' is interpreted as a location in one of the 63 banks of the data memory space. The bank is designated by the Bank Select Register (BSR). The address can be in any implemented bank in the data memory space.

| U-0              | U-0                                                                                       | U-0               | U-0  | U-0                            | U-0              | R/W/HC-1/u    | U-0 |  |  |  |  |
|------------------|-------------------------------------------------------------------------------------------|-------------------|------|--------------------------------|------------------|---------------|-----|--|--|--|--|
| _                | _                                                                                         | —                 | —    | —                              | —                | MEMV          | _   |  |  |  |  |
| bit 7 bit 0      |                                                                                           |                   |      |                                |                  |               |     |  |  |  |  |
|                  |                                                                                           |                   |      |                                |                  |               |     |  |  |  |  |
| Legend:          | Legend:                                                                                   |                   |      |                                |                  |               |     |  |  |  |  |
| R = Readable b   | bit                                                                                       | W = Writable I    | oit  | U = Unimpler                   | mented bit, read | <b>as</b> '0' |     |  |  |  |  |
| u = Bit is uncha | u = Bit is unchanged x = Bit is unknown -m/n = Value at POR and BOR/Value at all other Re |                   |      |                                |                  | other Resets  |     |  |  |  |  |
| '1' = Bit is set |                                                                                           | '0' = Bit is clea | ared | q = Value depends on condition |                  |               |     |  |  |  |  |

#### REGISTER 6-3: PCON1: POWER CONTROL REGISTER 1

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

bit 1 **MEMV**: Memory Violation Flag bit

1 = No memory violation Reset occurred or set to '1' by firmware

0 = A memory violation Reset occurred (set to '0' in hardware when a Memory Violation occurs)

bit 0 Unimplemented: Read as '0'

#### TABLE 6-4: SUMMARY OF REGISTERS ASSOCIATED WITH RESETS

| Name   | Bit 7  | Bit 6  | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0  | Register<br>on Page |
|--------|--------|--------|-------|-------|-------|-------|-------|--------|---------------------|
| BORCON | SBOREN |        | _     | —     |       | _     |       | BORRDY | 85                  |
| PCON0  | STKOVF | STKUNF | WDTWV | RWDT  | RMCLR | RI    | POR   | BOR    | 90                  |
| PCON1  | _      |        | _     | _     | _     | _     | MEMV  | _      | 91                  |

**Legend:** — = unimplemented location, read as '0'. Shaded cells are not used by Resets.

| U-0              | R-f/f     | R-f/f             | R-f/f | R-f/f                                               | R-f/f            | R-f/f    | R-f/f |
|------------------|-----------|-------------------|-------|-----------------------------------------------------|------------------|----------|-------|
| —                | COSC<2:0> |                   |       |                                                     | CDIV             | <3:0>    |       |
| bit 7            |           |                   |       |                                                     |                  |          | bit 0 |
|                  |           |                   |       |                                                     |                  |          |       |
| Legend:          |           |                   |       |                                                     |                  |          |       |
| R = Readable I   | bit       | W = Writable b    | oit   | U = Unimpler                                        | nented bit, read | l as '0' |       |
| u = Bit is uncha | anged     | x = Bit is unkn   | own   | -n/n = Value at POR and BOR/Value at all other Rese |                  |          |       |
| '1' = Bit is set |           | '0' = Bit is clea | ared  |                                                     |                  |          |       |

#### REGISTER 7-2: OSCCON2: OSCILLATOR CONTROL REGISTER 2

| bit 7   | Unimplemented: Read as '0'                                                  |
|---------|-----------------------------------------------------------------------------|
| bit 6-4 | COSC<2:0>: Current Oscillator Source Select bits (read-only) <sup>(1)</sup> |
|         | Indicates the current source oscillator and PLL combination per Table 7-1.  |
| bit 3-0 | CDIV<3:0>: Current Divider Select bits (read-only) <sup>(1)</sup>           |
|         | Indicates the current postscaler division ratio per Table 7-1.              |

Note 1: The POR value is the value present when user code execution begins.

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

| R/W/HC-0/0 | R/W-0/0 | U-0 | R-0/0 | R-0/0 | U-0 | U-0 | U-0   |
|------------|---------|-----|-------|-------|-----|-----|-------|
| CSWHOLD    | SOSCPWR |     | ORDY  | NOSCR | —   | _   | —     |
| bit 7      |         |     |       |       |     |     | bit 0 |

| Legend:              |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | x = Bit is unknown   | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set     | '0' = Bit is cleared | HC = Bit is cleared by hardware                       |

| bit 7   | CSWHOLD: Clock Switch Hold bit                                                                                                                                                                                                              |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | <ul> <li>1 = Clock switch will hold (with interrupt) when the oscillator selected by NOSC is ready</li> <li>0 = Clock switch may proceed when the oscillator selected by NOSC is ready; NOSCR becomes '1', the switch will occur</li> </ul> |
| bit 6   | SOSCPWR: Secondary Oscillator Power Mode Select bit                                                                                                                                                                                         |
|         | <ol> <li>Secondary oscillator operating in High-Power mode</li> </ol>                                                                                                                                                                       |
|         | 0 = Secondary oscillator operating in Low-Power mode                                                                                                                                                                                        |
| bit 5   | Unimplemented: Read as '0'                                                                                                                                                                                                                  |
| bit 4   | ORDY: Oscillator Ready bit (read-only)                                                                                                                                                                                                      |
|         | 1 = OSCCON1 = OSCCON2; the current system clock is the clock specified by NOSC                                                                                                                                                              |
|         | 0 = A clock switch is in progress                                                                                                                                                                                                           |
| bit 3   | NOSCR: New Oscillator is Ready bit (read-only) <sup>(1)</sup>                                                                                                                                                                               |
|         | 1 = A clock switch is in progress and the oscillator selected by NOSC indicates a "ready" condition                                                                                                                                         |
|         | 0 = A clock switch is not in progress, or the NOSC-selected oscillator is not yet ready                                                                                                                                                     |
| bit 2-0 | Unimplemented: Read as '0'                                                                                                                                                                                                                  |
| Note 1: | If CSWHOLD = 0, the user may not see this bit set because, when the oscillator becomes ready there                                                                                                                                          |

Note 1: If CSWHOLD = 0, the user may not see this bit set because, when the oscillator becomes ready there may be a delay of one instruction clock before this bit is set. The clock switch occurs in the next instruction cycle and this bit is cleared.

| _              |                                                                      |                                    | _              |                |                  |                  |              |
|----------------|----------------------------------------------------------------------|------------------------------------|----------------|----------------|------------------|------------------|--------------|
| R/W/HS-0/      | 0 R/W/HS-0/0                                                         | R/W/HS-0/0                         | U-0            | R/W/HS-0/0     | R/W/HS-0/0       | R/W/HS-0/0       | R/W/HS-0/0   |
| CLC1IF         | CWG1IF                                                               | NCO1IF                             |                | CCP1IF         | TMR2IF           | TMR1GIF          | TMR1IF       |
| bit 7          |                                                                      |                                    |                |                |                  |                  | bit 0        |
|                |                                                                      |                                    |                |                |                  |                  |              |
| Legend:        |                                                                      |                                    |                |                |                  |                  |              |
| R = Readab     | ole bit                                                              | W = Writable                       | oit            | U = Unimpler   | nented bit, read | l as '0'         |              |
| u = Bit is un  | changed                                                              | x = Bit is unkn                    | own            | -n/n = Value a | at POR and BO    | R/Value at all c | other Resets |
| '1' = Bit is s | et                                                                   | '0' = Bit is clea                  | ared           | HS = Bit is se | et in hardware   |                  |              |
|                |                                                                      |                                    |                |                |                  |                  |              |
| bit 7          | CLC1IF: CLC                                                          | 1 Interrupt Flag                   | g bit          |                |                  |                  |              |
|                |                                                                      | has occurred (r                    |                | ed by software | )                |                  |              |
|                | •                                                                    | event has not o                    |                |                |                  |                  |              |
| bit 6          |                                                                      | /G1 Interrupt FI                   | •              |                |                  |                  |              |
|                |                                                                      | has occurred (r<br>event has not o |                | ed by software | )                |                  |              |
| bit 5          |                                                                      | D1 Interrupt Fla                   |                |                |                  |                  |              |
| bit 0          |                                                                      | has occurred (r                    | •              | ed by software | )                |                  |              |
|                |                                                                      | event has not o                    |                |                | /                |                  |              |
| bit 4          | Unimplemen                                                           | ted: Read as '                     | )'             |                |                  |                  |              |
| bit 3          | CCP1IF: CCF                                                          | P1 Interrupt Flag                  | g bit          |                |                  |                  |              |
|                |                                                                      | has occurred (r                    |                | ed by software | )                |                  |              |
|                |                                                                      | event has not o                    |                |                |                  |                  |              |
| bit 2          |                                                                      | R2 Interrupt Fla                   | •              |                | ,                |                  |              |
|                |                                                                      | has occurred (r<br>event has not o |                | ed by software | )                |                  |              |
| bit 1          | •                                                                    | /R1 Gate Inter                     |                |                |                  |                  |              |
|                |                                                                      | has occurred (r                    |                | ed bv software | )                |                  |              |
|                |                                                                      | event has not o                    |                |                | /                |                  |              |
| bit 0          | TMR1IF: TMF                                                          | R1 Interrupt Fla                   | g bit          |                |                  |                  |              |
|                | •                                                                    | has occurred (r                    |                | ed by software | )                |                  |              |
|                |                                                                      | event has not o                    |                |                |                  |                  |              |
| e              | nterrupt flag bits g<br>enable bit, or the g<br>clear prior to enabl | lobal enable bi                    | t. User softwa |                |                  |                  |              |
|                |                                                                      |                                    |                |                |                  |                  |              |

### REGISTER 9-7: PIR4: PERIPHERAL INTERRUPT REGISTER 4<sup>(1)</sup>

|                 | <b>3-32</b> . II K7.      |                                       |                |              |                  | 1                |              |  |  |  |  |
|-----------------|---------------------------|---------------------------------------|----------------|--------------|------------------|------------------|--------------|--|--|--|--|
| U-0             | U-0                       | R/W-1/1                               | R/W-1/1        | R/W-1/1      | U-0              | R/W-1/1          | R/W-1/1      |  |  |  |  |
| _               | -                         | INT2IP                                | CLC2IP         | CWG2IP       | —                | CCP2IP           | TMR4IP       |  |  |  |  |
| bit 7           |                           |                                       |                |              | -                |                  | bit (        |  |  |  |  |
|                 |                           |                                       |                |              |                  |                  |              |  |  |  |  |
| Legend:         |                           |                                       |                |              |                  |                  |              |  |  |  |  |
| R = Readab      | le bit                    | W = Writable                          | bit            | U = Unimple  | mented bit, read | as '0'           |              |  |  |  |  |
| u = Bit is un   | changed                   | x = Bit is unki                       | nown           | -n/n = Value | at POR and BO    | R/Value at all o | other Resets |  |  |  |  |
| '1' = Bit is se | et                        | '0' = Bit is cle                      | ared           |              |                  |                  |              |  |  |  |  |
|                 |                           |                                       |                |              |                  |                  |              |  |  |  |  |
| bit 7-6         | Unimpleme                 | n <b>ted:</b> Read as '               | 0'             |              |                  |                  |              |  |  |  |  |
| bit 5           | INT2IP: Exte              | ernal Interrupt 2                     | Interrupt Prio | rity bit     |                  |                  |              |  |  |  |  |
|                 | 1 = High pri              | 1 = High priority                     |                |              |                  |                  |              |  |  |  |  |
|                 | 0 = Low price             | prity                                 |                |              |                  |                  |              |  |  |  |  |
| bit 4           | CLC2IP: CL                | C2 Interrupt Prie                     | ority bit      |              |                  |                  |              |  |  |  |  |
|                 | • .                       | 1 = High priority                     |                |              |                  |                  |              |  |  |  |  |
|                 | 0 = Low price             | •                                     |                |              |                  |                  |              |  |  |  |  |
| bit 3           |                           | NG2 Interrupt F                       | riority bit    |              |                  |                  |              |  |  |  |  |
|                 | 1 = High prior            |                                       |                |              |                  |                  |              |  |  |  |  |
| <b>h</b> # 0    | 0 = Low pric              | •                                     | ~              |              |                  |                  |              |  |  |  |  |
| bit 2           | -                         | nted: Read as '                       |                |              |                  |                  |              |  |  |  |  |
| bit 1           |                           | CCP2IP: CRC Interrupt Priority bit    |                |              |                  |                  |              |  |  |  |  |
|                 | 01                        | 1 = High priority<br>0 = Low priority |                |              |                  |                  |              |  |  |  |  |
| bit 0           | •                         | •                                     | iority hit     |              |                  |                  |              |  |  |  |  |
|                 |                           | IR4 Interrupt Pr                      |                |              |                  |                  |              |  |  |  |  |
|                 | 1 = High prid0 = Low prid | ,                                     |                |              |                  |                  |              |  |  |  |  |
|                 | 5 2017 pric               |                                       |                |              |                  |                  |              |  |  |  |  |

#### REGISTER 9-32: IPR7: PERIPHERAL INTERRUPT PRIORITY REGISTER 7

#### REGISTER 9-33: IPR8: PERIPHERAL INTERRUPT PRIORITY REGISTER 8

| R/W-1/1 | R/W-1/1 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0   |
|---------|---------|-----|-----|-----|-----|-----|-------|
| TMR5GIP | TMR5IP  | —   | —   | —   | —   | —   | —     |
| bit 7   |         |     |     |     |     |     | bit 0 |

| Legend:              |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | x = Bit is unknown   | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set     | '0' = Bit is cleared |                                                       |

| bit 7   | TMR5GIP: TMR5 Gate Interrupt Priority bit |
|---------|-------------------------------------------|
|         | 1 = High priority                         |
|         | 0 = Low priority                          |
| bit 6   | TMR5IP: TMR5 Interrupt Priority bit       |
|         | 1 = High priority                         |
|         | 0 = Low priority                          |
| bit 5-0 | Unimplemented: Read as '0'                |

© 2017 Microchip Technology Inc.

## 15.9.7 ABORT TRIGGER, MESSAGE IN PROGRESS

When an abort interrupt request is received in a DMA transaction, the DMA will perform a soft-stop by clearing the DGO (i.e., if the DMA was reading the source register, it will complete the read operation and then clear the DGO bit).

The SIREQEN bit is cleared to prevent any overrun and the AIRQEN bit is cleared to prevent any false aborts.

When the DGO bit is set again the DMA will resume operation from where it left off after the soft-stop.



|                               | 0 0 0 0 0 0 0 0 0 0 0                                                              | Rav. 10-001275G<br>8/12/2016 |
|-------------------------------|------------------------------------------------------------------------------------|------------------------------|
| Instruction<br>Clock          |                                                                                    |                              |
| EN                            |                                                                                    |                              |
| SIRQEN                        |                                                                                    |                              |
| AIRQEN                        |                                                                                    |                              |
| Source Hardware<br>Trigger —— |                                                                                    |                              |
| Abort Hardware<br>Trigger     |                                                                                    |                              |
| DGO                           |                                                                                    |                              |
| DMAxSPTR <                    | 0x3EEF 0x3EF0 0x3EF0 0x3EEF                                                        |                              |
| DMAxDPTR                      | 0x100 0x101 0x102                                                                  |                              |
|                               | 2 1 2                                                                              |                              |
|                               | 10 9 8                                                                             |                              |
| DMA STATE                     | $IDLE$ $SR^{(1)}$ $IDLE$ $DW^{(2)}$ $SR^{(1)}$ $DW^{(2)}$ $IDLE$ $DW^{(2)}$ $IDLE$ |                              |
| DMAxCONbits.XIP               |                                                                                    |                              |
| DMAxAIF ——                    |                                                                                    |                              |
| DMAxSSA                       | 0x3EEF DMAxDSA 0x100                                                               |                              |
|                               |                                                                                    |                              |
| DMAxSSZ                       | 0x2 DMAxDSZ 0xA                                                                    |                              |
| Note 1: SR - So               |                                                                                    |                              |
| <b>2:</b> DW - De             | estination Write                                                                   |                              |

The following table contains some of the cases in which the DMA module can be configured to.

|       |     |     |     |     |         |          | •       |
|-------|-----|-----|-----|-----|---------|----------|---------|
| U-0   | U-0 | U-0 | U-0 | U-0 | R/W-0/x | R/W-0/x  | R/W-0/x |
| —     | —   | —   | _   | —   |         | CTS<2:0> |         |
| bit 7 |     |     |     |     |         |          | bit 0   |

#### REGISTER 23-3: CCPxCAP: CAPTURE INPUT SELECTION MULTIPLEXER REGISTER

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

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

bit 2-0 CTS<2:0>: Capture Trigger Input Selection bits

| CTS<1:0> | Connection                 |                            |                            |                            |  |  |  |
|----------|----------------------------|----------------------------|----------------------------|----------------------------|--|--|--|
| 019<1.02 | CCP1                       | CCP2                       | CCP3                       | CCP4                       |  |  |  |
| 111      |                            | CLC                        | 4_out                      |                            |  |  |  |
| 110      |                            | CLC                        | 3_out                      |                            |  |  |  |
| 101      |                            | CLC2_out                   |                            |                            |  |  |  |
| 100      |                            | CLC                        | 1_out                      |                            |  |  |  |
| 011      |                            | IOC_Ir                     | nterrupt                   |                            |  |  |  |
| 010      |                            | CMP2                       | _output                    |                            |  |  |  |
| 001      |                            | CMP1                       | _output                    |                            |  |  |  |
| 000      | Pin selected by<br>CCP1PPS | Pin selected by<br>CCP2PPS | Pin selected by<br>CCP3PPS | Pin selected by<br>CCP4PPS |  |  |  |

#### REGISTER 23-4: CCPRxL: CCPx REGISTER LOW BYTE

| R/W-x/x   | R/W-x/x | R/W-x/x | R/W-x/x | R/W-x/x | R/W-x/x | R/W-x/x | R/W-x/x |  |
|-----------|---------|---------|---------|---------|---------|---------|---------|--|
| RL<7:0>   |         |         |         |         |         |         |         |  |
| bit 7 bit |         |         |         |         |         |         |         |  |

| 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-0
 MODE = Capture Mode: RL<7:0>: LSB of captured TMR1 value MODE = Compare Mode: RL<7:0>: LSB compared to TMR1 value MODE = PWM Mode && FMT = 0: RL<7:0>: CCPW<7:0> - Pulse-Width LS 8 bits MODE = PWM Mode && FMT = 1: RL<7:6>: CCPW<1:0> - Pulse-Width LS 2 bits RL<5:0>: Not used

#### REGISTER 24-3: PWMxDCH: PWM DUTY CYCLE HIGH BITS

| R/W-x/u          | R/W-x/u | R/W-x/u           | R/W-x/u | R/W-x/u                                             | R/W-x/u          | R/W-x/u  | R/W-x/u      |
|------------------|---------|-------------------|---------|-----------------------------------------------------|------------------|----------|--------------|
|                  |         |                   | DC      | <9:2>                                               |                  |          |              |
| bit 7            |         |                   |         |                                                     |                  |          | bit 0        |
|                  |         |                   |         |                                                     |                  |          |              |
| Legend:          |         |                   |         |                                                     |                  |          |              |
| R = Readable     | bit     | W = Writable b    | oit     | U = Unimplen                                        | nented bit, read | l as '0' |              |
| u = Bit is unch  | nanged  | x = Bit is unkn   | own     | -n/n = Value at POR and BOR/Value at all other Rese |                  |          | other Resets |
| '1' = Bit is set |         | '0' = Bit is clea | ared    |                                                     |                  |          |              |

bit 7-0 **DC<9:2>:** PWM Duty Cycle Most Significant bits These bits are the MSbs of the PWM duty cycle. The two LSbs are found in PWMxDCL Register.

#### REGISTER 24-4: PWMxDCL: PWM DUTY CYCLE LOW BITS

| R/W-x/u | R/W-x/u | U-0 | U-0 | U-0 | U-0 | U-0 | U-0   |
|---------|---------|-----|-----|-----|-----|-----|-------|
| DC<1:0> |         | —   | —   | —   | _   | —   | —     |
| bit 7   |         |     |     |     |     |     | bit 0 |

| Legend:              |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | x = Bit is unknown   | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set     | '0' = Bit is cleared |                                                       |

bit 7-6 **DC<1:0>:** PWM Duty Cycle Least Significant bits These bits are the LSbs of the PWM duty cycle. The MSbs are found in PWMxDCH Register. bit 5-0 **Unimplemented:** Read as '0'

#### TABLE 24-3: SUMMARY OF REGISTERS ASSOCIATED WITH PWM

| Name     | Bit 7       | Bit 6   | Bit 5 | Bit 4  | Bit 3 | Bit 2  | Bit 1 | Bit 0  | Register<br>on Page |
|----------|-------------|---------|-------|--------|-------|--------|-------|--------|---------------------|
| PWMxCON  | EN          | _       | OUT   | POL    | —     | —      |       |        | 358                 |
| PWMxDCH  | DC<9:2>     |         |       |        |       |        |       |        | 360                 |
| PWMxDCL  | DC<1:0> — — |         |       | _      | _     | _      | _     | _      | 360                 |
| CCPTMRS1 | P8TSE       | EL<1:0> | P7TSE | L<1:0> | P6TSE | L<1:0> | P5TSE | L<1:0> | 359                 |

Legend: - = Unimplemented locations, read as '0', u = unchanged, x = unknown. Shaded cells are not used by the PWM.

#### 26.2.4.2 Asynchronous Steering Mode

In Asynchronous mode (MODE<2:0> bits = 000, Register 26-1), steering takes effect at the end of the instruction cycle that writes to STR. In Asynchronous Steering mode, the output signal may be an incomplete waveform (Figure 26-10). This operation may be useful when the user firmware needs to immediately remove a signal from the output pin.

#### FIGURE 26-10: EXAMPLE OF ASYNCHRONOUS STEERING (MODE<2:0>= 000)



#### 26.2.4.3 Start-up Considerations

The application hardware must use the proper external pull-up and/or pull-down resistors on the CWG output pins. This is required because all I/O pins are forced to high-impedance at Reset.

The POLy bits (Register 26-2) allow the user to choose whether the output signals are active-high or active-low.

© 2017 Microchip Technology Inc.

-n/n = Value at POR and BOR/Value at all other Resets

q = Value depends on condition

| U-0            | U-0 | U-0          | R/W-0/0 | R/W-0/0      | R/W-0/0          | R/W-0/0 | R/W-0/0 |
|----------------|-----|--------------|---------|--------------|------------------|---------|---------|
| —              | —   | —            |         |              | ISM<4:0>         |         |         |
| bit 7          |     |              |         |              |                  |         | bit 0   |
|                |     |              |         |              |                  |         |         |
| Legend:        |     |              |         |              |                  |         |         |
| R = Readable b | bit | W = Writable | bit     | U = Unimpler | mented bit, read | as '0'  |         |

#### REGISTER 26-4: CWGxISM: CWGx INPUT SELECTION REGISTER

#### bit 7-5 Unimplemented Read as '0'

u = Bit is unchanged

'1' = Bit is set

bit 4-0 ISM<4:0>: CWG Data Input Selection Multiplexer Select bits

x = Bit is unknown

'0' = Bit is cleared

| ICM (4:0)   | CWG1                       | CWG2                       | CWG3                       |
|-------------|----------------------------|----------------------------|----------------------------|
| ISM<4:0>    | Input Selection            | Input Selection            | Input Selection            |
| 11111-10011 | Reserved                   | Reserved                   | Reserved                   |
| 10010       | CLC4_out                   | CLC4_out                   | CLC4_out                   |
| 10001       | CLC3_out                   | CLC3_out                   | CLC3_out                   |
| 10000       | CLC2_out                   | CLC2_out                   | CLC2_out                   |
| 01111       | CLC1_out                   | CLC1_out                   | CLC1_out                   |
| 01110       | DSM_out                    | DSM_out                    | DSM_out                    |
| 01101       | CMP2OUT                    | CMP2OUT                    | CMP2OUT                    |
| 01100       | CMP1OUT                    | CMP1OUT                    | CMP1OUT                    |
| 01011       | NCO10UT                    | NCO1OUT                    | NCO10UT                    |
| 01010-01001 | Reserved                   | Reserved                   | Reserved                   |
| 01000       | PWM8OUT                    | PWM8OUT                    | PWM8OUT                    |
| 00111       | PWM7OUT                    | PWM7OUT                    | PWM7OUT                    |
| 00110       | PWM6OUT                    | PWM6OUT                    | PWM6OUT                    |
| 00101       | PWM5OUT                    | PWM5OUT                    | PWM5OUT                    |
| 00100       | CCP4_out                   | CCP4_out                   | CCP4_out                   |
| 00011       | CCP3_out                   | CCP3_out                   | CCP3_out                   |
| 00010       | CCP2_out                   | CCP2_out                   | CCP2_out                   |
| 00001       | CCP1_out                   | CCP1_out                   | CCP1_out                   |
| 00000       | Pin selected by<br>CWG1PPS | Pin selected by<br>CWG2PPS | Pin selected by<br>CWG3PPS |



### 29.2 ZCD Logic Output

The ZCD module includes a Status bit, which can be read to determine whether the current source or sink is active. The OUT bit of the ZCDCON register is set when the current sink is active, and cleared when the current source is active. The OUT bit is affected by the polarity bit, even if the module is disabled.

The OUT signal can also be used as input to other modules. This is controlled by the registers of the corresponding module. OUT can be used as follows:

- Gate source for TMR1/3/5
- Clock source for TMR2/4/6
- Reset source for TMR2/4/6

### 29.3 ZCD Logic Polarity

The POL bit of the ZCDCON register inverts the OUT bit relative to the current source and sink output. When the POL bit is set, a OUT high indicates that the current source is active, and a low output indicates that the current sink is active.

The POL bit affects the ZCD interrupts.

| U-0              | U-0   | U-0               | R/W-0/0 | R/W-0/0        | R/W-0/0                | R/W-0/0          | R/W-0/0     |
|------------------|-------|-------------------|---------|----------------|------------------------|------------------|-------------|
| —                | —     | —                 |         |                | CH<4:0> <sup>(1)</sup> |                  |             |
| bit 7            | •     | ·                 |         |                |                        |                  | bit 0       |
|                  |       |                   |         |                |                        |                  |             |
| Legend:          |       |                   |         |                |                        |                  |             |
| R = Readable I   | oit   | W = Writable      | bit     | U = Unimpler   | nented bit, read       | as '0'           |             |
| u = Bit is uncha | anged | x = Bit is unkr   | nown    | -n/n = Value a | at POR and BOI         | R/Value at all o | ther Resets |
| '1' = Bit is set |       | '0' = Bit is clea | ared    |                |                        |                  |             |
|                  |       |                   |         |                |                        |                  |             |

#### REGISTER 30-3: MD1CARH: MODULATION HIGH CARRIER CONTROL REGISTER

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

bit 4-0 CH<4:0>: Modulator Carrier High Selection bits<sup>(1)</sup> See Table 30-1 for signal list

Note 1: Unused selections provide an input value.

#### REGISTER 30-4: MD1CARL: MODULATION LOW CARRIER CONTROL REGISTER

| U-0   | U-0 | U-0 | R/W-0/0 | R/W-0/0 | R/W-0/0    | R/W-0/0 | R/W-0/0 |
|-------|-----|-----|---------|---------|------------|---------|---------|
| —     | —   | _   |         |         | CL<4:0>(1) |         |         |
| bit 7 |     |     |         |         |            |         | bit 0   |

| Legend:              |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | x = Bit is unknown   | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set     | '0' = Bit is cleared |                                                       |

bit 7-5 Unimplemented: Read as '0'

bit 4-0 CL<4:0>: Modulator Carrier Low Input Selection bits<sup>(1)</sup> See Table 30-1 for signal list

Note 1: Unused selections provide a zero as the input value.

© 2017 Microchip Technology Inc.

### 31.16 Clock Accuracy with Asynchronous Operation

The factory calibrates the internal oscillator block output (INTOSC). However, the INTOSC frequency may drift as VDD or temperature changes, and this directly affects the asynchronous baud rate. Two methods may be used to adjust the baud rate clock, but both require a reference clock source of some kind.

The first (preferred) method uses the OSCTUNE register to adjust the INTOSC output. Adjusting the value of the OSCTUNE register allows for fine resolution changes to the system clock source. See Section **7.2.2.3 "Internal Oscillator Frequency Adjustment"** for more information.

The other method adjusts the value of the Baud Rate Generator. This can be done automatically with the Auto-Baud Detect feature (see Section **31.17.1 "Auto-Baud Detect"**). There may not be fine enough resolution when adjusting the Baud Rate Generator to compensate for a gradual change of the peripheral clock frequency.

### 31.17 UART Baud Rate Generator (BRG)

The Baud Rate Generator (BRG) is a 16-bit timer that is dedicated to the support of the UART operation.

The UxBRGH, UxBRGL register pair determines the period of the free running baud rate timer. The multiplier of the baud rate period is determined by the BRGS bit in the UxCON0 register.

Table 31-1 contains the formulas for determining the baud rate. Example 31-1 provides a sample calculation for determining the baud rate and baud rate error.

The high baud rate range (BRGS = 1) is intended to extend the baud rate range up to a faster rate when the desired baud rate is not possible otherwise. Using the normal baud rate range (BRGS = 0) is recommended when the desired baud rate is achievable with either range.

Writing a new value to the UxBRGH, UxBRGL register pair causes the BRG timer to be reset (or cleared). This ensures that the BRG does not wait for a timer overflow before outputting the new baud rate.

If the system clock is changed during an active receive operation, a receive error or data loss may result. To avoid this problem, check the status of the RXIDL bit to make sure that the receive operation is idle before changing the system clock.

#### EXAMPLE 31-1: CALCULATING BAUD RATE ERROR



#### TABLE 31-1: BAUD RATE FORMULAS

| BRGS | BRG/UART Mode | Baud Rate Formula |
|------|---------------|-------------------|
| 1    | High Rate     | Fosc/[4 (n+1)]    |
| 0    | Normal Rate   | Fosc/[16(n+1)]    |

**Legend:** n = value of UxBRGH, UxBRGL register pair.

### 32.4 Transfer Counter

In all master modes, the transfer counter can be used to determine how many data transfers the SPI will send/receive. The transfer counter is comprised of the SPIxTCTH/L set of registers, and is also partially controlled by the SPIxTWIDTH register. The Transfer Counter has two primary modes, determined by the BMODE bit of the SPIxCON0 register. Each mode uses the SPIxTCTH/L and SPIxTWIDTH registers to determine the number and size of the transfers. In both modes, when the transfer counter reaches zero, the TCZIF interrupt flag is set.

- Note: When BMODE=1 in all master modes (and at all times in slave modes), the Transfer Counter will still decrement as transfers occur and can be used to count the number of messages sent/received, as well as to control SS(out) and to trigger TCZIF. Also when BMODE = 1, the SPIxTWIDTH register can be used in Master and Slave modes to determine the size of messages sent and received by the SPI, even if the Transfer Counter is not being actively used to control the number of messages being sent/received by the SPI module.
- 32.4.1 TOTAL BIT COUNT MODE (BMODE = 0)

In this mode, SPIxTCTH/L and SPIxTWIDTH are concatenated to determine the total number of bits to be transferred. These bits will be loaded from/into the transmit/receive FIFOs in 8-bit increments and the transfer counter will be decremented by eight until the total number of remaining bits is less than eight. If there are any remaining bits (SPIxTWIDTH  $\neq$  0), the transmit FIFO will send out one final message with any extra bits greater than the remainder ignored. The SPIxTWIDTH is the remaining bit count but the value does not change as it does for the SPIxTCT value. Similarly, the receiver will load a final byte into the receiver FIFO, and pad the extra bits with zeros. The LSBF bit of SPIxCON0 determines whether the Most Significant or Least Significant bits of this final byte are ignored/ padded. For example, when LSBF = 0 and the final transfer contains only two bits then if the last byte sent was 5Fh then the RXB of the receiver will contain 40h which are the two MSbits of the final byte padded with zeros in the LSbits.

In this mode, the SPI master will only transmit messages when the SPIxTCT value is greater than zero, regardless of TXR and RXR settings. In Master Transmit mode, the transfer starts with the data write to the SPIxTXB register or the count value written to the SPIxTCTL register, which ever occurs last. In Master Receive-only mode, the transfer clocks start when the SPIxTCTL value is written. Transfer clocks are suspended when the receive FIFO is full and resume as the FIFO is read.

#### 32.4.2 VARIABLE TRANSFER SIZE MODE (BMODE = 1)

In this mode, SPIxTWIDTH specifies the width of every individual piece of the data transfer in bits. SPIxTCTH/ SPIxTCTL specifies the number of transfers of this bit length. If SPIxTWIDTH = 0, each piece is a full byte of data. If SPIxTWIDTH  $\neq$  0, then only the specified number of bits from the transmit FIFO are shifted out, with the unused bits ignored. Received data is padded with zeros in the unused bit areas when transfered into the receive FIFO. The LSBF bit of SPIxCON0 determines whether the Most Significant or Least Significant bits of the transfers are ignored/padded. In this mode, the transfer counter being zero only stops messages from being sent/received when in "Receive only" mode.

Note: With BMODE = 1, it is possible for the transfer counter (SPIxTCTH/L) to decrement below zero, although when in "Receive only" Master mode, transfer clocks will cease when the transfer counter reaches zero.

#### REGISTER 36-27: ADSTPTH: ADC THRESHOLD SETPOINT REGISTER HIGH

| R/W-0/0         | R/W-0/0 | R/W-0/0         | R/W-0/0 | R/W-0/0        | R/W-0/0          | R/W-0/0          | R/W-0/0      |
|-----------------|---------|-----------------|---------|----------------|------------------|------------------|--------------|
|                 |         |                 | STPT    | <15:8>         |                  |                  |              |
| bit 7           |         |                 |         |                |                  |                  | bit 0        |
|                 |         |                 |         |                |                  |                  |              |
| Legend:         |         |                 |         |                |                  |                  |              |
| R = Readable    | bit     | W = Writable I  | oit     | U = Unimplen   | nented bit, read | d as '0'         |              |
| u = Bit is unch | anged   | x = Bit is unkn | own     | -n/n = Value a | at POR and BO    | R/Value at all o | other Resets |

bit 7-0 **STPT<15:8>**: ADC Threshold Setpoint MSB. Upper byte of ADC threshold setpoint, depending on ADCALC, may be used to determine ERR, see Register 36-29 for more details.

#### REGISTER 36-28: ADSTPTL: ADC THRESHOLD SETPOINT REGISTER LOW

'0' = Bit is cleared

| R/W-0/0 |
|---------|---------|---------|---------|---------|---------|---------|---------|
|         |         |         | STPT    | <7:0>   |         |         |         |
| bit 7   |         |         |         |         |         |         | bit 0   |
|         |         |         |         |         |         |         |         |

| Legend:              |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | x = Bit is unknown   | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set     | '0' = Bit is cleared |                                                       |

bit 7-0 **STPT<7:0>**: ADC Threshold Setpoint LSB. Lower byte of ADC threshold setpoint, depending on ADCALC, may be used to determine ERR, see Register 36-30 for more details.

'1' = Bit is set

| RCAL   | -L            | Relative C                          | Call                              |                 | RES   | ET                            | Reset     |                                         |           |
|--------|---------------|-------------------------------------|-----------------------------------|-----------------|-------|-------------------------------|-----------|-----------------------------------------|-----------|
| Syntax | <b>c</b> :    | RCALL n                             |                                   |                 | Synta | ax:                           | RESET     |                                         |           |
| Opera  | nds:          | -1024 ≤ n ≤                         | 1023                              |                 | Oper  | ands:                         | None      |                                         |           |
| Opera  | tion:         | $(PC) + 2 \rightarrow (PC) + 2 + 2$ | )                                 |                 | Oper  | ation:                        |           | gi <u>sters a</u> nd fla<br>a MCLR Rese | •         |
| Status | Affected:     | None                                |                                   |                 | Statu | s Affected:                   | All       |                                         |           |
| Encod  | ling:         | 1101                                | 1nnn nn:                          | nn nnnn         | Enco  | ding:                         | 0000      | 0000 111                                | L1 1111   |
| Descri | ption:        |                                     | call with a jun                   |                 | Desc  | ription:                      |           | tion provides a<br>//CLR Reset b        |           |
|        |               | •                                   | C + 2) is push                    |                 | Word  | ls:                           | 1         |                                         |           |
|        |               |                                     | , add the 2's o<br>to the PC. Sir | nce the PC will | Cycle | es:                           | 1         |                                         |           |
|        |               |                                     | nented to fetch                   |                 | QC    | ycle Activity:                |           |                                         |           |
|        |               | ,                                   | the new addre                     |                 |       | Q1                            | Q2        | Q3                                      | Q4        |
|        |               | 2-cycle inst                        |                                   |                 |       | Decode                        | Start     | No                                      | No        |
| Words  | :             | 1                                   |                                   |                 |       |                               | Reset     | operation                               | operation |
| Cycles | 3:            | 2                                   |                                   |                 | Exan  | nle:                          | RESET     |                                         |           |
| Q Cv   | cle Activity: |                                     |                                   |                 |       |                               |           |                                         |           |
| ,      | Q1            | Q2                                  | Q3                                | Q4              |       | After Instructio<br>Registers |           | alue                                    |           |
|        | Decode        | Read literal<br>'n'                 | Process<br>Data                   | Write to PC     |       | Flags*                        | = Reset V |                                         |           |
|        |               | PUSH PC to stack                    |                                   |                 |       |                               |           |                                         |           |
| Γ      | No            | No                                  | No                                | No              |       |                               |           |                                         |           |
|        | operation     | operation                           | operation                         | operation       |       |                               |           |                                         |           |

Example: HERE RCALL Jump

> Before Instruction PC = Address (HERE) After Instruction PC = Address (Jump) TOS = Address (HERE + 2)

© 2017 Microchip Technology Inc.

Preliminary

| SUBWF                                              | Subtract                                                                                                                                                                                                 | W from f                                                                                                         |                |  |  |  |
|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|----------------|--|--|--|
| Syntax:                                            | SUBWF                                                                                                                                                                                                    | f {,d {,a}}                                                                                                      |                |  |  |  |
| Operands:                                          |                                                                                                                                                                                                          | $0 \leq f \leq 255$                                                                                              |                |  |  |  |
|                                                    | d ∈ [0,1]<br>a ∈ [0,1]                                                                                                                                                                                   |                                                                                                                  |                |  |  |  |
| Operation:                                         | a ∈ [0, 1]<br>(f) – (W) –                                                                                                                                                                                | > dest                                                                                                           |                |  |  |  |
|                                                    |                                                                                                                                                                                                          |                                                                                                                  |                |  |  |  |
| Status Affected:                                   | N, OV, C,                                                                                                                                                                                                |                                                                                                                  |                |  |  |  |
| Encoding:                                          | 0101                                                                                                                                                                                                     | 11da ffi                                                                                                         |                |  |  |  |
| Description:                                       | result is st<br>result is st<br>(default).<br>If 'a' is '0',<br>selected. I<br>to select th<br>If 'a' is '0' a<br>set is enat<br>operates in<br>Addressin<br>$f \le 95$ (5FH<br>41.2.3 "By<br>ented Inst | 'd' is '0', the<br>l' is '1', the<br>egister 'f'<br>ank is<br>BSR is used<br>ed instruction<br>al Offset<br>ever |                |  |  |  |
|                                                    |                                                                                                                                                                                                          | de" for details.                                                                                                 |                |  |  |  |
| Words:                                             | 1                                                                                                                                                                                                        |                                                                                                                  |                |  |  |  |
| Cycles:                                            | 1                                                                                                                                                                                                        |                                                                                                                  |                |  |  |  |
| Q Cycle Activity:                                  | 00                                                                                                                                                                                                       | 01                                                                                                               | 04             |  |  |  |
| Q1<br>Decode                                       | Q2<br>Read                                                                                                                                                                                               | Q3<br>Process                                                                                                    | Q4<br>Write to |  |  |  |
| Decode                                             | register 'f'                                                                                                                                                                                             | Data                                                                                                             | destination    |  |  |  |
| Example 1:<br>Before Instruc<br>REG<br>W           | SUBWF<br>tion<br>= 3<br>= 2<br>= ?                                                                                                                                                                       | REG, 1, 0                                                                                                        |                |  |  |  |
| C<br>After Instructic                              | -                                                                                                                                                                                                        |                                                                                                                  |                |  |  |  |
| REG<br>W<br>C<br>Z<br>N<br>Example 2:              | = 1<br>= 2                                                                                                                                                                                               | esult is positive                                                                                                | •              |  |  |  |
| Before Instruc                                     |                                                                                                                                                                                                          | , _, _                                                                                                           |                |  |  |  |
| REG<br>W<br>C<br>After Instructic<br>REG<br>W<br>C | = 2<br>= 0<br>= 1 ; re                                                                                                                                                                                   | esult is zero                                                                                                    |                |  |  |  |
| Z<br>N                                             | = 1<br>= 0                                                                                                                                                                                               |                                                                                                                  |                |  |  |  |
| Example 3:                                         | SUBWF                                                                                                                                                                                                    | REG, 1, 0                                                                                                        |                |  |  |  |
| Before Instruc<br>REG<br>W<br>C                    | = 1<br>= 2                                                                                                                                                                                               |                                                                                                                  |                |  |  |  |
|                                                    | = ?                                                                                                                                                                                                      |                                                                                                                  |                |  |  |  |
| After Instructic<br>REG<br>W<br>C<br>Z<br>N        | on<br>= FFh ;(2<br>= 2                                                                                                                                                                                   | 's complement                                                                                                    |                |  |  |  |

| SUBWFB                                       | Su                                                                                                | Subtract W from f with Borrow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                           |       |             |  |  |  |  |
|----------------------------------------------|---------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|-------|-------------|--|--|--|--|
| Syntax:                                      | SU                                                                                                | SUBWFB f {,d {,a}}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                           |       |             |  |  |  |  |
| Operands:                                    | 0 ≤                                                                                               | $0 \leq f \leq 255$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                           |       |             |  |  |  |  |
|                                              |                                                                                                   | d ∈ [0,1]<br>a ∈ [0,1]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                           |       |             |  |  |  |  |
| Operation:                                   |                                                                                                   | $(f) - (W) - (\overline{C}) \rightarrow dest$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                           |       |             |  |  |  |  |
| Status Affected:                             | Ν,                                                                                                | N, OV, C, DC, Z                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                           |       |             |  |  |  |  |
| Encoding:                                    | C                                                                                                 | 0101 10da ffff ffff                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                           |       |             |  |  |  |  |
| Description:<br>Words:<br>Cycles:            | (bo<br>me<br>sto<br>sto<br>If 'a<br>GP<br>If 'a<br>set<br>in I<br>mo<br><b>tion</b><br><b>Ori</b> | Subtract W and the CARRY flag<br>(borrow) from register 'f' (2's comple-<br>ment method). If 'd' is '0', the result is<br>stored in W. If 'd' is '1', the result is<br>stored back in register 'f' (default).<br>If 'a' is '0', the Access Bank is selected.<br>If 'a' is '1', the BSR is used to select the<br>GPR bank.<br>If 'a' is '0' and the extended instruction<br>set is enabled, this instruction operates<br>in Indexed Literal Offset Addressing<br>mode whenever $f \le 95$ (5Fh). See Sec-<br>tion 41.2.3 "Byte-Oriented and Bit-<br>Oriented Instructions in Indexed Lit-<br>eral Offset Mode" for details. |                           |       |             |  |  |  |  |
| Q Cycle Activity:                            | -                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                           |       |             |  |  |  |  |
| Q1                                           | Q2 Q3 Q4                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                           |       |             |  |  |  |  |
| Decode                                       |                                                                                                   | Read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Proces                    | S     | Write to    |  |  |  |  |
| Example 1:                                   |                                                                                                   | ister 'f'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | REG, 1,                   | 0     | destination |  |  |  |  |
| Before Instruc                               |                                                                                                   | UBWFB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | REG, I,                   | 0     |             |  |  |  |  |
| REG<br>₩<br>C                                | =<br>=<br>=                                                                                       | 19h<br>0Dh<br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | (0001<br>(0000            |       |             |  |  |  |  |
| After Instructio<br>REG<br><sup>₩</sup><br>C | on<br>=<br>=<br>=                                                                                 | 0Ch<br>0Dh<br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | (0000<br>(0000            |       |             |  |  |  |  |
| Z<br>N                                       | =                                                                                                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ; result                  | is po | sitive      |  |  |  |  |
| Example 2:                                   | S                                                                                                 | UBWFB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | REG, 0,                   | •     |             |  |  |  |  |
| Before Instruc                               | tion                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                           |       |             |  |  |  |  |
| REG<br>W<br>C                                | =<br>=<br>=                                                                                       | 1Bh<br>1Ah<br>0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | (0001<br>(0001            |       |             |  |  |  |  |
| After Instructio<br>REG<br>W                 | =                                                                                                 | 1Bh<br>00h<br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | (0001                     | 101   | .1)         |  |  |  |  |
| C<br>Z                                       | =                                                                                                 | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ; result                  | is ze | ro          |  |  |  |  |
| N<br>Everale 2:                              | =                                                                                                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 550 1                     | 0     |             |  |  |  |  |
| Example 3:<br>Before Instruc                 |                                                                                                   | UBWFB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | REG, 1,                   | 0     |             |  |  |  |  |
| REG<br>W<br>C                                | =<br>=<br>=                                                                                       | 03h<br>0Eh<br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | (0000<br>(0000            |       |             |  |  |  |  |
| After Instruction<br>REG                     | on<br>=                                                                                           | F5h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | (1111<br>; <b>[2's co</b> |       | 01)         |  |  |  |  |
| W<br>C                                       | =                                                                                                 | 0Eh<br>0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | (0000                     |       | .0)         |  |  |  |  |
| Z<br>N                                       | =<br>=                                                                                            | 0<br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ; result is negative      |       |             |  |  |  |  |

### FIGURE 44-1: VOLTAGE FREQUENCY GRAPH, -40°C $\leq$ TA $\leq$ +125°C, PIC18F26/45/46/55/56K42 ONLY



FIGURE 44-2: VOLTAGE FREQUENCY GRAPH, -40°C <- TA <+125°C, PIC18(L)F26/27/45/46/47/ 55/56/57K42 ONLY



#### 40-Lead Plastic Ultra Thin Quad Flat, No Lead Package (MV) - 5x5 mm Body [UQFN]

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



RECOMMENDED LAND PATTERN

|                            | MILLIMETERS |          |      |      |  |
|----------------------------|-------------|----------|------|------|--|
| Dimension Limits           |             | MIN      | NOM  | MAX  |  |
| Contact Pitch              | E           | 0.40 BSC |      |      |  |
| Optional Center Pad Width  | W2          |          |      | 3.80 |  |
| Optional Center Pad Length | T2          |          |      | 3.80 |  |
| Contact Pad Spacing        | C1          |          | 5.00 |      |  |
| Contact Pad Spacing        | C2          |          | 5.00 |      |  |
| Contact Pad Width (X40)    | X1          |          |      | 0.20 |  |
| Contact Pad Length (X40)   | Y1          |          |      | 0.75 |  |
| Distance Between Pads      | G           | 0.20     |      |      |  |

Notes:

1. Dimensioning and tolerancing per ASME Y14.5M

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

Microchip Technology Drawing No. C04-2156B