# E·XFL



#### 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             | Not For New Designs                                            |
|----------------------------|----------------------------------------------------------------|
| Core Processor             | 8051                                                           |
| Core Size                  | 8-Bit                                                          |
| Speed                      | 25MHz                                                          |
| Connectivity               | SMBus (2-Wire/I²C), SPI, UART/USART                            |
| Peripherals                | Cap Sense, POR, PWM, WDT                                       |
| Number of I/O              | 13                                                             |
| 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            | -                                                              |
| Oscillator Type            | Internal                                                       |
| Operating Temperature      | -40°C ~ 85°C (TA)                                              |
| Mounting Type              | Surface Mount                                                  |
| Package / Case             | 16-SOIC (0.154", 3.90mm Width)                                 |
| Supplier Device Package    | 16-SOIC                                                        |
| Purchase URL               | https://www.e-xfl.com/product-detail/silicon-labs/c8051f821-gs |

Email: info@E-XFL.COM

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





Figure 1.1. C8051F800, C8051F806, C8051F812, C8051F818 Block Diagram



## 8. 10-Bit ADC (ADC0)

ADC0 on the C8051F800/1/2/3/4/5, C8051F812/3/4/5/6/7, C8051F824/5/6, and C8051F830/1/2 is a 500 ksps, 10-bit successive-approximation-register (SAR) ADC with integrated track-and-hold, a gain stage programmable to 1x or 0.5x, and a programmable window detector. The ADC is fully configurable under software control via Special Function Registers. The ADC may be configured to measure various different signals using the analog multiplexer described in Section "8.5. ADC0 Analog Multiplexer" on page 56. The voltage reference for the ADC is selected as described in Section "9. Temperature Sensor" on page 58. The ADC0 subsystem is enabled only when the AD0EN bit in the ADC0 Control register (ADC0CN) is set to logic 1. The ADC0 subsystem is in low power shutdown when this bit is logic 0.



Figure 8.1. ADC0 Functional Block Diagram



### SFR Definition 8.1. ADC0CF: ADC0 Configuration

| Bit   | 7             | 6                                                                                                                                                                                                                                                                                                                                                          | 6         5         4         3         2         1         0                                                                                                  |                                                                                                                |                                                                                                                    |                       |                           |                      |  |  |
|-------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|-----------------------|---------------------------|----------------------|--|--|
| Nam   | e             | AD0SC[4:0] AD0LJST AD08BE                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                |                                                                                                                |                                                                                                                    |                       |                           |                      |  |  |
| Туре  | •             |                                                                                                                                                                                                                                                                                                                                                            | R/W                                                                                                                                                            |                                                                                                                |                                                                                                                    | R/W                   | R/W                       | R/W                  |  |  |
| Rese  | et 1          | 1                                                                                                                                                                                                                                                                                                                                                          | 1                                                                                                                                                              | 1                                                                                                              | 1                                                                                                                  | 0                     | 0                         | 1                    |  |  |
| SFR A | Address = 0xB | C                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                |                                                                                                                |                                                                                                                    |                       |                           |                      |  |  |
| Bit   | Name          |                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                |                                                                                                                | Function                                                                                                           |                       |                           |                      |  |  |
| 2     | ADOSC[4:0]    | ADC0 SAR<br>SAR Conver<br>AD0SC refe<br>requirement<br>AD0SC =<br>ADC0 Left .<br>0: Data in Al<br>1: Data in Al<br>Note: The A                                                                                                                                                                                                                             | Conversion<br>rsion clock is<br>rs to the 5-bis<br>s are given is<br>$= \frac{SYSCLK}{CLK_{SAR}}$<br>Justify Select<br>DC0H:ADC0<br>DC0H:ADC0<br>DOLJST bit is | Clock Period<br>derived from<br>it value held<br>in the ADC s<br>- 1<br>ct.<br>L registers a<br>only valid for | od Bits.<br>n system clo<br>in bits AD0S<br>becification t<br>ne right-justifi<br>re left-justifi<br>10-bit mode ( | fied.<br>AD08BE = 0). | lowing equa<br>Conversion | tion, where<br>clock |  |  |
| 1     | AD08BE        | <ul> <li>Note: The ADULIST bit is only valid for 10-bit mode (AD08BE = 0).</li> <li>8-Bit Mode Enable.</li> <li>0: ADC operates in 10-bit mode (normal).</li> <li>1: ADC operates in 8-bit mode.</li> <li>Note: When AD08BE is set to 1, the AD0LJST bit is ignored.</li> <li>ADC Gain Control Bit.</li> <li>0: Gain = 0.5</li> <li>1: Gain = 1</li> </ul> |                                                                                                                                                                |                                                                                                                |                                                                                                                    |                       |                           |                      |  |  |





Figure 13.2. Auto-Scan Example

#### 13.4. CS0 Comparator

The CS0 comparator compares the latest capacitive sense conversion result with the value stored in CS0THH:CS0THL. If the result is less than or equal to the stored value, the CS0CMPF bit(CS0CN:0) is set to 0. If the result is greater than the stored value, CS0CMPF is set to 1.

If the CS0 conversion accumulator is configured to accumulate multiple conversions, a comparison will not be made until the last conversion has been accumulated.

An interrupt will be generated if CS0 greater-than comparator interrupts are enabled by setting the ECS-GRT bit (EIE2.1) when the comparator sets CS0CMPF to 1.

If auto-scan is running when the comparator sets the CS0CMPF bit, no further auto-scan initiated conversions will start until firmware sets CS0BUSY to 1.

A CS0 greater-than comparator event can wake a device from suspend mode. This feature is useful in systems configured to continuously sample one or more capacitive sense channels. The device will remain in the low-power suspend state until the captured value of one of the scanned channels causes a CS0 greater-than comparator event to occur. It is not necessary to have CS0 comparator interrupts enabled in order to wake a device from suspend with a greater-than event.

**Note:** On waking from suspend mode due to a CS0 greater-than comparator event, the CS0CN register should be accessed only after at least two system clock cycles have elapsed.

For a summary of behavior with different CS0 comparator, auto-scan, and auto accumulator settings, please see Table 13.1.





### SFR Definition 18.1. IE: Interrupt Enable

| Bit   | 7   | 6     | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|-----|-------|-----|-----|-----|-----|-----|-----|
| Name  | EA  | ESPI0 | ET2 | ES0 | ET1 | EX1 | ET0 | EX0 |
| Туре  | R/W | R/W   | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset | 0   | 0     | 0   | 0   | 0   | 0   | 0   | 0   |

#### SFR Address = 0xA8; Bit-Addressable

| Bit | Name  | Function                                                                                                                                                                                                                                                              |
|-----|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | EA    | <ul> <li>Enable All Interrupts.</li> <li>Globally enables/disables all interrupts. It overrides individual interrupt mask settings.</li> <li>0: Disable all interrupt sources.</li> <li>1: Enable each interrupt according to its individual mask setting.</li> </ul> |
| 6   | ESPI0 | Enable Serial Peripheral Interface (SPI0) Interrupt.<br>This bit sets the masking of the SPI0 interrupts.<br>0: Disable all SPI0 interrupts.<br>1: Enable interrupt requests generated by SPI0.                                                                       |
| 5   | ET2   | Enable Timer 2 Interrupt.<br>This bit sets the masking of the Timer 2 interrupt.<br>0: Disable Timer 2 interrupt.<br>1: Enable interrupt requests generated by the TF2L or TF2H flags.                                                                                |
| 4   | ES0   | Enable UART0 Interrupt.<br>This bit sets the masking of the UART0 interrupt.<br>0: Disable UART0 interrupt.<br>1: Enable UART0 interrupt.                                                                                                                             |
| 3   | ET1   | <ul> <li>Enable Timer 1 Interrupt.</li> <li>This bit sets the masking of the Timer 1 interrupt.</li> <li>0: Disable all Timer 1 interrupt.</li> <li>1: Enable interrupt requests generated by the TF1 flag.</li> </ul>                                                |
| 2   | EX1   | Enable External Interrupt 1.<br>This bit sets the masking of External Interrupt 1.<br>0: Disable external interrupt 1.<br>1: Enable interrupt requests generated by the INT1 input.                                                                                   |
| 1   | ET0   | <ul> <li>Enable Timer 0 Interrupt.</li> <li>This bit sets the masking of the Timer 0 interrupt.</li> <li>0: Disable all Timer 0 interrupt.</li> <li>1: Enable interrupt requests generated by the TF0 flag.</li> </ul>                                                |
| 0   | EX0   | <ul> <li>Enable External Interrupt 0.</li> <li>This bit sets the masking of External Interrupt 0.</li> <li>0: Disable external interrupt 0.</li> <li>1: Enable interrupt requests generated by the INTO input.</li> </ul>                                             |



8. Restore previous interrupt state.

Steps 4–6 must be repeated for each 512-byte page to be erased.

**Note:** Flash security settings may prevent erasure of some Flash pages, such as the reserved area and the page containing the lock bytes. For a summary of Flash security settings and restrictions affecting Flash erase operations, please see Section "19.3. Security Options" on page 114.

#### 19.1.3. Flash Write Procedure

A write to Flash memory can clear bits to logic 0 but cannot set them; only an erase operation can set bits to logic 1 in Flash. A byte location to be programmed should be erased before a new value is written.

The recommended procedure for writing a single byte in Flash is as follows:

- 1. Save current interrupt state and disable interrupts.
- 2. Ensure that the Flash byte has been erased (has a value of 0xFF).
- 3. Set the PSWE bit (register PSCTL).
- 4. Clear the PSEE bit (register PSCTL).
- 5. Write the first key code to FLKEY: 0xA5.
- 6. Write the second key code to FLKEY: 0xF1.
- 7. Using the MOVX instruction, write a single data byte to the desired location within the 512-byte sector.
- 8. Clear the PSWE bit.
- 9. Restore previous interrupt state.

Steps 5–7 must be repeated for each byte to be written.

**Note:** Flash security settings may prevent writes to some areas of Flash, such as the reserved area. For a summary of Flash security settings and restrictions affecting Flash write operations, please see Section "19.3. Security Options" on page 114.

#### 19.2. Non-volatile Data Storage

The Flash memory can be used for non-volatile data storage as well as program code. This allows data such as calibration coefficients to be calculated and stored at run time. Data is written using the MOVX write instruction and read using the MOVC instruction.

**Note:** MOVX read instructions always target XRAM.

#### **19.3. Security Options**

The CIP-51 provides security options to protect the Flash memory from inadvertent modification by software as well as to prevent the viewing of proprietary program code and constants. The Program Store Write Enable (bit PSWE in register PSCTL) and the Program Store Erase Enable (bit PSEE in register PSCTL) bits protect the Flash memory from accidental modification by software. PSWE must be explicitly set to 1 before software can modify the Flash memory; both PSWE and PSEE must be set to 1 before software can erase Flash memory. Additional security features prevent proprietary program code and data constants from being read or altered across the C2 interface.

A Security Lock Byte located at the last byte of Flash user space offers protection of the Flash program memory from access (reads, writes, and erases) by unprotected code or the C2 interface. The Flash security mechanism allows the user to lock all Flash pages, starting at page 0, by writing a non-0xFF value to the lock byte. Note that writing a non-0xFF value to the lock byte will lock all pages of FLASH from reads, writes, and erases, including the page containing the lock byte.

The level of Flash security depends on the Flash access method. The three Flash access methods that can be restricted are reads, writes, and erases from the C2 debug interface, user firmware executing on unlocked pages, and user firmware executing on locked pages. Table 19.1 summarizes the Flash security



#### SFR Definition 23.5. P1MASK: Port 1 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 Address = 0xEE

| 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.<br><b>Note:</b> P1.4–P1.7 are not available on 16-pin packages. |

#### SFR Definition 23.6. P1MAT: Port 1 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 Address = 0xED

| Bit | Name       | Function                                                                                                                                                                                                                                                                                   |
|-----|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | P1MAT[7:0] | Port 1 Match Value.                                                                                                                                                                                                                                                                        |
|     |            | <ul> <li>Match comparison value used on Port 1 for bits in P1MASK which are set to 1.</li> <li>0: P1.n pin logic value is compared with logic LOW.</li> <li>1: P1.n pin logic value is compared with logic HIGH.</li> <li>Note: P1.4–P1.7 are not available on 16-pin packages.</li> </ul> |

#### 23.6. Special Function Registers for Accessing and Configuring Port I/O

All Port I/O are accessed through corresponding special function registers (SFRs) that are both byte addressable and bit addressable. When writing to a Port, the value written to the SFR is latched to maintain the output data value at each pin. When reading, the logic levels of the Port's input pins are returned regardless of the XBRn settings (i.e., even when the pin is assigned to another signal by the Crossbar, the Port register can always read its corresponding Port I/O pin). The exception to this is the execution of the read-modify-write instructions that target a Port Latch register as the destination. The read-modify-write instructions when operating on a Port SFR are the following: ANL, ORL, XRL, JBC, CPL, INC, DEC, DJNZ and MOV, CLR or SETB, when the destination is an individual bit in a Port SFR. For these instructions, the value of the latch register (not the pin) is read, modified, and written back to the SFR.



#### SFR Definition 23.10. P0SKIP: Port 0 Skip

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

SFR Address = 0xD4

| Bit | Name        | Function                                                                                                                                                                                                                                                                                                           |
|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | P0SKIP[7:0] | Port 0 Crossbar Skip Enable Bits.                                                                                                                                                                                                                                                                                  |
|     |             | <ul> <li>These bits select Port 0 pins to be skipped by the Crossbar Decoder. Port pins used for analog, special functions or GPIO should be skipped by the Crossbar.</li> <li>0: Corresponding P0.n pin is not skipped by the Crossbar.</li> <li>1: Corresponding P0.n pin is skipped by the Crossbar.</li> </ul> |

#### SFR Definition 23.11. P1: Port 1

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

#### SFR Address = 0x90; Bit-Addressable

| Bit | Name    | Description                                                                                                                                                                                           | Write                                                                         | Read                                                                    |
|-----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| 7:0 | P1[7:0] | Port 1 Data.<br>Sets the Port latch logic<br>value or reads the Port pin<br>logic state in Port cells con-<br>figured for digital I/O.<br>Note: P1.4–P1.7 are not<br>available on 16-pin<br>packages. | 0: Set output latch to logic<br>LOW.<br>1: Set output latch to logic<br>HIGH. | 0: P1.n Port pin is logic<br>LOW.<br>1: P1.n Port pin is logic<br>HIGH. |



#### 24.3. Preparing for a CRC Calculation

To prepare CRC0 for a CRC calculation, software should select the desired polynomial and set the initial value of the result. Two polynomials are available: 0x1021 (16-bit) and 0x04C11DB7 (32-bit). The CRC0 result may be initialized to one of two values: 0x00000000 or 0xFFFFFFFF. The following steps can be used to initialize CRC0.

- 1. Select a polynomial (Set CRC0SEL to 0 for 32-bit or 1 for 16-bit).
- 2. Select the initial result value (Set CRC0VAL to 0 for 0x0000000 or 1 for 0xFFFFFFF).
- 3. Set the result to its initial value (Write 1 to CRC0INIT).

#### 24.4. Performing a CRC Calculation

Once CRC0 is initialized, the input data stream is sequentially written to CRC0IN, one byte at a time. The CRC0 result is automatically updated after each byte is written. The CRC engine may also be configured to automatically perform a CRC on one or more Flash sectors. The following steps can be used to automatically perform a CRC on Flash memory.

- 1. Prepare CRC0 for a CRC calculation as shown above.
- 2. Write the index of the starting page to CRC0AUTO.
- 3. Set the AUTOEN bit in CRC0AUTO.
- 4. Write the number of Flash sectors to perform in the CRC calculation to CRC0CNT.

**Note:** Each Flash sector is 512 bytes.

- 5. Write any value to CRC0CN (or OR its contents with 0x00) to initiate the CRC calculation. The CPU will not execute code any additional code until the CRC operation completes.
- 6. Clear the AUTOEN bit in CRC0AUTO.
- 7. Read the CRC result using the procedure below.

#### 24.5. Accessing the CRC0 Result

The internal CRC0 result is 32-bits (CRC0SEL = 0b) or 16-bits (CRC0SEL = 1b). The CRC0PNT bits select the byte that is targeted by read and write operations on CRC0DAT and increment after each read or write. The calculation result will remain in the internal CR0 result register until it is set, overwritten, or additional data is written to CRC0IN.





Figure 25.4. 4-Wire Single Master Mode and 4-Wire Slave Mode Connection Diagram

#### 25.3. SPI0 Slave Mode Operation

When SPI0 is enabled and not configured as a master, it will operate as a SPI slave. As a slave, bytes are shifted in through the MOSI pin and out through the MISO pin by a master device controlling the SCK signal. A bit counter in the SPI0 logic counts SCK edges. When 8 bits have been shifted through the shift register, the SPIF flag is set to logic 1, and the byte is copied into the receive buffer. Data is read from the receive buffer by reading SPI0DAT. A slave device cannot initiate transfers. Data to be transferred to the master device is pre-loaded into the shift register by writing to SPI0DAT. Writes to SPI0DAT are double-buffered, and are placed in the transmit buffer first. If the shift register is empty, the contents of the transmit buffer will immediately be transferred into the shift register. When the shift register already contains data, the SPI will load the shift register with the transmit buffer's contents after the last SCK edge of the next (or current) SPI transfer.

When configured as a slave, SPI0 can be configured for 4-wire or 3-wire operation. The default, 4-wire slave mode, is active when NSSMD1 (SPI0CN.3) = 0 and NSSMD0 (SPI0CN.2) = 1. In 4-wire mode, the NSS signal is routed to a port pin and configured as a digital input. SPI0 is enabled when NSS is logic 0, and disabled when NSS is logic 1. The bit counter is reset on a falling edge of NSS. Note that the NSS signal must be driven low at least 2 system clocks before the first active edge of SCK for each byte transfer. Figure 25.4 shows a connection diagram between two slave devices in 4-wire slave mode and a master device.

3-wire slave mode is active when NSSMD1 (SPI0CN.3) = 0 and NSSMD0 (SPI0CN.2) = 0. NSS is not used in this mode, and is not mapped to an external port pin through the crossbar. Since there is no way of uniquely addressing the device in 3-wire slave mode, SPI0 must be the only slave device present on the bus. It is important to note that in 3-wire slave mode there is no external means of resetting the bit counter that determines when a full byte has been received. The bit counter can only be reset by disabling and reenabling SPI0 with the SPIEN bit. Figure 25.3 shows a connection diagram between a slave device in 3-wire slave mode and a master device.



#### 25.4. SPI0 Interrupt Sources

When SPI0 interrupts are enabled, the following four flags will generate an interrupt when they are set to logic 1:

All of the following bits must be cleared by software.

- The SPI Interrupt Flag, SPIF (SPI0CN.7) is set to logic 1 at the end of each byte transfer. This flag can occur in all SPI0 modes.
- The Write Collision Flag, WCOL (SPI0CN.6) is set to logic 1 if a write to SPI0DAT is attempted when the transmit buffer has not been emptied to the SPI shift register. When this occurs, the write to SPI0DAT will be ignored, and the transmit buffer will not be written. This flag can occur in all SPI0 modes.
- The Mode Fault Flag MODF (SPI0CN.5) is set to logic 1 when SPI0 is configured as a master, and for multi-master mode and the NSS pin is pulled low. When a Mode Fault occurs, the MSTEN and SPIEN bits in SPI0CN are set to logic 0 to disable SPI0 and allow another master device to access the bus.
- The Receive Overrun Flag RXOVRN (SPI0CN.4) is set to logic 1 when configured as a slave, and a transfer is completed and the receive buffer still holds an unread byte from a previous transfer. The new byte is not transferred to the receive buffer, allowing the previously received data byte to be read. The data byte which caused the overrun is lost.

#### 25.5. Serial Clock Phase and Polarity

Four combinations of serial clock phase and polarity can be selected using the clock control bits in the SPI0 Configuration Register (SPI0CFG). The CKPHA bit (SPI0CFG.5) selects one of two clock phases (edge used to latch the data). The CKPOL bit (SPI0CFG.4) selects between an active-high or active-low clock. Both master and slave devices must be configured to use the same clock phase and polarity. SPI0 should be disabled (by clearing the SPIEN bit, SPI0CN.0) when changing the clock phase or polarity. The clock and data line relationships for master mode are shown in Figure 25.5. For slave mode, the clock and data relationships are shown in Figure 25.6 and Figure 25.7. Note that CKPHA should be set to 0 on both the master and slave SPI when communicating between two Silicon Labs C8051 devices.

The SPI0 Clock Rate Register (SPI0CKR) as shown in SFR Definition 25.3 controls the master mode serial clock frequency. This register is ignored when operating in slave mode. When the SPI is configured as a master, the maximum data transfer rate (bits/sec) is one-half the system clock frequency or 12.5 MHz, whichever is slower. When the SPI is configured as a slave, the maximum data transfer rate (bits/sec) for full-duplex operation is 1/10 the system clock frequency, provided that the master issues SCK, NSS (in 4-wire slave mode), and the serial input data synchronously with the slave's system clock. If the master issues SCK, NSS, and the serial input data asynchronously, the maximum data transfer rate (bits/sec) must be less than 1/10 the system clock frequency. In the special case where the master only wants to transmit data to the slave and does not need to receive data from the slave (i.e. half-duplex operation), the SPI slave can receive data at a maximum data transfer rate (bits/sec) of 1/4 the system clock frequency. This is provided that the master issues SCK, NSS, and the serial input data transfer rate (bits/sec) of 1/4 the system clock frequency. This is provided that the master issues SCK, NSS, and the serial input data synchronously with the slave's system clock frequency.



### SFR Definition 25.1. SPI0CFG: SPI0 Configuration

| Bit   | 7      | 6     | 5     | 4     | 3      | 2     | 1    | 0     |
|-------|--------|-------|-------|-------|--------|-------|------|-------|
| Name  | SPIBSY | MSTEN | СКРНА | CKPOL | SLVSEL | NSSIN | SRMT | RXBMT |
| Туре  | R      | R/W   | R/W   | R/W   | R      | R     | R    | R     |
| Reset | 0      | 0     | 0     | 0     | 0      | 1     | 1    | 1     |

SFR Address = 0xA1

| Bit   | Name                                  | Function                                                                                                                                                                    |  |  |  |  |  |
|-------|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7     | SPIBSY                                | SPI Busy.                                                                                                                                                                   |  |  |  |  |  |
|       |                                       | This bit is set to logic 1 when a SPI transfer is in progress (master or slave mode).                                                                                       |  |  |  |  |  |
| 6     | MSTEN                                 | Master Mode Enable.                                                                                                                                                         |  |  |  |  |  |
|       |                                       | 0: Disable master mode. Operate in slave mode.                                                                                                                              |  |  |  |  |  |
|       |                                       | 1: Enable master mode. Operate as a master.                                                                                                                                 |  |  |  |  |  |
| 5     | СКРНА                                 | SPI0 Clock Phase.                                                                                                                                                           |  |  |  |  |  |
|       |                                       | 0: Data centered on first edge of SCK period.*                                                                                                                              |  |  |  |  |  |
|       |                                       | 1: Data centered on second edge of SCK period.                                                                                                                              |  |  |  |  |  |
| 4     | CKPOL                                 | SPI0 Clock Polarity.                                                                                                                                                        |  |  |  |  |  |
|       |                                       | 0: SCK line low in idle state.                                                                                                                                              |  |  |  |  |  |
|       |                                       | 1: SCK line high in idle state.                                                                                                                                             |  |  |  |  |  |
| 3     | SLVSEL                                | Slave Selected Flag.                                                                                                                                                        |  |  |  |  |  |
|       |                                       | This bit is set to logic 1 whenever the NSS pin is low indicating SPI0 is the selected slave. It is cleared to logic 0 when NSS is high (slave not selected). This bit does |  |  |  |  |  |
|       |                                       | not indicate the instantaneous value at the NSS pin, but rather a de-glitched ver-                                                                                          |  |  |  |  |  |
|       |                                       | sion of the pin input.                                                                                                                                                      |  |  |  |  |  |
| 2     | NSSIN                                 | NSS Instantaneous Pin Input.                                                                                                                                                |  |  |  |  |  |
|       |                                       | This bit mimics the instantaneous value that is present on the NSS port pin at the time that the register is read. This input is not de-glitched.                           |  |  |  |  |  |
| 1     | SRMT                                  | Shift Register Empty (valid in slave mode only).                                                                                                                            |  |  |  |  |  |
|       |                                       | This bit will be set to logic 1 when all data has been transferred in/out of the shift                                                                                      |  |  |  |  |  |
|       |                                       | register, and there is no new information available to read from the transmit buffer                                                                                        |  |  |  |  |  |
|       |                                       | or write to the receive buffer. It returns to logic 0 when a data byte is transferred to                                                                                    |  |  |  |  |  |
|       |                                       | the shift register from the transmit buffer or by a transition on SCK. SRMT = 1 when                                                                                        |  |  |  |  |  |
|       | DVDMT                                 | In Master Mode.                                                                                                                                                             |  |  |  |  |  |
| 0     | RABINI                                | Receive Buffer Empty (valid in slave mode only).                                                                                                                            |  |  |  |  |  |
|       |                                       | I his bit will be set to logic 1 when the receive buffer has been read and contains no                                                                                      |  |  |  |  |  |
|       |                                       | not been read, this bit will return to logic 0. RXBMT = 1 when in Master Mode.                                                                                              |  |  |  |  |  |
| Note: | In slave mode, o                      | data on MOSI is sampled in the center of each data bit. In master mode, data on MISO is                                                                                     |  |  |  |  |  |
|       | sampled one SY                        | SCLK before the end of each data bit, to provide maximum settling time for the slave device.                                                                                |  |  |  |  |  |
|       | See Table 25.1 for timing parameters. |                                                                                                                                                                             |  |  |  |  |  |



| Bit        | Set by Hardware When:                                                                                          | Cleared by Hardware When:                                                      |
|------------|----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|
| MASTED     | A START is generated.                                                                                          | A STOP is generated.                                                           |
| WASTER     |                                                                                                                | <ul> <li>Arbitration is lost.</li> </ul>                                       |
|            | <ul> <li>START is generated.</li> </ul>                                                                        | A START is detected.                                                           |
|            | <ul> <li>SMB0DAT is written before the start of an</li> </ul>                                                  | <ul> <li>Arbitration is lost.</li> </ul>                                       |
| TAMODE     | SMBus frame.                                                                                                   | <ul> <li>SMB0DAT is not written before the start of an SMBus frame.</li> </ul> |
| STA        | <ul> <li>A START followed by an address byte is received.</li> </ul>                                           | <ul> <li>Must be cleared by software.</li> </ul>                               |
|            | A STOP is detected while addressed as a                                                                        | A pending STOP is generated.                                                   |
| STO        | slave.                                                                                                         |                                                                                |
|            | <ul> <li>Arbitration is lost due to a detected STOP.</li> </ul>                                                |                                                                                |
|            | A byte has been received and an ACK                                                                            | After each ACK cycle.                                                          |
| ACKRQ      | hardware ACK is not enabled)                                                                                   |                                                                                |
|            | <ul> <li>A repeated START is detected as a</li> </ul>                                                          | <ul> <li>Each time SL is cleared</li> </ul>                                    |
|            | MASTER when STA is low (unwanted repeated START).                                                              |                                                                                |
| ARBLOST    | <ul> <li>SCL is sensed low while attempting to<br/>generate a STOP or repeated START<br/>condition.</li> </ul> |                                                                                |
|            | <ul> <li>SDA is sensed low while transmitting a 1<br/>(excluding ACK bits).</li> </ul>                         |                                                                                |
| ACK        | The incoming ACK value is low                                                                                  | The incoming ACK value is high                                                 |
|            | (ACKNOWLEDGE).                                                                                                 | (NOT ACKNOWLEDGE).                                                             |
|            | A START has been generated.                                                                                    | Must be cleared by software.                                                   |
|            | Lost arbitration.                                                                                              |                                                                                |
| <u>e</u> i | <ul> <li>A byte has been transmitted and an<br/>ACK/NACK received.</li> </ul>                                  |                                                                                |
| 51         | A byte has been received.                                                                                      |                                                                                |
|            | <ul> <li>A START or repeated START followed by a<br/>slave address + R/W has been received.</li> </ul>         |                                                                                |
|            | A STOP has been received.                                                                                      |                                                                                |

Table 26.3. Sources for Hardware Changes to SMB0CN

#### 26.4.3. Hardware Slave Address Recognition

The SMBus hardware has the capability to automatically recognize incoming slave addresses and send an ACK without software intervention. Automatic slave address recognition is enabled by setting the EHACK bit in register SMB0ADM to 1. This will enable both automatic slave address recognition and automatic hardware ACK generation for received bytes (as a master or slave). More detail on automatic hardware ACK generation can be found in Section 26.4.2.2.

The registers used to define which address(es) are recognized by the hardware are the SMBus Slave Address register (SFR Definition 26.3) and the SMBus Slave Address Mask register (SFR Definition 26.4). A single address or range of addresses (including the General Call Address 0x00) can be specified using these two registers. The most-significant seven bits of the two registers are used to define which addresses will be ACKed. A 1 in bit positions of the slave address mask SLVM[6:0] enable a comparison between the received slave address and the hardware's slave address SLV[6:0] for those bits. A 0 in a bit of the slave address mask means that bit will be treated as a "don't care" for comparison purposes. In this



### 27. UART0

UART0 is an asynchronous, full duplex serial port offering modes 1 and 3 of the standard 8051 UART. Enhanced baud rate support allows a wide range of clock sources to generate standard baud rates (details in Section "27.1. Enhanced Baud Rate Generation" on page 202). Received data buffering allows UART0 to start reception of a second incoming data byte before software has finished reading the previous data byte.

UART0 has two associated SFRs: Serial Control Register 0 (SCON0) and Serial Data Buffer 0 (SBUF0). The single SBUF0 location provides access to both transmit and receive registers. Writes to SBUF0 always access the Transmit register. Reads of SBUF0 always access the buffered Receive register; it is not possible to read data from the Transmit register.

With UART0 interrupts enabled, an interrupt is generated each time a transmit is completed (TI0 is set in SCON0), or a data byte has been received (RI0 is set in SCON0). The UART0 interrupt flags are not cleared by hardware when the CPU vectors to the interrupt service routine. They must be cleared manually by software, allowing software to determine the cause of the UART0 interrupt (transmit complete or receive complete).







### SFR Definition 27.2. SBUF0: Serial (UART0) Port Data Buffer

| Bit   | 7                | 6                                      | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|------------------|----------------------------------------|---|---|---|---|---|---|
| Nam   | SBUF0[7:0]       |                                        |   |   |   |   |   |   |
| Туре  | 9                | R/W                                    |   |   |   |   |   |   |
| Rese  | et 0             | 0                                      | 0 | 0 | 0 | 0 | 0 | 0 |
| SFR A | R Address = 0x99 |                                        |   |   |   |   |   |   |
| Bit   | Name             | Function                               |   |   |   |   |   |   |
| 7:0   | SBUF0[7:0]       | Serial Data Buffer Bits 7–0 (MSB–LSB). |   |   |   |   |   |   |
|       |                  |                                        |   |   |   |   |   |   |

This SFR accesses two registers; a transmit shift register and a receive latch register. When data is written to SBUF0, it goes to the transmit shift register and is held for serial transmission. Writing a byte to SBUF0 initiates the transmission. A read of SBUF0 returns the contents of the receive latch.



### SFR Definition 28.8. TMR2CN: Timer 2 Control

| Bit   | 7    | 6    | 5      | 4      | 3       | 2   | 1 | 0      |
|-------|------|------|--------|--------|---------|-----|---|--------|
| Name  | TF2H | TF2L | TF2LEN | TF2CEN | T2SPLIT | TR2 |   | T2XCLK |
| Туре  | R/W  | R/W  | R/W    | R/W    | R/W     | R/W | R | R/W    |
| Reset | 0    | 0    | 0      | 0      | 0       | 0   | 0 | 0      |

#### SFR Address = 0xC8; Bit-Addressable

| Bit | Name    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | TF2H    | Timer 2 High Byte Overflow Flag.                                                                                                                                                                                                                                                                                                                                                                                                                            |
|     |         | Set by hardware when the Timer 2 high byte overflows from 0xFF to 0x00. In 16 bit mode, this will occur when Timer 2 overflows from 0xFFFF to 0x0000. When the Timer 2 interrupt is enabled, setting this bit causes the CPU to vector to the Timer 2 interrupt service routine. This bit is not automatically cleared by hardware.                                                                                                                         |
| 6   | TF2L    | Timer 2 Low Byte Overflow Flag.                                                                                                                                                                                                                                                                                                                                                                                                                             |
|     |         | Set by hardware when the Timer 2 low byte overflows from 0xFF to 0x00. TF2L will be set when the low byte overflows regardless of the Timer 2 mode. This bit is not automatically cleared by hardware.                                                                                                                                                                                                                                                      |
| 5   | TF2LEN  | Timer 2 Low Byte Interrupt Enable.                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |         | When set to 1, this bit enables Timer 2 Low Byte interrupts. If Timer 2 interrupts are also enabled, an interrupt will be generated when the low byte of Timer 2 overflows.                                                                                                                                                                                                                                                                                 |
| 4   | TF2CEN  | Timer 2 Comparator Capture Enable.                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |         | When set to 1, this bit enables Timer 2 Comparator Capture Mode. If TF2CEN is set, on a rising edge of the Comparator0 output the current 16-bit timer value in TMR2H:TMR2L will be copied to TMR2RLH:TMR2RLL. If Timer 2 interrupts are also enabled, an interrupt will be generated on this event.                                                                                                                                                        |
| 3   | T2SPLIT | Timer 2 Split Mode Enable.                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|     |         | <ul><li>When this bit is set, Timer 2 operates as two 8-bit timers with auto-reload.</li><li>0: Timer 2 operates in 16-bit auto-reload mode.</li><li>1: Timer 2 operates as two 8-bit auto-reload timers.</li></ul>                                                                                                                                                                                                                                         |
| 2   | TR2     | Timer 2 Run Control.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|     |         | Timer 2 is enabled by setting this bit to 1. In 8-bit mode, this bit enables/disables TMR2H only; TMR2L is always enabled in split mode.                                                                                                                                                                                                                                                                                                                    |
| 1   | Unused  | Read = 0b; Write = Don't Care.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0   | T2XCLK  | Timer 2 External Clock Select.                                                                                                                                                                                                                                                                                                                                                                                                                              |
|     |         | This bit selects the external clock source for Timer 2. If Timer 2 is in 8-bit mode, this bit selects the external oscillator clock source for both timer bytes. However, the Timer 2 Clock Select bits (T2MH and T2ML in register CKCON) may still be used to select between the external clock and the system clock for either timer.<br>0: System clock divided by 12.<br>1: External clock divided by 8 (synchronized with SYSCLK when not in suspend). |



### SFR Definition 28.9. TMR2RLL: Timer 2 Reload Register Low Byte

| Bit   | 7                                              | 6        | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|------------------------------------------------|----------|---|---|---|---|---|---|
| Nam   | ame TMR2RLL[7:0]                               |          |   |   |   |   |   |   |
| Тур   | /pe R/W                                        |          |   |   |   |   |   |   |
| Rese  | et <sup>0</sup>                                | 0        | 0 | 0 | 0 | 0 | 0 | 0 |
| SFR A | SFR Address = 0xCA                             |          |   |   |   |   |   |   |
| Bit   | Name                                           | Function |   |   |   |   |   |   |
| 7:0   | TMR2RLL[7:0] Timer 2 Reload Register Low Byte. |          |   |   |   |   |   |   |

TMR2RLL holds the low byte of the reload value for Timer 2.

#### SFR Definition 28.10. TMR2RLH: Timer 2 Reload Register High Byte

| Bit                | 7   | 6 | 5 | 4     | 3       | 2 | 1 | 0 |
|--------------------|-----|---|---|-------|---------|---|---|---|
| Name               |     |   |   | TMR2R | LH[7:0] |   |   |   |
| Туре               | R/W |   |   |       |         |   |   |   |
| Reset              | 0   | 0 | 0 | 0     | 0       | 0 | 0 | 0 |
| SFR Address = 0xCB |     |   |   |       |         |   |   |   |

| Bi | it | Name         | Function                                                     |  |  |  |
|----|----|--------------|--------------------------------------------------------------|--|--|--|
| 7: | 0  | TMR2RLH[7:0] | Timer 2 Reload Register High Byte.                           |  |  |  |
|    |    |              | TMR2RLH holds the high byte of the reload value for Timer 2. |  |  |  |



#### 29.3.2. Software Timer (Compare) Mode

In Software Timer mode, the PCA counter/timer value is compared to the module's 16-bit capture/compare register (PCA0CPHn and PCA0CPLn). When a match occurs, the Capture/Compare Flag (CCFn) in PCA0CN is set to logic 1. An interrupt request is generated if the CCFn interrupt for that module is enabled. The CCFn bit is not automatically cleared by hardware when the CPU vectors to the interrupt service routine, and must be cleared by software. Setting the ECOMn and MATn bits in the PCA0CPMn register enables Software Timer mode.

**Important Note About Capture/Compare Registers**: When writing a 16-bit value to the PCA0 Capture/Compare registers, the low byte should always be written first. Writing to PCA0CPLn clears the ECOMn bit to 0; writing to PCA0CPHn sets ECOMn to 1.



Figure 29.5. PCA Software Timer Mode Diagram



Rev. 1.0