



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             | Obsolete                                                        |
|----------------------------|-----------------------------------------------------------------|
| Core Processor             | CIP-51 8051                                                     |
| Core Size                  | 8-Bit                                                           |
| Speed                      | 25MHz                                                           |
| Connectivity               | SMBus (2-Wire/I <sup>2</sup> C), SPI, UART/USART                |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, Temp Sensor, WDT              |
| Number of I/O              | 17                                                              |
| Program Memory Size        | 8KB (8K x 8)                                                    |
| Program Memory Type        | FLASH                                                           |
| EEPROM Size                | -                                                               |
| RAM Size                   | 512 x 8                                                         |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                                     |
| Data Converters            | A/D 10x12b                                                      |
| Oscillator Type            | Internal                                                        |
| Operating Temperature      | -40°C ~ 85°C (TA)                                               |
| Mounting Type              | Surface Mount                                                   |
| Package / Case             | 24-WFQFN Exposed Pad                                            |
| Supplier Device Package    | 24-QFN (4x4)                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/silicon-labs/c8051f986-gmr |

Email: info@E-XFL.COM

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

# 3. Pinout and Package Definitions

|                    | Pin                                                                        | Numbe                                                                    | ſS                                   |                  |                                                                                                                                                                                                                                                                                                                   |
|--------------------|----------------------------------------------------------------------------|--------------------------------------------------------------------------|--------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Name               | <sup>•</sup> F980/1/2<br><sup>•</sup> F983/5<br><sup>•</sup> F990/1<br>-GM | <sup>•</sup> F986/7<br><sup>•</sup> F988/9<br><sup>•</sup> F996/7<br>-GM | 'F986/7<br>'F988/9<br>'F996/7<br>-GU | Туре             | Description                                                                                                                                                                                                                                                                                                       |
| V <sub>DD</sub>    | 4                                                                          | 3                                                                        | 6                                    | P In             | Power Supply Voltage. Must be 1.8 to 3.6 V.                                                                                                                                                                                                                                                                       |
| GND                | 3, 12                                                                      | 2                                                                        | 5                                    | G                | Required Ground.                                                                                                                                                                                                                                                                                                  |
| RST/               | 5                                                                          | 6                                                                        | 9                                    | D I/O            | Device Reset. Open-drain output of internal POR or $V_{DD}$ monitor. An external source can initiate a system reset by driving this pin low for at least 15 µs. A 1 k $\Omega$ to 5 k $\Omega$ pullup to $V_{DD}$ is recommended. See Section "18. Reset Sources" on page 181 Section for a complete description. |
| C2CK               |                                                                            |                                                                          |                                      | D I/O            | Clock signal for the C2 Debug Interface.                                                                                                                                                                                                                                                                          |
| P2.7/              | 6                                                                          | 7                                                                        | 10                                   | D I/O            | Port 2.7. This pin can only be used as GPIO. The<br>Crossbar cannot route signals to this pin and it cannot be<br>configured as an analog input. See Port I/O Section for a<br>complete description.                                                                                                              |
| C2D                |                                                                            |                                                                          |                                      | D I/O            | Bi-directional data signal for the C2 Debug Interface.                                                                                                                                                                                                                                                            |
| P1.6/              | 8                                                                          | 9                                                                        | 12                                   | D I/O            | Port 1.6. See Port I/O Section for a complete description.                                                                                                                                                                                                                                                        |
| XTAL3              |                                                                            |                                                                          |                                      | A In             | SmaRTClock Oscillator Crystal Input.<br>See Section 20 for a complete description.                                                                                                                                                                                                                                |
| P1.7/              | 7                                                                          | 8                                                                        | 11                                   | D I/O            | Port 1.7. See Port I/O Section for a complete description.                                                                                                                                                                                                                                                        |
| XTAL4              |                                                                            |                                                                          |                                      | A Out            | SmaRTClock Oscillator Crystal Output.<br>See Section 20 for a complete description.                                                                                                                                                                                                                               |
| P0.0/              | 2                                                                          | 24                                                                       | 3                                    | D I/O or<br>A In | Port 0.0. See Port I/O Section for a complete description.                                                                                                                                                                                                                                                        |
| V <sub>REF</sub> * |                                                                            |                                                                          |                                      | A In             | External V <sub>REF</sub> Input.<br>See Section "5.9. Voltage and Ground Reference<br>Options" on page 88.                                                                                                                                                                                                        |
| *Note: Availa      | ble only on t                                                              | he C805 <sup>-</sup>                                                     | 1F980/2/6                            | 6/8 and C8       | 051F990/6 devices.                                                                                                                                                                                                                                                                                                |

### Table 3.1. Pin Definitions for the C8051F99x-C8051F98x





Figure 3.4. QFN-20 Package Marking Diagram



Figure 3.5. QFN-24 Package Marking Diagram



### SFR Definition 6.2. IREF0CF: Current Reference Configuration

| Bit   | 7     | 6   | 5   | 4   | 3   | 2          | 1 | 0 |  |
|-------|-------|-----|-----|-----|-----|------------|---|---|--|
| Name  | PWMEN |     |     |     |     | PWMSS[2:0] |   |   |  |
| Туре  | R/W   | R/W | R/W | R/W | R/W | R/W        |   |   |  |
| Reset | 0     | 0   | 0   | 0   | 0   | 0          | 0 | 0 |  |

#### SFR Page = All; SFR Address = 0xB9

| Bit | Name       | Function                                                           |
|-----|------------|--------------------------------------------------------------------|
| 7   | PWMEN      | PWM Enhanced Mode Enable.                                          |
|     |            | Enables the PWM Enhanced Mode.                                     |
|     |            | 0: PWM Enhanced Mode disabled.                                     |
|     |            | 1: PWM Enhanced Mode enabled.                                      |
| 6:3 | Unused     | Read = 0000b, Write = don't care.                                  |
| 2:0 | PWMSS[2:0] | PWM Source Select.                                                 |
|     |            | Selects the PCA channel to use for the fine-tuning control signal. |
|     |            | 000: CEX0 selected as fine-tuning control signal.                  |
|     |            | 001: CEX1 selected as fine-tuning control signal.                  |
|     |            | 010: CEX2 selected as fine-tuning control signal.                  |
|     |            | All Other Values: Reserved.                                        |

### 6.2. IREF0 Specifications

See Table 4.13 on page 62 for a detailed listing of IREF0 specifications.



# SFR Definition 7.2. CPT0MD: Comparator 0 Mode Selection

| Bit   | 7   | 6 | 5      | 4      | 3 | 2 | 1          | 0 |  |
|-------|-----|---|--------|--------|---|---|------------|---|--|
| Name  |     |   | CP0RIE | CP0FIE |   |   | CP0MD[1:0] |   |  |
| Туре  | R/W | R | R/W    | R/W    | R | R | R/W        |   |  |
| Reset | 1   | 0 | 0      | 0      | 0 | 0 | 1          | 0 |  |

# SFR Page = 0x0; SFR Address = 0x9D

| Bit | Name       | Function                                                                                                                                                                                                                                                           |
|-----|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | Reserved   | Read = 1b, Must Write 1b.                                                                                                                                                                                                                                          |
| 6   | Unused     | Read = 0b, Write = don't care.                                                                                                                                                                                                                                     |
| 5   | CP0RIE     | <b>Comparator0 Rising-Edge Interrupt Enable.</b><br>0: Comparator0 Rising-edge interrupt disabled.<br>1: Comparator0 Rising-edge interrupt enabled.                                                                                                                |
| 4   | CP0FIE     | <b>Comparator0 Falling-Edge Interrupt Enable.</b><br>0: Comparator0 Falling-edge interrupt disabled.<br>1: Comparator0 Falling-edge interrupt enabled.                                                                                                             |
| 3:2 | Unused     | Read = 00b, Write = don't care.                                                                                                                                                                                                                                    |
| 1:0 | CP0MD[1:0] | Comparator0 Mode Select<br>These bits affect the response time and power consumption for Comparator0.<br>00: Mode 0 (Fastest Response Time, Highest Power Consumption)<br>01: Mode 1<br>10: Mode 2<br>11: Mode 3 (Slowest Response Time, Lowest Power Consumption) |



### SFR Definition 8.14. CS0PM: Capacitive Sense Pin Monitor

| Bit   | 7    | 6     | 5     | 4     | 3     | 2     | 1           | 0 |  |
|-------|------|-------|-------|-------|-------|-------|-------------|---|--|
| Name  | UAPM | SPIPM | SMBPM | PCAPM | PIOPM | CP0PM | CSPMMD[1:0] |   |  |
| Туре  | R/W  | R/W   | R/W   | R/W   | R/W   | R/W   | R/W         |   |  |
| Reset | 0    | 0     | 0     | 0     | 0     | 0     | 0           | 0 |  |

SFR Page = 0xF; SFR Address = 0xDE;

| Bit | Name        | Description                                                          |
|-----|-------------|----------------------------------------------------------------------|
| 7   | UAPM        | UART Pin Monitor Enable.                                             |
|     |             | Enables monitoring of the UART TX pin.                               |
| 6   | SPIPM       | SPI Pin Monitor Enable.                                              |
|     |             | Enables monitoring SPI output pins.                                  |
| 5   | SMBPM       | SMBus Pin Monitor Enable.                                            |
|     |             | Enables monitoring of the SMBus pins.                                |
| 4   | PCAPM       | PCA Pin Monitor Enable.                                              |
|     |             | Enables monitoring of PCA output pins.                               |
| 3   | PIOPM       | Port I/O Pin Monitor Enable.                                         |
|     |             | Enables monitoring of writes to the port latch registers.            |
| 2   | CP0PM       | CP0 Pin Monitor Enable.                                              |
|     |             | Enables monitoring of the comparator CP0 output.                     |
| 1:0 | CSPMMD[1:0] | CS0 Pin Monitor Mode.                                                |
|     |             | Selects the operation to take when a monitored signal changes state. |
|     |             | 00: Always retry bit cycles on a pin state change.                   |
|     |             | 01: Retry up to twice on consecutive bit cycles.                     |
|     |             | 10: Retry up to four times on consecutive bit cycles.                |
|     |             | 11: Reserved.                                                        |



With the CIP-51's maximum system clock at 25 MHz, it has a peak throughput of 25 MIPS. The CIP-51 has a total of 109 instructions. The table below shows the total number of instructions that require each execution time.

| Clocks to Execute      | 1  | 2  | 2/3 | 3  | 3/4 | 4 | 4/5 | 5 | 8 |
|------------------------|----|----|-----|----|-----|---|-----|---|---|
| Number of Instructions | 26 | 50 | 5   | 14 | 7   | 3 | 1   | 2 | 1 |

### 9.2. Programming and Debugging Support

In-system programming of the Flash program memory and communication with on-chip debug support logic is accomplished via the Silicon Labs 2-Wire Development Interface (C2).

The on-chip debug support logic facilitates full speed in-circuit debugging, allowing the setting of hardware breakpoints, starting, stopping and single stepping through program execution (including interrupt service routines), examination of the program's call stack, and reading/writing the contents of registers and memory. This method of on-chip debugging is completely non-intrusive, requiring no RAM, Stack, timers, or other on-chip resources. C2 details can be found in Section "27. C2 Interface" on page 319.

The CIP-51 is supported by development tools from Silicon Labs and third party vendors. Silicon Labs provides an integrated development environment (IDE) including editor, debugger and programmer. The IDE's debugger and programmer interface to the CIP-51 via the C2 interface to provide fast and efficient in-system device programming and debugging. Third party macro assemblers and C compilers are also available.

### 9.3. Instruction Set

The instruction set of the CIP-51 System Controller is fully compatible with the standard MCS-51<sup>™</sup> instruction set. Standard 8051 development tools can be used to develop software for the CIP-51. All CIP-51 instructions are the binary and functional equivalent of their MCS-51<sup>™</sup> counterparts, including opcodes, addressing modes and effect on PSW flags. However, instruction timing is different than that of the standard 8051.

### 9.3.1. Instruction and CPU Timing

In many 8051 implementations, a distinction is made between machine cycles and clock cycles, with machine cycles varying from 2 to 12 clock cycles in length. However, the CIP-51 implementation is based solely on clock cycle timing. All instruction timings are specified in terms of clock cycles.

Due to the pipelined architecture of the CIP-51, most instructions execute in the same number of clock cycles as there are program bytes in the instruction. Conditional branch instructions take one less clock cycle to complete when the branch is not taken as opposed to when the branch is taken. Table 9.1 is the CIP-51 Instruction Set Summary, which includes the mnemonic, number of bytes, and number of clock cycles for each instruction.



# **10. Memory Organization**

The memory organization of the CIP-51 System Controller is similar to that of a standard 8051. There are two separate memory spaces: program memory and data memory. Program and data memory share the same address space but are accessed via different instruction types. The memory organization of the C8051F99x-C8051F98x device family is shown in Figure 10.1.







# 16. Cyclic Redundancy Check Unit (CRC0)

C8051F99x-C8051F98x devices include a cyclic redundancy check unit (CRC0) that can perform a CRC using a 16-bit polynomial. CRC0 accepts a stream of 8-bit data written to the CRC0IN register. CRC0 posts the 16-bit result to an internal register. The internal result register may be accessed indirectly using the CRC0PNT bits and CRC0DAT register, as shown in Figure 16.1. CRC0 also has a bit reverse register for quick data manipulation.



Figure 16.1. CRC0 Block Diagram

### 16.1. CRC Algorithm

The C8051F99x-C8051F98x CRC unit generates a CRC result equivalent to the following algorithm:

- XOR the input with the most-significant bits of the current CRC result. If this is the first iteration of the CRC unit, the current CRC result will be the set initial value (0x0000 or 0xFFFF).
- 2a. If the MSB of the CRC result is set, shift the CRC result and XOR the result with the selected polynomial.
- 2b. If the MSB of the CRC result is not set, shift the CRC result.

Repeat Steps 2a/2b for the number of input bits (8). The algorithm is also described in the following example.



### **19.4.** Special Function Registers for Selecting and Configuring the System Clock

The clocking sources on C8051F99x-C8051F98x devices are enabled and configured using the OSCICN, OSCICL, OSCXCN and the SmaRTClock internal registers. See Section "20. SmaRTClock (Real Time Clock)" on page 197 for SmaRTClock register descriptions. The system clock source for the MCU can be selected using the CLKSEL register. To minimize active mode current, the oneshot timer which sets Flash read time should by bypassed when the system clock is greater than 10 MHz. See the FLSCL register description for details.

The clock selected as the system clock can be divided by 1, 2, 4, 8, 16, 32, 64, or 128. When switching between two clock divide values, the transition may take up to 128 cycles of the undivided clock source. The CLKRDY flag can be polled to determine when the new clock divide value has been applied. The clock divider must be set to "divide by 1" when entering Suspend or Sleep Mode.

The system clock source may also be switched on-the-fly. The switchover takes effect after one clock period of the slower oscillator.

### SFR Definition 19.1. CLKSEL: Clock Select

| Bit   | 7      | 6 | 5           | 4 | 3   | 2 | 1           | 0 |
|-------|--------|---|-------------|---|-----|---|-------------|---|
| Name  | CLKRDY |   | CLKDIV[2:0] |   |     |   | CLKSEL[2:0] | ] |
| Туре  | R      |   | R/W         |   | R/W |   | R/W         |   |
| Reset | 1      | 0 | 0           | 0 | 0   | 0 | 1           | 0 |

#### SFR Page = All; SFR Address = 0xA9

| Bit | Name        | Function                                                                       |
|-----|-------------|--------------------------------------------------------------------------------|
| 7   | CLKRDY      | System Clock Divider Clock Ready Flag.                                         |
|     |             | 0: The selected clock divide setting has not been applied to the system clock. |
|     |             | 1: The selected clock divide setting has been applied to the system clock.     |
| 6:4 | CLKDIV[2:0] | System Clock Divider Bits.                                                     |
|     |             | Selects the clock division to be applied to the undivided system clock source. |
|     |             | 000: System clock is divided by 1.                                             |
|     |             | 001: System clock is divided by 2.                                             |
|     |             | 010: System clock is divided by 4.                                             |
|     |             | 011: System clock is divided by 8.                                             |
|     |             | 100: System clock is divided by 16.                                            |
|     |             | 101: System clock is divided by 32.                                            |
|     |             | 110: System clock is divided by 64.                                            |
|     |             | 111: System clock is divided by 128.                                           |
| 3   | Unused      | Read = 0b. Must Write 0b.                                                      |
| 2:0 | CLKSEL[2:0] | System Clock Select.                                                           |
|     |             | Selects the oscillator to be used as the undivided system clock source.        |
|     |             | 000: Precision Internal Oscillator.                                            |
|     |             | 001: External Oscillator.                                                      |
|     |             | 010: Low Power Oscillator divided by 8.                                        |
|     |             | 011: SmaRTClock Oscillator.                                                    |
|     |             | 100: Low Power Oscillator.                                                     |
|     |             | All other values reserved.                                                     |



### 20.3.2. Setting a SmaRTClock Alarm

The SmaRTClock alarm function compares the 32-bit value of SmaRTClock Timer to the value of the ALARMn registers. An alarm event is triggered if the SmaRTClock timer is **equal to** the ALARMn registers. If Auto Reset is enabled, the 32-bit timer will be cleared to zero one SmaRTClock cycle after the alarm event.

The SmaRTClock alarm event can be configured to reset the MCU, wake it up from a low power mode, or generate an interrupt. See Section "13. Interrupt Handler" on page 138, Section "15. Power Management" on page 162, and Section "18. Reset Sources" on page 181 for more information.

The following steps can be used to set up a SmaRTClock Alarm:

- 1. Disable SmaRTClock Alarm Events (RTC0AEN = 0).
- 2. Set the ALARMn registers to the desired value.
- 3. Enable SmaRTClock Alarm Events (RTC0AEN = 1).

#### Notes:

- 1. The ALRM bit, which is used as the SmaRTClock Alarm Event flag, is cleared by disabling SmaRTClock Alarm Events (RTC0AEN = 0).
- If AutoReset is disabled, disabling (RTC0AEN = 0) then Re-enabling Alarm Events (RTC0AEN = 1) after a SmaRTClock Alarm without modifying ALARMn registers will automatically schedule the next alarm after 2^32 SmaRTClock cycles (approximately 36 hours using a 32.768 kHz crystal).
- 3. The SmaRTClock Alarm Event flag will remain asserted for a maximum of one SmaRTClock cycle. See Section "15. Power Management" on page 162 for information on how to capture a SmaRTClock Alarm event using a flag which is not automatically cleared by hardware.



Registers XBR0, XBR1, and XBR2 are used to assign the digital I/O resources to the physical I/O Port pins. Note that when the SMBus is selected, the Crossbar assigns both pins associated with the SMBus (SDA and SCL); when either UART is selected, the Crossbar assigns both pins associated with the UART (TX and RX). UART0 pin assignments are fixed for bootloading purposes: UART TX0 is always assigned to P0.4; UART RX0 is always assigned to P0.5. Standard Port I/Os appear contiguously after the prioritized functions have been assigned.

#### Notes:

- 1. The Crossbar must be enabled (XBARE = 1) before any Port pin is used as a digital output. Port output drivers are disabled while the Crossbar is disabled.
- 2. When SMBus is selected in the Crossbar, the pins associated with SDA and SCL will automatically be forced into open-drain output mode regardless of the PnMDOUT setting.
- 3. SPI0 can be operated in either 3-wire or 4-wire modes, depending on the state of the NSSMD1-NSSMD0 bits in register SPI0CN. The NSS signal is only routed to a Port pin when 4-wire mode is selected. When SPI0 is selected in the Crossbar, the SPI0 mode (3-wire or 4-wire) will affect the pinout of all digital functions lower in priority than SPI0.
- 4. For given XBRn, PnSKIP, and SPInCN register settings, one can determine the I/O pin-out of the device using Figure 21.3.
- 5. On 20-pin devices, P1.4 should be skipped in the Crossbar. It is not available as a device pin.



### SFR Definition 21.6. P1MASK: Port1 Mask Register

| Bit   | 7           | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|-------|-------------|---|---|---|---|---|---|---|--|--|
| Name  | P1MASK[7:0] |   |   |   |   |   |   |   |  |  |
| Туре  | R/W         |   |   |   |   |   |   |   |  |  |
| Reset | 0           | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |

SFR Page= 0x0; SFR Address = 0xBF

| Bit | Name        | Function                                                                                                                                                                                            |
|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | P1MASK[7:0] | Port 1 Mask Value.                                                                                                                                                                                  |
|     |             | Selects P1 pins to be compared to the corresponding bits in P1MAT.<br>0: P1.n pin logic value is ignored and cannot cause a Port Mismatch event.<br>1: P1.n pin logic value is compared to P1MAT.n. |

# SFR Definition 21.7. P1MAT: Port1 Match Register

| Bit   | 7          | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|------------|---|---|---|---|---|---|---|
| Name  | P1MAT[7:0] |   |   |   |   |   |   |   |
| Туре  | R/W        |   |   |   |   |   |   |   |
| Reset | 1          | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

SFR Page = 0x0; SFR Address = 0xCF

| Bit | Name       | Function                                                                                                                                                                                    |
|-----|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | P1MAT[7:0] | Port 1 Match Value.                                                                                                                                                                         |
|     |            | Match comparison value used on Port 1 for bits in P1MASK which are set to 1.<br>0: P1.n pin logic value is compared with logic LOW.<br>1: P1.n pin logic value is compared with logic HIGH. |



### 22.5.4. Read Sequence (Slave)

During a read sequence, an SMBus master reads data from a slave device. The slave in this transfer will be a receiver during the address byte, and a transmitter during all data bytes. When slave events are enabled (INH = 0), the interface enters Slave Receiver Mode (to receive the slave address) when a START followed by a slave address and direction bit (READ in this case) is received. If hardware ACK generation is disabled, upon entering Slave Receiver Mode, an interrupt is generated and the ACKRQ bit is set. The software must respond to the received slave address with an ACK, or ignore the received slave address with a NACK. If hardware ACK generation is enabled, the hardware will apply the ACK for a slave address which matches the criteria set up by SMB0ADR and SMB0ADM. The interrupt will occur after the ACK cycle.

If the received slave address is ignored (by software or hardware), slave interrupts will be inhibited until the next START is detected. If the received slave address is acknowledged, zero or more data bytes are transmitted. If the received slave address is acknowledged, data should be written to SMB0DAT to be transmitted. The interface enters Slave Transmitter Mode, and transmits one or more bytes of data. After each byte is transmitted, the master sends an acknowledge bit; if the acknowledge bit is an ACK, SMB0DAT should be written with the next data byte. If the acknowledge bit is a NACK, SMB0DAT should not be written to before SI is cleared (Note: an error condition may be generated if SMB0DAT is written following a received NACK while in Slave Transmitter Mode). The interface exits Slave Transmitter Mode after receiving a STOP. Note that the interface will switch to Slave Receiver Mode if SMB0DAT is not written following a slave Transmitter interrupt. Figure 22.8 shows a typical slave read sequence. Two transmitted data bytes are shown, though any number of bytes may be transmitted. Notice that all of the 'data byte transferred' interrupts occur **after** the ACK cycle in this mode, regardless of whether hardware ACK generation is enabled.



Figure 22.8. Typical Slave Read Sequence

### 22.6. SMBus Status Decoding

The current SMBus status can be easily decoded using the SMBOCN register. The appropriate actions to take in response to an SMBus event depend on whether hardware slave address recognition and ACK generation is enabled or disabled. Table 22.5 describes the typical actions when hardware slave address recognition and ACK generation is disabled. Table 22.6 describes the typical actions when hardware slave address recognition and ACK generation is enabled. In the tables, STATUS VECTOR refers to the four upper bits of SMB0CN: MASTER, TXMODE, STA, and STO. The shown response options are only the typical responses; application-specific procedures are allowed as long as they conform to the SMBus specification. Highlighted responses are allowed by hardware but do not conform to the SMBus specification.



# 24. Enhanced Serial Peripheral Interface (SPI0)

The Enhanced Serial Peripheral Interface (SPI0) provides access to a flexible, full-duplex synchronous serial bus. SPI0 can operate as a master or slave device in both 3-wire or 4-wire modes, and supports multiple masters and slaves on a single SPI bus. The slave-select (NSS) signal can be configured as an input to select SPI0 in slave mode, or to disable Master Mode operation in a multi-master environment, avoiding contention on the SPI bus when more than one master attempts simultaneous data transfers. NSS can also be configured as a chip-select output in master mode, or disabled for 3-wire operation. Additional general purpose port I/O pins can be used to select multiple slave devices in master mode.







## SFR Definition 24.2. SPI0CN: SPI0 Control

| Bit   | 7    | 6    | 5    | 4      | 3    | 2       | 1     | 0     |
|-------|------|------|------|--------|------|---------|-------|-------|
| Name  | SPIF | WCOL | MODF | RXOVRN | NSSM | ID[1:0] | TXBMT | SPIEN |
| Туре  | R/W  | R/W  | R/W  | R/W    | R/W  |         | R     | R/W   |
| Reset | 0    | 0    | 0    | 0      | 0    | 1       | 1     | 0     |

# SFR Page = 0x0; SFR Address = 0xF8; Bit-Addressable

| Bit | Name       | Function                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | SPIF       | SPI0 Interrupt Flag.                                                                                                                                                                                                                                                                                                                                                                                                                  |
|     |            | This bit is set to logic 1 by hardware at the end of a data transfer. If SPI interrupts are enabled, an interrupt will be generated. This bit is not automatically cleared by hardware, and must be cleared by software.                                                                                                                                                                                                              |
| 6   | WCOL       | Write Collision Flag.                                                                                                                                                                                                                                                                                                                                                                                                                 |
|     |            | This bit is set to logic 1 if a write to SPI0DAT is attempted when TXBMT is 0. When this occurs, the write to SPI0DAT will be ignored, and the transmit buffer will not be written. If SPI interrupts are enabled, an interrupt will be generated. This bit is not automatically cleared by hardware, and must be cleared by software.                                                                                                |
| 5   | MODF       | Mode Fault Flag.                                                                                                                                                                                                                                                                                                                                                                                                                      |
|     |            | This bit is set to logic 1 by hardware when a master mode collision is detected (NSS is low, MSTEN = 1, and NSSMD[1:0] = 01). If SPI interrupts are enabled, an interrupt will be generated. This bit is not automatically cleared by hardware, and must be cleared by software.                                                                                                                                                      |
| 4   | RXOVRN     | Receive Overrun Flag (valid in slave mode only).                                                                                                                                                                                                                                                                                                                                                                                      |
|     |            | This bit is set to logic 1 by hardware when the receive buffer still holds unread data from a previous transfer and the last bit of the current transfer is shifted into the SPI0 shift register. If SPI interrupts are enabled, an interrupt will be generated. This bit is not automatically cleared by hardware, and must be cleared by software.                                                                                  |
| 3:2 | NSSMD[1:0] | Slave Select Mode.                                                                                                                                                                                                                                                                                                                                                                                                                    |
|     |            | <ul> <li>Selects between the following NSS operation modes:</li> <li>(See Section 24.2 and Section 24.3).</li> <li>00: 3-Wire Slave or 3-Wire Master Mode. NSS signal is not routed to a port pin.</li> <li>01: 4-Wire Slave or Multi-Master Mode (Default). NSS is an input to the device.</li> <li>1x: 4-Wire Single-Master Mode. NSS signal is mapped as an output from the device and will assume the value of NSSMD0.</li> </ul> |
| 1   | TXBMT      | Transmit Buffer Empty.                                                                                                                                                                                                                                                                                                                                                                                                                |
|     |            | This bit will be set to logic 0 when new data has been written to the transmit buffer.<br>When data in the transmit buffer is transferred to the SPI shift register, this bit will<br>be set to logic 1, indicating that it is safe to write a new byte to the transmit buffer.                                                                                                                                                       |
| 0   | SPIEN      | SPI0 Enable.                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |            | 0: SPI disabled.<br>1: SPI enabled.                                                                                                                                                                                                                                                                                                                                                                                                   |



## SFR Definition 24.3. SPI0CKR: SPI0 Clock Rate

| Bit   | 7              | 6                                                                                                                                         | 5                                                                                                                                                                        | 4                                                                                                       | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 2                                                            | 1                                                                 | 0                                                 |
|-------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|-------------------------------------------------------------------|---------------------------------------------------|
| Nam   | e              | SCR[7:0]                                                                                                                                  |                                                                                                                                                                          |                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                              |                                                                   |                                                   |
| Туре  | )              |                                                                                                                                           |                                                                                                                                                                          | R                                                                                                       | W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                              |                                                                   |                                                   |
| Rese  | et O           | 0                                                                                                                                         | 0                                                                                                                                                                        | 0                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0                                                            | 0                                                                 | 0                                                 |
| SFR F | Page = 0x0; SF | R Address =                                                                                                                               | = 0xA2                                                                                                                                                                   |                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                              |                                                                   |                                                   |
| Bit   | Name           |                                                                                                                                           |                                                                                                                                                                          |                                                                                                         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1                                                            |                                                                   |                                                   |
| 7:0   | SCR[7:0]       | SPI0 Cloc                                                                                                                                 | k Rate.                                                                                                                                                                  |                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                              |                                                                   |                                                   |
|       |                | These bits<br>configured<br>sion of the<br>the system<br>register.<br>$f_{SCK} =$<br>for 0 <= S<br>Example:<br>$f_{SCK} =$<br>$f_{SCK} =$ | s determine for master<br>e system cloch<br>n clock frequ<br>$\frac{SY}{2 \times (SPI00)}$ PI0CKR <=<br>If SYSCLK =<br>$\frac{2000000}{2 \times (4 + 1)}$ 200 <i>kHz</i> | the frequenc<br>mode opera<br>ck, and is giv<br>uency and S<br>SCLK<br>CKR[7:0] +<br>255<br>= 2 MHz and | y of the SC<br>tion. The SC<br>yen in the fo<br><i>PIOCKR</i> is the second sec | K output wh<br>CK clock fre<br>Illowing equ<br>he 8-bit valu | ien the SPI0 i<br>quency is a d<br>ation, where<br>ue held in the | module is<br>livided ver-<br>SYSCLK is<br>SPI0CKR |

## SFR Definition 24.4. SPI0DAT: SPI0 Data

| Bit   | 7            | 6               | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|--------------|-----------------|---|---|---|---|---|---|
| Name  | SPI0DAT[7:0] |                 |   |   |   |   |   |   |
| Туре  | R/W          |                 |   |   |   |   |   |   |
| Reset | 0            | 0 0 0 0 0 0 0 0 |   |   |   |   |   | 0 |

SFR Page = 0x0; SFR Address = 0xA3

| Bit | Name         | Function                                                                                                                                                                                                                                     |
|-----|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | SPI0DAT[7:0] | SPI0 Transmit and Receive Data.                                                                                                                                                                                                              |
|     |              | The SPI0DAT register is used to transmit and receive SPI0 data. Writing data to SPI0DAT places the data into the transmit buffer and initiates a transfer when in Master Mode. A read of SPI0DAT returns the contents of the receive buffer. |





\* SCK is shown for CKPOL = 0. SCK is the opposite polarity for CKPOL = 1.





### Figure 24.9. SPI Master Timing (CKPHA = 1)



## SFR Definition 25.2. TCON: Timer Control

| Bit   | 7             | 6                                                                               | 5                                                                                                                                                | 4                                              | 3                                              | 2                                           | 1                               | 0                         |  |  |
|-------|---------------|---------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|------------------------------------------------|---------------------------------------------|---------------------------------|---------------------------|--|--|
| Nam   | e TF1         | TR1                                                                             | TF0                                                                                                                                              | TR0                                            | IE1                                            | IT1                                         | IE0                             | IT0                       |  |  |
| Туре  | R/W           | R/W R/W R/W R/W F                                                               |                                                                                                                                                  |                                                |                                                |                                             | R/W                             | R/W                       |  |  |
| Rese  | t 0           | 0                                                                               | 0 0 0 0 0 0 0                                                                                                                                    |                                                |                                                |                                             |                                 |                           |  |  |
| SFR F | age = 0x0; SI | FR Address =                                                                    | = 0x88; Bit-A                                                                                                                                    | ddressable                                     |                                                | L                                           |                                 |                           |  |  |
| Bit   | Name          |                                                                                 |                                                                                                                                                  |                                                | Function                                       |                                             |                                 |                           |  |  |
| 7     | TF1           | Timer 1 Ov                                                                      | erflow Flag                                                                                                                                      |                                                |                                                |                                             |                                 |                           |  |  |
|       |               | Set to 1 by l<br>but is autom<br>routine.                                       | nardware wh<br>natically clea                                                                                                                    | red when th                                    | overflows. T<br>e CPU vecto                    | his flag can t<br>ors to the Tim            | be cleared by<br>her 1 interrup | y software<br>ot service  |  |  |
| 6     | TR1           | Timer 1 Ru                                                                      | n Control.                                                                                                                                       |                                                |                                                |                                             |                                 |                           |  |  |
|       |               | Timer 1 is e                                                                    | nabled by se                                                                                                                                     | etting this bit                                | to 1.                                          |                                             |                                 |                           |  |  |
| 5     | TF0           | Timer 0 Ov                                                                      | erflow Flag                                                                                                                                      |                                                |                                                |                                             |                                 |                           |  |  |
|       |               | Set to 1 by l<br>but is autom<br>routine.                                       | nardware wh<br>natically clea                                                                                                                    | nen Timer 0<br>red when th                     | overflows. T<br>e CPU vecto                    | his flag can b<br>ors to the Tim            | be cleared by<br>her 0 interrup | y software<br>t service   |  |  |
| 4     | TR0           | Timer 0 Ru                                                                      | n Control.                                                                                                                                       |                                                |                                                |                                             |                                 |                           |  |  |
|       |               | Timer 0 is e                                                                    | nabled by se                                                                                                                                     | etting this bit                                | to 1.                                          |                                             |                                 |                           |  |  |
| 3     | IE1           | External In                                                                     | terrupt 1.                                                                                                                                       |                                                |                                                |                                             |                                 |                           |  |  |
|       |               | This flag is s<br>can be clear<br>External Inte                                 | set by hardw<br>red by softwa<br>errupt 1 serv                                                                                                   | are when ar<br>are but is au<br>rice routine i | n edge/level<br>tomatically c<br>n edge-trigge | of type define<br>leared when<br>ered mode. | ed by IT1 is<br>the CPU ve      | detected. It ctors to the |  |  |
| 2     | IT1           | Interrupt 1                                                                     | Type Select                                                                                                                                      | <b>.</b>                                       |                                                |                                             |                                 |                           |  |  |
|       |               | This bit sele                                                                   | cts whether                                                                                                                                      | the configur                                   | ed INT1 inte                                   | rrupt will be                               | edge or leve                    | l sensitive.              |  |  |
|       |               | SFR Definit                                                                     | ion 13.7).                                                                                                                                       |                                                |                                                |                                             | TOTOL Tegis                     | 101 (300                  |  |  |
|       |               | 0: INT1 is le                                                                   | vel triggered                                                                                                                                    | Ч                                              |                                                |                                             |                                 |                           |  |  |
| 1     |               |                                                                                 |                                                                                                                                                  | u.                                             |                                                |                                             |                                 |                           |  |  |
| 1     | IEU           | This flag is s                                                                  | set by hardw                                                                                                                                     | are when ar                                    | n edge/level                                   | of type defin                               | ed by IT1 is                    | detected It               |  |  |
|       |               | can be clear<br>External Inte                                                   | can be cleared by software but is automatically cleared when the CPU vectors to the External Interrupt 0 service routine in edge-triggered mode. |                                                |                                                |                                             |                                 |                           |  |  |
| 0     | IT0           | Interrupt 0                                                                     | Type Select                                                                                                                                      |                                                |                                                |                                             |                                 |                           |  |  |
|       |               | This bit sele<br>INT0 is conf<br>Definition 13<br>0: INT0 is le<br>1: INT0 is e | ects whether<br>Figured active<br>3.7).<br>Evel triggeree<br>dge triggeree                                                                       | the configur<br>e low or high<br>d.<br>d.      | red INTO intention by the INOF                 | rrupt will be<br>PL bit in regis            | edge or leve<br>ster IT01CF     | l sensitive.<br>(see SFR  |  |  |



### 25.2.2. 8-bit Timers with Auto-Reload

When T2SPLIT is set, Timer 2 operates as two 8-bit timers (TMR2H and TMR2L). Both 8-bit timers operate in auto-reload mode as shown in Figure 25.5. TMR2RLL holds the reload value for TMR2L; TMR2RLH holds the reload value for TMR2H. The TR2 bit in TMR2CN handles the run control for TMR2H. TMR2L is always running when configured for 8-bit Mode.

Each 8-bit timer may be configured to use SYSCLK, SYSCLK divided by 12, SmaRTClock divided by 8 or Comparator 0 output. The Timer 2 Clock Select bits (T2MH and T2ML in CKCON) select either SYSCLK or the clock defined by the Timer 2 External Clock Select bits (T2XCLK[1:0] in TMR2CN), as follows:

| T2MH | T2XCLK[1:0] | TMR2H Clock<br>Source |
|------|-------------|-----------------------|
| 0    | 00          | SYSCLK / 12           |
| 0    | 01          | SmaRTClock / 8        |
| 0    | 10          | Reserved              |
| 0    | 11          | Comparator 0          |
| 1    | Х           | SYSCLK                |

| T2ML | T2XCLK[1:0] | TMR2L Clock<br>Source |
|------|-------------|-----------------------|
| 0    | 00          | SYSCLK / 12           |
| 0    | 01          | SmaRTClock / 8        |
| 0    | 10          | Reserved              |
| 0    | 11          | Comparator 0          |
| 1    | Х           | SYSCLK                |

The TF2H bit is set when TMR2H overflows from 0xFF to 0x00; the TF2L bit is set when TMR2L overflows from 0xFF to 0x00. When Timer 2 interrupts are enabled (IE.5), an interrupt is generated each time TMR2H overflows. If Timer 2 interrupts are enabled and TF2LEN (TMR2CN.5) is set, an interrupt is generated each time either TMR2L or TMR2H overflows. When TF2LEN is enabled, software must check the TF2H and TF2L flags to determine the source of the Timer 2 interrupt. The TF2H and TF2L interrupt flags are not cleared by hardware and must be manually cleared by software.



Figure 25.5. Timer 2 8-Bit Mode Block Diagram



The 8-bit offset held in PCA0CPH2 is compared to the upper byte of the 16-bit PCA counter. This offset value is the number of PCA0L overflows before a reset. Up to 256 PCA clocks may pass before the first PCA0L overflow occurs, depending on the value of the PCA0L when the update is performed. The total offset is then given (in PCA clocks) by Equation 26.5, where PCA0L is the value of the PCA0L register at the time of the update.

 $Offset = (256 \times PCA0CPL2) + (256 - PCA0L)$ 

#### Equation 26.5. Watchdog Timer Offset in PCA Clocks

The WDT reset is generated when PCA0L overflows while there is a match between PCA0CPH2 and PCA0H. Software may force a WDT reset by writing a 1 to the CCF2 flag (PCA0CN.2) while the WDT is enabled.

#### 26.4.2. Watchdog Timer Usage

To configure the WDT, perform the following tasks:

- 1. Disable the WDT by writing a 0 to the WDTE bit.
- 2. Select the desired PCA clock source (with the CPS2–CPS0 bits).
- 3. Load PCA0CPL2 with the desired WDT update offset value.
- 4. Configure the PCA Idle mode (set CIDL if the WDT should be suspended while the CPU is in Idle mode).
- 5. Enable the WDT by setting the WDTE bit to 1.
- 6. Reset the WDT timer by writing to PCA0CPH2.

The PCA clock source and Idle mode select cannot be changed while the WDT is enabled. The watchdog timer is enabled by setting the WDTE or WDLCK bits in the PCA0MD register. When WDLCK is set, the WDT cannot be disabled until the next system reset. If WDLCK is not set, the WDT is disabled by clearing the WDTE bit.

The WDT is enabled following any reset. The PCA0 counter clock defaults to the system clock divided by 12, PCA0L defaults to 0x00, and PCA0CPL2 defaults to 0x00. Using Equation 26.5, this results in a WDT timeout interval of 256 PCA clock cycles, or 3072 system clock cycles. Table 26.3 lists some example timeout intervals for typical system clocks.

| System Clock (Hz)                                                                                        | PCA0CPL2       | Timeout Interval (ms) |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------|----------------|-----------------------|--|--|--|--|--|
| 24,500,000                                                                                               | 255            | 32.1                  |  |  |  |  |  |
| 24,500,000                                                                                               | 128            | 16.2                  |  |  |  |  |  |
| 24,500,000                                                                                               | 32             | 4.1                   |  |  |  |  |  |
| 3,062,500 <sup>2</sup>                                                                                   | 255            | 257                   |  |  |  |  |  |
| 3,062,500 <sup>2</sup>                                                                                   | 128            | 129.5                 |  |  |  |  |  |
| 3,062,500 <sup>2</sup>                                                                                   | 32             | 33.1                  |  |  |  |  |  |
| 32,000                                                                                                   | 255            | 24576                 |  |  |  |  |  |
| 32,000                                                                                                   | 128            | 12384                 |  |  |  |  |  |
| 32,000                                                                                                   | 32,000 32 3168 |                       |  |  |  |  |  |
| Notes:<br>1. Assumes SYSCLK/12 as the PCA clock source, and a PCA0L value<br>of 0x00 at the update time. |                |                       |  |  |  |  |  |

### Table 26.3. Watchdog Timer Timeout Intervals<sup>1</sup>

