# 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             | Active                                                           |
|----------------------------|------------------------------------------------------------------|
| Core Processor             | 8051                                                             |
| Core Size                  | 8-Bit                                                            |
| Speed                      | 25MHz                                                            |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                            |
| Number of I/O              | 16                                                               |
| Program Memory Size        | 2KB (2K x 8)                                                     |
| Program Memory Type        | FLASH                                                            |
| EEPROM Size                | -                                                                |
| RAM Size                   | 256 x 8                                                          |
| Voltage - Supply (Vcc/Vdd) | 2.2V ~ 3.6V                                                      |
| Data Converters            | -                                                                |
| Oscillator Type            | Internal                                                         |
| Operating Temperature      | -40°C ~ 125°C (TA)                                               |
| Mounting Type              | Surface Mount                                                    |
| Package / Case             | 24-SSOP (0.154", 3.90mm Width)                                   |
| Supplier Device Package    | -                                                                |
| Purchase URL               | https://www.e-xfl.com/product-detail/silicon-labs/c8051f855-c-iu |

Email: info@E-XFL.COM

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

### Table 1.7. ADC

| Parameter                       | Symbol                            | Test Condition                                                           | Min | Тур  | Max                   | Unit |
|---------------------------------|-----------------------------------|--------------------------------------------------------------------------|-----|------|-----------------------|------|
| Resolution                      | Resolution N <sub>bits</sub> 12 B |                                                                          | 12  |      |                       | Bits |
|                                 |                                   | 10 Bit Mode                                                              |     | 10   |                       | Bits |
| Throughput Rate                 | f <sub>S</sub>                    | 12 Bit Mode                                                              | _   |      | 200                   | ksps |
| (High Speed Mode)               |                                   | 10 Bit Mode                                                              | _   |      | 800                   | ksps |
| Throughput Rate                 | f <sub>S</sub>                    | 12 Bit Mode                                                              | _   |      | 62.5                  | ksps |
| (Low Power Mode)                |                                   | 10 Bit Mode                                                              | _   |      | 250                   | ksps |
| Tracking Time                   | t <sub>TRK</sub>                  | High Speed Mode                                                          | 230 |      | _                     | ns   |
|                                 |                                   | Low Power Mode                                                           | 450 |      | _                     | ns   |
| Power-On Time                   | t <sub>PWR</sub>                  |                                                                          | 1.2 |      |                       | μs   |
| SAR Clock Frequency             | f <sub>SAR</sub>                  | High Speed Mode,<br>Reference is 2.4 V internal                          | _   |      | 6.25                  | MHz  |
|                                 | -                                 | High Speed Mode,<br>Reference is not 2.4 V internal                      | _   | _    | 12.5                  | MHz  |
|                                 |                                   | Low Power Mode                                                           | _   |      | 4                     | MHz  |
| Conversion Time                 | t <sub>CNV</sub>                  | 10-Bit Conversion,<br>SAR Clock = 12.25 MHz,<br>System Clock = 24.5 MHz. |     | 1.1  |                       | μs   |
| Sample/Hold Capacitor           | C <sub>SAR</sub>                  | Gain = 1                                                                 | _   | 5    |                       | pF   |
|                                 |                                   | Gain = 0.5                                                               | _   | 2.5  | _                     | pF   |
| Input Pin Capacitance           | C <sub>IN</sub>                   |                                                                          | _   | 20   | _                     | pF   |
| Input Mux Impedance             | R <sub>MUX</sub>                  |                                                                          | _   | 550  |                       | Ω    |
| Voltage Reference Range         | V <sub>REF</sub>                  |                                                                          | 1   |      | V <sub>DD</sub>       | V    |
| Input Voltage Range*            | V <sub>IN</sub>                   | Gain = 1                                                                 | 0   |      | V <sub>REF</sub>      | V    |
|                                 |                                   | Gain = 0.5                                                               | 0   |      | $2 \mathrm{xV}_{REF}$ | V    |
| Power Supply Rejection<br>Ratio | PSRR <sub>ADC</sub>               |                                                                          | _   | 70   | —                     | dB   |
| DC Performance                  |                                   |                                                                          |     |      |                       |      |
| Integral Nonlinearity           | INL                               | 12 Bit Mode                                                              | _   | ±1   | ±2.3                  | LSB  |
|                                 |                                   | 10 Bit Mode                                                              | _   | ±0.2 | ±0.6                  | LSB  |
| Differential Nonlinearity       | DNL                               | 12 Bit Mode                                                              | -1  | ±0.7 | 1.9                   | LSB  |
| (Guaranteed Monotonic)          |                                   | 10 Bit Mode                                                              | _   | ±0.2 | ±0.6                  | LSB  |
| *Note: Absolute input pin volta | age is limited by                 | the V <sub>DD</sub> supply.                                              |     |      |                       |      |



# Table 1.7. ADC (Continued)

| Parameter                                                                                       | Symbol                                                                      | Test Condition             | Min | Тур   | Max   | Unit   |  |  |
|-------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|----------------------------|-----|-------|-------|--------|--|--|
| Offset Error                                                                                    | E <sub>OFF</sub>                                                            | 12 Bit Mode, VREF = 1.65 V | -3  | 0     | 3     | LSB    |  |  |
|                                                                                                 |                                                                             | 10 Bit Mode, VREF = 1.65 V | -2  | 0     | 2     | LSB    |  |  |
| Offset Temperature Coefficient                                                                  | TC <sub>OFF</sub>                                                           |                            | _   | 0.004 | _     | LSB/°C |  |  |
| Slope Error                                                                                     | E <sub>M</sub>                                                              | 12 Bit Mode                |     | ±0.02 | ±0.1  | %      |  |  |
|                                                                                                 |                                                                             | 10 Bit Mode                |     | ±0.06 | ±0.24 | %      |  |  |
| Dynamic Performance 10 kHz Sine Wave Input 1dB below full scale, Max throughput, using AGND pin |                                                                             |                            |     |       |       |        |  |  |
| Signal-to-Noise                                                                                 | SNR                                                                         | 12 Bit Mode                | 61  | 66    | —     | dB     |  |  |
|                                                                                                 |                                                                             | 10 Bit Mode                | 53  | 60    | —     | dB     |  |  |
| Signal-to-Noise Plus Distor-                                                                    | SNDR                                                                        | 12 Bit Mode                | 61  | 66    | _     | dB     |  |  |
| tion                                                                                            |                                                                             | 10 Bit Mode                | 53  | 60    | _     | dB     |  |  |
| Total Harmonic Distortion                                                                       | THD                                                                         | 12 Bit Mode                |     | 71    | _     | dB     |  |  |
| (Up to 5th Harmonic)                                                                            |                                                                             | 10 Bit Mode                |     | 70    |       | dB     |  |  |
| Spurious-Free Dynamic                                                                           | SFDR                                                                        | 12 Bit Mode                |     | -79   |       | dB     |  |  |
| Range                                                                                           |                                                                             | 10 Bit Mode                | _   | -74   | —     | dB     |  |  |
| *Note: Absolute input pin voltag                                                                | *Note: Absolute input pin voltage is limited by the V <sub>DD</sub> supply. |                            |     |       |       |        |  |  |



### 1.2. Typical Performance Curves

### 1.2.1. Operating Supply Current



### Figure 1.1. Typical Operating Current Running From 24.5 MHz Internal Oscillator







### 1.2.3. Port I/O Output Drive



Figure 1.5. Typical  $V_{OH}$  vs. Source Current





### **1.3. Thermal Conditions**

### Table 1.12. Thermal Conditions

| Parameter                           | Symbol        | Test Condition              | Min            | Тур    | Max | Unit |
|-------------------------------------|---------------|-----------------------------|----------------|--------|-----|------|
| Thermal Resistance*                 | $\theta_{JA}$ | SOIC-16 Packages            | _              | 70     |     | °C/W |
|                                     |               | QFN-20 Packages             | _              | 60     |     | °C/W |
|                                     |               | QSOP-24 Packages            |                | 65     |     | °C/W |
| *Note: Thermal resistance assumes a | multi-layer F | PCB with any exposed pad so | Idered to a PC | B pad. |     |      |



# 4. Ordering Information



#### Figure 4.1. C8051F85x/86x Part Numbering

All C8051F85x/86x family members have the following features:

- CIP-51 Core running up to 25 MHz
- Two Internal Oscillators (24.5 MHz and 80 kHz)
- I2C/SMBus
- SPI
- UART
- 3-Channel Programmable Counter Array (PWM, Clock Generation, Capture/Compare)
- 4 16-bit Timers
- 2 Analog Comparators
- 16-bit CRC Unit

In addition to these features, each part number in the C8051F85x/86x family has a set of features that vary across the product line. The product selection guide in Table 4.1 shows the features available on each family member.

All devices in Table 4.1 are also available in an industrial version. For the industrial version, the -G in the ordering part number is replaced with -I. For example, the industrial version of the C8051F850-C-GM is the C8051F850-C-IM.



| Ordering Part Number | Flash Memory (kB) | RAM (Bytes) | Digital Port I/Os (Total) | Number of ADC0 Channels | I/O with Comparator 0/1 Inputs | Pb-free (RoHS Compliant) | AEC-Q100 Qualified | Temperature Range | Package |
|----------------------|-------------------|-------------|---------------------------|-------------------------|--------------------------------|--------------------------|--------------------|-------------------|---------|
| C8051F850-C-GM       | 8                 | 512         | 16                        | 15                      | 15                             | ~                        | ~                  | -40 to 85 °C      | QFN-20  |
| C8051F850-C-GU       | 8                 | 512         | 18                        | 16                      | 16                             | ~                        | ~                  | -40 to 85 °C      | QSOP-24 |
| C8051F851-C-GM       | 4                 | 512         | 16                        | 15                      | 15                             | ~                        | ~                  | -40 to 85 °C      | QFN-20  |
| C8051F851-C-GU       | 4                 | 512         | 18                        | 16                      | 16                             | ~                        | ~                  | -40 to 85 °C      | QSOP-24 |
| C8051F852-C-GM       | 2                 | 256         | 16                        | 15                      | 15                             | $\checkmark$             | $\checkmark$       | -40 to 85 °C      | QFN-20  |
| C8051F852-C-GU       | 2                 | 256         | 18                        | 16                      | 16                             | $\checkmark$             | $\checkmark$       | -40 to 85 °C      | QSOP-24 |
| C8051F853-C-GM       | 8                 | 512         | 16                        |                         | 15                             | $\checkmark$             | $\checkmark$       | -40 to 85 °C      | QFN-20  |
| C8051F853-C-GU       | 8                 | 512         | 18                        |                         | 16                             | $\checkmark$             | $\checkmark$       | -40 to 85 °C      | QSOP-24 |
| C8051F854-C-GM       | 4                 | 512         | 16                        |                         | 15                             | $\checkmark$             | $\checkmark$       | -40 to 85 °C      | QFN-20  |
| C8051F854-C-GU       | 4                 | 512         | 18                        |                         | 16                             | $\checkmark$             | $\checkmark$       | -40 to 85 °C      | QSOP-24 |
| C8051F855-C-GM       | 2                 | 256         | 16                        |                         | 15                             | $\checkmark$             | $\checkmark$       | -40 to 85 °C      | QFN-20  |
| C8051F855-C-GU       | 2                 | 256         | 18                        |                         | 16                             | $\checkmark$             | $\checkmark$       | -40 to 85 °C      | QSOP-24 |
| C8051F860-C-GS       | 8                 | 512         | 13                        | 12                      | 12                             | $\checkmark$             | $\checkmark$       | -40 to 85 °C      | SOIC-16 |
| C8051F861-C-GS       | 4                 | 512         | 13                        | 12                      | 12                             | $\checkmark$             | $\checkmark$       | -40 to 85 °C      | SOIC-16 |
| C8051F862-C-GS       | 2                 | 256         | 13                        | 12                      | 12                             | $\checkmark$             | $\checkmark$       | -40 to 85 °C      | SOIC-16 |
| C8051F863-C-GS       | 8                 | 512         | 13                        |                         | 12                             | ~                        | ~                  | -40 to 85 °C      | SOIC-16 |
| C8051F864-C-GS       | 4                 | 512         | 13                        | —                       | 12                             | ~                        | $\checkmark$       | -40 to 85 °C      | SOIC-16 |
| C8051F865-C-GS       | 2                 | 256         | 13                        | —                       | 12                             | $\checkmark$             | $\checkmark$       | -40 to 85 °C      | SOIC-16 |

Table 4.1. Product Selection Guide



The upper 128 bytes of data memory are accessible only by indirect addressing. This region occupies the same address space as the Special Function Registers (SFR) but is physically separate from the SFR space. The addressing mode used by an instruction when accessing locations above 0x7F determines whether the CPU accesses the upper 128 bytes of data memory space or the SFRs. Instructions that use direct addressing will access the SFR space. Instructions using indirect addressing above 0x7F access the upper 128 bytes of data memory organization of the C8051F85x/ 86x.

Revision C C8051F852/5 and C8051F862/5 devices implement the upper four bytes of internal RAM as a 32-bit Unique Identifier. More information can be found in "Device Identification and Unique Identifier" on page 68.

#### 8.2.1.1. General Purpose Registers

The lower 32 bytes of data memory, locations 0x00 through 0x1F, may be addressed as four banks of general-purpose registers. Each bank consists of eight byte-wide registers designated R0 through R7. Only one of these banks may be enabled at a time. Two bits in the program status word (PSW) register, RS0 and RS1, select the active register bank. This allows fast context switching when entering subroutines and interrupt service routines. Indirect addressing modes use registers R0 and R1 as index registers.

#### 8.2.1.2. Bit Addressable Locations

In addition to direct access to data memory organized as bytes, the sixteen data memory locations at 0x20 through 0x2F are also accessible as 128 individually addressable bits. Each bit has a bit address from 0x00 to 0x7F. Bit 0 of the byte at 0x20 has bit address 0x00 while bit7 of the byte at 0x20 has bit address 0x07. Bit 7 of the byte at 0x2F has bit address 0x7F. A bit access is distinguished from a full byte access by the type of instruction used (bit source or destination operands as opposed to a byte source or destination).

The MCS-51<sup>™</sup> assembly language allows an alternate notation for bit addressing of the form XX.B where XX is the byte address and B is the bit position within the byte. For example, the instruction:

MOV C, 22.3h

moves the Boolean value at 0x13 (bit 3 of the byte at location 0x22) into the Carry flag.

#### 8.2.1.3. Stack

A programmer's stack can be located anywhere in the 256-byte data memory. The stack area is designated using the Stack Pointer (SP) SFR. The SP will point to the last location used. The next value pushed on the stack is placed at SP+1 and then SP is incremented. A reset initializes the stack pointer to location 0x07. Therefore, the first value pushed on the stack is placed at location 0x08, which is also the first register (R0) of register bank 1. Thus, if more than one register bank is to be used, the SP should be initialized to a location in the data memory not being used for data storage. The stack depth can extend up to 256 bytes.

#### 8.2.2. External RAM

On devices with 512 bytes total RAM, there are 256 bytes of on-chip RAM mapped into the external data memory space. All of these address locations may be accessed using the external move instruction (MOVX) and the data pointer (DPTR), or using MOVX indirect addressing mode. Note: The 16-bit MOVX instruction is also used for writes to the flash memory. See Section "10. Flash Memory" on page 61 for details. The MOVX instruction accesses XRAM by default.

For a 16-bit MOVX operation (@DPTR), the upper 8 bits of the 16-bit external data memory address word are "don't cares". As a result, addresses 0x0000 through 0x00FF are mapped modulo style over the entire 64 k external data memory address range. For example, the XRAM byte at address 0x0000 is shadowed at addresses 0x0100, 0x0200, 0x0300, 0x0400, etc.

Revision C C8051F850/1/3/4 and C8051F860/1/3/4 devices implement the upper four bytes of external RAM as a 32-bit Unique Identifier. More information can be found in "Device Identification and Unique Identifier" on page 68.



# 9. Special Function Register Memory Map

This section details the special function register memory map for the C8051F85x/86x devices.

| F8 | SPI0CN  | PCA0L    | PCA0H    | PCA0CPL0 | PCA0CPH0 | POMAT    | POMASK   | VDM0CN   |
|----|---------|----------|----------|----------|----------|----------|----------|----------|
| F0 | В       | POMDIN   | P1MDIN   | EIP1     | -        | -        | PRTDRV   | PCA0PWM  |
| E8 | ADC0CN0 | PCA0CPL1 | PCA0CPH1 | PCA0CPL2 | PCA0CPH2 | P1MAT    | P1MASK   | RSTSRC   |
| E0 | ACC     | XBR0     | XBR1     | XBR2     | IT01CF   | -        | EIE1     | -        |
| D8 | PCA0CN  | PCA0MD   | PCA0CPM0 | PCA0CPM1 | PCA0CPM2 | CRC0IN   | CRC0DAT  | ADC0PWR  |
| D0 | PSW     | REF0CN   | CRC0AUTO | CRC0CNT  | P0SKIP   | P1SKIP   | SMB0ADM  | SMB0ADR  |
| C8 | TMR2CN  | REG0CN   | TMR2RLL  | TMR2RLH  | TMR2L    | TMR2H    | CRC0CN   | CRC0FLIP |
| C0 | SMB0CN  | SMB0CF   | SMB0DAT  | ADC0GTL  | ADC0GTH  | ADC0LTL  | ADC0LTH  | OSCICL   |
| B8 | IP      | ADC0TK   | -        | ADC0MX   | ADC0CF   | ADC0L    | ADC0H    | CPT1CN   |
| В0 | -       | OSCLCN   | ADC0CN1  | ADC0AC   | -        | DEVICEID | REVID    | FLKEY    |
| A8 | IE      | CLKSEL   | CPT1MX   | CPT1MD   | SMB0TC   | DERIVID  | -        | -        |
| A0 | P2      | SPI0CFG  | SPI0CKR  | SPI0DAT  | POMDOUT  | P1MDOUT  | P2MDOUT  | -        |
| 98 | SCON0   | SBUF0    | -        | CPT0CN   | PCA0CLR  | CPT0MD   | PCA0CENT | CPT0MX   |
| 90 | P1      | TMR3CN   | TMR3RLL  | TMR3RLH  | TMR3L    | TMR3H    | PCA0POL  | WDTCN    |
| 88 | TCON    | TMOD     | TL0      | TL1      | TH0      | TH1      | CKCON    | PSCTL    |
| 80 | P0      | SP       | DPL      | DPH      | -        | -        | -        | PCON     |
|    | 0(8)    | 1(9)     | 2(A)     | 3(B)     | 4(C)     | 5(D)     | 6(E)     | 7(F)     |

### Table 9.1. Special Function Register (SFR) Memory Map

(bit addressable)

| Table 9.2. Spec | ial Function | Registers |
|-----------------|--------------|-----------|
|-----------------|--------------|-----------|

| Register | Address | Register Description           | Page |
|----------|---------|--------------------------------|------|
| ACC      | 0xE0    | Accumulator                    | 122  |
| ADC0AC   | 0xB3    | ADC0 Accumulator Configuration | 102  |
| ADC0CF   | 0xBC    | ADC0 Configuration             | 101  |
| ADC0CN0  | 0xE8    | ADC0 Control 0                 | 99   |
| ADC0CN1  | 0xB2    | ADC0 Control 1                 | 100  |
| ADC0GTH  | 0xC4    | ADC0 Greater-Than High Byte    | 107  |
| ADC0GTL  | 0xC3    | ADC0 Greater-Than Low Byte     | 108  |
| ADC0H    | 0xBE    | ADC0 Data Word High Byte       | 105  |



### 14.1. ADC0 Analog Multiplexer

ADC0 on C8051F85x/86x has an analog multiplexer capable of selecting any pin on ports P0 and P1 (up to 16 total), the on-chip temperature sensor, the internal regulated supply, the VDD supply, or GND. ADC0 input channels are selected using the ADC0MX register.

| ADC0MX setting | Signal Name | QSOP24 Pin Name             | QFN20 Pin Name | SOIC16 Pin Name |  |  |  |
|----------------|-------------|-----------------------------|----------------|-----------------|--|--|--|
| 00000          | ADC0.0      | P0.0                        | P0.0           | P0.0            |  |  |  |
| 00001          | ADC0.1      | P0.1                        | P0.1           | P0.1            |  |  |  |
| 00010          | ADC0.2      | P0.2                        | P0.2           | P0.2            |  |  |  |
| 00011          | ADC0.3      | P0.3                        | P0.3           | P0.3            |  |  |  |
| 00100          | ADC0.4      | P0.4                        | P0.4           | P0.4            |  |  |  |
| 00101          | ADC0.5      | P0.5                        | P0.5           | P0.5            |  |  |  |
| 00110          | ADC0.6      | P0.6                        | P0.6           | P0.6            |  |  |  |
| 00111          | ADC0.7      | P0.7                        | P0.7           | P0.7            |  |  |  |
| 01000          | ADC0.8      | P1.0                        | P1.0           | P1.0            |  |  |  |
| 01001          | ADC0.9      | P1.1                        | P1.1           | P1.1            |  |  |  |
| 01010          | ADC0.10     | P1.2                        | P1.2           | P1.2            |  |  |  |
| 01011          | ADC0.11     | P1.3                        | P1.3           | P1.3            |  |  |  |
| 01100          | ADC0.12     | P1.4                        | P1.4           | Reserved        |  |  |  |
| 01101          | ADC0.13     | P1.5                        | P1.5           | Reserved        |  |  |  |
| 01110          | ADC0.14     | P1.6                        | P1.6           | Reserved        |  |  |  |
| 01111          | ADC0.15     | P1.7                        | Reserved       | Reserved        |  |  |  |
| 10000          | Temp Sensor | Internal Temperature Sensor |                |                 |  |  |  |
| 10001          | LDO         | Internal 1.8 V LDO Output   |                |                 |  |  |  |
| 10010          | VDD         | VDD Supply Pin              |                |                 |  |  |  |
| 10011          | GND         |                             | GND Supply Pin |                 |  |  |  |
| 10100-11111    | None        |                             | No connection  |                 |  |  |  |

 Table 14.1. ADC0 Input Multiplexer Channels



# Register 17.4. CPT1CN: Comparator 1 Control

| Bit     | 7                 | 6     | 5     | 4     | 3     | 2 | 1   | 0   |
|---------|-------------------|-------|-------|-------|-------|---|-----|-----|
| Name    | CPEN              | CPOUT | CPRIF | CPFIF | CPHYP |   | CPI | HYN |
| Туре    | RW                | R     | RW    | RW    | RW    |   | R   | W   |
| Reset   | 0                 | 0     | 0     | 0     | 0     | 0 | 0   | 0   |
| SFR Add | SFR Address: 0xBF |       |       |       |       |   |     |     |

# Table 17.8. CPT1CN Register Bit Descriptions

| Bit | Name  | Function                                                                                                                                                                                                                 |
|-----|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | CPEN  | Comparator 1 Enable Bit.<br>0: Comparator Disabled.<br>1: Comparator Enabled.                                                                                                                                            |
| 6   | CPOUT | Comparator 1 Output State Flag.0: Voltage on CP1P < CP1N.                                                                                                                                                                |
| 5   | CPRIF | <ul> <li>Comparator 1 Rising-Edge Flag. Must be cleared by software.</li> <li>0: No Comparator Rising Edge has occurred since this flag was last cleared.</li> <li>1: Comparator Rising Edge has occurred.</li> </ul>    |
| 4   | CPFIF | <ul> <li>Comparator 1 Falling-Edge Flag. Must be cleared by software.</li> <li>0: No Comparator Falling Edge has occurred since this flag was last cleared.</li> <li>1: Comparator Falling Edge has occurred.</li> </ul> |
| 3:2 | СРНҮР | Comparator 1 Positive Hysteresis Control Bits.00: Positive Hysteresis Disabled.01: Positive Hysteresis = 5 mV.10: Positive Hysteresis = 10 mV.11: Positive Hysteresis = 20 mV.                                           |
| 1:0 | CPHYN | Comparator 1 Negative Hysteresis Control Bits.00: Negative Hysteresis Disabled.01: Negative Hysteresis = 5 mV.10: Negative Hysteresis = 10 mV.11: Negative Hysteresis = 20 mV.                                           |



# 18. Cyclic Redundancy Check Unit (CRC0)

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



Figure 18.1. CRC0 Block Diagram

### 18.1. CRC Algorithm

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

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

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



| Bit | Name  | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0 | IN0SL | INT0 Port Pin Selection Bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|     |       | These bits select which Port pin is assigned to INT0. This pin assignment is independent<br>of the Crossbar; INT0 will monitor the assigned Port pin without disturbing the peripheral<br>that has been assigned the Port pin via the Crossbar. The Crossbar will not assign the<br>Port pin to a peripheral if it is configured to skip the selected pin.<br>000: Select P0.0<br>001: Select P0.1<br>010: Select P0.2<br>011: Select P0.3<br>100: Select P0.4<br>101: Select P0.5<br>110: Select P0.6<br>111: Select P0.7 |

### Table 19.1. IT01CF Register Bit Descriptions



### Register 21.9. P0MDOUT: Port 0 Output Mode

| Bit     | 7                 | 6 | 5 | 1 | 3 | 2 | 1 | 0 |
|---------|-------------------|---|---|---|---|---|---|---|
| Dit     |                   | 0 | 5 | - | 5 | L | • | 0 |
| Name    | POMDOUT           |   |   |   |   |   |   |   |
| Туре    | RW                |   |   |   |   |   |   |   |
| Reset   | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| SFR Add | SFR Address: 0xA4 |   |   |   |   |   |   |   |

### Table 21.12. P0MDOUT Register Bit Descriptions

| Bit | Name    | Function                                                                                              |
|-----|---------|-------------------------------------------------------------------------------------------------------|
| 7:0 | P0MDOUT | Port 0 Output Mode.                                                                                   |
|     |         | These bits are only applicable when the pin is configured for digital mode using the P0MDIN register. |
|     |         | 0: Corresponding P0.n Output is open-drain.                                                           |
|     |         | 1: Corresponding P0.n Output is push-pull.                                                            |



# Register 21.11. P1MASK: Port 1 Mask

|         |                   |   | - |   | - |   |   |   |
|---------|-------------------|---|---|---|---|---|---|---|
| Bit     | 7                 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name    | P1MASK            |   |   |   |   |   |   |   |
| Туре    | RW                |   |   |   |   |   |   |   |
| Reset   | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| SFR Add | SFR Address: 0xEE |   |   |   |   |   |   |   |

### Table 21.14. P1MASK Register Bit Descriptions

| Bit            | Name                                                                                                                                               | Function                                                                                                                                                                                          |  |  |  |  |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 7:0            | P1MASK                                                                                                                                             | Port 1 Mask Value.                                                                                                                                                                                |  |  |  |  |
|                |                                                                                                                                                    | Selects P1 pins to be compared to the corresponding bits in P1MAT.<br>0: P1.x pin logic value is ignored and will cause a port mismatch event.<br>1: P1.x pin logic value is compared to P1MAT.x. |  |  |  |  |
| Note: Po<br>(P | lote: Port 1 consists of 8 bits (P1.0-P1.7) on QSOP24 packages and 7 bits (P1.0-P1.6) on QFN20 packages and 4 bits (P1.0-P1.3) on SOIC16 packages. |                                                                                                                                                                                                   |  |  |  |  |



# Register 21.13. P1: Port 1 Pin Latch

| Bit                                 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------------------------------------|----|---|---|---|---|---|---|---|
| Name                                | P1 |   |   |   |   |   |   |   |
| Туре                                | RW |   |   |   |   |   |   |   |
| Reset                               | 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| SFR Address: 0x90 (bit-addressable) |    |   |   |   |   |   |   |   |

### Table 21.16. P1 Register Bit Descriptions

| Bit            | Name                                                                                                                                                                 | Function                                                                                                     |  |  |  |  |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 7:0            | P1                                                                                                                                                                   | Port 1 Data.                                                                                                 |  |  |  |  |
|                |                                                                                                                                                                      | Writing this register sets the port latch logic value for the associated I/O pins configured as digital I/O. |  |  |  |  |
|                |                                                                                                                                                                      | Reading this register returns the logic value at the pin, regardless if it is configured as output or input. |  |  |  |  |
| Note: Po<br>(P | <ul> <li>te: Port 1 consists of 8 bits (P1.0-P1.7) on QSOP24 packages and 7 bits (P1.0-P1.6) on QFN20 packages and 4 bits (P1.0-P1.3) on SOIC16 packages.</li> </ul> |                                                                                                              |  |  |  |  |



### 22.2. Power-Fail Reset / Supply Monitor

C8051F85x/86x devices have a supply monitor that is enabled and selected as a reset source after each power-on.

The supply monitor senses the voltage on the device VDD supply and can generate a reset if the supply drops below the corresponding threshold. This monitor is enabled and enabled as a reset source after initial power-on to protect the device until VDD is an adequate and stable voltage.

When enabled and selected as a reset source, any power down transition or power irregularity that causes VDD to drop below the reset threshold will drive the RST pin low and hold the core in a reset state. When VDD returns to a level above the reset threshold, the monitor will release the core from the reset state. The reset status can then be read using the device reset sources module. After a power-fail reset, the PORF flag reads 1 and all of the other reset flags in the RSTSRC Register are indeterminate. The power-on reset delay ( $t_{POR}$ ) is not incurred after a supply monitor reset. The contents of RAM should be presumed invalid after a VDD monitor reset.

The enable state of the VDD supply monitor and its selection as a reset source is not altered by device resets. For example, if the VDD supply monitor is de-selected as a reset source and disabled by software, and then firmware performs a software reset, the VDD supply monitor will remain disabled and de-selected after the reset.

To protect the integrity of flash contents, the VDD supply monitor must be enabled and selected as a reset source if software contains routines that erase or write flash memory. If the VDD supply monitor is not enabled, any erase or write performed on flash memory will be ignored.



Figure 22.3. VDD Supply Monitor Threshold

### 22.3. Enabling the VDD Monitor

The VDD supply monitor is enabled by default. However, in systems which disable the supply monitor, it must be enabled before selecting it as a reset source. Selecting the VDD supply monitor as a reset source before it has stabilized may generate a system reset. In systems where this reset would be undesirable, a delay should be introduced between enabling the VDD supply monitor and selecting it as a reset source. No delay should be introduced in systems where software contains routines that erase or write flash memory. The procedure for enabling the VDD supply monitor and selecting it as a reset source is:



### 22.11. Supply Monitor Control Registers

| Bit   | 7     | 6       | 5 | 4        | 3 | 2 | 1 | 0 |
|-------|-------|---------|---|----------|---|---|---|---|
| Name  | VDMEN | VDDSTAT |   | Reserved |   |   |   |   |
| Туре  | RW    | R       |   | R        |   |   |   |   |
| Reset | Х     | Х       | Х | Х        | Х | Х | Х | Х |

### Register 22.2. VDM0CN: Supply Monitor Control

SFR Address: 0xFF

# Table 22.2. VDM0CN Register Bit Descriptions

| Bit | Name     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | VDMEN    | Supply Monitor Enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|     |          | This bit turns the supply monitor circuit on/off. The supply monitor cannot generate system resets until it is also selected as a reset source in register RSTSRC. Selecting the supply monitor as a reset source before it has stabilized may generate a system reset. In systems where this reset would be undesirable, a delay should be introduced between enabling the supply monitor and selecting it as a reset source.<br>0: Supply Monitor Disabled.<br>1: Supply Monitor Enabled. |
| 6   | VDDSTAT  | Supply Status.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|     |          | <ul> <li>This bit indicates the current power supply status (supply monitor output).</li> <li>0: V<sub>DD</sub> is at or below the supply monitor threshold.</li> <li>1: V<sub>DD</sub> is above the supply monitor threshold.</li> </ul>                                                                                                                                                                                                                                                   |
| 5:0 | Reserved | Must write reset value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |



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 23.5. For slave mode, the clock and data relationships are shown in Figure 23.6 and Figure 23.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) 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 synchronously with the slave's system clock frequency. This sprovided that the master issues SCK, NSS, and the serial input data synchronously with the slave's 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. This is provided that the master issues SCK, NSS, and the serial input data synchronously with the slave's system clock.



Figure 23.5. Master Mode Data/Clock Timing



### Table 25.15. TMR3CN Register Bit Descriptions

| Bit | Name   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | T3XCLK | Timer 3 External Clock Select.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|     |        | This bit selects the external clock source for Timer 3. If Timer 3 is in 8-bit mode, this bit selects the external oscillator clock source for both timer bytes. However, the Timer 3 Clock Select bits (T3MH and T3ML in register CKCON) may still be used to select between the external clock and the system clock for either timer.<br>0: Timer 3 clock is the system clock divided by 12.<br>1: Timer 3 clock is the external clock divided by 8 (synchronized with SYSCLK). |



### 29.2. C2 Interface Registers

The following describes the C2 registers necessary to perform flash programming through the C2 interface. All C2 registers are accessed through the C2 interface, and are not available in the SFR map for firmware access.

#### Register 29.1. C2ADD: C2 Address

| Bit                                       | 7     | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------------------------------------------|-------|---|---|---|---|---|---|---|
| Name                                      | C2ADD |   |   |   |   |   |   |   |
| Туре                                      | RW    |   |   |   |   |   |   |   |
| Reset                                     | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| This register is part of the C2 protocol. |       |   |   |   |   |   |   |   |

### Table 29.1. C2ADD Register Bit Descriptions

| Bit | Name  | Function                                                                                                                                                                                                                       |
|-----|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | C2ADD | C2 Address.                                                                                                                                                                                                                    |
|     |       | The C2ADD register is accessed via the C2 interface. The value written to C2ADD selects the target data register for C2 Data Read and Data Write commands.<br>0x00: C2DEVID<br>0x01: C2REVID<br>0x02: C2FPCTL<br>0xB4: C2FPDAT |

