

Welcome to E-XFL.COM

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

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

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

#### Details

E·XFI

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

Email: info@E-XFL.COM

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

On transitions from SEC\_RUN mode to PRI\_RUN mode, the peripherals and CPU continue to be clocked from the Timer1 oscillator while the primary clock is started. When the primary clock becomes ready, a clock switch back to the primary clock occurs (see

Figure 4-2). When the clock switch is complete, the T1RUN bit is cleared, the OSTS bit is set and the primary clock is providing the clock. The IDLEN and SCS bits are not affected by the wake-up; the Timer1 oscillator continues to run.









## 4.2.3 RC\_RUN MODE

In RC\_RUN mode, the CPU and peripherals are clocked from the internal oscillator block using the INTOSC multiplexer; the primary clock is shut down. When using the INTRC source, this mode provides the best power conservation of all the Run modes, while still executing code. It works well for user applications which are not highly timing-sensitive or do not require high-speed clocks at all times.

If the primary clock source is the internal oscillator block (either INTRC or INTOSC), there are no distinguishable differences between PRI\_RUN and RC\_RUN modes during execution. However, a clock switch delay will occur during entry to, and exit from, RC\_RUN mode. Therefore, if the primary clock source is the internal oscillator block, the use of RC\_RUN mode is not recommended. This mode is entered by setting SCS1 to '1'. Although it is ignored, it is recommended that SCS0 also be cleared; this is to maintain software compatibility with future devices. When the clock source is switched to the INTOSC multiplexer (see Figure 4-3), the primary oscillator is shut down and the OSTS bit is cleared. The IRCF bits may be modified at any time to immediately change the clock speed.

| Note: | Caution should be used when modifying a        |  |  |  |  |  |  |  |  |  |  |
|-------|------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
|       | single IRCF bit. If VDD is less than 3V, it is |  |  |  |  |  |  |  |  |  |  |
|       | possible to select a higher clock speed        |  |  |  |  |  |  |  |  |  |  |
|       | than is supported by the low VDD.              |  |  |  |  |  |  |  |  |  |  |
|       | Improper device operation may result if        |  |  |  |  |  |  |  |  |  |  |
|       | the VDD/FOSC specifications are violated.      |  |  |  |  |  |  |  |  |  |  |

<sup>© 2009</sup> Microchip Technology Inc.

### 6.1.2.4 Stack Full and Underflow Resets

Device Resets on stack overflow and stack underflow conditions are enabled by setting the STVREN bit in Configuration Register 4L. When STVREN is set, a full or underflow will set the appropriate STKFUL or STKUNF bit and then cause a device Reset. When STVREN is cleared, a full or underflow condition will set the appropriate STKFUL or STKUNF bit but not cause a device Reset. The STKFUL or STKUNF bits are cleared by the user software or a Power-on Reset.

#### 6.1.3 FAST REGISTER STACK

A Fast Register Stack is provided for the STATUS, WREG and BSR registers, to provide a "fast return" option for interrupts. Each stack is only one level deep and is neither readable nor writable. It is loaded with the current value of the corresponding register when the processor vectors for an interrupt. All interrupt sources will push values into the stack registers. The values in the registers are then loaded back into their associated registers, if the RETFIE, FAST instruction is used to return from the interrupt.

If both low and high-priority interrupts are enabled, the stack registers cannot be used reliably to return from low-priority interrupts. If a high-priority interrupt occurs while servicing a low-priority interrupt, the stack register values stored by the low-priority interrupt will be overwritten. In these cases, users must save the key registers in software during a low-priority interrupt.

If interrupt priority is not used, all interrupts may use the Fast Register Stack for returns from interrupt. If no interrupts are used, the Fast Register Stack can be used to restore the STATUS, WREG and BSR registers at the end of a subroutine call. To use the Fast Register Stack for a subroutine call, a CALL label, FAST instruction must be executed to save the STATUS, WREG and BSR registers to the Fast Register Stack. A RETURN, FAST instruction is then executed to restore these registers from the Fast Register Stack.

Example 6-1 shows a source code example that uses the Fast Register Stack during a subroutine call and return.

#### EXAMPLE 6-1: FAST REGISTER STACK CODE EXAMPLE

| CALL | SUB1, FAST<br>•<br>• | ;STATUS, WREG, BSR<br>;SAVED IN FAST REGISTER<br>;STACK |
|------|----------------------|---------------------------------------------------------|
| SUB1 | •<br>RETURN, FAST    | ;RESTORE VALUES SAVED<br>;IN FAST REGISTER STACK        |

### 6.1.4 LOOK-UP TABLES IN PROGRAM MEMORY

There may be programming situations that require the creation of data structures, or look-up tables, in program memory. For PIC18 devices, look-up tables can be implemented in two ways:

- Computed GOTO
- Table Reads

#### 6.1.4.1 Computed GOTO

A computed GOTO is accomplished by adding an offset to the program counter. An example is shown in Example 6-2.

A look-up table can be formed with an ADDWF PCL instruction and a group of RETLW nn instructions. The W register is loaded with an offset into the table before executing a call to that table. The first instruction of the called routine is the ADDWF PCL instruction. The next instruction executed will be one of the RETLW nn instructions, that returns the value 'nn' to the calling function.

The offset value (in WREG) specifies the number of bytes that the program counter should advance and should be multiples of 2 (LSb = 0).

In this method, only one data byte may be stored in each instruction location and room on the return address stack is required.

#### EXAMPLE 6-2: COMPUTED GOTO USING AN OFFSET VALUE

|       | MOVF<br>CALL | OFFSET,<br>TABLE | Ψ |
|-------|--------------|------------------|---|
| ORG   | nn00h        |                  |   |
| TABLE | ADDWF        | PCL              |   |
|       | RETLW        | nnh              |   |
|       | RETLW        | nnh              |   |
|       | RETLW        | nnh              |   |
|       |              |                  |   |
|       |              |                  |   |
|       |              |                  |   |

## 6.1.4.2 Table Reads and Table Writes

A better method of storing data in program memory allows two bytes of data to be stored in each instruction location.

Look-up table data may be stored two bytes per program word by using table reads and writes. The Table Pointer (TBLPTR) register specifies the byte address and the Table Latch (TABLAT) register contains the data that is read from or written to program memory. Data is transferred to or from program memory one byte at a time.

Table read and table write operations are discussed further in Section 7.1 "Table Reads and Table Writes".

## 6.2 PIC18 Instruction Cycle

#### 6.2.1 CLOCKING SCHEME

The microcontroller clock input, whether from an internal or external source, is internally divided by four to generate four non-overlapping quadrature clocks (Q1, Q2, Q3 and Q4). Internally, the Program Counter (PC) is incremented on every Q1; the instruction is fetched from the program memory and latched into the Instruction Register (IR) during Q4. The instruction is decoded and executed during the following Q1 through Q4. The clocks and instruction execution flow are shown in Figure 6-3.

#### 6.2.2 INSTRUCTION FLOW/PIPELINING

An "Instruction Cycle" consists of four Q cycles: Q1 through Q4. The instruction fetch and execute are pipelined in such a manner that a fetch takes one instruction cycle, while the decode and execute take another instruction cycle. However, due to the pipelining, each instruction effectively executes in one cycle. If an instruction causes the program counter to change (e.g., GOTO), then two cycles are required to complete the instruction (Example 6-3).

A fetch cycle begins with the program counter incrementing in Q1.

In the execution cycle, the fetched instruction is latched into the Instruction Register (IR) in cycle Q1. This instruction is then decoded and executed during the Q2, Q3 and Q4 cycles. Data memory is read during Q2 (operand read) and written during Q4 (destination write).



#### FIGURE 6-3: CLOCK/INSTRUCTION CYCLE

#### EXAMPLE 6-3: INSTRUCTION PIPELINE FLOW



**Note:** All instructions are single cycle, except for any program branches. These take two cycles since the fetch instruction is "flushed" from the pipeline while the new instruction is being fetched and then executed.

| Pin Name          | Function                                                                                                                                   | I/O | TRIS | Buffer | Description                                                                                                          |  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-----|------|--------|----------------------------------------------------------------------------------------------------------------------|--|
| RA0/AN0/CVREF     | RA0                                                                                                                                        | OUT | 0    | DIG    | LATA<0> data output.                                                                                                 |  |
|                   |                                                                                                                                            | IN  | 1    | TTL    | PORTA<0> data input.                                                                                                 |  |
|                   | AN0                                                                                                                                        | IN  | 1    | ANA    | A/D Input Channel 0. Enabled on POR; this analog input overrides the digital input (read as clear – low level).      |  |
|                   | CVREF <sup>(1)</sup> OUT     x     ANA     Comparator voltage reference analog output. E output overrides the digital I/O (read as clear – |     |      |        |                                                                                                                      |  |
| RA1/AN1           | RA1                                                                                                                                        | OUT | 0    | DIG    | LATA<1> data output.                                                                                                 |  |
|                   |                                                                                                                                            | IN  | 1    | TTL    | PORTA<1> data input.                                                                                                 |  |
|                   | AN1                                                                                                                                        | IN  | 1    | ANA    | A/D Input Channel 1. Enabled on POR; this analog input overrides the digital input (read as clear – low level).      |  |
| RA2/AN2/VREF-     | RA2                                                                                                                                        | OUT | 0    | DIG    | LATA<2> data output.                                                                                                 |  |
|                   |                                                                                                                                            | IN  | 1    | TTL    | PORTA<2> data input.                                                                                                 |  |
|                   | AN2                                                                                                                                        | IN  | 1    | ANA    | A/D Input Channel 2. Enabled on POR; this analog input overrides the digital input (read as clear – low level).      |  |
|                   | VREF-                                                                                                                                      | IN  | 1    | ANA    | A/D and comparator negative voltage analog input.                                                                    |  |
| RA3/AN3/VREF+     | RA3                                                                                                                                        | OUT | 0    | DIG    | LATA<3> data output.                                                                                                 |  |
|                   |                                                                                                                                            | IN  | 1    | TTL    | PORTA<3> data input.                                                                                                 |  |
|                   | AN3                                                                                                                                        | IN  | 1    | ANA    | A/D Input Channel 3. Enabled on POR; this analog input overrides the digital input (read as clear – low level).      |  |
|                   | VREF+                                                                                                                                      | IN  | 1    | ANA    | A/D and comparator positive voltage analog input.                                                                    |  |
| RA4/T0CKI         | RA4                                                                                                                                        | OUT | 0    | DIG    | LATA<4> data output.                                                                                                 |  |
|                   |                                                                                                                                            | IN  | 1    | TTL    | PORTA<4> data input.                                                                                                 |  |
|                   | TOCKI                                                                                                                                      | IN  | 1    | ST     | Timer0 clock input.                                                                                                  |  |
| RA5/AN4/SS/HLVDIN | RA5                                                                                                                                        | OUT | 0    | DIG    | LATA<5> data output.                                                                                                 |  |
|                   |                                                                                                                                            | IN  | 1    | TTL    | PORTA<5> data input.                                                                                                 |  |
|                   | AN4                                                                                                                                        | IN  | 1    | ANA    | A/D Input Channel 4. Enabled on POR; this analog input overrides the digital input (read as clear – low level).      |  |
|                   | SS                                                                                                                                         | IN  | 1    | TTL    | Slave select input for MSSP.                                                                                         |  |
|                   | HLVDIN                                                                                                                                     | IN  | 1    | ANA    | High/Low-Voltage Detect external trip point input.                                                                   |  |
| OSC2/CLKO/RA6     | OSC2                                                                                                                                       | OUT | х    | ANA    | Output connection; selected by FOSC<3:0> Configuration bits.<br>Enabling OSC2 overrides digital I/O.                 |  |
|                   | CLKO                                                                                                                                       | OUT | х    | DIG    | Output connection; selected by FOSC<3:0> Configuration bits.<br>Enabling CLKO overrides digital I/O (Fosc/4).        |  |
|                   | RA6                                                                                                                                        | OUT | 0    | DIG    | LATA<6> data output.                                                                                                 |  |
|                   |                                                                                                                                            | IN  | 1    | TTL    | PORTA<6> data input.                                                                                                 |  |
| OSC1/CLKI/RA7     | OSC1                                                                                                                                       | IN  | х    | ANA    | Main oscillator input connection determined by FOSC<3:0><br>Configuration bits. Enabling OSC1 overrides digital I/O. |  |
|                   | CLKI                                                                                                                                       | IN  | х    | ANA    | Main clock input connection determined by FOSC<3:0><br>Configuration bits. Enabling CLKI overrides digital I/O.      |  |
|                   | RA7                                                                                                                                        | OUT | 0    | DIG    | LATA<7> data output.                                                                                                 |  |
|                   |                                                                                                                                            | IN  | 1    | TTL    | PORTA<7> data input.                                                                                                 |  |

## TABLE 11-1: PORTA I/O SUMMARY

Legend: OUT = Output, IN = Input, ANA = Analog Signal, DIG = Digital Output, ST = Schmitt Buffer Input, TTL = TTL Buffer Input Note 1: Available on 40/44-pin devices only.

#### 12.3 Prescaler

An 8-bit counter is available as a prescaler for the Timer0 module. The prescaler is not directly readable or writable; its value is set by the PSA and T0PS<2:0> bits (T0CON<3:0>) which determine the prescaler assignment and prescale ratio.

Clearing the PSA bit assigns the prescaler to the Timer0 module. When it is assigned, prescale values from 1:2 through 1:256 in power-of-2 increments are selectable.

When assigned to the Timer0 module, all instructions writing to the TMR0 register (e.g., CLRF TMR0, MOVWF TMR0, BSF TMR0, etc.) clear the prescaler count.

Note: Writing to TMR0 when the prescaler is assigned to Timer0 will clear the prescaler count but will not change the prescaler assignment.

#### 12.3.1 SWITCHING PRESCALER ASSIGNMENT

The prescaler assignment is fully under software control and can be changed "on-the-fly" during program execution.

### 12.4 Timer0 Interrupt

The TMR0 interrupt is generated when the TMR0 register overflows from FFh to 00h in 8-bit mode, or from FFFFh to 0000h in 16-bit mode. This overflow sets the TMR0IF flag bit. The interrupt can be masked by clearing the TMR0IE bit (INTCON<5>). Before reenabling the interrupt, the TMR0IF bit must be cleared in software by the Interrupt Service Routine.

Since Timer0 is shut down in Sleep mode, the TMR0 interrupt cannot awaken the processor from Sleep.

 TABLE 12-1:
 REGISTERS ASSOCIATED WITH TIMER0

| Name   | Bit 7                                                                     | Bit 6     | Bit 5  | Bit 4  | Bit 3 | Bit 2  | Bit 1  | Bit 0 | Reset<br>Values<br>on Page: |  |  |
|--------|---------------------------------------------------------------------------|-----------|--------|--------|-------|--------|--------|-------|-----------------------------|--|--|
| TMR0L  | Timer0 Register Low Byte                                                  |           |        |        |       |        |        |       |                             |  |  |
| TMR0H  | Timer0 Register High Byte                                                 |           |        |        |       |        |        |       |                             |  |  |
| INTCON | GIE/GIEH                                                                  | PEIE/GIEL | TMR0IE | INT0IE | RBIE  | TMR0IF | INT0IF | RBIF  | 55                          |  |  |
| T0CON  | TMR0ON                                                                    | T08BIT    | TOCS   | T0SE   | PSA   | T0PS2  | T0PS1  | T0PS0 | 56                          |  |  |
| TRISA  | TRISA7 <sup>(1)</sup> TRISA6 <sup>(1)</sup> PORTA Data Direction Register |           |        |        |       |        |        |       |                             |  |  |

Legend: — = unimplemented locations, read as '0'. Shaded cells are not used by Timer0.

**Note 1:** RA6/RA7 and their associated latch and direction bits are individually configured as port pins based on various primary oscillator modes. When disabled, these bits read as '0'.

### 17.4.4 HALF-BRIDGE MODE

In the Half-Bridge Output mode, two pins are used as outputs to drive push-pull loads. The PWM output signal is output on the P1A pin, while the complementary PWM output signal is output on the P1B pin (Figure 17-4). This mode can be used for half-bridge applications, as shown in Figure 17-5, or for full-bridge applications where four power switches are being modulated with two PWM signals.

In Half-Bridge Output mode, the programmable dead-band delay can be used to prevent shoot-through current in half-bridge power devices. The value of bits, PDC<6:0>, sets the number of instruction cycles before the output is driven active. If the value is greater than the duty cycle, the corresponding output remains inactive during the entire cycle. See **Section 17.4.6** "**Programmable Dead-Band Delay**" for more details of the dead-band delay operations.

Since the P1A and P1B outputs are multiplexed with the PORTD<4> and PORTD<5> data latches, the TRISD<4> and TRISD<5> bits must be cleared to configure P1A and P1B as outputs.

#### FIGURE 17-4: HALF-BRIDGE PWM OUTPUT



#### FIGURE 17-5: EXAMPLES OF HALF-BRIDGE OUTPUT MODE APPLICATIONS



#### 18.3.3 ENABLING SPI I/O

To enable the serial port, MSSP Enable bit, SSPEN (SSPCON1<5>), must be set. To reset or reconfigure SPI mode, clear the SSPEN bit, reinitialize the SSPCON registers and then set the SSPEN bit. This configures the SDI, SDO, SCK and SS pins as serial port pins. For the pins to behave as the serial port function, some must have their data direction bits (in the TRIS register) appropriately programmed as follows:

- · SDI is automatically controlled by the SPI module
- SDO must have TRISC<5> bit cleared
- SCK (Master mode) must have TRISC<3> bit cleared
- SCK (Slave mode) must have TRISC<3> bit set
- SS must have TRISF<7> bit set

Any serial port function that is not desired may be overridden by programming the corresponding Data Direction (TRIS) register to the opposite value.

### 18.3.4 TYPICAL CONNECTION

Figure 18-2 shows a typical connection between two microcontrollers. The master controller (Processor 1) initiates the data transfer by sending the SCK signal. Data is shifted out of both shift registers on their programmed clock edge and latched on the opposite edge of the clock. Both processors should be programmed to the same Clock Polarity (CKP), then both controllers would send and receive data at the same time. Whether the data is meaningful (or dummy data) depends on the application software. This leads to three scenarios for data transmission:

- · Master sends data Slave sends dummy data
- · Master sends data Slave sends data
- · Master sends dummy data Slave sends data
- Note: When the module is enabled and in Master mode (CKE, SSPSTAT<6> = 1), a small glitch of approximately half a Tcy may be seen on the SCK pin. To resolve this, keep the SCK pin as an input while setting SPEN. Then, configure the SCK pin as an output (TRISC<3> = 0).

#### FIGURE 18-2: SPI MASTER/SLAVE CONNECTION



#### R/W-0 R-0 R/W-0 R/W-0 R/W-0 R/W-0 R-0 R-x SPEN RX9 SREN CREN ADDEN FERR OERR RX9D bit 7 bit 0 Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '0' = Bit is cleared '1' = Bit is set x = Bit is unknown bit 7 SPEN: Serial Port Enable bit 1 = Serial port enabled (configures RX/DT and TX/CK pins as serial port pins) 0 = Serial port disabled (held in Reset) bit 6 RX9: 9-Bit Receive Enable bit 1 = Selects 9-bit reception 0 = Selects 8-bit reception bit 5 SREN: Single Receive Enable bit Asynchronous mode: Don't care. Synchronous mode - Master: 1 = Enables single receive 0 = Disables single receive This bit is cleared after reception is complete. Synchronous mode - Slave: Don't care. bit 4 **CREN:** Continuous Receive Enable bit Asynchronous mode: 1 = Enables receiver 0 = Disables receiver Synchronous mode: 1 = Enables continuous receive until enable bit CREN is cleared (CREN overrides SREN) 0 = Disables continuous receive bit 3 ADDEN: Address Detect Enable bit Asynchronous mode 9-bit (RX9 = 1): 1 = Enables address detection, enables interrupt and loads the receive buffer when RSR<8> is set 0 = Disables address detection, all bytes are received and ninth bit can be used as parity bit Asynchronous mode 9-bit (RX9 = 0): Don't care. bit 2 FERR: Framing Error bit 1 = Framing error (can be updated by reading RCREG register and receiving next valid byte) 0 = No framing error bit 1 **OERR:** Overrun Error bit 1 = Overrun error (can be cleared by clearing bit CREN) 0 = No overrun error bit 0 RX9D: 9th bit of Received Data This can be an address/data bit or a parity bit and must be calculated by user firmware.

#### REGISTER 19-2: RCSTA: RECEIVE STATUS AND CONTROL REGISTER

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

| For a device with FOSC of 16 MHz, desired baud rate of 9600, Asynchronous mode, 8-bit BRG: |     |                                                              |  |  |  |  |  |  |  |  |
|--------------------------------------------------------------------------------------------|-----|--------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Desired Baud Rate                                                                          | =   | Fosc/(64 ([SPBRGH:SPBRG] + 1)                                |  |  |  |  |  |  |  |  |
| Solving for SPBRGH:S                                                                       | SPB | RG:                                                          |  |  |  |  |  |  |  |  |
| Х                                                                                          | =   | ((FOSC/Desired Baud Rate)/64) – 1                            |  |  |  |  |  |  |  |  |
|                                                                                            | =   | ((16000000/9600)/64) – 1                                     |  |  |  |  |  |  |  |  |
|                                                                                            | =   | [25.042] = 25                                                |  |  |  |  |  |  |  |  |
| Calculated Baud Rate                                                                       | =   | 16000000/(64 (25 + 1))                                       |  |  |  |  |  |  |  |  |
|                                                                                            | =   | 9615                                                         |  |  |  |  |  |  |  |  |
| Error                                                                                      | =   | (Calculated Baud Rate - Desired Baud Rate)/Desired Baud Rate |  |  |  |  |  |  |  |  |
|                                                                                            | =   | (9615 - 9600)/9600 = 0.16%                                   |  |  |  |  |  |  |  |  |

### TABLE 19-2: REGISTERS ASSOCIATED WITH BAUD RATE GENERATOR

| Name    | Bit 7                                         | Bit 6       | Bit 5       | Bit 4       | Bit 3  | Bit 2 | Bit 1 | Bit 0 | Reset<br>Values<br>on Page: |  |
|---------|-----------------------------------------------|-------------|-------------|-------------|--------|-------|-------|-------|-----------------------------|--|
| TXSTA   | CSRC                                          | TX9         | TXEN        | SYNC        | SENDB  | BRGH  | TRMT  | TX9D  | 57                          |  |
| RCSTA   | SPEN                                          | RX9         | SREN        | CREN        | ADDEN  | FERR  | OERR  | RX9D  | 57                          |  |
| BAUDCON | ABDOVF                                        | RCIDL       | —           | SCKP        | BRG16  | —     | WUE   | ABDEN | 57                          |  |
| SPBRGH  | EUSART Baud Rate Generator Register High Byte |             |             |             |        |       |       |       |                             |  |
| SPBRG   | EUSART E                                      | Baud Rate G | Generator R | egister Low | v Byte |       |       |       | 57                          |  |

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

#### 19.4.2 EUSART SYNCHRONOUS SLAVE RECEPTION

The operation of the Synchronous Master and Slave modes is identical, except in the case of Sleep or any Idle mode and bit, SREN, which is a "don't care" in Slave mode.

If receive is enabled by setting the CREN bit prior to entering Sleep or any Idle mode, then a word may be received while in this low-power mode. Once the word is received, the RSR register will transfer the data to the RCREG register. If the RCIE enable bit is set, the interrupt generated will wake the chip from the low-power mode. If the global interrupt is enabled, the program will branch to the interrupt vector. To set up a Synchronous Slave Reception:

- 1. Enable the synchronous master serial port by setting bits, SYNC and SPEN, and clearing bit, CSRC.
- 2. If interrupts are desired, set enable bit, RCIE.
- 3. If 9-bit reception is desired, set bit, RX9.
- 4. To enable reception, set enable bit, CREN.
- 5. Flag bit, RCIF, will be set when reception is complete. An interrupt will be generated if enable bit, RCIE, was set.
- Read the RCSTA register to get the 9th bit (if enabled) and determine if any error occurred during reception.
- 7. Read the 8-bit received data by reading the RCREG register.
- 8. If any error occurred, clear the error by clearing bit, CREN.
- If using interrupts, ensure that the GIE and PEIE bits in the INTCON register (INTCON<7:6>) are set.

| Name    | Bit 7                | Bit 6        | Bit 5       | Bit 4        | Bit 3 | Bit 2  | Bit 1  | Bit 0  | Reset<br>Values<br>on Page: |
|---------|----------------------|--------------|-------------|--------------|-------|--------|--------|--------|-----------------------------|
| INTCON  | GIE/GIEH             | PEIE/GIEL    | TMR0IE      | INT0IE       | RBIE  | TMR0IF | INT0IF | RBIF   | 55                          |
| PIR1    | PSPIF <sup>(1)</sup> | ADIF         | RCIF        | TXIF         | SSPIF | CCP1IF | TMR2IF | TMR1IF | 58                          |
| PIE1    | PSPIE <sup>(1)</sup> | ADIE         | RCIE        | TXIE         | SSPIE | CCP1IE | TMR2IE | TMR1IE | 58                          |
| IPR1    | PSPIP <sup>(1)</sup> | ADIP         | RCIP        | TXIP         | SSPIP | CCP1IP | TMR2IP | TMR1IP | 58                          |
| RCSTA   | SPEN                 | RX9          | SREN        | CREN         | ADDEN | FERR   | OERR   | RX9D   | 57                          |
| RCREG   | EUSART F             | Receive Regi | ster        |              |       |        |        |        | 57                          |
| TXSTA   | CSRC                 | TX9          | TXEN        | SYNC         | SENDB | BRGH   | TRMT   | TX9D   | 57                          |
| BAUDCON | ABDOVF               | RCIDL        | _           | SCKP         | BRG16 | —      | WUE    | ABDEN  | 57                          |
| SPBRGH  | EUSART B             | aud Rate G   | enerator Re | gister High  | Byte  |        |        |        | 57                          |
| SPBRG   | EUSART B             | aud Rate G   | enerator Re | gister Low I | Byte  |        |        |        | 57                          |

TABLE 19-10: REGISTERS ASSOCIATED WITH SYNCHRONOUS SLAVE RECEPTION

Legend: — = unimplemented, read as '0'. Shaded cells are not used for synchronous slave reception.

Note 1: Reserved in PIC18F2X80 devices; always maintain these bits clear.



### FIGURE 22-1: COMPARATOR VOLTAGE REFERENCE BLOCK DIAGRAM

## 22.2 Voltage Reference Accuracy/Error

The full range of voltage reference cannot be realized due to the construction of the module. The transistors on the top and bottom of the resistor ladder network (Figure 22-1) keep CVREF from approaching the reference source rails. The voltage reference is derived from the reference source; therefore, the CVREF output changes with fluctuations in that source. The tested absolute accuracy of the voltage reference can be found in **Section 28.0 "Electrical Characteristics"**.

## 22.3 Operation During Sleep

When the device wakes up from Sleep through an interrupt or a Watchdog Timer time-out, the contents of the CVRCON register are not affected. To minimize current consumption in Sleep mode, the voltage reference should be disabled.

## 22.4 Effects of a Reset

A device Reset disables the voltage reference by clearing bit, CVREN (CVRCON<7>). This Reset also disconnects the reference from the RA0 pin by clearing bit, CVROE (CVRCON<6>), and selects the high-voltage range by clearing bit, CVRR (CVRCON<5>). The CVR value select bits are also cleared.

## 22.5 Connection Considerations

The voltage reference module operates independently of the comparator module. The output of the reference generator may be connected to the RA0 pin if the TRISA<0> bit and the CVROE bit are both set. Enabling the voltage reference output onto the RA0 pin, with an input signal present, will increase current consumption. Connecting RA0 as a digital output with CVRSS enabled will also increase current consumption.

The RA0 pin can be used as a simple D/A output with limited drive capability. Due to the limited current drive capability, a buffer must be used on the voltage reference output for external connections to VREF. Figure 22-2 shows an example buffering technique.

#### 24.2.2 DEDICATED CAN TRANSMIT BUFFER REGISTERS

This section describes the dedicated CAN Transmit Buffer registers and their associated control registers.

### **REGISTER 24-5:** TXBnCON: TRANSMIT BUFFER n CONTROL REGISTERS $[0 \le n \le 2]$

| Mode 0                                                               | U-0                                                                                                                                                                                              | R-0                                                                 | R-0                                                        | R-0                                                 | R/W-0                | U-0             | R/W-0                 | R/W-0                 |  |  |  |
|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|------------------------------------------------------------|-----------------------------------------------------|----------------------|-----------------|-----------------------|-----------------------|--|--|--|
|                                                                      |                                                                                                                                                                                                  | TXABT <sup>(1)</sup>                                                | TXLARB <sup>(1)</sup>                                      | TXERR <sup>(1)</sup>                                | TXREQ <sup>(2)</sup> | —               | TXPRI1 <sup>(3)</sup> | TXPRI0 <sup>(3)</sup> |  |  |  |
|                                                                      |                                                                                                                                                                                                  |                                                                     |                                                            |                                                     |                      |                 |                       |                       |  |  |  |
| Mode 1.2                                                             | R/C-0                                                                                                                                                                                            | R-0                                                                 | R-0                                                        | R-0                                                 | R/W-0                | U-0             | R/W-0                 | R/W-0                 |  |  |  |
|                                                                      | TXBIF                                                                                                                                                                                            | TXABT <sup>(1)</sup>                                                | TXLARB <sup>(1)</sup>                                      | TXERR <sup>(1)</sup>                                | TXREQ <sup>(2)</sup> |                 | TXPRI1 <sup>(3)</sup> | TXPRI0 <sup>(3)</sup> |  |  |  |
|                                                                      | bit 7                                                                                                                                                                                            |                                                                     |                                                            |                                                     |                      |                 |                       | bit 0                 |  |  |  |
| Legend:                                                              |                                                                                                                                                                                                  |                                                                     | C = Clearable                                              | e bit                                               |                      |                 |                       |                       |  |  |  |
| R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' |                                                                                                                                                                                                  |                                                                     |                                                            |                                                     |                      |                 |                       |                       |  |  |  |
| -n = Value                                                           | at POR                                                                                                                                                                                           |                                                                     | '1' = Bit is set                                           | t                                                   | '0' = Bit is c       | leared          | x = Bit is unl        | known                 |  |  |  |
| bit 7                                                                | <u>Mode 0:</u><br>Unimplemen<br><u>Mode 1, 2:</u><br>TXBIF: Trans<br>1 = Transmit<br>0 = Transmit                                                                                                | ted: Read as<br>mit Buffer Inte<br>buffer has con<br>buffer has not | rrupt Flag bit<br>npleted transm<br>completed tra          | iission of me                                       | essage and r         | nay be reloa    | ded                   |                       |  |  |  |
| bit 6                                                                | TXABT: Transmission Aborted Status bit <sup>(1)</sup><br>1 = Message was aborted<br>0 = Message was not aborted                                                                                  |                                                                     |                                                            |                                                     |                      |                 |                       |                       |  |  |  |
| bit 5                                                                | <b>TXLARB:</b> Tra<br>1 = Message<br>0 = Message                                                                                                                                                 | ansmission Los<br>lost arbitratior<br>did not lose a                | st Arbitration S<br>while being s<br>bitration while       | ent<br>being sent                                   |                      |                 |                       |                       |  |  |  |
| bit 4                                                                | <b>TXERR:</b> Tran<br>1 = A bus erro<br>0 = A bus erro                                                                                                                                           | esmission Erro<br>or occurred wh<br>or did not occu                 | r Detected Sta<br>nile the messag<br>Ir while the me       | tus bit <sup>(1)</sup><br>ge was bein<br>essage was | g sent<br>beina sent |                 |                       |                       |  |  |  |
| bit 3                                                                | <b>TXREQ:</b> Tran<br>1 = Requests<br>0 = Automatic                                                                                                                                              | smit Request<br>sending a me<br>cally cleared w                     | Status bit <sup>(2)</sup><br>ssage. Clears<br>hen the mess | the TXABT,                                          | TXLARB ar            | id TXERR bi     | ts.                   |                       |  |  |  |
| bit 2                                                                | Unimplemen                                                                                                                                                                                       | ted: Read as                                                        | ʻ0 <b>'</b>                                                | 0                                                   |                      |                 |                       |                       |  |  |  |
| bit 1-0                                                              | TXPRI<1:0>:                                                                                                                                                                                      | Transmit Prio                                                       | rity bits <sup>(3)</sup>                                   |                                                     |                      |                 |                       |                       |  |  |  |
|                                                                      | IXPRI<1:0>: Iransmit Priority bits'         11 = Priority Level 3 (highest priority)         10 = Priority Level 2         01 = Priority Level 1         00 = Priority Level 0 (lowest priority) |                                                                     |                                                            |                                                     |                      |                 |                       |                       |  |  |  |
| Note 1:                                                              | This bit is auto                                                                                                                                                                                 | matically clea                                                      | red when TXR                                               | EQ is set.                                          |                      |                 |                       |                       |  |  |  |
| 2:                                                                   | While TXREQ set will reques                                                                                                                                                                      | is set, Transm<br>t a message a                                     | it Buffer regist<br>bort.                                  | ers remain r                                        | ead-only. Cle        | earing this bit | t in software w       | hile the bit is       |  |  |  |
| 3:                                                                   | These bits def<br>message iden                                                                                                                                                                   | ine the order in tifier.                                            | n which transn                                             | nit buffers wi                                      | ill be transfe       | rred. They do   | o not alter the       | CAN                   |  |  |  |

#### EXAMPLE 24-3: TRANSMITTING A CAN MESSAGE USING BANKED METHOD

; Need to transmit Standard Identifier message 123h using TXB0 buffer. ; To successfully transmit, CAN module must be either in Normal or Loopback mode. ; TXBO buffer is not in access bank. And since we want banked method, we need to make sure ; that correct bank is selected. BANKSEL TXBOCON ; One BANKSEL in beginning will make sure that we are ; in correct bank for rest of the buffer access. ; Now load transmit data into TXB0 buffer. MOVLW MY\_DATA\_BYTE1 ; Load first data byte into buffer MOVWE TXB0D0 ; Compiler will automatically set "BANKED" bit ; Load rest of data bytes - up to 8 bytes into TXBO buffer. ; Load message identifier MOVLW 60H ; Load SID2:SID0, EXIDE = 0 MOVWE TXB0SIDL MOVLW 24H ; Load SID10:SID3 MOVWF TXB0SIDH ; No need to load TXB0EIDL:TXB0EIDH, as we are transmitting Standard Identifier Message only. ; Now that all data bytes are loaded, mark it for transmission. MOVLW B'00001000' ; Normal priority; Request transmission TXB0CON MOVWF ; If required, wait for message to get transmitted BTFSC TXB0CON, TXREQ ; Is it transmitted? BRA \$-2 ; No. Continue to wait... ; Message is transmitted.

#### EXAMPLE 24-4: TRANSMITTING A CAN MESSAGE USING WIN BITS

```
; Need to transmit Standard Identifier message 123h using TXB0 buffer.
; To successfully transmit, CAN module must be either in Normal or Loopback mode.
; TXBO buffer is not in access bank. Use WIN bits to map it to RXBO area.
MOVE
      CANCON, W
                                    ; WIN bits are in lower 4 bits only. Read CANCON
                                    ; register to preserve all other bits. If operation
                                    ; mode is already known, there is no need to preserve
                                    ; other bits.
ANDLW B'11110000'
                                    ; Clear WIN bits.
IORLW B'00001000'
                                   ; Select Transmit Buffer 0
MOVWE CANCON
                                    ; Apply the changes.
; Now TXBO is mapped in place of RXBO. All future access to RXBO registers will actually
; yield TXB0 register values.
; Load transmit data into TXB0 buffer.
MOVLW MY_DATA_BYTE1
                                   ; Load first data byte into buffer
MOVWF RXB0D0
                                   ; Access TXB0D0 via RXB0D0 address.
; Load rest of the data bytes - up to 8 bytes into "TXBO" buffer using RXB0 registers.
; Load message identifier
MOVLW 60H
                                   ; Load SID2:SID0, EXIDE = 0
MOVWF RXB0SIDL
MOVLW 24H
                                    ; Load SID10:SID3
MOVWF RXB0SIDH
; No need to load RXB0EIDL:RXB0EIDH, as we are transmitting Standard Identifier Message only.
; Now that all data bytes are loaded, mark it for transmission.
MOVLW B'00001000'
                                   ; Normal priority; Request transmission
MOVWF RXB0CON
; If required, wait for message to get transmitted
BTFSC RXB0CON, TXREQ
                      ; Is it transmitted?
BRA
       $-2
                                    ; No. Continue to wait ...
; Message is transmitted.
; If required, reset the WIN bits to default state.
```

## REGISTER 24-42: RXMnSIDL: RECEIVE ACCEPTANCE MASK n STANDARD IDENTIFIER MASK REGISTERS, LOW BYTE [0 $\leq$ n $\leq$ 1]

| R/W-x                     | R/W-x                                                                                                               | R/W-x                                                                                                          | U-0                                                                       | R/W-0                                                                   | U-0                                                  | R/W-x           | R/W-x |
|---------------------------|---------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------|-----------------|-------|
| SID2                      | SID1                                                                                                                | SID0                                                                                                           |                                                                           | EXIDEN <sup>(1)</sup>                                                   | —                                                    | EID17           | EID16 |
| bit 7                     |                                                                                                                     |                                                                                                                |                                                                           |                                                                         |                                                      |                 | bit 0 |
|                           |                                                                                                                     |                                                                                                                |                                                                           |                                                                         |                                                      |                 |       |
| Legend:                   |                                                                                                                     |                                                                                                                |                                                                           |                                                                         |                                                      |                 |       |
| R = Readable              | bit                                                                                                                 | W = Writable                                                                                                   | bit                                                                       | U = Unimpler                                                            | mented bit, read                                     | as '0'          |       |
| -n = Value at P           | OR                                                                                                                  | '1' = Bit is set                                                                                               |                                                                           | '0' = Bit is cle                                                        | ared                                                 | x = Bit is unkr | nown  |
| bit 7-5<br>bit 4<br>bit 3 | SID<2:0>: Sta<br>Unimplemen<br>Mode 0:<br>Unimplemen<br>Mode 1, 2:<br>EXIDEN: Exte<br>1 = Messages<br>0 = Both stan | andard Identifie<br>ted: Read as f<br>ted: Read as f<br>ended Identifien<br>s selected by th<br>dard and exten | er Mask bits or<br>D'<br>Filter Enable<br>ne EXIDEN bit<br>ded identifier | Extended Ide<br>Mask bit <sup>(1)</sup><br>in RXFnSIDL<br>messages will | ntifier Mask bits<br>will be accepted<br>be accepted | (EID<20:18>)    |       |
| bit 2                     | Unimplemen                                                                                                          | ted: Read as '                                                                                                 | כי                                                                        |                                                                         |                                                      |                 |       |
| bit 1-0                   | EID<17:16>:                                                                                                         | Extended Iden                                                                                                  | tifier Mask bits                                                          | 6                                                                       |                                                      |                 |       |

Note 1: This bit is available in Mode 1 and 2 only.

## REGISTER 24-43: RXMnEIDH: RECEIVE ACCEPTANCE MASK n EXTENDED IDENTIFIER MASK REGISTERS, HIGH BYTE [0 $\leq$ n $\leq$ 1]

| R/W-x |
|-------|-------|-------|-------|-------|-------|-------|-------|
| EID15 | EID14 | EID13 | EID12 | EID11 | EID10 | EID9  | EID8  |
| bit 7 |       |       |       |       |       |       | bit 0 |

| 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-0 EID<15:8>: Extended Identifier Mask bits

## REGISTER 24-44: RXMnEIDL: RECEIVE ACCEPTANCE MASK n EXTENDED IDENTIFIER MASK REGISTERS, LOW BYTE [0 $\leq$ n $\leq$ 1]

| R/W-x |
|-------|-------|-------|-------|-------|-------|-------|-------|
| EID7  | EID6  | EID5  | EID4  | EID3  | EID2  | EID1  | EID0  |
| bit 7 |       |       |       |       |       |       | bit 0 |

| 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-0 EID<7:0>: Extended Identifier Mask bits

| R/W-0                                                                | R/W-1          | R/W-0             | R/W-1        | R/W-0            | R/W-0  | R/W-0           | R/W-0  |  |
|----------------------------------------------------------------------|----------------|-------------------|--------------|------------------|--------|-----------------|--------|--|
| FIL3_1                                                               | FIL3_0         | FIL2_1            | FIL2_0       | FIL1_1           | FIL1_0 | FIL0_1          | FIL0_0 |  |
| bit 7                                                                |                |                   |              |                  |        |                 | bit 0  |  |
|                                                                      |                |                   |              |                  |        |                 |        |  |
| Legend:                                                              |                |                   |              |                  |        |                 |        |  |
| R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' |                |                   |              |                  |        |                 |        |  |
| -n = Value at P                                                      | OR             | '1' = Bit is set  |              | '0' = Bit is cle | ared   | x = Bit is unkr | nown   |  |
|                                                                      |                |                   |              |                  |        |                 |        |  |
| bit 7-6                                                              | FIL3_<1:0>:    | Filter 3 Select b | oits 1 and 0 |                  |        |                 |        |  |
|                                                                      | 11 = No mask   | K                 |              |                  |        |                 |        |  |
|                                                                      | 10 = Filter 15 | nce Mask 1        |              |                  |        |                 |        |  |
|                                                                      | 00 = Accepta   | nce Mask 0        |              |                  |        |                 |        |  |
| bit 5-4                                                              | FIL2_<1:0>: F  | -ilter 2 Select b | oits 1 and 0 |                  |        |                 |        |  |
|                                                                      | 11 = No mask   |                   |              |                  |        |                 |        |  |
|                                                                      | 10 = Filter 15 |                   |              |                  |        |                 |        |  |
|                                                                      | 01 = Accepta   | nce Mask 1        |              |                  |        |                 |        |  |
| hit 3_2                                                              |                | Filter 1 Select k | vite 1 and 0 |                  |        |                 |        |  |
| 510-2                                                                | 11 = No mask   |                   |              |                  |        |                 |        |  |
|                                                                      | 10 = Filter 15 | ,                 |              |                  |        |                 |        |  |
|                                                                      | 01 = Accepta   | nce Mask 1        |              |                  |        |                 |        |  |
|                                                                      | 00 = Accepta   | nce Mask 0        |              |                  |        |                 |        |  |
| bit 1-0                                                              | FIL0_<1:0>: F  | Filter 0 Select b | oits 1 and 0 |                  |        |                 |        |  |
|                                                                      | 11 = No mask   | < C               |              |                  |        |                 |        |  |
|                                                                      | 10 = Filler 15 | nce Mask 1        |              |                  |        |                 |        |  |
|                                                                      | 00 = Accepta   | nce Mask 0        |              |                  |        |                 |        |  |

## REGISTER 24-48: MSEL0: MASK SELECT REGISTER 0<sup>(1)</sup>

**Note 1:** This register is available in Mode 1 and 2 only.

#### 24.2.6 CAN INTERRUPT REGISTERS

The registers in this section are the same as described in **Section 10.0 "Interrupts"**. They are duplicated here for convenience.

| Mode 0     | R/W-0                                                                                                                | R/W-0                                                                                                                         | R/W-0                                                                                                                    | R/W-0                                                                         | R/W-0                                          | R/W-0                                | R/W-0                  | R/W-0          |
|------------|----------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|------------------------------------------------|--------------------------------------|------------------------|----------------|
|            | IRXIF                                                                                                                | WAKIF                                                                                                                         | ERRIF                                                                                                                    | TXB2IF                                                                        | TXB1IF <sup>(1)</sup>                          | TXB0IF <sup>(1)</sup>                | RXB1IF                 | RXB0IF         |
|            | R/M-0                                                                                                                | R/\\/_0                                                                                                                       | R/\\/_0                                                                                                                  | R/W_0                                                                         | R/M_0                                          | R/\\/_0                              | R/\/_0                 | R/\\\_0        |
| Mode 1,2   | IRXIF                                                                                                                | WAKIF                                                                                                                         | ERRIF                                                                                                                    | TXBnIF                                                                        | TXB1IF <sup>(1)</sup>                          | TXB0IF <sup>(1)</sup>                | RXBnIF                 | FIFOWMIF       |
|            | bit 7                                                                                                                |                                                                                                                               |                                                                                                                          |                                                                               |                                                |                                      |                        | bit (          |
| Leaend:    |                                                                                                                      |                                                                                                                               |                                                                                                                          |                                                                               |                                                |                                      |                        |                |
| R = Reada  | able bit                                                                                                             |                                                                                                                               | W = Writabl                                                                                                              | e bit                                                                         | U = Unimple                                    | emented bit, re                      | ead as '0'             |                |
| -n = Value | at POR                                                                                                               |                                                                                                                               | '1' = Bit is s                                                                                                           | et                                                                            | '0' = Bit is cl                                | eared                                | x = Bit is un          | known          |
| bit 7      | IRXIF: CAN<br>1 = An invali<br>0 = No inval                                                                          | Bus Error Me<br>id message h<br>id message o                                                                                  | essage Recei<br>as occurred o<br>n CAN bus                                                                               | ved Interrup                                                                  | t Flag bit<br>ous                              |                                      |                        |                |
| bit 6      | WAKIF: CAI<br>1 = Activity o<br>0 = No activity                                                                      | N Bus Activity<br>on CAN bus h<br>ity on CAN bu                                                                               | / Wake-up Int<br>has occurred<br>us                                                                                      | errupt Flag I                                                                 | bit                                            |                                      |                        |                |
| bit 5      | <b>ERRIF:</b> CAN<br>1 = An error<br>0 = No CAN                                                                      | N Module Erro<br>has occurred<br>module error                                                                                 | or Interrupt FI<br>in the CAN n<br>s                                                                                     | ag bit<br>nodule (multi                                                       | ple sources; re                                | efer to <b>Sectio</b> i              | n 24.15.6 "Er          | ror Interrupt" |
|            | TXB2IF: CA<br>1 = Transm<br>0 = Transm<br>When CAN i<br>TXBnIF: An<br>1 = One or<br>0 = No trans                     | N Transmit B<br>it Buffer 2 has<br>it Buffer 2 has<br>is in Mode 1 o<br>y Transmit Bu<br>more transmi<br>smit buffer is       | uffer 2 Intern<br>s completed t<br>s not complet<br>o <u>r 2:</u><br>uffer Interrupt<br>t buffers have<br>ready for relo | upt Flag bit<br>ransmission<br>ed transmiss<br>Flag bit<br>e completed<br>bad | of a message<br>sion of a mess<br>transmission | e and may be<br>sage<br>of a message | reloaded<br>and may be | reloaded       |
| bit 3      | <b>TXB1IF:</b> CA<br>1 = Transmit<br>0 = Transmit                                                                    | N Transmit B.<br>t Buffer 1 has<br>t Buffer 1 has                                                                             | uffer 1 Interru<br>completed tr<br>not completed                                                                         | upt Flag bit <sup>(1</sup><br>ansmission<br>ed transmiss                      | )<br>of a message<br>ion of a mess             | and may be r<br>age                  | eloaded                |                |
| bit 2      | <b>TXB0IF:</b> CA<br>1 = Transmit<br>0 = Transmit                                                                    | N Transmit B<br>t Buffer 0 has<br>t Buffer 0 has                                                                              | uffer 0 Interru<br>completed tr<br>not completed                                                                         | upt Flag bit <sup>(1</sup><br>ansmission<br>ed transmiss                      | )<br>of a message<br>ion of a mess             | and may be r                         | eloaded                |                |
| bit 1      | When CAN is<br><b>RXB1IF</b> : CA<br>1 = Receive<br>0 = Receive<br>When CAN is<br><b>RXBnIF</b> : An<br>1 = One or r | is in Mode 0:<br>N Receive B<br>Buffer 1 has<br>Buffer 1 has<br>is in Mode 1 o<br>y Receive Bu<br>nore receive                | uffer 1 Interru<br>received a no<br>not received<br>or <u>2:</u><br>Iffer Interrupt<br>buffers has re                    | pt Flag bit<br>ew message<br>a new mess<br>Flag bit<br>eceived a ne           | age<br>w message                               | -                                    |                        |                |
| bit 0      | When CAN i<br><b>RXB0IF:</b> CA<br>1 = Receive<br>0 = Receive<br>When CAN i<br>Unimpleme<br>When CAN i<br>FIFOWMIF:  | is in Mode 0:<br>N Receive B<br>Buffer 0 has<br>Buffer 0 has<br>is in Mode 1:<br>nted: Read a<br>is in Mode 2:<br>FIFO Watern | uffer 0 Interru<br>received a not<br>not received<br>not received                                                        | upt Flag bit<br>ew message<br>a new mess                                      | age                                            |                                      |                        |                |

**Note 1:** In CAN Mode 1 and 2, these bits are forced to '0'.

## 25.0 SPECIAL FEATURES OF THE CPU

PIC18F2480/2580/4480/4580 devices include several features intended to maximize reliability and minimize cost through elimination of external components. These are:

- Oscillator Selection
- Resets:
  - Power-on Reset (POR)
  - Power-up Timer (PWRT)
  - Oscillator Start-up Timer (OST)
  - Brown-out Reset (BOR)
- Interrupts
- Watchdog Timer (WDT)
- Fail-Safe Clock Monitor
- · Two-Speed Start-up
- Code Protection
- ID Locations
- · In-Circuit Serial Programming

The oscillator can be configured for the application depending on frequency, power, accuracy and cost. All of the options are discussed in detail in **Section 3.0 "Oscillator Configurations"**.

A complete discussion of device Resets and interrupts is available in previous sections of this data sheet.

In addition to their Power-up and Oscillator Start-up Timers provided for Resets, PIC18F2480/2580/4480/ 4580 devices have a Watchdog Timer, which is either permanently enabled via the Configuration bits or software controlled (if configured as disabled). The inclusion of an internal RC oscillator also provides the additional benefits of a Fail-Safe Clock Monitor (FSCM) and Two-Speed Start-up. FSCM provides for background monitoring of the peripheral clock and automatic switchover in the event of its failure. Two-Speed Start-up enables code to be executed almost immediately on start-up, while the primary clock source completes its start-up delays.

All of these features are enabled and configured by setting the appropriate Configuration register bits.

## 25.1 Configuration Bits

The Configuration bits can be programmed (read as '0') or left unprogrammed (read as '1') to select various device configurations. These bits are mapped starting at program memory location 300000h.

The user will note that address 300000h is beyond the user program memory space. In fact, it belongs to the configuration memory space (300000h-3FFFFFh), which can only be accessed using table reads and table writes.

Programming the Configuration registers is done in a manner similar to programming the Flash memory. The WR bit in the EECON1 register starts a self-timed write to the Configuration register. In normal operation mode, a TBLWT instruction with the TBLPTR pointing to the Configuration register sets up the address and the data for the Configuration register write. Setting the WR bit starts a long write to the Configuration register. The Configuration registers are written a byte at a time. To write or erase a configuration cell, a TBLWT instruction can write a '1' or a '0' into the cell. For additional details on Flash programming, refer to Section 7.5 "Writing to Flash Program Memory".

Default/ **File Name** Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 Unprogrammed Value 300001h CONFIG1H IESO FCMEN FOSC3 FOSC2 FOSC1 FOSC0 00-- 0111 300002h CONFIG2L BORV1 BORV0 BOREN1 BOREN0 PWRTEN ---1 1111 300003h CONFIG2H \_\_\_\_ WDTPS3 WDTPS2 WDTPS1 WDTPS0 WDTEN ---1 1111 \_ 300005h MCLRE LPT1OSC PBADEN CONFIG3H \_\_\_ \_ \_ 1--- -01-\_\_\_\_ 300006h CONFIG4L DEBUG XINST BBSIZ LVP STVREN 10-0 -1-1 ---- 1111 300008h CONFIG5L CP3 CP2 CP1 CP0 \_ \_\_\_ \_\_\_\_ \_ 300009h CONFIG5H CPD CPB 11-- ----— 30000Ah CONFIG6L \_ \_ WRT3 WRT2 WRT1 ---- 1111 \_\_\_\_ \_ WRT0 30000Bh CONFIG6H WRTD WRTB WRTC 111- ----30000Ch CONFIG7L ---- 1111 \_\_\_\_ \_\_\_\_ \_\_\_\_ \_\_\_\_ EBTR3 EBTR2 EBTR1 EBTR0 30000Dh CONFIG7H \_ EBTRB \_ \_\_\_ \_ -1----3FFFFEh ×××× ×××××(1) DEVID1 DEV1 DEV2 DEV0 REV4 REV3 REV2 REV1 REV0 3FFFFFh DEVID2 DEV10 DEV9 DEV8 DEV7 DEV6 DEV5 DEV4 DEV3 0000 1100

TABLE 25-1:CONFIGURATION BITS AND DEVICE IDs

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

Note 1: See Register 25-12 for DEVID1 values. DEVID registers are read-only and cannot be programmed by the user.





#### 25.4.3 FSCM INTERRUPTS IN POWER-MANAGED MODES

By entering a power-managed mode, the clock multiplexer selects the clock source selected by the OSCCON register. Fail-Safe Clock Monitoring of the power-managed clock source resumes in the power-managed mode.

If an oscillator failure occurs during power-managed operation, the subsequent events depend on whether or not the oscillator failure interrupt is enabled. If enabled (OSCFIF = 1), code execution will be clocked by the INTOSC multiplexer. An automatic transition back to the failed clock source will not occur.

If the interrupt is disabled, subsequent interrupts while in Idle mode will cause the CPU to begin executing instructions while being clocked by the INTOSC source.

#### 25.4.4 POR OR WAKE-UP FROM SLEEP

The FSCM is designed to detect oscillator failure at any point after the device has exited Power-on Reset (POR) or low-power Sleep mode. When the primary device clock is EC, RC or INTRC modes, monitoring can begin immediately following these events. For oscillator modes involving a crystal or resonator (HS, HSPLL, LP or XT), the situation is somewhat different. Since the oscillator may require a start-up time considerably longer than the FCSM sample clock time, a false clock failure may be detected. To prevent this, the internal oscillator block is automatically configured as the device clock and functions until the primary clock is stable (the OST and PLL timers have timed out). This is identical to Two-Speed Start-up mode. Once the primary clock is stable, the INTRC returns to its role as the FSCM source.

Note: The same logic that prevents false oscillator failure interrupts on POR, or wake from Sleep, will also prevent the detection of the oscillator's failure to start at all following these events. This can be avoided by monitoring the OSTS bit and using a timing routine to determine if the oscillator is taking too long to start. Even so, no oscillator failure interrupt will be flagged.

As noted in Section 25.3.1 "Special Considerations for Using Two-Speed Start-up", it is also possible to select another clock configuration and enter an alternate power-managed mode while waiting for the primary clock to become stable. When the new power-managed mode is selected, the primary clock is disabled.

| DC Characteristics |       |                                                                      | $\begin{array}{l} \mbox{Standard Operating Conditions (unless otherwise stated)} \\ \mbox{Operating temperature } -40^{\circ}C \leq TA \leq +85^{\circ}C \mbox{ for industrial} \\ -40^{\circ}C \leq TA \leq +125^{\circ}C \mbox{ for extended} \end{array}$ |      |       |       |                                                                  |  |  |
|--------------------|-------|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|-------|------------------------------------------------------------------|--|--|
| Param<br>No.       | Sym   | Characteristic                                                       | Min                                                                                                                                                                                                                                                          | Typ† | Max   | Units | Conditions                                                       |  |  |
|                    |       | Internal Program Memory<br>Programming Specifications <sup>(1)</sup> |                                                                                                                                                                                                                                                              |      |       |       |                                                                  |  |  |
| D110               | Vpp   | Voltage on MCLR/VPP/RE3 Pin                                          | 9.00                                                                                                                                                                                                                                                         | —    | 13.25 | V     | (Note 3)                                                         |  |  |
| D113               | IDDP  | Supply Current during<br>Programming                                 | —                                                                                                                                                                                                                                                            | —    | 10    | mA    |                                                                  |  |  |
|                    |       | Data EEPROM Memory                                                   |                                                                                                                                                                                                                                                              |      |       |       |                                                                  |  |  |
| D120               | ED    | Byte Endurance                                                       | 100K                                                                                                                                                                                                                                                         | 1M   | —     | E/W   | -40°C to +85°C                                                   |  |  |
| D121               | Vdrw  | VDD for Read/Write                                                   | VMIN                                                                                                                                                                                                                                                         | _    | 5.5   | V     | Using EECON to read/write<br>VMIN = Minimum operating<br>voltage |  |  |
| D122               | TDEW  | Erase/Write Cycle Time                                               | _                                                                                                                                                                                                                                                            | 4    | —     | ms    |                                                                  |  |  |
| D123               | TRETD | Characteristic Retention                                             | 40                                                                                                                                                                                                                                                           | —    | —     | Year  | Provided no other specifications are violated                    |  |  |
| D124               | TREF  | Number of Total Erase/Write<br>Cycles before Refresh <sup>(2)</sup>  | 1M                                                                                                                                                                                                                                                           | 10M  | —     | E/W   | -40°C to +85°C                                                   |  |  |
|                    |       | Program Flash Memory                                                 |                                                                                                                                                                                                                                                              |      |       |       |                                                                  |  |  |
| D130               | Eр    | Cell Endurance                                                       | 10K                                                                                                                                                                                                                                                          | 100K | —     | E/W   | -40°C to +85°C                                                   |  |  |
| D131               | Vpr   | VDD for Read                                                         | VMIN                                                                                                                                                                                                                                                         | _    | 5.5   | V     | Vмın = Minimum operating<br>voltage                              |  |  |
| D132               | VIE   | VDD for Block Erase                                                  | 4.5                                                                                                                                                                                                                                                          | —    | 5.5   | V     | Using ICSP™ port                                                 |  |  |
| D132A              | Viw   | VDD for Externally Timed Erase<br>or Write                           | 4.5                                                                                                                                                                                                                                                          | _    | 5.5   | V     | Using ICSP port                                                  |  |  |
| D132B              | Vpew  | VDD for Self-Timed Write                                             | VMIN                                                                                                                                                                                                                                                         | —    | 5.5   | V     | Vмın = Minimum operating<br>voltage                              |  |  |
| D133               | TIE   | ICSP Block Erase Cycle Time                                          | —                                                                                                                                                                                                                                                            | 4    | _     | ms    | VDD > 4.5V                                                       |  |  |
| D133A              | Tiw   | ICSP Erase or Write Cycle Time (externally timed)                    | 1                                                                                                                                                                                                                                                            | —    | —     | ms    | VDD > 4.5V                                                       |  |  |
| D133A              | Tiw   | Self-Timed Write Cycle Time                                          | —                                                                                                                                                                                                                                                            | 2    | —     | ms    |                                                                  |  |  |
| D134               | TRETD | Characteristic Retention                                             | 40                                                                                                                                                                                                                                                           | 100  | —     | Year  | Provided no other specifications are violated                    |  |  |

#### TABLE 28-1: MEMORY PROGRAMMING REQUIREMENTS

† Data in "Typ" column is at 5.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

**Note 1:** These specifications are for programming the on-chip program memory through the use of table write instructions.

2: Refer to Section 8.8 "Using the Data EEPROM" for a more detailed discussion on data EEPROM endurance.

3: Required only if Single-Supply Programming is disabled.





#### TABLE 28-4: HIGH/LOW-VOLTAGE DETECT CHARACTERISTICS

|              |        |                        |                  | Standard Operating Conditions (unless otherwise st<br>Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for indust<br>$-40^{\circ}C < TA < +125^{\circ}C$ for exter |      |      |       |            |  |
|--------------|--------|------------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|-------|------------|--|
| Param<br>No. | Symbol | Characteristic         | C                | Min                                                                                                                                                                            | Тур  | Max  | Units | Conditions |  |
| D420         |        | HLVD Voltage on VDD    | VV = 0000        | 2.12                                                                                                                                                                           | 2.17 | 2.22 | V     |            |  |
|              |        | Transition High-to-Low | VV = 0001        | 2.18                                                                                                                                                                           | 2.23 | 2.28 | V     |            |  |
|              |        | Ľ                      | VV = 0010        | 2.31                                                                                                                                                                           | 2.36 | 2.42 | V     |            |  |
|              |        | Ľ                      | VV = 0011        | 2.38                                                                                                                                                                           | 2.44 | 2.49 | V     |            |  |
|              |        | Ľ                      | VV = 0100        | 2.54                                                                                                                                                                           | 2.60 | 2.66 | V     |            |  |
|              |        | Ľ                      | VV = 0101        | 2.72                                                                                                                                                                           | 2.79 | 2.85 | V     |            |  |
|              |        | Ľ                      | VV = 0110        | 2.82                                                                                                                                                                           | 2.89 | 2.95 | V     |            |  |
|              |        | Ľ                      | <b>VV =</b> 0111 | 3.05                                                                                                                                                                           | 3.12 | 3.19 | V     |            |  |
|              |        | Ľ                      | <b>VV =</b> 1000 | 3.31                                                                                                                                                                           | 3.39 | 3.47 | V     |            |  |
|              |        | Ľ                      | <b>VV =</b> 1001 | 3.46                                                                                                                                                                           | 3.55 | 3.63 | V     |            |  |
|              |        | Ľ                      | <b>VV =</b> 1010 | 3.63                                                                                                                                                                           | 3.71 | 3.80 | V     |            |  |
|              |        | Ľ                      | <b>VV =</b> 1011 | 3.81                                                                                                                                                                           | 3.90 | 3.99 | V     |            |  |
|              |        | Ľ                      | <b>VV =</b> 1100 | 4.01                                                                                                                                                                           | 4.11 | 4.20 | V     |            |  |
|              |        | Ľ                      | VV = 1101        | 4.23                                                                                                                                                                           | 4.33 | 4.43 | V     |            |  |
|              |        | Ľ                      | <b>VV</b> = 1110 | 4.48                                                                                                                                                                           | 4.59 | 4.69 | V     |            |  |
|              |        | Ľ                      | <b>VV =</b> 1111 | 1.14                                                                                                                                                                           | 1.2  | 1.26 | V     |            |  |