# 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 <sup>2</sup> C), SPI, UART/USART               |
| Peripherals                | Cap Sense, POR, PWM, Temp Sensor, WDT                          |
| Number of I/O              | 13                                                             |
| Program Memory Size        | 8KB (8K x 8)                                                   |
| Program Memory Type        | FLASH                                                          |
| EEPROM Size                | -                                                              |
| RAM Size                   | 256 x 8                                                        |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                                    |
| Data Converters            | A/D 12x10b                                                     |
| 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/c8051f824-gs |

Email: info@E-XFL.COM

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





Figure 1.8. C8051F825, C8051F828, C8051F831, C8051F834 Block Diagram



| Part<br>Number    | Digital<br>Port I/Os | Capacitive Sense<br>Channels | Flash<br>Memory<br>(kB) | RAM<br>(Bytes) | 10-bit<br>500 ksps<br>ADC | ADC<br>Channels | Temperature<br>Sensor | Package (RoHS) |
|-------------------|----------------------|------------------------------|-------------------------|----------------|---------------------------|-----------------|-----------------------|----------------|
| C8051F821-GS      | 13                   | 12                           | 8                       | 512            | —                         |                 | —                     | SOIC-16        |
| C8051F822-GS      | 13                   | 8                            | 8                       | 512            | —                         | —               |                       | SOIC-16        |
| C8051F823-GS      | 13                   | _                            | 8                       | 512            | —                         | —               |                       | SOIC-16        |
| C8051F824-GS      | 13                   | 12                           | 8                       | 256            | $\checkmark$              | 12              | $\checkmark$          | SOIC-16        |
| C8051F825-GS      | 13                   | 8                            | 8                       | 256            | $\checkmark$              | 12              | ~                     | SOIC-16        |
| C8051F826-GS      | 13                   | _                            | 8                       | 256            | $\checkmark$              | 12              | $\checkmark$          | SOIC-16        |
| C8051F827-GS      | 13                   | 12                           | 8                       | 256            | —                         |                 |                       | SOIC-16        |
| C8051F828-GS      | 13                   | 8                            | 8                       | 256            | —                         |                 |                       | SOIC-16        |
| C8051F829-GS      | 13                   | _                            | 8                       | 256            | —                         |                 |                       | SOIC-16        |
| C8051F830-GS      | 13                   | 12                           | 4                       | 256            | $\checkmark$              | 12              | $\checkmark$          | SOIC-16        |
| C8051F831-GS      | 13                   | 8                            | 4                       | 256            | $\checkmark$              | 12              | $\checkmark$          | SOIC-16        |
| C8051F832-GS      | 13                   | _                            | 4                       | 256            | $\checkmark$              | 12              | $\checkmark$          | SOIC-16        |
| C8051F833-GS      | 13                   | 12                           | 4                       | 256            | —                         |                 |                       | SOIC-16        |
| C8051F834-GS      | 13                   | 8                            | 4                       | 256            | —                         |                 | —                     | SOIC-16        |
| C8051F835-GS      | 13                   | —                            | 4                       | 256            | —                         | —               | —                     | SOIC-16        |
| Lead finish mater | rial on a            | Il devices is 10             | 00% matte               | tin (Sn).      |                           |                 |                       |                |

Table 2.1. Product Selection Guide (Continued)









#### **13.1. Configuring Port Pins as Capacitive Sense Inputs**

In order for a port pin to be measured by CS0, that port pin must be configured as an analog input (see "23. Port Input/Output"). Configuring the input multiplexer to a port pin not configured as an analog input will cause the capacitive sense comparator to output incorrect measurements.

#### 13.2. Capacitive Sense Start-Of-Conversion Sources

A capacitive sense conversion can be initiated in one of seven ways, depending on the programmed state of the CS0 start of conversion bits (CS0CF6:4). Conversions may be initiated by one of the following:

- 1. Writing a 1 to the CS0BUSY bit of register CS0CN
- 2. Timer 0 overflow
- 3. Timer 2 overflow
- 4. Timer 1 overflow
- 5. Convert continuously
- 6. Convert continuously with auto-scan enabled

Conversions can be configured to be initiated continuously through one of two methods. CS0 can be configured to convert at a single channel continuously or it can be configured to convert continuously with auto-scan enabled. When configured to convert continuously, conversions will begin after the CS0BUSY bit in CS0CF has been set.

An interrupt will be generated if CS0 conversion complete interrupts are enabled by setting the ECSCPT bit (EIE2.0).

**Note:** CS0 conversion complete interrupt behavior depends on the settings of the CS0 accumulator. If CS0 is configured to accumulate multiple conversions on an input channel, a CS0 conversion complete interrupt will be generated only after the last conversion completes.

#### 13.3. Automatic Scanning

CS0 can be configured to automatically scan a sequence of contiguous CS0 input channels by configuring and enabling auto-scan. Using auto-scan with the CS0 comparator interrupt enabled allows a system to detect a change in measured capacitance without requiring any additional dedicated MCU resources.

Auto-scan is enabled by setting the CS0 start-of-conversion bits (CS0CF6:4) to 111b. After enabling autoscan, the starting and ending channels should be set to appropriate values in CS0SS and CS0SE, respectively. Writing to CS0SS when auto-scan is enabled will cause the value written to CS0SS to be copied into CS0MX. After being enabled, writing a 1 to CS0BUSY will start auto-scan conversions. When auto-scan completes the number of conversions defined in the CS0 accumulator bits (CS0CF1:0) (see "13.5. CS0 Conversion Accumulator"), auto-scan configures CS0MX to the next highest port pin configured as an analog input and begins a conversion on that channel. This scan sequence continues until CS0MX reaches the ending input channel value defined in CS0SE. After one or more conversions have been taken at this channel, auto-scan configures CS0MX back to the starting input channel. For an example system configured to use auto-scan, please see Figure "13.2 Auto-Scan Example" on page 73.

**Note:** Auto-scan attempts one conversion on a CS0MX channel regardless of whether that channel's port pin has been configured as an analog input.

If auto-scan is enabled when the device enters suspend mode, auto-scan will remain enabled and running. This feature allows the device to wake from suspend through CS0 greater-than comparator event on any configured capacitive sense input included in the auto-scan sequence of inputs.



## 21. Reset Sources

Reset circuitry allows the controller to be easily placed in a predefined default condition. On entry to this reset state, the following occur:

- CIP-51 halts program execution
- Special Function Registers (SFRs) are initialized to their defined reset values
- External Port pins are forced to a known state
- Interrupts and timers are disabled.

All SFRs are reset to the predefined values noted in the SFR detailed descriptions. The contents of internal data memory are unaffected during a reset; any previously stored data is preserved. However, since the stack pointer SFR is reset, the stack is effectively lost, even though the data on the stack is not altered.

The Port I/O latches are reset to 0xFF (all logic ones) in open-drain mode. Weak pullups are enabled during and after the reset. For  $V_{DD}$  Monitor and power-on resets, the  $\overrightarrow{RST}$  pin is driven low until the device exits the reset state.

On exit from the reset state, the program counter (PC) is reset, and the system clock defaults to the internal oscillator. The Watchdog Timer is enabled with the system clock divided by 12 as its clock source. Program execution begins at location 0x0000.



Figure 21.1. Reset Sources



### SFR Definition 21.2. RSTSRC: Reset Source

| Bit   | 7 | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|-------|---|--------|--------|--------|--------|--------|--------|--------|
| Name  |   | FERROR | CORSEF | SWRSF  | WDTRSF | MCDRSF | PORSF  | PINRSF |
| Туре  | R | R      | R/W    | R/W    | R      | R/W    | R/W    | R      |
| Reset | 0 | Varies |

SFR Address = 0xEF

| Bit   | Name       | Description                                                                                    | Write                                                                                                                                                                | Read                                                                                                                                           |
|-------|------------|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 7     | Unused     | Unused.                                                                                        | Don't care.                                                                                                                                                          | 0                                                                                                                                              |
| 6     | FERROR     | Flash Error Reset Flag.                                                                        | N/A                                                                                                                                                                  | Set to 1 if Flash<br>read/write/erase error<br>caused the last reset.                                                                          |
| 5     | CORSEF     | Comparator0 Reset Enable and Flag.                                                             | Writing a 1 enables<br>Comparator0 as a reset<br>source (active-low).                                                                                                | Set to 1 if Comparator0 caused the last reset.                                                                                                 |
| 4     | SWRSF      | Software Reset Force and Flag.                                                                 | Writing a 1 forces a system reset.                                                                                                                                   | Set to 1 if last reset was caused by a write to SWRSF.                                                                                         |
| 3     | WDTRSF     | Watchdog Timer Reset Flag.                                                                     | N/A                                                                                                                                                                  | Set to 1 if Watchdog Timer overflow caused the last reset.                                                                                     |
| 2     | MCDRSF     | Missing Clock Detector<br>Enable and Flag.                                                     | Writing a 1 enables the<br>Missing Clock Detector.<br>The MCD triggers a reset<br>if a missing clock condition<br>is detected.                                       | Set to 1 if Missing Clock<br>Detector timeout caused<br>the last reset.                                                                        |
| 1     | PORSF      | Power-On / V <sub>DD</sub> Monitor<br>Reset Flag, and V <sub>DD</sub> monitor<br>Reset Enable. | Writing a 1 enables the $V_{DD}$ monitor as a reset source.<br>Writing 1 to this bit before the $V_{DD}$ monitor is enabled and stabilized may cause a system reset. | Set to 1 anytime a power-<br>on or V <sub>DD</sub> monitor reset<br>occurs.<br>When set to 1 all other<br>RSTSRC flags are inde-<br>terminate. |
| 0     | PINRSF     | HW Pin Reset Flag.                                                                             | N/A                                                                                                                                                                  | Set to 1 if RST pin caused the last reset.                                                                                                     |
| Note: | Do not use | read-modify-write operations on this                                                           | s register                                                                                                                                                           | 1                                                                                                                                              |



#### 24.2. 32-bit CRC Algorithm

The C8051F80x-83x CRC unit calculates the 32-bit CRC using a poly of 0x04C11DB7. The CRC-32 algorithm is "reflected", meaning that all of the input bytes and the final 32-bit output are bit-reversed in the processing engine. The following is a description of a simplified CRC algorithm that produces results identical to the hardware:

- 1. XOR the least-significant byte of the current CRC result with the input byte. If this is the first iteration of the CRC unit, the current CRC result will be the set initial value (0x00000000 or 0xFFFFFFF).
- 2. Right-shift the CRC result.
- 3. If the LSB of the CRC result is set, XOR the CRC result with the reflected polynomial (0xEDB88320).
- 4. Repeat at Step 2 for the number of input bits (8).

For example, the 32-bit C8051F80x-83x CRC algorithm can be described by the following code:

```
unsigned long UpdateCRC (unsigned long CRC_acc, unsigned char CRC_input) {
   unsigned char i; // loop counter
   #define POLY 0xEDB88320 // bit-reversed version of the poly 0x04C11DB7
   // Create the CRC "dividend" for polynomial arithmetic (binary arithmetic
   // with no carries)
   CRC_acc = CRC_acc ^ CRC_input;
   // "Divide" the poly into the dividend using CRC XOR subtraction
   // CRC_acc holds the "remainder" of each divide
   // Only complete this division for 8 bits since input is 1 byte
   for (i = 0; i < 8; i++)
   {
      // Check if the MSB is set (if MSB is 1, then the POLY can "divide" \,
      // into the "dividend")
      if ((CRC_acc & 0x0000001) == 0x0000001)
      {
          // if so, shift the CRC value, and XOR "subtract" the poly
          CRC_acc = CRC_acc >> 1;
          CRC_acc ^= POLY;
      }
      else
      {
          // if not, just shift the CRC value
          CRC_acc = CRC_acc >> 1;
      }
   }
   return CRC_acc; // Return the final remainder (CRC value)
```

Table 24.2 lists example input values and the associated outputs using the 32-bit C8051F80x-83x CRC algorithm (an initial value of 0xFFFFFFF is used):

#### Table 24.2. Example 32-bit CRC Outputs

| Input                        | Output     |
|------------------------------|------------|
| 0x63                         | 0xF9462090 |
| 0xAA, 0xBB, 0xCC             | 0x41B207B3 |
| 0x00, 0x00, 0xAA, 0xBB, 0xCC | 0x78D129BC |



## 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    |
|       |                  | 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    |
|       |                  | the shift register from the transmit buffer or by a transition on SCK SRMT = 1 when     |
|       |                  | in Master Mode.                                                                         |
| 0     | RXBMT            | Receive Buffer Empty (valid in slave mode only).                                        |
|       |                  | This bit will be set to logic 1 when the receive buffer has been read and contains no   |
|       |                  | new information. If there is new information available in the receive buffer that has   |
|       |                  | 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 |
|       | See Table 25.1   | for timing parameters.                                                                  |
|       |                  |                                                                                         |



## SFR Definition 25.2. SPI0CN: SPI0 Control

| Bit   | 7    | 6    | 5    | 4      | 3          | 2 | 1     | 0     |
|-------|------|------|------|--------|------------|---|-------|-------|
| Name  | SPIF | WCOL | MODF | RXOVRN | NSSMD[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 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.                                                                                                                                                                                                                                                                                                                                                                           |
|     |            | Selects between the following NSS operation modes:<br>(See Section 25.2 and Section 25.3).<br>00: 3-Wire Slave or 3-Wire Master Mode. NSS signal is not routed to a port pin.<br>01: 4-Wire Slave or Multi-Master Mode (Default). NSS is an input to the device.<br>1x: 4-Wire Single-Master Mode. NSS signal is mapped as an output from the<br>device and will assume the value of NSSMD0. |
| 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.                                                                                                                                                                                                                                                                                                                                                          |



| Parameter                 | Description                                                      | Min                          | Max                     | Units |
|---------------------------|------------------------------------------------------------------|------------------------------|-------------------------|-------|
| Master Mode               | Timing (See Figure 25.8 and Figure 25.9)                         |                              |                         |       |
| Т <sub>МСКН</sub>         | SCK High Time                                                    | 1 x T <sub>SYSCLK</sub>      | —                       | ns    |
| T <sub>MCKL</sub>         | SCK Low Time                                                     | 1 x T <sub>SYSCLK</sub>      | —                       | ns    |
| T <sub>MIS</sub>          | MISO Valid to SCK Shift Edge                                     | 1 x T <sub>SYSCLK</sub> + 20 | —                       | ns    |
| т <sub>мін</sub>          | SCK Shift Edge to MISO Change                                    | 0                            | —                       | ns    |
| Slave Mode                | Fiming (See Figure 25.10 and Figure 25.11)                       |                              |                         |       |
| T <sub>SE</sub>           | NSS Falling to First SCK Edge                                    | 2 x T <sub>SYSCLK</sub>      | —                       | ns    |
| T <sub>SD</sub>           | Last SCK Edge to NSS Rising                                      | 2 x T <sub>SYSCLK</sub>      | —                       | ns    |
| T <sub>SEZ</sub>          | NSS Falling to MISO Valid                                        | —                            | 4 x T <sub>SYSCLK</sub> | ns    |
| T <sub>SDZ</sub>          | NSS Rising to MISO High-Z                                        | _                            | 4 x T <sub>SYSCLK</sub> | ns    |
| Т <sub>СКН</sub>          | SCK High Time                                                    | 5 x T <sub>SYSCLK</sub>      | —                       | ns    |
| T <sub>CKL</sub>          | SCK Low Time                                                     | 5 x T <sub>SYSCLK</sub>      | —                       | ns    |
| T <sub>SIS</sub>          | MOSI Valid to SCK Sample Edge                                    | 2 x T <sub>SYSCLK</sub>      | —                       | ns    |
| T <sub>SIH</sub>          | SCK Sample Edge to MOSI Change                                   | 2 x T <sub>SYSCLK</sub>      | —                       | ns    |
| т <sub>soн</sub>          | SCK Shift Edge to MISO Change                                    | _                            | 4 x T <sub>SYSCLK</sub> | ns    |
| T <sub>SLH</sub>          | Last SCK Edge to MISO Change<br>(CKPHA = 1 ONLY)                 | 6 x T <sub>SYSCLK</sub>      | 8 x T <sub>SYSCLK</sub> | ns    |
| Note: T <sub>SYSCLI</sub> | $_{\rm C}$ is equal to one period of the device system clock (S) | /SCLK).                      |                         | 1     |

## Table 25.1. SPI Slave Timing Parameters



### 26. SMBus

The SMBus I/O interface is a two-wire, bi-directional serial bus. The SMBus is compliant with the System Management Bus Specification, version 1.1, and compatible with the I<sup>2</sup>C serial bus. Reads and writes to the interface by the system controller are byte oriented with the SMBus interface autonomously controlling the serial transfer of the data. Data can be transferred at up to 1/20th of the system clock as a master or slave (this can be faster than allowed by the SMBus specification, depending on the system clock used). A method of extending the clock-low duration is available to accommodate devices with different speed capabilities on the same bus.

The SMBus interface may operate as a master and/or slave, and may function on a bus with multiple masters. The SMBus provides control of SDA (serial data), SCL (serial clock) generation and synchronization, arbitration logic, and START/STOP control and generation. The SMBus peripheral can be fully driven by software (i.e., software accepts/rejects slave addresses, and generates ACKs), or hardware slave address recognition and automatic ACK generation can be enabled to minimize software overhead. A block diagram of the SMBus peripheral and the associated SFRs is shown in Figure 26.1.



Figure 26.1. SMBus Block Diagram



imum setup and hold times for the two EXTHOLD settings. Setup and hold time extensions are typically necessary when SYSCLK is above 10 MHz.

| EXTHOLD                                                 | Minimum SDA Setup Time                                                                                                                                      | Minimum SDA Hold Time                                                                                                             |
|---------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 0                                                       | T <sub>low</sub> – 4 system clocks<br>or<br>1 system clock + s/w delay <sup>*</sup>                                                                         | 3 system clocks                                                                                                                   |
| 1                                                       | 11 system clocks                                                                                                                                            | 12 system clocks                                                                                                                  |
| Note: Setup Tin<br>software a<br>ACK is w<br>that defin | ne for ACK bit transmissions and the<br>acknowledgement, the s/w delay occ<br>ritten and when SI is cleared. Note th<br>es the outgoing ACK value, s/w dela | MSB of all data transfers. When using<br>curs between the time SMB0DAT or<br>nat if SI is cleared in the same write<br>y is zero. |

Table 26.2. Minimum SDA Setup and Hold Times

With the SMBTOE bit set, Timer 3 should be configured to overflow after 25 ms in order to detect SCL low timeouts (see Section "26.3.4. SCL Low Timeout" on page 182). The SMBus interface will force Timer 3 to reload while SCL is high, and allow Timer 3 to count when SCL is low. The Timer 3 interrupt service routine should be used to reset SMBus communication by disabling and re-enabling the SMBus.

SMBus Free Timeout detection can be enabled by setting the SMBFTE bit. When this bit is set, the bus will be considered free if SDA and SCL remain high for more than 10 SMBus clock source periods (see Figure 26.4).



### SFR Definition 28.2. TCON: Timer Control

| Bit   | 7            | 6                                                                                                                                                                                                                                                                       | 5                                                                                                                                                                             | 4                                              | 3                                             | 2                                           | 1                               | 0                         |  |  |
|-------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|-----------------------------------------------|---------------------------------------------|---------------------------------|---------------------------|--|--|
| Name  | e TF1        | TR1                                                                                                                                                                                                                                                                     | TF0                                                                                                                                                                           | TR0                                            | IE1                                           | IT1                                         | IE0                             | IT0                       |  |  |
| Туре  | R/W          | R/W                                                                                                                                                                                                                                                                     | R/W                                                                                                                                                                           | R/W                                            | R/W                                           | R/W                                         | R/W                             | R/W                       |  |  |
| Rese  | t 0          | 0                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                             | 0                                              | 0                                             | 0                                           | 0                               | 0                         |  |  |
| SFR A | ddress = 0x8 | 38: Bit-Addres                                                                                                                                                                                                                                                          | sable                                                                                                                                                                         |                                                |                                               |                                             |                                 |                           |  |  |
| Bit   | Name         |                                                                                                                                                                                                                                                                         |                                                                                                                                                                               |                                                | Function                                      |                                             |                                 |                           |  |  |
| 7     | TF1          | Timer 1 Ov                                                                                                                                                                                                                                                              | erflow Flag                                                                                                                                                                   |                                                |                                               |                                             |                                 |                           |  |  |
|       |              | Set to 1 by but is autom routine.                                                                                                                                                                                                                                       | hardware wh<br>natically clea                                                                                                                                                 | nen Timer 1<br>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 but is autom routine.                                                                                                                                                                                                                                       | Set to 1 by hardware when Timer 0 overflows. This flag can be cleared by software but is automatically cleared when the CPU vectors to the Timer 0 interrupt service routine. |                                                |                                               |                                             |                                 |                           |  |  |
| 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 clea<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-trigg | of type defin<br>cleared when<br>ered mode. | ed by IT1 is the CPU ve         | detected. It ctors to the |  |  |
| 2     | IT1          | Interrupt 1                                                                                                                                                                                                                                                             | Type Select                                                                                                                                                                   |                                                |                                               |                                             |                                 |                           |  |  |
|       |              | This bit selects whether the configured /INT1 interrupt will be edge or level sensitive.<br>/INT1 is configured active low or high by the IN1PL bit in the IT01CF register (see<br>SFR Definition 18.7).<br>0: /INT1 is level triggered.<br>1: /INT1 is edge triggered. |                                                                                                                                                                               |                                                |                                               |                                             |                                 |                           |  |  |
| 1     | IE0          | External In                                                                                                                                                                                                                                                             | terrupt 0.                                                                                                                                                                    |                                                |                                               |                                             |                                 |                           |  |  |
|       |              | This flag is a can be clea                                                                                                                                                                                                                                              | set by hardw<br>red by softwa<br>errupt 0 serv                                                                                                                                | are when ar<br>are but is au<br>rice routine i | n edge/level<br>tomatically c<br>n edge-trigg | of type defin<br>cleared when<br>ered mode. | ed by IT1 is<br>the CPU ve      | detected. It ctors to the |  |  |
| 0     | IT0          | Interrupt 0                                                                                                                                                                                                                                                             | Interrupt 0 Type Select                                                                                                                                                       |                                                |                                               |                                             |                                 |                           |  |  |

 This bit selects whether the configured INT0 interrupt will be edge or level sensitive.

 INT0 is configured active low or high by the IN0PL bit in register IT01CF (see SFR Definition 18.7).

 0: INT0 is level triggered.

 1: INT0 is edge triggered.



#### 28.2. Timer 2

Timer 2 is a 16-bit timer formed by two 8-bit SFRs: TMR2L (low byte) and TMR2H (high byte). Timer 2 may operate in 16-bit auto-reload mode or (split) 8-bit auto-reload mode. The T2SPLIT bit (TMR2CN.3) defines the Timer 2 operation mode. Timer 2 can also be used in capture mode to capture rising edges of the Comparator 0 output.

Timer 2 may be clocked by the system clock, the system clock divided by 12, or the external oscillator source divided by 8. The external clock mode is ideal for real-time clock (RTC) functionality, where the internal oscillator drives the system clock while Timer 2 (and/or the PCA) is clocked by an external oscillator source. The external oscillator source divided by 8 is synchronized with the system clock when in all operating modes except suspend. When the internal oscillator is placed in suspend mode, The external clock/8 signal can directly drive the timer. This allows the use of an external clock to wake up the device from suspend mode. The timer will continue to run in suspend mode and count up. When the timer overflow occurs, the device will wake from suspend mode, and begin executing code again. The timer value may be set prior to entering suspend, to overflow in the desired amount of time (number of clocks) to wake the device. If a wake-up source other than the timer wakes the device from suspend mode, it may take up to three timer clocks before the timer registers can be read or written. During this time, the STSYNC bit in register OSCICN will be set to 1, to indicate that it is not safe to read or write the timer registers.

#### 28.2.1. 16-bit Timer with Auto-Reload

When T2SPLIT (TMR2CN.3) is zero, Timer 2 operates as a 16-bit timer with auto-reload. Timer 2 can be clocked by SYSCLK, SYSCLK divided by 12, or the external oscillator clock source divided by 8. As the 16-bit timer register increments and overflows from 0xFFFF to 0x0000, the 16-bit value in the Timer 2 reload registers (TMR2RLH and TMR2RLL) is loaded into the Timer 2 register as shown in Figure 28.4, and the Timer 2 High Byte Overflow Flag (TMR2CN.7) is set. If Timer 2 interrupts are enabled (if IE.5 is set), an interrupt will be generated on each Timer 2 overflow. Additionally, if Timer 2 interrupts are enabled and the TF2LEN bit is set (TMR2CN.5), an interrupt will be generated each time the lower 8 bits (TMR2L) overflow from 0xFF to 0x00.



Figure 28.4. Timer 2 16-Bit Mode Block Diagram



#### 29.3. Capture/Compare Modules

Each module can be configured to operate independently in one of six operation modes: edge-triggered capture, software timer, high-speed output, frequency output, 8-bit through 15-bit pulse width modulator, or 16-bit pulse width modulator. Each module has Special Function Registers (SFRs) associated with it in the CIP-51 system controller. These registers are used to exchange data with a module and configure the module's mode of operation. Table 29.2 summarizes the bit settings in the PCA0CPMn and PCA0PWM registers used to select the PCA capture/compare module's operating mode. Note that all modules set to use 8-bit through 15-bit PWM mode must use the same cycle length (8–15 bits). Setting the ECCFn bit in a PCA0CPMn register enables the module's CCFn interrupt.

| Operational Mode                              | PCA0CPMn |   |   |   |   |   | PCA0PWM |   |   |   |   |   |   |     |
|-----------------------------------------------|----------|---|---|---|---|---|---------|---|---|---|---|---|---|-----|
| Bit Number                                    | 7        | 6 | 5 | 4 | 3 | 2 | 1       | 0 | 7 | 6 | 5 | 4 | 3 | 2–0 |
| Capture triggered by positive edge on CEXn    | Х        | Х | 1 | 0 | 0 | 0 | 0       | А | 0 | Х | В | Х | Х | XXX |
| Capture triggered by negative edge on CEXn    | Х        | Х | 0 | 1 | 0 | 0 | 0       | А | 0 | Х | В | Х | Х | XXX |
| Capture triggered by any transition on CEXn   | Х        | Х | 1 | 1 | 0 | 0 | 0       | А | 0 | Х | В | Х | Х | XXX |
| Software Timer                                | Х        | С | 0 | 0 | 1 | 0 | 0       | А | 0 | Х | В | Х | Х | XXX |
| High Speed Output                             | Х        | С | 0 | 0 | 1 | 1 | 0       | А | 0 | Х | В | Х | Х | XXX |
| Frequency Output                              | Х        | С | 0 | 0 | 0 | 1 | 1       | А | 0 | Х | В | Х | Х | XXX |
| 8-Bit Pulse Width Modulator <sup>7</sup>      |          |   |   | 0 | Е | 0 | 1       | А | 0 | Х | В | Х | Х | 000 |
| 9-Bit Pulse Width Modulator <sup>7</sup>      |          |   |   | 0 | Е | 0 | 1       | Α | D | Х | В | Х | Х | 001 |
| 10-Bit Pulse Width Modulator <sup>7</sup>     |          |   |   | 0 | Е | 0 | 1       | Α | D | Х | В | Х | Х | 010 |
| 11-Bit Pulse Width Modulator <sup>7</sup>     |          |   |   | 0 | Е | 0 | 1       | А | D | Х | В | Х | Х | 011 |
| 12-Bit Pulse Width Modulator <sup>7</sup>     | 0        | С | 0 | 0 | Е | 0 | 1       | Α | D | Х | В | Х | Х | 100 |
| 13-Bit Pulse Width Modulator <sup>7</sup>     | 0        | С | 0 | 0 | Е | 0 | 1       | Α | D | Х | В | Х | Х | 101 |
| 14-Bit Pulse Width Modulator <sup>7</sup>     | 0        | С | 0 | 0 | Е | 0 | 1       | А | D | Х | В | Х | Х | 110 |
| 15-Bit Pulse Width Modulator <sup>7</sup>     | 0        | С | 0 | 0 | Е | 0 | 1       | А | D | Х | В | Х | Х | 111 |
| 16-Bit Pulse Width Modulator                  | 1        | С | 0 | 0 | Е | 0 | 1       | А | 0 | Х | В | Х | 0 | XXX |
| 16-Bit Pulse Width Modulator with Auto-Reload | 1        | С | 0 | 0 | Е | 0 | 1       | А | D | Х | В | Х | 1 | XXX |

#### Table 29.2. PCA0CPM and PCA0PWM Bit Settings for PCA Capture/Compare Modules<sup>1,2,3,4,5,6</sup>

Notes:

- 1. X = Don't Care (no functional difference for individual module if 1 or 0).
- 2. A = Enable interrupts for this module (PCA interrupt triggered on CCFn set to 1).
- 3. B = Enable 8th through 15th bit overflow interrupt (Depends on setting of CLSEL[2:0]).
- **4.** C = When set to 0, the digital comparator is off. For high speed and frequency output modes, the associated pin will not toggle. In any of the PWM modes, this generates a 0% duty cycle (output = 0).
- 5. D = Selects whether the Capture/Compare register (0) or the Auto-Reload register (1) for the associated channel is accessed via addresses PCA0CPHn and PCA0CPLn.
- 6. E = When set, a match event will cause the CCFn flag for the associated channel to be set.
- 7. All modules set to 8-bit through 15-bit PWM mode use the same cycle length setting.



#### 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

#### 29.3.3. High-Speed Output Mode

In high-speed output mode, a module's associated CEXn pin is toggled each time a match occurs between the PCA Counter and 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 TOGn, MATn, and ECOMn bits in the PCA0CPMn register enables the high-speed output mode. If ECOMn is cleared, the associated pin will retain its state, and not toggle on the next match event.

**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.6. PCA High-Speed Output Mode Diagram



## SFR Definition 29.5. PCA0L: PCA0 Counter/Timer Low Byte

| Bit   | 7   | 6   | 5   | 4   | 3      | 2   | 1   | 0   |
|-------|-----|-----|-----|-----|--------|-----|-----|-----|
| Name  |     |     |     | PCA | 0[7:0] |     |     |     |
| Туре  | 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 = 0xF9

| Bit   | Name                        | Function                                                                                                                                              |
|-------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | PCA0[7:0]                   | PCA Counter/Timer Low Byte.                                                                                                                           |
|       |                             | The PCA0L register holds the low byte (LSB) of the 16-bit PCA Counter/Timer.                                                                          |
| Note: | When the WI<br>the PCA0L re | DTE bit is set to 1, the PCA0L register cannot be modified by software. To change the contents of egister, the Watchdog Timer must first be disabled. |

#### SFR Definition 29.6. PCA0H: PCA0 Counter/Timer High Byte

| Bit   | 7   | 6   | 5   | 4    | 3      | 2   | 1   | 0   |
|-------|-----|-----|-----|------|--------|-----|-----|-----|
| Name  |     |     |     | PCA0 | [15:8] |     |     |     |
| Туре  | 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 = 0xFA

| Bit   | Name                     | Function                                                                                                                                                                                                                                            |
|-------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0   | PCA0[15:8]               | PCA Counter/Timer High Byte.                                                                                                                                                                                                                        |
|       |                          | The PCA0H register holds the high byte (MSB) of the 16-bit PCA Counter/Timer.<br>Reads of this register will read the contents of a "snapshot" register, whose contents<br>are updated only when the contents of PCA0L are read (see Section 29.1). |
| Note: | When the WE the PCA0H re | DTE bit is set to 1, the PCA0H register cannot be modified by software. To change the contents of egister, the Watchdog Timer must first be disabled.                                                                                               |



#### 30.2. C2CK Pin Sharing

The C2 protocol allows the C2 pins to be shared with user functions so that in-system debugging and Flash programming may be performed. This is possible because C2 communication is typically performed when the device is in the halt state, where all on-chip peripherals and user software are stalled. In this halted state, the C2 interface can safely "borrow" the C2CK (RST) and C2D pins. In most applications, external resistors are required to isolate C2 interface traffic from the user application. A typical isolation configuration is shown in Figure 30.1.



### Figure 30.1. Typical C2 Pin Sharing

The configuration in Figure 30.1 assumes the following:

- 1. The user input (b) cannot change state while the target device is halted.
- 2. The RST pin on the target device is used as an input only.

Additional resistors may be necessary depending on the specific application.

