



#### Welcome to E-XFL.COM

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

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

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

#### Details

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

Email: info@E-XFL.COM

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

#### **Pin Diagrams (Continued)**



### 4.4.3 RC\_IDLE MODE

In RC\_IDLE mode, the CPU is disabled but the peripherals continue to be clocked from the internal oscillator block using the INTOSC multiplexer. This mode allows for controllable power conservation during Idle periods.

From RC\_RUN, this mode is entered by setting the IDLEN bit and executing a SLEEP instruction. If the device is in another Run mode, first set IDLEN, then set the SCS1 bit and execute SLEEP. Although its value is ignored, it is recommended that SCS0 also be cleared; this is to maintain software compatibility with future devices. The INTOSC multiplexer may be used to select a higher clock frequency, by modifying the IRCF bits, before executing the SLEEP instruction. When the clock source is switched to the INTOSC multiplexer, the primary oscillator is shut down and the OSTS bit is cleared.

If the IRCF bits are set to any non-zero value or the INTSRC bit is set, the INTOSC output is enabled. The IOFS bit becomes set, after the INTOSC output becomes stable, after an interval of TIOBST (parameter 39, Table 28-10). Clocks to the peripherals continue while the INTOSC source stabilizes. If the IRCF bits were previously at a non-zero value, or INTSRC was set before the SLEEP instruction was executed and the INTOSC source was already stable, the IOFS bit will remain set. If the IRCF bits and INTSRC are all clear, the INTOSC output will not be enabled, the IOFS bit will remain clear and there will be no indication of the current clock source.

When a wake event occurs, the peripherals continue to be clocked from the INTOSC multiplexer. After a delay of TCSD following the wake event, the CPU begins executing code being clocked by the INTOSC multiplexer. The IDLEN and SCS bits are not affected by the wake-up. The INTRC source will continue to run if either the WDT or the Fail-Safe Clock Monitor is enabled.

### 4.5 Exiting Idle and Sleep Modes

An exit from Sleep mode or any of the Idle modes is triggered by an interrupt, a Reset or a WDT time-out. This section discusses the triggers that cause exits from power-managed modes. The clocking subsystem actions are discussed in each of the power-managed modes (see Section 4.2 "Run Modes", Section 4.3 "Sleep Mode" and Section 4.4 "Idle Modes").

#### 4.5.1 EXIT BY INTERRUPT

Any of the available interrupt sources can cause the device to exit from an Idle mode or the Sleep mode to a Run mode. To enable this functionality, an interrupt source must be enabled by setting its enable bit in one of the INTCON or PIE registers. The exit sequence is initiated when the corresponding interrupt flag bit is set.

On all exits from Idle or Sleep modes by interrupt, code execution branches to the interrupt vector if the GIE/GIEH bit (INTCON<7>) is set. Otherwise, code execution continues or resumes without branching (see Section 10.0 "Interrupts").

A fixed delay of interval, TCSD, following the wake event is required when leaving Sleep and Idle modes. This delay is required for the CPU to prepare for execution. Instruction execution resumes on the first clock cycle following this delay.

#### 4.5.2 EXIT BY WDT TIME-OUT

A WDT time-out will cause different actions depending on which power-managed mode the device is in when the time-out occurs.

If the device is not executing code (all Idle modes and Sleep mode), the time-out will result in an exit from the power-managed mode (see Section 4.2 "Run Modes" and Section 4.3 "Sleep Mode"). If the device is executing code (all Run modes), the time-out will result in a WDT Reset (see Section 25.2 "Watchdog Timer (WDT)").

The WDT timer and postscaler are cleared by executing a SLEEP or CLRWDT instruction, the loss of a currently selected clock source (if the Fail-Safe Clock Monitor is enabled) and modifying the IRCF bits in the OSCCON register if the internal oscillator block is the device clock source.

#### 4.5.3 EXIT BY RESET

Normally, the device is held in Reset by the Oscillator Start-up Timer (OST) until the primary clock becomes ready. At that time, the OSTS bit is set and the device begins executing code. If the internal oscillator block is the new clock source, the IOFS bit is set instead.

The exit delay time from Reset to the start of code execution depends on both the clock sources before and after the wake-up and the type of oscillator if the new clock source is the primary clock. Exit delays are summarized in Table 4-2.

Code execution can begin before the primary clock becomes ready. If either the Two-Speed Start-up (see **Section 25.3 "Two-Speed Start-up"**) or Fail-Safe Clock Monitor (see **Section 25.4 "Fail-Safe Clock Monitor**") is enabled, the device may begin execution as soon as the Reset source has cleared. Execution is clocked by the INTOSC multiplexer driven by the internal oscillator block. Execution is clocked by the internal oscillator block until either the primary clock becomes ready or a power-managed mode is entered before the primary clock becomes ready; the primary clock is then shut down.



|                      | 1       | 1       | 1                   | · · ·   | 1                      | i                       |                        | i                      | · ·                  | 1                   |
|----------------------|---------|---------|---------------------|---------|------------------------|-------------------------|------------------------|------------------------|----------------------|---------------------|
| File Name            | Bit 7   | Bit 6   | Bit 5               | Bit 4   | Bit 3                  | Bit 2                   | Bit 1                  | Bit 0                  | Value on<br>POR, BOR | Details on<br>Page: |
| RXB0CON<br>Mode 0    | RXFUL   | RXM1    | RXM0 <sup>(7)</sup> | (7)     | RXRTRRO <sup>(7)</sup> | RXBODBEN <sup>(7)</sup> | JTOFF <sup>(7)</sup>   | FILHITO <sup>(7)</sup> | 000- 0000            | 59, 293             |
| RXB0CON<br>Mode 1, 2 | RXFUL   | RXM1    | RTRRO               | FILHIT4 | FILHIT3                | FILHIT2                 | FILHIT1                | FILHIT0                | 0000 0000            | 59, 293             |
| RXB1D7               | RXB1D77 | RXB1D76 | RXB1D75             | RXB1D74 | RXB1D73                | RXB1D72                 | RXB1D71                | RXB1D70                | XXXX XXXX            | 59, 298             |
| RXB1D6               | RXB1D67 | RXB1D66 | RXB1D65             | RXB1D64 | RXB1D63                | RXB1D62                 | RXB1D61                | RXB1D60                | XXXX XXXX            | 59, 298             |
| RXB1D5               | RXB1D57 | RXB1D56 | RXB1D55             | RXB1D54 | RXB1D53                | RXB1D52                 | RXB1D51                | RXB1D50                | XXXX XXXX            | 59, 298             |
| RXB1D4               | RXB1D47 | RXB1D46 | RXB1D45             | RXB1D44 | RXB1D43                | RXB1D42                 | RXB1D41                | RXB1D40                | XXXX XXXX            | 59, 298             |
| RXB1D3               | RXB1D37 | RXB1D36 | RXB1D35             | RXB1D34 | RXB1D33                | RXB1D32                 | RXB1D31                | RXB1D30                | XXXX XXXX            | 59, 298             |
| RXB1D2               | RXB1D27 | RXB1D26 | RXB1D25             | RXB1D24 | RXB1D23                | RXB1D22                 | RXB1D21                | RXB1D20                | XXXX XXXX            | 59, 298             |
| RXB1D1               | RXB1D17 | RXB1D16 | RXB1D15             | RXB1D14 | RXB1D13                | RXB1D12                 | RXB1D11                | RXB1D10                | XXXX XXXX            | 59, 298             |
| RXB1D0               | RXB1D07 | RXB1D06 | RXB1D05             | RXB1D04 | RXB1D03                | RXB1D02                 | RXB1D01                | RXB1D00                | XXXX XXXX            | 59, 298             |
| RXB1DLC              | _       | RXRTR   | RB1                 | RB0     | DLC3                   | DLC2                    | DLC1                   | DLC0                   | -xxx xxxx            | 59, 298             |
| RXB1EIDL             | EID7    | EID6    | EID5                | EID4    | EID3                   | EID2                    | EID1                   | EID0                   | XXXX XXXX            | 59, 297             |
| RXB1EIDH             | EID15   | EID14   | EID13               | EID12   | EID11                  | EID10                   | EID9                   | EID8                   | XXXX XXXX            | 59, 297             |
| RXB1SIDL             | SID2    | SID1    | SID0                | SRR     | EXID                   | —                       | EID17                  | EID16                  | XXXX XXXX            | 59, 297             |
| RXB1SIDH             | SID10   | SID9    | SID8                | SID7    | SID6                   | SID5                    | SID4                   | SID3                   | XXXX XXXX            | 60, 296             |
| RXB1CON<br>Mode 0    | RXFUL   | RXM1    | RXM0 <sup>(7)</sup> | (7)     | RXRTRRO <sup>(7)</sup> | FILHIT2 <sup>(7)</sup>  | FILHIT1 <sup>(7)</sup> | FILHITO <sup>(7)</sup> | 000- 0000            | 60, 293             |
| RXB1CON<br>Mode 1, 2 | RXFUL   | RXM1    | RTRRO               | FILHIT4 | FILHIT3                | FILHIT2                 | FILHIT1                | FILHIT0                | 0000 0000            | 60, 293             |
| TXB0D7               | TXB0D77 | TXB0D76 | TXB0D75             | TXB0D74 | TXB0D73                | TXB0D72                 | TXB0D71                | TXB0D70                | XXXX XXXX            | 60, 290             |
| TXB0D6               | TXB0D67 | TXB0D66 | TXB0D65             | TXB0D64 | TXB0D63                | TXB0D62                 | TXB0D61                | TXB0D60                | XXXX XXXX            | 60, 290             |
| TXB0D5               | TXB0D57 | TXB0D56 | TXB0D55             | TXB0D54 | TXB0D53                | TXB0D52                 | TXB0D51                | TXB0D50                | XXXX XXXX            | 60, 290             |
| TXB0D4               | TXB0D47 | TXB0D46 | TXB0D45             | TXB0D44 | TXB0D43                | TXB0D42                 | TXB0D41                | TXB0D40                | XXXX XXXX            | 60, 290             |
| TXB0D3               | TXB0D37 | TXB0D36 | TXB0D35             | TXB0D34 | TXB0D33                | TXB0D32                 | TXB0D31                | TXB0D30                | XXXX XXXX            | 60, 290             |
| TXB0D2               | TXB0D27 | TXB0D26 | TXB0D25             | TXB0D24 | TXB0D23                | TXB0D22                 | TXB0D21                | TXB0D20                | XXXX XXXX            | 60, 290             |
| TXB0D1               | TXB0D17 | TXB0D16 | TXB0D15             | TXB0D14 | TXB0D13                | TXB0D12                 | TXB0D11                | TXB0D10                | XXXX XXXX            | 60, 290             |
| TXB0D0               | TXB0D07 | TXB0D06 | TXB0D05             | TXB0D04 | TXB0D03                | TXB0D02                 | TXB0D01                | TXB0D00                | XXXX XXXX            | 60, 290             |
| TXB0DLC              | —       | TXRTR   | —                   | _       | DLC3                   | DLC2                    | DLC1                   | DLC0                   | -x xxxx              | 60, 291             |
| TXB0EIDL             | EID7    | EID6    | EID5                | EID4    | EID3                   | EID2                    | EID1                   | EID0                   | XXXX XXXX            | 60, 290             |
| TXB0EIDH             | EID15   | EID14   | EID13               | EID12   | EID11                  | EID10                   | EID9                   | EID8                   | XXXX XXXX            | 60, 289             |
| TXB0SIDL             | SID2    | SID1    | SID0                | _       | EXIDE                  | —                       | EID17                  | EID16                  | xxx- x-xx            | 60, 289             |
| TXB0SIDH             | SID10   | SID9    | SID8                | SID7    | SID6                   | SID5                    | SID4                   | SID3                   | XXXX XXXX            | 60, 289             |
| TXB0CON              | TXBIF   | TXABT   | TXLARB              | TXERR   | TXREQ                  | —                       | TXPRI1                 | TXPRI0                 | 0000 0-00            | 60, 288             |
| TXB1D7               | TXB1D77 | TXB1D76 | TXB1D75             | TXB1D74 | TXB1D73                | TXB1D72                 | TXB1D71                | TXB1D70                | XXXX XXXX            | 60, 290             |
| TXB1D6               | TXB1D67 | TXB1D66 | TXB1D65             | TXB1D64 | TXB1D63                | TXB1D62                 | TXB1D61                | TXB1D60                | XXXX XXXX            | 60, 290             |
| TXB1D5               | TXB1D57 | TXB1D56 | TXB1D55             | TXB1D54 | TXB1D53                | TXB1D52                 | TXB1D51                | TXB1D50                | XXXX XXXX            | 60, 290             |
| TXB1D4               | TXB1D47 | TXB1D46 | TXB1D45             | TXB1D44 | TXB1D43                | TXB1D42                 | TXB1D41                | TXB1D40                | XXXX XXXX            | 60, 290             |
| TXB1D3               | TXB1D37 | TXB1D36 | TXB1D35             | TXB1D34 | TXB1D33                | TXB1D32                 | TXB1D31                | TXB1D30                | XXXX XXXX            | 60, 290             |
| TXB1D2               | TXB1D27 | TXB1D26 | TXB1D25             | TXB1D24 | TXB1D23                | TXB1D22                 | TXB1D21                | TXB1D20                | xxxx xxxx            | 60, 290             |

#### TABLE 6-2: REGISTER FILE SUMMARY (PIC18F2480/2580/4480/4580) (CONTINUED)

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

**Note 1:** Bit 21 of the PC is only available in Test mode and Serial Programming modes.

2: The SBOREN bit is only available when CONFIG2L<1:0> = 01; otherwise, it is disabled and reads as '0'. See Section 5.4 "Brown-out Reset (BOR)".

3: These registers and/or bits are not implemented on PIC18F2X80 devices and are read as '0'. Reset values are shown for PIC18F4X80 devices; individual unimplemented bits should be interpreted as '--'.

4: The PLLEN bit is only available in specific oscillator configuration; otherwise, it is disabled and reads as '0'. See Section 3.6.4 "PLL in INTOSC Modes".

5: The RE3 bit is only available when Master Clear Reset is disabled (CONFIG3H<7> = 0); otherwise, RE3 reads as '0'. This bit is read-only.

6: 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'.

7: CAN bits have multiple functions depending on the selected mode of the CAN module.

8: This register reads all '0's until the ECAN<sup>™</sup> technology is set up in Mode 1 or Mode 2.

9: These registers are available on PIC18F4X80 devices only.

#### 13.2 Timer1 16-Bit Read/Write Mode

Timer1 can be configured for 16-bit reads and writes (see Figure 13-2). When the RD16 control bit (T1CON<7>) is set, the address for TMR1H is mapped to a buffer register for the high byte of Timer1. A read from TMR1L will load the contents of the high byte of Timer1 into the Timer1 High Byte Buffer register. This provides the user with the ability to accurately read all 16 bits of Timer1 without having to determine whether a read of the high byte, followed by a read of the low byte, has become invalid due to a rollover between reads.

A write to the high byte of Timer1 must also take place through the TMR1H Buffer register. The Timer1 high byte is updated with the contents of TMR1H when a write occurs to TMR1L. This allows a user to write all 16 bits to both the high and low bytes of Timer1 at once.

The high byte of Timer1 is not directly readable or writable in this mode. All reads and writes must take place through the Timer1 High Byte Buffer register. Writes to TMR1H do not clear the Timer1 prescaler. The prescaler is only cleared on writes to TMR1L.

### 13.3 Timer1 Oscillator

An on-chip crystal oscillator circuit is incorporated between pins, T1OSI (input) and T1OSO (amplifier output). It is enabled by setting the Timer1 Oscillator Enable bit, T1OSCEN (T1CON<3>). The oscillator is a low-power circuit rated for 32 kHz crystals. It will continue to run during all power-managed modes. The circuit for a typical LP oscillator is shown in Figure 13-3. Table 13-1 shows the capacitor selection for the Timer1 oscillator.

The user must provide a software time delay to ensure proper start-up of the Timer1 oscillator.

#### FIGURE 13-3: EXTERNAL COMPONENTS FOR THE TIMER1 LP OSCILLATOR



#### TABLE 13-1: CAPACITOR SELECTION FOR THE TIMER OSCILLATOR<sup>(1-4)</sup>

| Osc Type | Freq   | C1    | C2    |  |
|----------|--------|-------|-------|--|
| LP       | 32 kHz | 27 pF | 27 pF |  |
|          |        |       |       |  |

- Note 1: Microchip suggests these values as a starting point in validating the oscillator circuit.
  - 2: Higher capacitance increases the stability of the oscillator but also increases the start-up time.
  - 3: Since each resonator/crystal has its own characteristics, the user should consult the resonator/crystal manufacturer for appropriate values of external components.
  - **4:** Capacitor values are for design guidance only.

#### 13.3.1 USING TIMER1 AS A CLOCK SOURCE

The Timer1 oscillator is also available as a clock source in power-managed modes. By setting the clock select bits, SCS<1:0> (OSCCON<1:0>), to '01', the device switches to SEC\_RUN mode; both the CPU and peripherals are clocked from the Timer1 oscillator. If the IDLEN bit (OSCCON<7>) is cleared and a SLEEP instruction is executed, the device enters SEC\_IDLE mode. Additional details are available in **Section 4.0 "Power-Managed Modes"**.

Whenever the Timer1 oscillator is providing the clock source, the Timer1 system clock status flag, T1RUN (T1CON<6>), is set. This can be used to determine the controller's current clocking mode. It can also indicate the clock source being currently used by the Fail-Safe Clock Monitor. If the Clock Monitor is enabled and the Timer1 oscillator fails while providing the clock, polling the T1RUN bit will indicate whether the clock is being provided by the Timer1 oscillator or another source.

#### 13.3.2 LOW-POWER TIMER1 OPTION

The Timer1 oscillator can operate at two distinct levels of power consumption based on device configuration. When the LPT1OSC Configuration bit is set, the Timer1 oscillator operates in a low-power mode. When LPT1OSC is not set, Timer1 operates at a higher power level. Power consumption for a particular mode is relatively constant, regardless of the device's operating mode. The default Timer1 configuration is the higher power mode.

As the low-power Timer1 mode tends to be more sensitive to interference, high noise environments may cause some oscillator instability. The low-power option is, therefore, best suited for low noise applications where power conservation is an important design consideration.

#### SSPSTAT: MSSP STATUS REGISTER (I<sup>2</sup>C<sup>™</sup> MODE) REGISTER 18-3: R/W-0 R/W-0 R-0 R-0 R-0 R-0 R-0 R-0 $P^{(1)}$ S(1) R/W(2,3) SMP CKE D/A UA BF bit 7 bit 0 Legend: R = Readable bit U = Unimplemented bit, read as '0' W = Writable bit -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 7 SMP: Slew Rate Control bit In Master or Slave mode: 1 = Slew rate control disabled for Standard Speed mode (100 kHz and 1 MHz) 0 = Slew rate control enabled for High-Speed mode (400 kHz) bit 6 CKE: SMBus Select bit In Master or Slave mode: 1 = Enable SMBus specific inputs 0 = Disable SMBus specific inputs D/A: Data/Address bit bit 5 In Master mode: Reserved. In Slave mode: 1 = Indicates that the last byte received or transmitted was data 0 = Indicates that the last byte received or transmitted was address P: Stop bit<sup>(1)</sup> bit 4 1 = Indicates that a Stop bit has been detected last 0 = Stop bit was not detected last S: Start bit<sup>(1)</sup> bit 3 1 = Indicates that a Start bit has been detected last 0 = Start bit was not detected last R/W: Read/Write Information bit (I<sup>2</sup>C mode only)<sup>(2,3)</sup> bit 2 In Slave mode: 1 = Read 0 = Write In Master mode: 1 = Transmit is in progress 0 = Transmit is not in progress bit 1 UA: Update Address bit (10-Bit Slave mode only) 1 = Indicates that the user needs to update the address in the SSPADD register 0 = Address does not need to be updated BF: Buffer Full Status bit bit 0 In Receive mode: 1 = Receive complete, SSPBUF is full 0 = Receive is not complete, SSPBUF is empty In Transmit mode: 1 = Data transmit in progress (does not include the ACK and Stop bits), SSPBUF is full 0 = Data transmit complete (does not include the ACK and Stop bits), SSPBUF is empty Note 1: This bit is cleared on Reset and when SSPEN is cleared. 2: This bit holds the R/W bit information following the last address match. This bit is only valid from the address match to the next Start bit, Stop bit or not ACK bit.

3: ORing this bit with SEN, RSEN, PEN, RCEN or ACKEN will indicate if the MSSP is in Idle mode.

#### 18.4.9 I<sup>2</sup>C MASTER MODE REPEATED START CONDITION TIMING

A Repeated Start condition occurs when the RSEN bit (SSPCON2<1>) is programmed high and the I<sup>2</sup>C logic module is in the Idle state. When the RSEN bit is set, the SCL pin is asserted low. When the SCL pin is sampled low, the Baud Rate Generator is loaded with the contents of SSPADD<5:0> and begins counting. The SDA pin is released (brought high) for one Baud Rate Generator count (TBRG). When the Baud Rate Generator times out, and if SDA is sampled high, the SCL pin will be deasserted (brought high). When SCL is sampled high, the Baud Rate Generator is reloaded with the contents of SSPADD<6:0> and begins counting. SDA and SCL must be sampled high for one TBRG. This action is then followed by assertion of the SDA pin (SDA = 0) for one TBRG while SCL is high. Following this, the RSEN bit (SSPCON2<1>) will be automatically cleared and the Baud Rate Generator will not be reloaded, leaving the SDA pin held low. As soon as a Start condition is detected on the SDA and SCL pins, the S bit (SSPSTAT<3>) will be set. The SSPIF bit will not be set until the Baud Rate Generator has timed out.

- Note 1: If RSEN is programmed while any other event is in progress, it will not take effect.
  - **2:** A bus collision during the Repeated Start condition occurs if:
    - SDA is sampled low when SCL goes from low-to-high.
    - SCL goes low before SDA is asserted low. This may indicate that another master is attempting to transmit a data '1'.

Immediately following the SSPIF bit getting set, the user may write the SSPBUF with the 7-bit address in 7-bit mode, or the default first address in 10-bit mode. After the first eight bits are transmitted and an ACK is received, the user may then transmit an additional eight bits of address (10-bit mode) or eight bits of data (7-bit mode).

#### 18.4.9.1 WCOL Status Flag

If the user writes the SSPBUF when a Repeated Start sequence is in progress, the WCOL is set and the contents of the buffer are unchanged (the write doesn't occur).

Note: Because queueing of events is not allowed, writing of the lower 5 bits of SSPCON2 is disabled until the Repeated Start condition is complete.

### FIGURE 18-20: REPEAT START CONDITION WAVEFORM









## 18.4.17.2 Bus Collision During a Repeated Start Condition

During a Repeated Start condition, a bus collision occurs if:

- a) A low level is sampled on SDA when SCL goes from a low level to a high level.
- b) SCL goes low before SDA is asserted low, indicating that another master is attempting to transmit a data '1'.

When the user deasserts SDA and the pin is allowed to float high, the BRG is loaded with SSPADD<6:0> and counts down to 0. The SCL pin is then deasserted and when sampled high, the SDA pin is sampled.

If SDA is low, a bus collision has occurred (i.e., another master is attempting to transmit a data '0', see Figure 18-29). If SDA is sampled high, the BRG is reloaded and begins counting. If SDA goes from high-to-low before the BRG times out, no bus collision occurs because no two masters can assert SDA at exactly the same time.

If SCL goes from high-to-low before the BRG times out, and SDA has not already been asserted, a bus collision occurs. In this case, another master is attempting to transmit a data '1' during the Repeated Start condition, see Figure 18-30.

If, at the end of the BRG time-out, both SCL and SDA are still high, the SDA pin is driven low and the BRG is reloaded and begins counting. At the end of the count regardless of the status of the SCL pin, the SCL pin is driven low and the Repeated Start condition is complete.

#### FIGURE 18-29: BUS COLLISION DURING A REPEATED START CONDITION (CASE 1)



#### FIGURE 18-30: BUS COLLISION DURING REPEATED START CONDITION (CASE 2)



NOTES:

## 24.0 ECAN MODULE

PIC18F2480/2580/4480/4580 devices contain an Enhanced Controller Area Network (ECAN) module. The ECAN module is fully backward compatible with the CAN module available in PIC18CXX8 and PIC18FXX8 devices.

The Controller Area Network (CAN) module is a serial interface which is useful for communicating with other peripherals or microcontroller devices. This interface, or protocol, was designed to allow communications within noisy environments.

The ECAN module is a communication controller, implementing the CAN 2.0A or B protocol as defined in the BOSCH specification. The module will support CAN 1.2, CAN 2.0A, CAN 2.0B Passive and CAN 2.0B Active versions of the protocol. The module implementation is a full CAN system; however, the CAN specification is not covered within this data sheet. Refer to the BOSCH CAN specification for further details.

The module features are as follows:

- Implementation of the CAN protocol, CAN 1.2, CAN 2.0A and CAN 2.0B
- DeviceNet<sup>™</sup> data bytes filter support
- Standard and extended data frames
- · 0-8 bytes data length
- Programmable bit rate up to 1 Mbit/sec
- Fully backward compatible with the PIC18XXX8
   CAN module
- Three modes of operation:
  - Mode 0 Legacy mode
  - Mode 1 Enhanced Legacy mode with DeviceNet support
- Mode 2 FIFO mode with DeviceNet support
- · Support for remote frames with automated handling
- Double-buffered receiver with two prioritized received message storage buffers
- Six buffers programmable as RX and TX message buffers
- 16 full (standard/extended identifier) acceptance filters that can be linked to one of four masks
- Two full acceptance filter masks that can be assigned to any filter
- One full acceptance filter that can be used as either an acceptance filter or acceptance filter mask
- Three dedicated transmit buffers with application specified prioritization and abort capability
- Programmable wake-up functionality with integrated low-pass filter
- Programmable Loopback mode supports self-test operation
- Signaling via interrupt capabilities for all CAN receiver and transmitter error states
- · Programmable clock source
- Programmable link to timer module for time-stamping and network synchronization
- · Low-power Sleep mode

#### 24.1 Module Overview

The CAN bus module consists of a protocol engine and message buffering and control. The CAN protocol engine automatically handles all functions for receiving and transmitting messages on the CAN bus. Messages are transmitted by first loading the appropriate data registers. Status and errors can be checked by reading the appropriate registers. Any message detected on the CAN bus is checked for errors and then matched against filters to see if it should be received and stored in one of the two receive registers.

The CAN module supports the following frame types:

- Standard Data Frame
- · Extended Data Frame
- Remote Frame
- Error Frame
- Overload Frame Reception

The CAN module uses the RB2/CANTX and RB3/ CANRX pins to interface with the CAN bus. In normal mode, the CAN module automatically overrides TRISB<2>. The user must ensure that TRISB<3> is set.

#### 24.1.1 MODULE FUNCTIONALITY

The CAN bus module consists of a protocol engine, message buffering and control (see Figure 24-1). The protocol engine can best be understood by defining the types of data frames to be transmitted and received by the module.

The following sequence illustrates the necessary initialization steps before the ECAN module can be used to transmit or receive a message. Steps can be added or removed depending on the requirements of the application.

- 1. Initial LAT and TRIS bits for RX and TX CAN.
- 2. Ensure that the ECAN module is in Configuration mode.
- 3. Select ECAN Operational mode.
- 4. Set up the Baud Rate registers.
- 5. Set up the Filter and Mask registers.
- 6. Set the ECAN module to normal mode or any other mode required by the application logic.

#### EXAMPLE 24-1: CHANGING TO CONFIGURATION MODE

```
; Request Configuration mode.
   MOVLW B'1000000'
                                       ; Set to Configuration Mode.
   MOVWF CANCON
   ; A request to switch to Configuration mode may not be immediately honored.
   ; Module will wait for CAN bus to be idle before switching to Configuration Mode.
   ; Request for other modes such as Loopback, Disable etc. may be honored immediately.
   ; It is always good practice to wait and verify before continuing.
ConfigWait:
   MOVF CANSTAT, W
                                       ; Read current mode state.
   ANDLW B'10000000'
                                        ; Interested in OPMODE bits only.
   TSTFSZ WREG
                                        ; Is it Configuration mode yet?
   BRA ConfigWait
                                        ; No. Continue to wait...
   ; Module is in Configuration mode now.
   ; Modify configuration registers as required.
   ; Switch back to Normal mode to be able to communicate.
```

## EXAMPLE 24-2: WIN AND ICODE BITS USAGE IN INTERRUPT SERVICE ROUTINE TO ACCESS TX/RX BUFFERS

```
; Save application required context.
   ; Poll interrupt flags and determine source of interrupt
   ; This was found to be CAN interrupt
   ; TempCANCON and TempCANSTAT are variables defined in Access Bank low
   MOVFF CANCON, TempCANCON
                                       ; Save CANCON.WIN bits
                                       ; This is required to prevent CANCON
                                       ; from corrupting CAN buffer access
                                       ; in-progress while this interrupt
                                       : occurred
   MOVFF CANSTAT, TempCANSTAT
                                       ; Save CANSTAT register
                                       ; This is required to make sure that
                                       ; we use same CANSTAT value rather
                                       ; than one changed by another CAN
                                       ; interrupt.
   MOVF
         TempCANSTAT, W
                                       ; Retrieve ICODE bits
   ANDLW B'00001110'
                                       ; Perform computed GOTO
   ADDWF PCL, F
                                       ; to corresponding interrupt cause
   BRA
        NoInterrupt
                                      ; 000 = No interrupt
   BRA ErrorInterrupt
                                      ; 001 = Error interrupt
                                      ; 010 = TXB2 interrupt
   BRA TXB2Interrupt
                                      ; 011 = TXB1 interrupt
   BRA
          TXB1Interrupt
                                      ; 100 = TXB0 interrupt
   BRA
          TXB0Interrupt
   BRA
          RXB1Interrupt
                                       ; 101 = RXB1 interrupt
        RXB0Interrupt
   BRA
                                       ; 110 = RXB0 interrupt
                                       ; 111 = Wake-up on interrupt
WakeupInterrupt
   BCF PIR3, WAKIF
                                      ; Clear the interrupt flag
   ; User code to handle wake-up procedure
   :
   ;
   ; Continue checking for other interrupt source or return from here
NoInterrupt
                                       ; PC should never vector here. User may
                                       ; place a trap such as infinite loop or pin/port
                                        ; indication to catch this error.
```

R/W-x SID3

bit 0

#### **REGISTER 24-6:** TXBnSIDH: TRANSMIT BUFFER n STANDARD IDENTIFIER REGISTERS, HIGH BYTE I0 < n < 21

|       |       |       | 1     |       |       |       |  |
|-------|-------|-------|-------|-------|-------|-------|--|
| R/W-x |  |
| SID10 | SID9  | SID8  | SID7  | SID6  | SID5  | SID4  |  |

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

bit 7-0

bit 7

**SID<10:3>:** Standard Identifier bits (if EXIDE (TXBnSIDL<3>) = 0) Extended Identifier bits EID<28:21> (if EXIDE = 1).

# REGISTER 24-7: TXBnSIDL: TRANSMIT BUFFER n STANDARD IDENTIFIER REGISTERS, LOW BYTE [0 $\leq$ n $\leq$ 2]

| R/W-x | R/W-x | R/W-x | U-0 | R/W-x | U-0 | R/W-x | R/W-x |
|-------|-------|-------|-----|-------|-----|-------|-------|
| SID2  | SID1  | SID0  | —   | EXIDE | —   | EID17 | EID16 |
| bit 7 |       |       |     |       |     |       | bit 0 |

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

| bit 7-5 | SID<2:0>: Standard Identifier bits (if EXIDE (TXBnSIDL<3>) = 0)                                                                    |
|---------|------------------------------------------------------------------------------------------------------------------------------------|
|         | Extended Identifier bits EID<20:18> (if EXIDE = 1).                                                                                |
| bit 4   | Unimplemented: Read as '0'                                                                                                         |
| bit 3   | EXIDE: Extended Identifier Enable bit                                                                                              |
|         | 1 = Message will transmit extended ID, SID<10:0> become EID<28:18><br>0 = Message will transmit standard ID, EID<17:0> are ignored |
| bit 2   | Unimplemented: Read as '0'                                                                                                         |
| bit 1-0 | EID<17:16>: Extended Identifier bits                                                                                               |

#### 

| 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 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 bits (not used when transmitting standard identifier message)

## 24.2.3.1 Programmable TX/RX and Auto-RTR Buffers

The ECAN module contains 6 message buffers that can be programmed as transmit or receive buffers. Any of these buffers can also be programmed to automatically handle RTR messages.

**Note:** These registers are not used in Mode 0.

# REGISTER 24-22: BnCON: TX/RX BUFFER n CONTROL REGISTERS IN RECEIVE MODE $[0 \le n \le 5, TXnEN (BSEL0 \le n) = 0]^{(1)}$

| R/W-0                | R/W-0 | R-0     | R-0     | R-0     | R-0     | R-0     | R-0     |
|----------------------|-------|---------|---------|---------|---------|---------|---------|
| RXFUL <sup>(2)</sup> | RXM1  | RXRTRRO | FILHIT4 | FILHIT3 | FILHIT2 | FILHIT1 | FILHIT0 |
| bit 7                |       |         |         |         |         |         | bit 0   |

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

| bit 7   | RXFUL: Receive Full Status bit <sup>(2)</sup>                                                                                                                                 |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | <ul><li>1 = Receive buffer contains a received message</li><li>0 = Receive buffer is open to receive a new message</li></ul>                                                  |
| bit 6   | RXM1: Receive Buffer Mode bit                                                                                                                                                 |
|         | <ul> <li>1 = Receive all messages including partial and invalid (acceptance filters are ignored)</li> <li>0 = Receive all valid messages as per acceptance filters</li> </ul> |
| bit 5   | RXRTRRO: Read-Only Remote Transmission Request for Received Message bit                                                                                                       |
|         | 1 = Received message is a remote transmission request                                                                                                                         |
|         | 0 = Received message is not a remote transmission request                                                                                                                     |
| bit 4-0 | FILHIT<4:0>: Filter Hit bits                                                                                                                                                  |
|         | These bits indicate which acceptance filter enabled the last message reception into this buffer.                                                                              |
|         | 01111 = Acceptance Filter 15 (RXF15)                                                                                                                                          |
|         | 01110 = Acceptance Filter 14 (RXF14)                                                                                                                                          |
|         |                                                                                                                                                                               |
|         | 00001 = Acceptance Filter 1 (RXF1)                                                                                                                                            |
|         | 00000 = Acceptance Filter U (RXFU)                                                                                                                                            |
|         |                                                                                                                                                                               |

- **Note 1:** These registers are available in Mode 1 and 2 only.
  - 2: This bit is set by the CAN module upon receiving a message and must be cleared by software after the buffer is read. As long as RXFUL is set, no new message will be loaded and the buffer will be considered full.

#### 24.2.4 CAN BAUD RATE REGISTERS

This section describes the CAN Baud Rate registers.

| Note: | These | registers | are | writable | in |
|-------|-------|-----------|-----|----------|----|
|       | only. |           |     |          |    |

#### REGISTER 24-52: BRGCON1: BAUD RATE CONTROL REGISTER 1

| R/W-0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| SJW1  | SJW0  | BRP5  | BRP4  | BRP3  | BRP2  | BRP1  | BRP0  |
| 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-6 | SJW<1:0>: Synchronized Jump Width bits               |
|---------|------------------------------------------------------|
|         | 11 = Synchronization jump width time = $4 \times TQ$ |
|         | 10 = Synchronization jump width time = 3 x TQ        |
|         | 01 = Synchronization jump width time = 2 x TQ        |
|         | 00 = Synchronization jump width time = 1 x TQ        |
| bit 5-0 | BRP<5:0>: Baud Rate Prescaler bits                   |
|         | 111111 = Tq = (2 x 64)/Fosc                          |
|         | 111110 = TQ = (2 x 63)/Fosc                          |
|         | :                                                    |
|         | :                                                    |
|         | 000001 = Tq = (2 x 2)/Fosc                           |
|         | 000000 = Tq = (2 x 1)/Fosc                           |

| ANDWF                                          |                                                                                                                                                                         | AND W w                                                                                                                                                                                                                                                                             | /ith f                |          |            |                               |  |
|------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|----------|------------|-------------------------------|--|
| Syntax:                                        |                                                                                                                                                                         | ANDWF                                                                                                                                                                                                                                                                               | f {,d {,a}            | }        |            |                               |  |
| Operands:                                      |                                                                                                                                                                         | $0 \le f \le 255$<br>$d \in [0,1]$<br>$a \in [0,1]$                                                                                                                                                                                                                                 |                       |          |            |                               |  |
| Operation:                                     |                                                                                                                                                                         | (W) .AND.                                                                                                                                                                                                                                                                           | $(f) \rightarrow des$ | st       |            |                               |  |
| Status Affecte                                 | d:                                                                                                                                                                      | N, Z                                                                                                                                                                                                                                                                                |                       |          |            |                               |  |
| Encoding:                                      |                                                                                                                                                                         | 0001                                                                                                                                                                                                                                                                                | 01da                  | fff      | f          | ffff                          |  |
| Description:                                   | Description: The contents of W are AND'ed with<br>register 'f'. If 'd' is '0', the result is store<br>in W. If 'd' is '1', the result is stored bac<br>in register 'f'. |                                                                                                                                                                                                                                                                                     |                       |          |            | with<br>is stored<br>red back |  |
|                                                |                                                                                                                                                                         | If 'a' is '1', f<br>GPR bank.                                                                                                                                                                                                                                                       | the BSR i             | s used   | to s       | elect the                     |  |
|                                                |                                                                                                                                                                         | If 'a' is '0' and the extended instruction<br>set is enabled, this instruction operates<br>in Indexed Literal Offset Addressing<br>mode whenever f ≤ 95 (5Fh). See<br>Section 26.2.3 "Byte-Oriented and<br>Bit-Oriented Instructions in Indexed<br>Literal Offset Mode" for details |                       |          |            |                               |  |
| Words:                                         |                                                                                                                                                                         | 1                                                                                                                                                                                                                                                                                   |                       |          |            |                               |  |
| Cycles:                                        |                                                                                                                                                                         | 1                                                                                                                                                                                                                                                                                   |                       |          |            |                               |  |
| Q Cycle Activ                                  | vity:                                                                                                                                                                   |                                                                                                                                                                                                                                                                                     |                       |          |            |                               |  |
| Q1                                             |                                                                                                                                                                         | Q2                                                                                                                                                                                                                                                                                  | Q3                    | 6        |            | Q4                            |  |
| Deco                                           | de                                                                                                                                                                      | Read<br>register 'f'                                                                                                                                                                                                                                                                | Proce<br>Data         | ess<br>a | Wi<br>dest | rite to<br>tination           |  |
| Example:                                       |                                                                                                                                                                         | ANDWF                                                                                                                                                                                                                                                                               | REG,                  | 0, 0     |            |                               |  |
| Before Ir<br>W<br>REC<br>After Ins<br>W<br>REC | nstruct<br>G<br>tructio<br>G                                                                                                                                            | tion<br>= 17h<br>= C2h<br>n<br>= 02h<br>= C2h                                                                                                                                                                                                                                       |                       |          |            |                               |  |

| BC Branch if Carry |                                                                                                                                                                                      |                            |                    |             |            |  |  |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|--------------------|-------------|------------|--|--|
| Synta              | ax:                                                                                                                                                                                  | BC n                       |                    |             |            |  |  |
| Oper               | ands:                                                                                                                                                                                | -128 ≤ n ≤                 | 127                |             |            |  |  |
| Oper               | ation:                                                                                                                                                                               | if Carry bit<br>(PC) + 2 + | is '1',<br>2n → PC | ;           |            |  |  |
| Statu              | is Affected:                                                                                                                                                                         | None                       |                    |             |            |  |  |
| Enco               | oding:                                                                                                                                                                               | 1110                       | 0010               | nnnn        | nnnn       |  |  |
| Desc               | cription:                                                                                                                                                                            | If the Carry will branch.  | bit is '1',        | , then the  | program    |  |  |
|                    | added to the PC. Since the PC will hav<br>incremented to fetch the next<br>instruction, the new address will be<br>PC + 2 + 2n. This instruction is then a<br>two-cycle instruction. |                            |                    |             |            |  |  |
| Word               | ls:                                                                                                                                                                                  | 1                          | 1                  |             |            |  |  |
| Cycle              | es:                                                                                                                                                                                  | 1(2)                       | 1(2)               |             |            |  |  |
| Q C<br>If Ju       | ycle Activity:                                                                                                                                                                       |                            |                    |             |            |  |  |
|                    | Q1                                                                                                                                                                                   | Q2                         | Q3                 | 5           | Q4         |  |  |
|                    | Decode                                                                                                                                                                               | Read literal<br>'n'        | Proce<br>Data      | ess Wi<br>a | rite to PC |  |  |
|                    | No                                                                                                                                                                                   | No                         | No                 |             | No         |  |  |
|                    | operation                                                                                                                                                                            | operation                  | operat             | ion o       | peration   |  |  |
| lf No              | o Jump:                                                                                                                                                                              |                            |                    |             |            |  |  |
|                    | Q1                                                                                                                                                                                   | Q2                         | Q3                 | 5           | Q4         |  |  |
|                    | Decode                                                                                                                                                                               | Read literal               | Proce              | SS          | No         |  |  |
|                    |                                                                                                                                                                                      | 'n'                        | Data               | a o         | peration   |  |  |
| <u>Exan</u>        | nple:                                                                                                                                                                                | HERE                       | BC                 | 5           |            |  |  |
|                    | Before Instruction<br>PC = address (HERE)<br>After Instruction                                                                                                                       |                            |                    |             |            |  |  |

| + | 12) |
|---|-----|
|   |     |
| + | 2)  |
|   | +++ |

| IORLW Inclusive OR Literal with W |                     |                                                                                       |                            |          | w  |                    |
|-----------------------------------|---------------------|---------------------------------------------------------------------------------------|----------------------------|----------|----|--------------------|
| Synta                             | ax:                 | IORLW k                                                                               |                            |          |    |                    |
| Oper                              | ands:               | $0 \le k \le 25$                                                                      | $0 \leq k \leq 255$        |          |    |                    |
| Oper                              | ation:              | (W) .OR. k                                                                            | (W) .OR. $k \rightarrow W$ |          |    |                    |
| Status Affected: N, Z             |                     |                                                                                       |                            |          |    |                    |
| Enco                              | ding:               | 0000                                                                                  | 1001                       | kkk      | k  | kkkk               |
| Desc                              | ription:            | The contents of W are ORed with the eight-bit literal 'k'. The result is placed in W. |                            |          |    | with the<br>placed |
| Word                              | ls:                 | 1                                                                                     |                            |          |    |                    |
| Cycle                             | es:                 | 1                                                                                     |                            |          |    |                    |
| QC                                | ycle Activity:      |                                                                                       |                            |          |    |                    |
|                                   | Q1                  | Q2                                                                                    | Q3                         | 3        |    | Q4                 |
|                                   | Decode              | Read<br>literal 'k'                                                                   | Proce<br>Data              | ess<br>a | Wr | ite to W           |
| Exan                              | nple:               | IORLW                                                                                 | 35h                        |          |    |                    |
|                                   | Before Instruc<br>W | tion<br>= 9Ah                                                                         |                            |          |    |                    |

| IOR   | WF             | Inclusive                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ORW                   | with f   | F        |                       |  |
|-------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|----------|----------|-----------------------|--|
| Synta | ax:            | IORWF                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | f {,d {,a}}           |          |          |                       |  |
| Oper  | ands:          | $0 \le f \le 255$<br>$d \in [0,1]$<br>$a \in [0,1]$                                                                                                                                                                                                                                                                                                                                                                                                                        |                       |          |          |                       |  |
| Oper  | ation:         | (W) .OR. (1                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $f) \rightarrow dest$ |          |          |                       |  |
| Statu | s Affected:    | N, Z                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                       |          |          |                       |  |
| Enco  | ding:          | 0001                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0001 00da ffff ffff   |          |          |                       |  |
| Desc  | ription:       | 000100daffffffffInclusive OR W with register 'f'. If 'd' is'0', the result is placed in W. If 'd' is '1',<br>the result is placed back in register 'f'.If 'a' is '0', the Access Bank is selected.If 'a' is '1', the BSR is used to select the<br>GPR bank.If 'a' is '0' and the extended instruction<br>set is enabled, this instruction operates<br>in Indexed Literal Offset Addressing<br>mode whenever $f \le 95$ (5Fh). See<br>Section 26.2.3 "Byte-Oriented and<br> |                       |          |          |                       |  |
| Word  | ls:            | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                       |          |          |                       |  |
| Cycle | es:            | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                       |          |          |                       |  |
| QC    | ycle Activity: |                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                       |          |          |                       |  |
|       | Q1             | Q2                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Q3                    | 3        |          | Q4                    |  |
|       | Decode         | Read<br>register 'f'                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Proce<br>Data         | ess<br>a | W<br>des | /rite to<br>stination |  |

#### Example:

| mple:              | IORWF          | RESULT, | Ο, | 1 |
|--------------------|----------------|---------|----|---|
| Before Instruction | on             |         |    |   |
| RESULT =<br>W =    | = 13h<br>= 91h |         |    |   |
| After Instruction  |                |         |    |   |
| RESULT =<br>W =    | = 13h<br>= 93h |         |    |   |

After Instruction W = BFh

| SLEEP             | Enter Slo                       | eep mode                       |                | SUBFWB                | Subtract                  | f from W wi            | ith Borrow      |
|-------------------|---------------------------------|--------------------------------|----------------|-----------------------|---------------------------|------------------------|-----------------|
| Syntax:           | SLEEP                           |                                |                | Syntax:               | SUBFWB                    | f {,d {,a}}            |                 |
| Operands:         | None                            |                                |                | Operands:             | $0 \le f \le 255$         | 5                      |                 |
| Operation:        | $00h \rightarrow WE$            | DT,                            |                |                       | d ∈ [0,1]                 |                        |                 |
|                   | $0 \rightarrow WDT$             | postscaler,                    |                |                       | a ∈ [0,1]                 | _                      |                 |
|                   | $1 \rightarrow \underline{TO},$ |                                |                | Operation:            | (W) – (f) –               | $(C) \rightarrow dest$ |                 |
| Status Affactad:  |                                 |                                |                | Status Affected:      | N, OV, C,                 | DC, Z                  |                 |
| Status Allecteu.  |                                 | 0000 000                       | 0 0011         | Encoding:             | 0101                      | 01da ff:               | ff ffff         |
| Encounty.         | The Down                        |                                | bit (DD) in    | Description:          | Subtract re               | egister 'f' and (      | Carry flag      |
| Description.      | cleared. T                      | he Time-out St                 | atus bit (TO)  |                       | (borrow) in method). I    | f 'd' is '0', the r    | esult is stored |
|                   | is set. Wat<br>postscaler       | tchdog Timer a<br>are cleared. | nd its         |                       | in W. If 'd' register 'f' | is '1', the resu       | It is stored in |
|                   | The proce                       | essor is put into              | Sleep mode     |                       | <b>If 'a' is '</b> 0', '  | the Access Bar         | nk is selected. |
|                   | with the os                     | scillator stoppe               | d.             |                       | If 'a' is '1', '          | the BSR is use         | d to select the |
| Words:            | 1                               |                                |                |                       |                           | <br>and the extend     | ed instruction  |
| Cycles:           | 1                               |                                |                |                       | set is enab               | oled, this instruc     | ction operates  |
| Q Cycle Activity: |                                 |                                |                |                       | in Indexed                | Literal Offset         | Addressing      |
| Q1                | Q2                              | Q3                             | Q4             |                       | Section 2                 | 6.2.3 "Byte-Or         | rin). See       |
| Decode            | NO<br>operation                 | Process<br>Data                | Go to<br>Sleep |                       | Bit-Orient                | ed Instructior         | ns in Indexed   |
|                   |                                 |                                |                |                       | Literal Of                | fset Mode" for         | details.        |
| Example:          | SLEEP                           |                                |                | Words:                | 1                         |                        |                 |
| Before Instruc    | ction                           |                                |                | Cycles:               | 1                         |                        |                 |
| <u>TO</u> =       | ?                               |                                |                | Q Cycle Activity:     |                           |                        |                 |
| PD =              | ?                               |                                |                | Q1                    | Q2                        | Q3                     | Q4              |
| TO =              | 1†                              |                                |                | Decode                | register 'f'              | Data                   | destination     |
| PD =              | 0                               |                                |                | Example 1             | SUBEWB                    | REG 1 0                |                 |
|                   |                                 | hitin alaawad                  |                | Before Instruc        | tion                      | 100, 1, 0              |                 |
| T If WD1 causes   | wake-up, this t                 | oit is cleared.                |                | REG                   | = 3                       |                        |                 |
|                   |                                 |                                |                | VV<br>C               | = 2<br>= 1                |                        |                 |
|                   |                                 |                                |                | After Instructio      | on                        |                        |                 |
|                   |                                 |                                |                | REG<br>W              | = FF<br>= 2               |                        |                 |
|                   |                                 |                                |                | C<br>Z                | = 0<br>= 0                |                        |                 |
|                   |                                 |                                |                | Ň                     | = 0<br>= 1 ; re           | sult is negative       | e               |
|                   |                                 |                                |                | Example 2:            | SUBFWB                    | REG, 0, 0              |                 |
|                   |                                 |                                |                | Before Instruc        | tion                      |                        |                 |
|                   |                                 |                                |                | W                     | = 2                       |                        |                 |
|                   |                                 |                                |                | C<br>After Instructio | = 1                       |                        |                 |
|                   |                                 |                                |                | REG                   | = 2                       |                        |                 |
|                   |                                 |                                |                | W                     | = 3<br>= 1                |                        |                 |
|                   |                                 |                                |                | Z                     | = 0                       |                        |                 |
|                   |                                 |                                |                | N                     | = 0 ; re                  | sult is positive       |                 |

Example 3:

Before Instruction REG W C

After Instruction

REG W C Z N

SUBFWB REG, 1, 0

; result is zero

1 2 0 = = =

=



#### TABLE 28-22: EUSART SYNCHRONOUS TRANSMISSION REQUIREMENTS

| Param<br>No. | Symbol   | Characteristic                                  |             | Min | Мах | Units | Conditions |
|--------------|----------|-------------------------------------------------|-------------|-----|-----|-------|------------|
| 120          | TCKH2DTV | SYNC XMIT (MASTER & SLAVE)                      |             |     | 40  |       |            |
|              |          | Clock High to Data Out Valid                    | PIC18FXXXX  |     | 40  | ns    |            |
|              |          |                                                 | PIC18LFXXXX |     | 100 | ns    | VDD = 2.0V |
| 121          | TCKRF    | Clock Out Rise Time and Fall Time (Master mode) | PIC18FXXXX  | _   | 20  | ns    |            |
|              |          |                                                 | PIC18LFXXXX | —   | 50  | ns    | VDD = 2.0V |
| 122          | TDTRF    | Data Out Rise Time and Fall Time                | PIC18FXXXX  | _   | 20  | ns    |            |
|              |          |                                                 | PIC18LFXXXX | _   | 50  | ns    | VDD = 2.0V |

#### FIGURE 28-21: EUSART SYNCHRONOUS RECEIVE (MASTER/SLAVE) TIMING



#### TABLE 28-23: EUSART SYNCHRONOUS RECEIVE REQUIREMENTS

| Param.<br>No. | Symbol   | Characteristic                                                               | Min | Max | Units | Conditions |
|---------------|----------|------------------------------------------------------------------------------|-----|-----|-------|------------|
| 125           | TDTV2CKL | <u>SYNC RCV (MASTER &amp; SLAVE)</u><br>Data Hold before CK ↓ (DT hold time) | 10  | _   | ns    |            |
| 126           | TCKL2DTL | Data Hold after CK $\downarrow$ (DT hold time)                               | 15  | _   | ns    |            |

## THE MICROCHIP WEB SITE

Microchip provides online support via our WWW site at www.microchip.com. This web site is used as a means to make files and information easily available to customers. Accessible by using your favorite Internet browser, the web site contains the following information:

- Product Support Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software
- General Technical Support Frequently Asked Questions (FAQ), technical support requests, online discussion groups, Microchip consultant program member listing
- Business of Microchip Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Microchip sales offices, distributors and factory representatives

## CUSTOMER CHANGE NOTIFICATION SERVICE

Microchip's customer notification service helps keep customers current on Microchip products. Subscribers will receive e-mail notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest.

To register, access the Microchip web site at www.microchip.com, click on Customer Change Notification and follow the registration instructions.

## **CUSTOMER SUPPORT**

Users of Microchip products can receive assistance through several channels:

- Distributor or Representative
- Local Sales Office
- Field Application Engineer (FAE)
- Technical Support
- Development Systems Information Line

Customers should contact their distributor, representative or field application engineer (FAE) for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in the back of this document.

Technical support is available through the web site at: http://support.microchip.com