



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Active                                                                     |
|----------------------------|----------------------------------------------------------------------------|
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 64MHz                                                                      |
| Connectivity               | CANbus, I <sup>2</sup> C, LINbus, SPI, UART/USART                          |
| Peripherals                | Brown-out Detect/Reset, DMA, 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-SSOP (0.209", 5.30mm Width)                                             |
| Supplier Device Package    | 28-SSOP                                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18f26k83-i-ss |

Email: info@E-XFL.COM

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

|  | TABLE 1-1: | DEVICE FEATURES |
|--|------------|-----------------|
|--|------------|-----------------|

| Features                                                                                    | PIC18(L)F25K83                                                          | PIC18(L)F26K83                                                              |  |  |
|---------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|-----------------------------------------------------------------------------|--|--|
| Program Memory (Bytes)                                                                      | 32768                                                                   | 65536                                                                       |  |  |
| Program Memory (Instructions)                                                               | 16384                                                                   | 32768                                                                       |  |  |
| Data Memory (Bytes)                                                                         | 2048                                                                    | 4096                                                                        |  |  |
| Data EEPROM Memory (Bytes)                                                                  | 1024                                                                    | 1024                                                                        |  |  |
| Packages                                                                                    | 28-pin SPDIP<br>28-pin SOIC<br>28-pin SSOP<br>28-pin QFN<br>28-pin UQFN | 28-pin SPDIP<br>28-pin SOIC<br>28-pin SSOP<br>28-pin QFN<br>28-pin UQFN     |  |  |
| I/O Ports                                                                                   | A,B,C,E <sup>(1)</sup>                                                  | A,B,C,E <sup>(1)</sup>                                                      |  |  |
| 12-Bit Analog-to-Digital Conversion Module (ADC <sup>2</sup> ) with Computation Accelerator | 5 internal<br>24 external                                               | 5 internal<br>24 external                                                   |  |  |
| Capture/Compare/PWM Modules (CCP)                                                           |                                                                         | 4                                                                           |  |  |
| 10-Bit Pulse-Width Modulator (PWM)                                                          |                                                                         | 4                                                                           |  |  |
| Timers (16-/8-bit)                                                                          | 4                                                                       | /3                                                                          |  |  |
| Serial Communications                                                                       | 2 UARTs with DMX/E                                                      | DALI/LIN, 2 I <sup>2</sup> C, 1 SPI                                         |  |  |
| Complementary Waveform Generator (CWG)                                                      | 3                                                                       |                                                                             |  |  |
| Zero-Cross Detect (ZCD)                                                                     | 1                                                                       |                                                                             |  |  |
| Data Signal Modulator (DSM)                                                                 |                                                                         | 1                                                                           |  |  |
| Signal Measurement Timer (SMT)                                                              |                                                                         | 2                                                                           |  |  |
| 5-bit Digital to Analog Converter (DAC)                                                     | 1                                                                       |                                                                             |  |  |
| Numerically Controlled Oscillator (NCO)                                                     | 1                                                                       |                                                                             |  |  |
| Comparator Module                                                                           |                                                                         | 2                                                                           |  |  |
| Direct Memory Access (DMA)                                                                  |                                                                         | 2                                                                           |  |  |
| Configurable Logic Cell (CLC)                                                               | 4                                                                       |                                                                             |  |  |
| Control Area Network (CAN)                                                                  | Yes                                                                     |                                                                             |  |  |
| Peripheral Module Disable (PMD)                                                             | Y                                                                       | es                                                                          |  |  |
| 16-bit CRC with Scanner                                                                     | Y                                                                       | es                                                                          |  |  |
| Programmable High/Low-Voltage Detect (HLVD)                                                 | Y                                                                       | es                                                                          |  |  |
| Resets (and Delays)                                                                         | POR, Progra<br>RESET Ir<br>Stack C<br>Stack U<br>(PWRT<br>MCLR, W       | mmable BOR,<br>nstruction,<br>Dverflow,<br>nderflow<br>r, OST),<br>DT, MEMV |  |  |
| Instruction Set                                                                             | 81 Inst<br>87 with Extended In                                          | ructions;<br>struction Set enabled                                          |  |  |
| Maximum Operating Frequency                                                                 | 64                                                                      | MHz                                                                         |  |  |

**Note 1:** PORTE contains the single RE3 input-only pin.

## 9.4.4 SIMULTANEOUS LOW AND HIGH PRIORITY INTERRUPTS

When both high and low interrupts are active in the same instruction cycle (i.e., simultaneous interrupt events), both the high and the low priority requests are generated. The high priority ISR is serviced first before servicing the low priority interrupt see Figure 9-5.

# FIGURE 9-5: INTERRUPT EXECUTION: SIMULTANEOUS LOW AND HIGH PRIORITY INTERRUPTS



| U-0              | R/W-1/1            | R/W-1/1           | R/W-1/1      | R/W-1/1        | R/W-1/1          | R/W-1/1          | R/W-1/1      |
|------------------|--------------------|-------------------|--------------|----------------|------------------|------------------|--------------|
| —                | CLC4IP             | CCP4IP            | CLC3IP       | CWG3IP         | CCP3IP           | TMR6IP           | TMR5GIP      |
| bit 7            |                    |                   |              |                |                  |                  | bit 0        |
|                  |                    |                   |              |                |                  |                  |              |
| Legend:          |                    |                   |              |                |                  |                  |              |
| R = Readable     | bit                | W = Writable      | bit          | U = Unimpler   | mented bit, read | l as '0'         |              |
| u = Bit is unch  | anged              | x = Bit is unkr   | nown         | -n/n = Value a | at POR and BO    | R/Value at all o | other Resets |
| '1' = Bit is set |                    | '0' = Bit is cle  | ared         |                |                  |                  |              |
|                  |                    |                   |              |                |                  |                  |              |
| bit 7            | Unimplemen         | ted: Read as '    | 0'           |                |                  |                  |              |
| bit 6            | CLC4IP: CLC        | 4 Interrupt Price | ority bit    |                |                  |                  |              |
|                  | 1 = High prio      | rity              |              |                |                  |                  |              |
|                  | 0 = Low prior      | rity              |              |                |                  |                  |              |
| bit 5            | CCP4IP: CCF        | P4 Interrupt Pri  | ority bit    |                |                  |                  |              |
|                  | 1 = High prio      | rity              |              |                |                  |                  |              |
|                  | 0 = Low prior      | nty               |              |                |                  |                  |              |
| bit 4            | CLC3IP: CLC        | 3 Interrupt Prid  | ority bit    |                |                  |                  |              |
|                  | 1 = High prio      | rity              |              |                |                  |                  |              |
| <b>L</b> H 0     |                    |                   |              |                |                  |                  |              |
| DIT 3            |                    | /G3 Interrupt P   | riority dit  |                |                  |                  |              |
|                  | $\perp$ = High pho | rity              |              |                |                  |                  |              |
| bit 2            | CCP3IP: CCF        | P3 Interrupt Pri  | oritv bit    |                |                  |                  |              |
|                  | 1 = High prio      | ritv              |              |                |                  |                  |              |
|                  | 0 = Low prior      | rity              |              |                |                  |                  |              |
| bit 1            | TMR6IP: TMF        | R6IP Interrupt I  | Priority bit |                |                  |                  |              |
|                  | 1 = High prio      | rity              |              |                |                  |                  |              |
|                  | 0 = Low prior      | rity              |              |                |                  |                  |              |
| bit 0            | TMR5GIP: TN        | MR5 Interrupt F   | Priority bit |                |                  |                  |              |
|                  | 1 = High prio      | rity              |              |                |                  |                  |              |
|                  | 0 = Low prior      | rity              |              |                |                  |                  |              |
|                  |                    |                   |              |                |                  |                  |              |

# REGISTER 9-32: IPR9: PERIPHERAL INTERRUPT PRIORITY REGISTER 9

| <b>REGISTER 1</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0-2: CPUDOZ                                                                                                                       | E: DOZE AN            | D IDLE REG     | SISTER                 |                 |                 |           |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|-----------------------|----------------|------------------------|-----------------|-----------------|-----------|
| R/W-0/u                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R/W/HC/HS-0/0                                                                                                                     | R/W-0/0               | R/W-0/0        | U-0                    | R/W-0/0         | R/W-0/0         | R/W-0/0   |
| IDLEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | DOZEN                                                                                                                             | ROI                   | DOE            | _                      |                 | DOZE<2:0>       |           |
| bit 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ·                                                                                                                                 |                       |                |                        |                 |                 | bit 0     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                   |                       |                |                        |                 |                 |           |
| Legend:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                   |                       |                |                        |                 |                 |           |
| R = Readable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | bit                                                                                                                               | W = Writable          | bit            | U = Unimple            | emented bit, r  | ead as '0'      |           |
| u = Bit is unch                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | anged                                                                                                                             | x = Bit is unkr       | iown           | -n/n = Value<br>Resets | at POR and      | BOR/Value at a  | Ill other |
| '1' = Bit is set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                   | '0' = Bit is clea     | ared           | HC = Bit is c          | cleared by ha   | rdware          |           |
| bit 7       IDLEN: Idle Enable bit         1 = A SLEEP instruction inhibits the CPU clock, but not the peripheral clock(s)         0 = A SLEEP instruction places the device into full Sleep mode         bit 6       DOZEN: Doze Enable bit <sup>(1,2)</sup> 1 = The CPU executes instruction cycles according to DOZE setting         0 = The CPU executes all instruction cycles (fastest, highest power operation)         bit 5       ROI: Recover-On-Interrupt bit         1 = Entering the Interrupt Service Routine (ISR) makes DOZEN = 0 bit, bringing the CPU to full-speer operation         0 = Interrupt entry does not change DOZEN         bit 4       DOE: Doze-On-Exit bit |                                                                                                                                   |                       |                |                        |                 | U to full-speed |           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0 = RETFIE doe                                                                                                                    | es not change         | DOZEN          | 5 5                    |                 |                 |           |
| bit 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Unimplemented                                                                                                                     | <b>1:</b> Read as '0' |                |                        |                 |                 |           |
| bit 2-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | <b>DOZE&lt;2:0&gt;:</b> Ra<br>111 =1:256<br>110 =1:128<br>101 =1:64<br>100 =1:32<br>011 =1:16<br>010 =1:8<br>001 =1:4<br>000 =1:2 | tio of CPU Inst       | ruction Cycles | to Peripheral          | I Instruction C | Cycles          |           |

## **Note 1:** When ROI = 1 or DOE = 1, DOZEN is changed by hardware interrupt entry and/or exit.

2: Entering ICD overrides DOZEN, returning the CPU to full execution speed; this bit is not affected.

### TABLE 10-1: SUMMARY OF REGISTERS ASSOCIATED WITH POWER-DOWN MODE

| Name                   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2     | Bit 1  | Bit 0    | Register on<br>Page |
|------------------------|-------|-------|-------|-------|-------|-----------|--------|----------|---------------------|
| VREGCON <sup>(1)</sup> | -     | —     | _     | —     | _     | _         | VREGPM | Reserved | 166                 |
| CPUDOZE                | IDLEN | DOZEN | ROI   | DOE   | _     | DOZE<2:0> |        |          | 167                 |

 Legend:
 --= unimplemented location, read as '0'. Shaded cells are not used in Power-Down mode.

 Note
 1:
 Not present in LF parts.

## 13.1.4 NVM UNLOCK SEQUENCE

The unlock sequence is a mechanism that protects the NVM from unintended self-write programming or erasing. The sequence must be executed and completed without interruption to successfully complete any of the following operations:

- PFM Row Erase
- Write of PFM write latches to PFM memory
- Write of PFM write latches to User IDs
- Write to Data EEPROM Memory
- · Write to Configuration Words

The unlock sequence consists of the following steps and must be completed in order:

- Write 55h to NVMCON2
- Write AAh to NMVCON2
- · Set the WR bit of NVMCON1

Once the WR bit is set, the processor will stall internal operations until the operation is complete and then resume with the next instruction.

Since the unlock sequence must not be interrupted, global interrupts should be disabled prior to the unlock sequence and re-enabled after the unlock sequence is completed.





| BCF<br>BANKSEL | INTCON0,GIE<br>NVMCON1                                                                                                                                                                                                    | ; | Recommended so sequence is not interrupted |  |  |  |  |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------------------------------------------|--|--|--|--|
| BSF            | NVMCON1,WREN                                                                                                                                                                                                              | ; | Enable write/erase                         |  |  |  |  |
| MOVLW          | 55h                                                                                                                                                                                                                       | ; | Load 55h                                   |  |  |  |  |
| MOVWF          | NVMCON2                                                                                                                                                                                                                   | ; | Step 1: Load 55h into NVMCON2              |  |  |  |  |
| MOVLW          | AAh                                                                                                                                                                                                                       | ; | Step 2: Load W with AAh                    |  |  |  |  |
| MOVWF          | NVMCON2                                                                                                                                                                                                                   | ; | Step 3: Load AAh into NVMCON2              |  |  |  |  |
| BSF            | INTCON1,WR                                                                                                                                                                                                                | ; | Step 4: Set WR bit to begin write/erase    |  |  |  |  |
| BSF            | INTCON0,GIE                                                                                                                                                                                                               | ; | Re-enable interrupts                       |  |  |  |  |
| Note 1:        | Sequence begins when NVMCON2 is written; steps 1-4 must occur in the cycle-accurate order<br>shown. If the timing of the steps 1 to 4 is corrupted by an interrupt or a debugger Halt, the action<br>will not take place. |   |                                            |  |  |  |  |
| 2:             | Opcodes shown are illustrative; any instruction that has the indicated effect may be used.                                                                                                                                |   |                                            |  |  |  |  |

# EXAMPLE 13-2: NVM UNLOCK SEQUENCE

## 15.5.3.1 Clearing the SIRQEN bit

Clearing the SIRQEN bit (DMAxCON1 register) stops the sampling of external start interrupt triggers hence preventing further DMA Message transfers.

An example would be a communications peripheral with a level-triggered interrupt. The peripheral will continue to request data (because its buffer is empty) even though there is no more data to be moved. Disabling the SIRQEN bit prevents the DMA from processing these requests

### 15.5.3.2 Source/Destination Stop

The SSTP and DSTP bits (DMAxCON0 register) determine whether or not to disable the hardware triggers (SIRQEN = 0) once a DMA message has completed.

When the SSTP bit is set and the DMAxSCNT = 0, then the SIRQEN bit will be cleared. Similarly, when the DSTP bit is set and the DMAxDCNT = 0, the SIRQEN bit will be cleared.

Note: The SSTP and DSTP bits are independent functions and do not depend on each other. It is possible for a message to be stopped by either counter at message end or both counters at message end.

## 15.6 Types of Hardware Triggers

The DMA has two different trigger inputs namely the Source trigger and the abort trigger. Each of these trigger sources is user configurable using the DMAxSIRQ and DMAxAIRQ registers.

Based on the source selected for each trigger, there are two types of requests that can be sent to the DMA.

- Edge triggers
- · Level triggers

## 15.6.1 EDGE TRIGGER REQUESTS

An Edge request occurs only once when a given module interrupt requirements are true.

## 15.6.2 LEVEL TRIGGER REQUESTS

A level request is asserted as long as the condition that causes the interrupt is true.

## 15.7 Types of Data Transfers

Based on the memory access capabilities of the DMA (See Table 15-1), the following sections discuss the different types of data movement between the Source and Destination Memory regions.

• N: 1

This type of transfer is common when sending predefined data packets (such as strings) through a single interface point (such as communications modules transmit registers).

• N: N

This type of transfer is useful for moving information out of the Program Flash or Data EEPROM to SRAM for manipulation by the CPU or other peripherals.

• 1: N

This type of transfer is common when bridging two different modules data streams together (communications bridge).

• 1: N

This type of transfer is useful for moving information from a single data source into a memory buffer (communications receive registers).

# 15.8 DMA Interrupts

Each DMA has its own set of four interrupt flags, used to indicate a range of conditions during data transfers. The interrupt flag bits can be accessed using the corresponding PIR registers (Refer to the Interrupt Section).

### 15.8.1 DMA SOURCE COUNT INTERRUPT

The DMAxSCNTIF source count interrupt flag is set every time the DMAxSCNT<11:0> reaches zero and is reloaded to its starting value.

## 15.8.2 DMA DESTINATION COUNT INTERRUPT

The DMAxDCNTIF destination count interrupt flag is set every time the DMAxDCNT<11:0> reaches zero and is reloaded to its starting value.

The DMA Source Count zero and Destination Count zero interrupts are used in conjunction to determine when to signal the CPU when the DMA Messages are completed.

### 15.8.3 ABORT INTERRUPT

The DMAxAIF abort interrupt flag is used to signal that the DMA has halted activity due to an abort signal from one of the abort sources. This is used to indicate that the transaction has been halted for some reason.



| REGISTER 22-2: T | <b>TXRST: TIMER2 EXTERNAL RESET SIGNAL SELECTION REGISTER</b> |
|------------------|---------------------------------------------------------------|
|------------------|---------------------------------------------------------------|

| 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 |
|-------|-----|-----|---------|---------|-----------|---------|---------|
|       | _   | —   |         |         | RSEL<4: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-5 Unimplemented: Read as '0'

bit 4-0 RSEL<4:0>: Timer2 External Reset Signal Source Selection bits

|             | T2TMR                   | TMR4                    | TMR6                    |
|-------------|-------------------------|-------------------------|-------------------------|
| RSEL<4:0>   | Reset Source            | Reset Source            | Reset Source            |
| 11111-11001 | Reserved                | Reserved                | Reserved                |
| 11000       | UART2_tx_edge           | UART2_tx_edge           | UART2_tx_edge           |
| 10111       | UART2_rx_edge           | UART2_rx_edge           | UART2_rx_edge           |
| 10110       | UART1_tx_edge           | UART1_tx_edge           | UART1_tx_edge           |
| 10101       | UART1_rx_edge           | UART1_rx_edge           | UART1_rx_edge           |
| 10100       | CLC4_out                | CLC4_out                | CLC4_out                |
| 10011       | CLC3_out                | CLC3_out                | CLC3_out                |
| 10010       | CLC2_out                | CLC2_out                | CLC2_out                |
| 10001       | CLC1_out                | CLC1_out                | CLC1_out                |
| 10000       | ZCD_OUT                 | ZCD_OUT                 | ZCD_OUT                 |
| 01111       | CMP2OUT                 | CMP2OUT                 | CMP2OUT                 |
| 01110       | CMP1OUT                 | CMP1OUT                 | CMP1OUT                 |
| 01101-01100 | Reserved                | Reserved                | Reserved                |
| 01011       | PWM8OUT                 | PWM8OUT                 | PWM8OUT                 |
| 01010       | PWM7OUT                 | PWM7OUT                 | PWM7OUT                 |
| 01001       | PWM6OUT                 | PWM6OUT                 | PWM6OUT                 |
| 01000       | PWM5OUT                 | PWM5OUT                 | PWM5OUT                 |
| 00111       | CCP4OUT                 | CCP4OUT                 | CCP4OUT                 |
| 00110       | CCP3OUT                 | CCP3OUT                 | CCP3OUT                 |
| 00101       | CCP2OUT                 | CCP2OUT                 | CCP2OUT                 |
| 00100       | CCP1OUT                 | CCP10UT                 | CCP10UT                 |
| 00011       | TMR6 postscaled         | TMR6 postscaled         | Reserved                |
| 00010       | TMR4 postscaled         | Reserved                | TMR4 postscaled         |
| 00001       | Reserved                | T2TMR postscaled        | T2TMR postscaled        |
| 00000       | Pin selected by T2INPPS | Pin selected by T4INPPS | Pin selected by T6INPPS |





# 26.2.3.1 Direction Change in Full-Bridge Mode

In Full-Bridge mode, changing MODE<2:0> controls the forward/reverse direction. Changes to MODE<2:0> change to the new direction on the next rising edge of the modulated input.

A direction change is initiated in software by changing the MODE<2:0> bits of the CWGxCON0 register. The sequence is illustrated in Figure 26-8.

- The associated active output CWGxA and the inactive output CWGxC are switched to drive in the opposite direction.
- The previously modulated output CWGxD is switched to the inactive state, and the previously inactive output CWGxB begins to modulate.
- CWG modulation resumes after the directionswitch dead band has elapsed.

## 26.2.3.2 Dead-Band Delay in Full-Bridge Mode

Dead-band delay is important when either of the following conditions is true:

- The direction of the CWG output changes when the duty cycle of the data input is at or near 100%, or
- 2. The turn-off time of the power switch, including the power device and driver circuit, is greater than the turn-on time.

The dead-band delay is inserted only when changing directions, and only the modulated output is affected. The statically-configured outputs (CWGxA and CWGxC) are not afforded dead band, and switch essentially simultaneously.

Figure 26-8 shows an example of the CWG outputs changing directions from forward to reverse, at near 100% duty cycle. In this example, at time t1, the output of CWGxA and CWGxD become inactive, while output CWGxC becomes active. Since the turn-off time of the power devices is longer than the turn-on time, a shootthrough current will flow through power devices QC and QD for the duration of 't'. The same phenomenon will occur to power devices QA and QB for the CWG direction change from reverse to forward.

When changing the CWG direction at high duty cycle is required for an application, two possible solutions for eliminating the shoot-through current are:

- 1. Reduce the CWG duty cycle for one period before changing directions.
- 2. Use switch drivers that can drive the switches off faster than they can drive them on.



# FIGURE 26-8: EXAMPLE OF PWM DIRECTION CHANGE AT NEAR 100% DUTY CYCLE

| 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             |
|-----------------|---------------------|------------------|------------------|---------------------|---------------------|---------------------|---------------------|
| OVRD            | OVRC                | OVRB             | OVRA             | STRD <sup>(2)</sup> | STRC <sup>(2)</sup> | STRB <sup>(2)</sup> | STRA <sup>(2)</sup> |
| bit 7           |                     |                  |                  |                     |                     |                     | bit 0               |
|                 |                     |                  |                  |                     |                     |                     |                     |
| Legend:         |                     |                  |                  |                     |                     |                     |                     |
| R = Readab      | le bit              | W = Writable     | bit              | U = Unimplen        | nented bit, read    | l as '0'            |                     |
| u = Bit is un   | changed             | x = Bit is unkr  | nown             | -n/n = Value a      | at POR and BO       | R/Value at all c    | ther Resets         |
| '1' = Bit is se | et                  | '0' = Bit is cle | ared             | q = Value dep       | ends on condit      | ion                 |                     |
|                 |                     |                  |                  |                     |                     |                     |                     |
| bit 7           | OVRD: Steer         | ing Data D bit   |                  |                     |                     |                     |                     |
| bit 6           | OVRC: Steer         | ing Data C bit   |                  |                     |                     |                     |                     |
| bit 5           | OVRB: Steer         | ing Data B bit   |                  |                     |                     |                     |                     |
| bit 4           | OVRA: Steer         | ing Data A bit   |                  |                     |                     |                     |                     |
| bit 3           | STRD: Steeri        | ng Enable bit D  | ) <sup>(2)</sup> |                     |                     |                     |                     |
|                 | 1 = CWGxD o         | output has the   | CWG data inp     | ut waveform wi      | th polarity contr   | ol from POLD I      | oit                 |
|                 | 0 = CWGxD d         | output is assigr | ed to value of   | OVRD bit            |                     |                     |                     |
| bit 2           | STRC: Steeri        | ng Enable bit C  | (2)              |                     |                     |                     |                     |
|                 | 1 = CWGxC o         | output has the   | CWG data inp     | ut waveform wit     | th polarity contr   | ol from POLC I      | oit                 |
|                 | 0 = CWGxC d         | output is assigr | ied to value of  | OVRC bit            |                     |                     |                     |
| bit 1           | STRB: Steeri        | ng Enable bit E  | 3(2)             |                     |                     |                     |                     |
|                 | 1 = CWGxB c         | output has the   | CWG data inpu    | ut waveform wit     | h polarity contr    | ol from POLB b      | bit                 |
|                 | 0 = CWGxB c         | output is assign | ed to value of   | OVRB bit            |                     |                     |                     |
| bit 0           | STRA: Steeri        | ng Enable bit A  | (2)              |                     |                     |                     |                     |
|                 | 1 = CWGxA c         | output has the   | CWG data inpi    | ut waveform wit     | h polarity contr    | ol from POLA b      | bit                 |
|                 | 0 = CWGXA c         | output is assign | ied to value of  | OVRA bit            |                     |                     |                     |
| Note 1: T       | he bits in this reg | ister apply only | when MODE        | <2:0> = 00x (R      | egister 26-1, St    | teering modes)      |                     |

# **REGISTER 26-5:** CWGxSTR<sup>(1)</sup>: CWG STEERING CONTROL REGISTER

**2:** This bit is double-buffered when MODE < 2:0 > = 0.01.

# 29.10 Register Definitions: ZCD Control

| R/W-0/0         | U-0              | R-x                   | R/W-0/0         | U-0              | U-0             | R/W-0/0         | R/W-0/0 |
|-----------------|------------------|-----------------------|-----------------|------------------|-----------------|-----------------|---------|
| SEN             | —                | OUT                   | POL             |                  | _               | INTP            | INTN    |
| bit 7           |                  |                       |                 |                  |                 |                 | bit 0   |
|                 |                  |                       |                 |                  |                 |                 |         |
| Legend:         |                  |                       |                 |                  |                 |                 |         |
| R = Readable    | bit              | W = Writable          | bit             | U = Unimple      | mented bit, rea | ad as '0'       |         |
| -n = Value at F | POR              | '1' = Bit is set      | t               | '0' = Bit is cle | eared           | x = Bit is unkr | nown    |
|                 |                  |                       |                 |                  |                 |                 |         |
| bit 7           | SEN: Zero-Cr     | oss Detect So         | ftware Enable   | bit              |                 |                 |         |
|                 | This bit is igno | ored when ZC          | DSEN Configu    | ration bit is se | et.             |                 |         |
|                 | 1= Zero-cro      | ss detect is er       | nabled.         |                  |                 |                 |         |
|                 | 0= Zero-cro      | ss detect is di       | sabled. ZCD p   | in operates ad   | cording to PP   | S and TRIS cont | rols.   |
| bit 6           | Unimplement      | ted: Read as '        | 0'              |                  |                 |                 |         |
| bit 5           | OUT: Zero-Cr     | oss Detect Da         | ta Output bit   |                  |                 |                 |         |
|                 | ZCDPOL bit =     | <u>: 0:</u>           |                 |                  |                 |                 |         |
|                 | 1 = 2CD pin is   | s sinking curre       | nt              |                  |                 |                 |         |
|                 | 0 = 2CD pin s    | s sourcing cun        | ent             |                  |                 |                 |         |
|                 | 1 = ZCD pin is   | <u> </u>              | rent            |                  |                 |                 |         |
|                 | 0 = ZCD pin is   | s sinking curre       | nt              |                  |                 |                 |         |
| bit 4           | POL: Zero-Cr     | oss Detect Po         | larity bit      |                  |                 |                 |         |
|                 | 1 = ZCD logic    | output is inve        | rted            |                  |                 |                 |         |
|                 | 0 = ZCD logic    | output is not i       | nverted         |                  |                 |                 |         |
| bit 3-2         | Unimplement      | <b>ted:</b> Read as ' | 0'              |                  |                 |                 |         |
| bit 1           | INTP: Zero-Ci    | ross Detect Po        | ositive-Going E | dge Interrupt    | Enable bit      |                 |         |
|                 | 1 = ZCDIF bit    | is set on low-        | to-high ZCD_o   | utput transitio  | n               |                 |         |
|                 | 0 = ZCDIF bit    | is unaffected         | by low-to-high  | ZCD_output t     | ransition       |                 |         |
| bit 0           | INTN: Zero-C     | ross Detect Ne        | egative-Going   | Edge Interrup    | t Enable bit    |                 |         |
|                 | 1 = ZCDIF bit    | is set on high        | -to-low ZCD_o   | utput transitio  | n               |                 |         |
|                 | 0 = ZCDIF bit    | is unaffected         | by high-to-low  | ZCD_output t     | ransition       |                 |         |

## REGISTER 29-1: ZCDCON: ZERO-CROSS DETECT CONTROL REGISTER

# TABLE 29-1: SUMMARY OF REGISTERS ASSOCIATED WITH THE ZCD MODULE

| Name   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Register<br>on page |
|--------|-------|-------|-------|-------|-------|-------|-------|-------|---------------------|
| ZCDCON | SEN   | —     | OUT   | POL   | —     | —     | INTP  | INTN  | 448                 |

**Legend:** — = unimplemented, read as '0'. Shaded cells are unused by the ZCD module.

| MS<4:0 | >  | Connection               |
|--------|----|--------------------------|
| 1 1111 | 31 | Reserved                 |
| -      | -  |                          |
| 1 1000 | 24 |                          |
| 1 0111 | 23 | CAN_tx0                  |
| 1 0110 | 22 | SPI1 SDO                 |
| 1 0101 | 21 | Reserved                 |
| 1 0100 | 20 | UART2 TX                 |
| 1 0011 | 19 | UART1 TX                 |
| 1 0010 | 18 | CLC4 OUT                 |
| 1 0001 | 17 | CLC3 OUT                 |
| 1 0000 | 16 | CLC2 OUT                 |
| 0 1111 | 15 | CLC1 OUT                 |
| 0 1110 | 14 | CMP2 OUT                 |
| 0 1101 | 13 | CMP1 OUT                 |
| 0 1100 | 12 | NCO1 OUT                 |
| 0 1011 | 11 | Reserved                 |
| 0 1010 | 10 | Reserved                 |
| 0 1001 | 9  | PWM8 OUT                 |
| 0 1000 | 8  | PWM7 OUT                 |
| 0 0111 | 7  | PWM6 OUT                 |
| 0 0110 | 6  | PWM5 OUT                 |
| 0 0101 | 5  | CCP4 OUT                 |
| 0 0100 | 4  | CCP3 OUT                 |
| 0 0011 | 3  | CCP2 OUT                 |
| 0 0010 | 2  | CCP1 OUT                 |
| 0 0001 | 1  | DSM1 BIT                 |
| 0 0000 | 0  | Pin selected by MDSRCPPS |

# TABLE 30-2:MD1SRC SELECTION MUX<br/>CONNECTIONS

## TABLE 30-3: SUMMARY OF REGISTERS ASSOCIATED WITH DATA SIGNAL MODULATOR MODE

| Name    | Bit 7 | Bit 6 | Bit 5 | Bit 4  | Bit 3     | Bit 2    | Bit 1 | Bit 0  | Register<br>on Page |
|---------|-------|-------|-------|--------|-----------|----------|-------|--------|---------------------|
| MD1CON0 | EN    | —     | OUT   | OPOL   |           | —        | —     | BIT    | 455                 |
| MD1CON1 | —     | —     | CHPOL | CHSYNC | -         | —        | CLPOL | CLSYNC | 456                 |
| MD1CARH | —     | —     | —     | _      | -         | CHS<2:0> |       | 457    |                     |
| MD1CARL | —     | —     | —     | -      | -         | CLS<2:0> |       | 457    |                     |
| MDSRC   | —     | —     | —     | —      | SRCS<3:0> |          |       | 458    |                     |

**Legend:** — = unimplemented, read as '0'. Shaded cells are not used in the Data Signal Modulator mode.

## 33.5.12 MASTER RECEPTION IN 10-BIT ADDRESSING MODE

This section describes the sequence of events for the  $I^2C$  module configured as an  $I^2C$  master in 10-bit Addressing mode and is receiving data. Figure 33-22 is used as a visual reference for this description.

- Master software loads high address byte in I2CxADB1 and low address byte in I2CxADB0 for write and sets restart enable (RSTEN) bit.
- 2. Master software sets START bit.
- Master hardware waits for BFRE bit to be set; then shifts out start, high address and waits for acknowledge.
- 4. If slave responds with a NACK, master hardware sends Stop and ends communication.
- 5. If slave responds with ACK, master hardware shifts out the low address.
- If the transmit buffer empty flag (TXBE) is set and I2CxCNT! = 0, the clock is stretched on 8th falling SCL edge. Allowing master software writes next data to I2CxTXB.
- Master hardware sends 9th SCL pulse for ACK from slave and loads the shift register from I2CxTXB.
- 8. If slave responds with a NACK, master hardware sends Stop and ends communication.
- If slave responds with an ACK and I2CxCNT = 0, master hardware sets MDR bit, go to Step 11.
- If slave responds with an ACK and I2CxCNT! = 0, master hardware outputs data in shift register on SDA and waits for ACK from slave. Go to step 4.
- 11. Master software loads I2CxADB0 for read, and I2CCNT with the number of bytes to be received in the current transaction.
- 12. Master software sets Start bit.
- 13. Master hardware shifts out Restart and high address with R/W = 1.
- 14. Master sends out 9th SCL pulse for ACK from slave.
- 15. If slave responds with a NACK, master hardware sends Stop or sets MDR (RSEN bit).
- 16. If slave responds with an ACK, master hardware shifts 7 bits of data into the shift register from the slave.
- 17. If the receive buffer full flag (RXBF) is set, clock is stretched on seventh falling SCL edge.
- 18. Master software can clear clock stretching by reading the previous data in the receive buffer.
- 19. Master hardware shifts 8th bit of data into the shift register from slave and loads it into I2CxRXB.
- 20. Master software reads data from I2CxRXB register.

- 21. If I2CxCNT! = 0, master hardware clocks out ACKDT as ACK value to slave.
- 22. If I2CxCNT = 0, master hardware clocks out ACKCNT as ACK value to slave
- 23. Go to step 4.

| R/W-1                                   | R/W-1 | R/W-1             | R/W-1 | R/W-1                                                 | R/W-1        | R/W-1         | R/W-1 |
|-----------------------------------------|-------|-------------------|-------|-------------------------------------------------------|--------------|---------------|-------|
| ADR7                                    | ADR6  | ADR5              | ADR4  | ADR3                                                  | ADR2         | ADR1          | ADR0  |
| bit 7                                   |       |                   |       |                                                       |              |               | bit 0 |
|                                         |       |                   |       |                                                       |              |               |       |
| Legend:                                 |       |                   |       |                                                       |              |               |       |
| R = Readable b                          | oit   | W = Writable I    | bit   | U = Unimplemented bit, read as '0'                    |              |               |       |
| u = Bit is unchanged x = Bit is unknown |       |                   | iown  | -n/n = Value at POR and BOR/Value at all other Resets |              |               |       |
| '1' = Bit is set                        |       | '0' = Bit is clea | ared  | HS = Hardwa                                           | are set HC = | Hardware clea | r     |

| REGISTER 33-12: | I2CxADR0: I <sup>2</sup> C | ADDRESS 0 | REGISTER |
|-----------------|----------------------------|-----------|----------|
|                 |                            |           |          |

| bit 7-0 | ADR<7-0>: Address 1 bits                                  |
|---------|-----------------------------------------------------------|
|         | MODE<2:0> = 00x   11x - 7-bit Slave/Multi-Master Modes    |
|         | ADR0<7:1>:7-bit Slave Address                             |
|         | ADR0<0>: Unused in this mode; bit state is a "don't care" |
|         | $MODE < 2.0 > = 0.1 \times - 10$ -bit Slave Modes         |

ADR0<7:0>:Eight Least Significant bits of 10-bit address 0

# REGISTER 33-15: I2CXADR3: I<sup>2</sup>C ADDRESS 3 REGISTER

| R/W-1  | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | U-0   |
|--------|-------|-------|-------|-------|-------|-------|-------|
| ADR14  | ADR13 | ADR12 | ADR11 | ADR10 | ADR9  | ADR8  | _     |
| bit 15 |       |       |       |       |       |       | bit 8 |
| R/W-1  | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | U-0   |
| ADR7   | ADR6  | ADR5  | ADR4  | ADR3  | ADR2  | ADR1  | —     |
| 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 | HS = Hardware set HC = Hardware clear                 |

bit 7-0 ADR<7-0>: Address 3 bits

MODE<2:0> = 000 | 110 - 7-bit Slave/Multi-Master Modes

ADR<7:1>:7-bit Slave Address

ADR<0>: Unused in this mode; bit state is a "don't care"

MODE<2:0> = 001 | 111 - 7-bit Slave/Multi-Master Mode with Masking

MSK1<7:1>:7-bit Slave Address

MSK1<0>: Unused in this mode; bit state is a "don't care"

MODE<2:0> = 010 - 10-Bit Slave Mode

ADR<14-10>:Bit pattern sent by master is fixed by I<sup>2</sup>C specification and must be equal to '11110'. However, these bit values are compared by hardware to the received data to determine a match. It is up to the user to set these bits as '11110'
ADR<9-8>:Two Most Significant bits of 10-bit address

MODE<2:0> = 011 - 10-Bit Slave Mode with Masking

**MSK0<14-8>:**The received address byte, bit *n*, is compared to I2CxADR0 to detect I<sup>2</sup>C address match

# 34.14 CAN Interrupts

The module has several sources of interrupts. Each of these interrupts can be individually enabled or disabled. The PIR5 register contains interrupt flags. The PIE5 register contains the enables for the eight main interrupts. A special set of read-only bits in the CANSTAT register, the ICODE bits, can be used in combination with a jump table for efficient handling of interrupts.

All interrupts have one source, with the exception of the error interrupt and buffer interrupts in Mode 1 and 2. Any of the error interrupt sources can set the error interrupt flag. The source of the error interrupt can be determined by reading the Communication Status register, COMSTAT. In Mode 1 and 2, there are two interrupt enable/disable and flag bits – one for all transmit buffers and the other for all receive buffers.

The interrupts can be broken up into two categories: receive and transmit interrupts.

The receive related interrupts are:

- Receive Interrupts
- · Wake-up Interrupt
- Receiver Overrun Interrupt
- Receiver Warning Interrupt
- · Receiver Error-Passive Interrupt

The transmit related interrupts are:

- Transmit Interrupts
- Transmitter Warning Interrupt
- Transmitter Error-Passive Interrupt
- · Bus-Off Interrupt

## 34.14.1 INTERRUPT CODE BITS

To simplify the interrupt handling process in user firmware, the ECAN module encodes a special set of bits. In Mode 0, these bits are ICODE<3:1> in the CANSTAT register. In Mode 1 and 2, these bits are EICODE<4:0> in the CANSTAT register. Interrupts are internally prioritized such that the higher priority interrupts are assigned lower values. Once the highest priority interrupt condition has been cleared, the code for the next highest priority interrupt that is pending (if any) will be reflected by the ICODE bits (see Table 34-4). Note that only those interrupt sources that have their associated interrupt enable bit set will be reflected in the ICODE bits.

In Mode 2, when a receive message interrupt occurs, the EICODE bits will always consist of '10000'. User firmware may use FIFO Pointer bits to actually access the next available buffer.

## 34.14.2 TRANSMIT INTERRUPT

When the transmit interrupt is enabled, an interrupt will be generated when the associated transmit buffer becomes empty and is ready to be loaded with a new message. In Mode 0, there are separate interrupt enable/ disable and flag bits for each of the three dedicated transmit buffers. The TXBnIF bit will be set to indicate the source of the interrupt. The interrupt is cleared by the MCU, resetting the TXBnIF bit to a '0'. In Mode 1 and 2, all transmit buffers share one interrupt enable/disable bit and one flag bit. In Mode 1 and 2, TXBnIE in PIE5 and TXBnIF in PIR5 indicate when a transmit buffer has completed transmission of its message. TXBnIF, TXBnIE and TXBnIP in PIR5, PIE5 and IPR5, respectively, are not used in Mode 1 and 2. Individual transmit buffer interrupts can be enabled or disabled by setting or clearing TXBnIE and B0IE register bits. When a shared interrupt occurs, user firmware must poll the TXREQ bit of all transmit buffers to detect the source of interrupt.

### 34.14.3 RECEIVE INTERRUPT

When the receive interrupt is enabled, an interrupt will be generated when a message has been successfully received and loaded into the associated receive buffer. This interrupt is activated immediately after receiving the End-of-Frame (EOF) field.

In Mode 0, the RXBnIF bit is set to indicate the source of the interrupt. The interrupt is cleared by the MCU, resetting the RXBnIF bit to a '0'.

In Mode 1 and 2, all receive buffers share RXBnIE, RXBnIF and RXBnIP in PIE5, PIR5 and IPR5, respectively. Individual receive buffer interrupts can be controlled by the TXBnIE and BIE0 registers. In Mode 1, when a shared receive interrupt occurs, user firmware must poll the RXFUL bit of each receive buffer to detect the source of interrupt. In Mode 2, a receive interrupt indicates that the new message is loaded into FIFO. FIFO can be read by using FIFO Pointer bits, FP.

# 34.15.5 CAN MODULE I/O CONTROL REGISTER

This register controls the operation of the CAN module's I/O pins in relation to the rest of the microcontroller.

## REGISTER 34-55: CIOCON: CAN I/O CONTROL REGISTER

| R/W-0  | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0  |
|--------|-----|-----|-----|-----|-----|-----|--------|
| TX1SRC | —   | —   | —   | —   | —   | —   | CLKSEL |
| bit 7  |     |     |     |     |     |     | bit 0  |

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

| bit 7   | TX1SRC: CAN_tx1 Signal Data Source bit                                                                                              |
|---------|-------------------------------------------------------------------------------------------------------------------------------------|
|         | 1 = CAN tx1 signal will output the CAN clock                                                                                        |
|         | 0 = CAN_tx1 signal will output CANTX                                                                                                |
| bit 6-1 | Unimplemented: Read as '0'                                                                                                          |
| bit 0   | CLKSEL: CAN Clock Source Selection bit                                                                                              |
|         | 1 = CAN clock is sourced by the clock selected by the FEXTOSC Configuration bit field, regardless of<br>system clock <sup>(1)</sup> |
|         | 0 = CAN clock is sourced from the system clock                                                                                      |

**Note 1:** When CLKSEL = 1, the clock supplied by FEXTOSC must be less than or equal to the system clock. If the CAN clock is greater than the system clock, unexpected behavior will occur.

## 36.2.1 CALIBRATION

## 36.2.1.1 Single-Point Calibration

Single-point calibration is performed by application software using Equation 36-1 and the assumed Mt. A reading of VTSENSE at a known temperature is taken, and the theoretical temperature is calculated by temporarily setting TOFFSET = 0. Then TOFFSET is computed as the difference of the actual and calculated temperatures. Finally, TOFFSET is stored in nonvolatile memory within the device, and is applied to future readings to gain a more accurate measurement.

## 36.2.1.2 Higher-Order Calibration

If the application requires more precise temperature measurement, additional calibrations steps will be necessary. For these applications, two-point or three-point calibration is recommended.

| Note 1: | The TOFFSET value may be determine<br>by the user with a temperature test.                                                                                                                                                                                                          |  |  |  |  |  |  |  |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 2:      | Although the measurement range is $-40^{\circ}$ C to $+125^{\circ}$ C, due to the variations in offset error, the single-point uncalibrated calculated TSENSE value may indicate a temperature from $-140^{\circ}$ C to $+225^{\circ}$ C, before the calibration offset is applied. |  |  |  |  |  |  |  |
| 3:      | The User must take into consideration<br>self-heating of the device at different<br>clock frequencies and output pin loading.<br>For package related thermal characteris-                                                                                                           |  |  |  |  |  |  |  |

tics information, refer to Table 45-6.

## 36.2.2 TEMPERATURE RESOLUTION

The resolution of the ADC reading, Ma (°C/count), depends on both the ADC resolution N and the reference voltage used for conversion, as shown in Equation 36-2. It is recommended to use the smallest VREF value, such as 2.048 FVR reference voltage, instead of VDD.

Note: Refer to Table 45-17 for FVR reference voltage accuracy.

# EQUATION 36-2: TEMPERATURE RESOLUTION (°C/LSb)

$$Ma = \frac{V_{REF}}{2^{N}} \times Mt$$
$$Ma = \frac{\frac{V_{REF}}{2^{N}}}{Mv}$$

Where:

Mv = sensor voltage sensitivity (V/°C)

VREF = Reference voltage of the ADC module (in Volts) N = Resolution of the ADC

The typical Mv value for a single diode is approximately -1.267 to -1.32 mV/C.

The typical Mv value for a stack of two diodes (Low Range setting) is approximately -2.533 mV/C.

The typical Mv value for a stack of three diodes (High range setting) is approximately -3.8 mV/C.

# 36.3 ADC Acquisition Time

To ensure accurate temperature measurements, the user must wait a certain time for the ADC value to settle, after the ADC input multiplexer is connected to the temperature indicator output, before the conversion is performed.

| Addr  | Name        | Bit 7                                    | Bit 6 | Bit 5   | Bit 4   | Bit 3   | Bit 2   | Bit 1   | Bit 0   | Register<br>on page |  |
|-------|-------------|------------------------------------------|-------|---------|---------|---------|---------|---------|---------|---------------------|--|
| 37A0h | RXF0SIDH    | SID10 SID9 SID8 SID7 SID6 SID5 SID4 SID3 |       |         |         |         |         |         |         |                     |  |
| 379Fh | CANCON_RO4  | CANCON_RO4                               |       |         |         |         |         |         |         |                     |  |
| 379Eh | CANSTAT_RO4 | CANSTAT_RO4                              |       |         |         |         |         |         |         |                     |  |
| 379Dh | B5D7        | B5D7                                     |       |         |         |         |         |         |         |                     |  |
| 379Ch | B5D6        |                                          | B5D6  |         |         |         |         |         |         |                     |  |
| 379Bh | B5D5        | B5D5                                     |       |         |         |         |         |         |         |                     |  |
| 379Ah | B5D4        | B5D4                                     |       |         |         |         |         |         |         |                     |  |
| 3799h | B5D3        | B5D3                                     |       |         |         |         |         |         |         |                     |  |
| 3798h | B5D2        | B5D2                                     |       |         |         |         |         |         |         |                     |  |
| 3797h | B5D1        | B5D1                                     |       |         |         |         |         |         |         |                     |  |
| 3796h | B5D0        | B5D0                                     |       |         |         |         |         |         |         |                     |  |
| 3795h | B5DLC       | _                                        | RXRTR | RB1     | RB0     | DLC3    | DLC2    | DLC1    | DLC0    | 628                 |  |
| 3795h | B5DLC       | _                                        | TXRTR | _       | _       | DLC3    | DLC2    | DLC1    | DLC0    | 629                 |  |
| 3794h | B5EIDL      | EID7                                     | EID6  | EID5    | EID4    | EID3    | EID2    | EID1    | EID0    | 626                 |  |
| 3793h | B5EIDH      | EID15                                    | EID14 | EID13   | EID12   | EID11   | EID10   | EID9    | EID8    | 626                 |  |
| 3792h | B5SIDL      | SID2                                     | SID1  | SID0    | SRR     | EXIDE   | _       | EID17   | EID16   | 625                 |  |
| 3791h | B5SIDH      | SID10                                    | SID9  | SID8    | SID7    | SID6    | SID5    | SID4    | SID3    | 624                 |  |
| 3790h | B5CON       | RXFUL                                    | RXM1  | RXRTRRO | FILHIT4 | FILHIT3 | FILHIT2 | FILHIT1 | FILHIT0 | 622                 |  |
| 3790h | B5CON       | TXBIF                                    | TXABT | TXLARB  | TXERR   | TXREQ   | RTREN   | TXPRI1  | TXPRI0  | 623                 |  |
| 378Fh | CANCON_RO5  | CANCON RO5                               |       |         |         |         |         |         |         |                     |  |
| 378Eh | CANSTAT RO5 | CANSTAT R05                              |       |         |         |         |         |         |         |                     |  |
| 378Dh | B4D7        |                                          |       |         | B4D     | 7       |         |         |         | 627                 |  |
| 378Ch | B4D6        | B4D6                                     |       |         |         |         |         |         |         |                     |  |
| 378Bh | B4D5        |                                          |       |         |         |         |         |         |         |                     |  |
| 378Ah | B4D4        | B4D4                                     |       |         |         |         |         |         |         |                     |  |
| 3789h | B4D3        | B4D3                                     |       |         |         |         |         |         |         |                     |  |
| 3788h | B4D2        | B4D2                                     |       |         |         |         |         |         |         |                     |  |
| 3787h | B4D1        | <br>B4D1                                 |       |         |         |         |         |         |         |                     |  |
| 3786h | B4D0        | B4D0                                     |       |         |         |         |         |         |         |                     |  |
| 3785h | B4DLC       | _                                        | RXRTR | RB1     | RB0     | DLC3    | DLC2    | DLC1    | DLC0    | 628                 |  |
| 3785h | B4DLC       | _                                        | TXRTR | _       | _       | DLC3    | DLC2    | DLC1    | DLC0    | 629                 |  |
| 3784h | B4EIDL      | EID7                                     | EID6  | EID5    | EID4    | EID3    | EID2    | EID1    | EID0    | 626                 |  |
| 3783h | B4EIDH      | EID15                                    | EID14 | EID13   | EID12   | EID11   | EID10   | EID9    | EID8    | 626                 |  |
| 3782h | B4SIDL      | SID2                                     | SID1  | SID0    | SRR     | EXIDE   | _       | EID17   | EID16   | 625                 |  |
| 3781h | B4SIDH      | SID10                                    | SID9  | SID8    | SID7    | SID6    | SID5    | SID4    | SID3    | 624                 |  |
| 3780h | B4CON       | RXFUL                                    | RXM1  | RXRTRRO | FILHIT4 | FILHIT3 | FILHIT2 | FILHIT1 | FILHIT0 | 622                 |  |
| 3780h | B4CON       | TXBIF                                    | TXABT | TXLARB  | TXERR   | TXREQ   | RTREN   | TXPRI1  | TXPRI0  | 623                 |  |
| 377Fh | CANCON RO6  | CANCON RO6                               |       |         |         |         |         |         |         |                     |  |
| 377Eh | CANSTAT RO6 | CANSTAT RO6                              |       |         |         |         |         |         |         |                     |  |
| 377Dh | B3D7        | B3D7                                     |       |         |         |         |         |         |         |                     |  |
| 377Ch | B3D6        | B3D6                                     |       |         |         |         |         |         |         |                     |  |
| 377Bh | B3D5        |                                          | B3D5  |         |         |         |         |         |         |                     |  |
| 377Ah | B3D4        | R3D4                                     |       |         |         |         |         |         |         |                     |  |
| 3779h | B3D3        |                                          |       |         | B3D     | 3       |         |         |         | 627                 |  |
| 3778h | B3D2        |                                          | R3D2  |         |         |         |         |         |         |                     |  |
| 3777h | B3D1        | B3D1                                     |       |         |         |         |         |         |         |                     |  |
| 3776h | B3D0        | R3D0                                     |       |         |         |         |         |         |         |                     |  |
| 3775h | B3DLC       | _                                        | RXRTR | RB1     | RB0     | DI C3   | DI C2   | DI C1   | DI CO   | 628                 |  |
| 3775h | B3DLC       |                                          | TXRTR |         |         | DLC3    | DLC2    |         |         | 620                 |  |
| 3774h | B3EIDI      | EID7                                     | FID6  | FID5    | FID4    | FID3    | FID2    | FID1    | FIDO    | 626                 |  |
|       |             |                                          | 2.00  |         |         | 2:00    |         |         | LIDU    | 020                 |  |

## TABLE 43-1: REGISTER FILE SUMMARY FOR PIC18(L)F25/26K83 DEVICES (CONTINUED)

Legend: x = unknown, u = unchanged, — = unimplemented, q = value depends on condition

Note 1: Not present in LF devices.