



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Obsolete                                                        |
|----------------------------|-----------------------------------------------------------------|
| Core Processor             | 8051                                                            |
| Core Size                  | 8-Bit                                                           |
| Speed                      | 25MHz                                                           |
| Connectivity               | SMBus (2-Wire/I <sup>2</sup> C), SPI, UART/USART                |
| Peripherals                | POR, PWM, Temp Sensor, WDT                                      |
| Number of I/O              | 29                                                              |
| Program Memory Size        | 8KB (8K x 8)                                                    |
| Program Memory Type        | OTP                                                             |
| EEPROM Size                | -                                                               |
| RAM Size                   | 1.25K x 8                                                       |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                                     |
| Data Converters            | A/D 21x10b                                                      |
| Oscillator Type            | Internal                                                        |
| Operating Temperature      | -40°C ~ 85°C (TA)                                               |
| Mounting Type              | Surface Mount                                                   |
| Package / Case             | 32-LQFP                                                         |
| Supplier Device Package    | 32-LQFP (7x7)                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/silicon-labs/c8051t612-gqr |

Email: info@E-XFL.COM

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

# **List of Tables**

| 2. Ordering Information                                                  |     |
|--------------------------------------------------------------------------|-----|
| Table 2.1. Product Selection Guide                                       | 19  |
| 3. Pin Definitions                                                       |     |
| Table 3.1. Pin Definitions for the C8051T610/1/2/3/4/5/6/7               | 20  |
| 4. LQFP-32 Package Specifications                                        |     |
| Table 4.1. LQFP-32 Package Dimensions                                    | 25  |
| Table 4.2. LQFP-32 PCB Land Pattern Dimesions                            | 26  |
| 5. QFN-28 Package Specifications                                         |     |
| Table 5.1. QFN-28 Package Dimensions                                     | 27  |
| Table 5.2. QFN-28 PCB Land Pattern Dimesions                             | 28  |
| 6. QFN-24 Package Specifications                                         |     |
| Table 6.1. QFN-24 Package Dimensions                                     | 29  |
| Table 6.2. QFN-24 PCB Land Pattern Dimesions                             | 30  |
| 7. Electrical Characteristics                                            |     |
| Table 7.1. Absolute Maximum Ratings                                      | 31  |
| Table 7.2. Global Electrical Characteristics                             | 32  |
| Table 7.3. Port I/O DC Electrical Characteristics                        | 33  |
| Table 7.4. Reset Electrical Characteristics                              | 34  |
| Table 7.5. Internal Voltage Regulator Electrical Characteristics         | 34  |
| Table 7.6. EPROM Electrical Characteristics                              | 34  |
| Table 7.7. Internal High-Frequency Oscillator Electrical Characteristics | 35  |
| Table 7.8. ADC0 Electrical Characteristics                               | 35  |
| Table 7.9. Temperature Sensor Electrical Characteristics                 | 36  |
| Table 7.10. Voltage Reference Electrical Characteristics                 | 36  |
| Table 7.11. Comparator Electrical Characteristics                        | 37  |
| 13. CIP-51 Microcontroller                                               |     |
| Table 13.1. CIP-51 Instruction Set Summary                               | 70  |
| 15. Special Function Registers                                           | -   |
| Table 15.1. Special Function Register (SFR) Memory Map                   | 81  |
| Table 15.2. Special Function Registers                                   | 82  |
| 16. Interrupts                                                           |     |
| Table 16.1. Interrupt Summary                                            | 87  |
| 17. EPROM Memory                                                         |     |
| Table 17.1. Security Byte Decoding                                       | 95  |
| 21. Port Input/Output                                                    |     |
| Table 21.1. Port I/O Assignment for Analog Functions                     | 116 |
| Table 21.2. Port I/O Assignment for Digital Functions                    | 116 |
| Table 21.3. Port I/O Assignment for INT0 and INT1 Functions              | 117 |
| 22. SMBus                                                                |     |
| Table 22.1. SMBus Clock Source Selection                                 | 136 |
| Table 22.2. Minimum SDA Setup and Hold Times                             | 137 |
| Table 22.3. Sources for Hardware Changes to SMB0CN                       | 141 |
| Table 22.4. SMBus Status Decoding                                        | 147 |
|                                                                          |     |



|                                                                        | ~~~ |
|------------------------------------------------------------------------|-----|
| C2 Register Definition 27.1. C2ADD: C2 Address                         | 208 |
| C2 Register Definition 27.2. DEVICEID: C2 Device ID                    | 209 |
| C2 Register Definition 27.3. REVID: C2 Revision ID                     | 209 |
| C2 Register Definition 27.4. DEVCTL: C2 Device Control                 | 210 |
| C2 Register Definition 27.5. EPCTL: EPROM Programming Control Register | 210 |
| C2 Register Definition 27.6. EPDAT: C2 EPROM Data                      | 211 |
| C2 Register Definition 27.7. EPSTAT: C2 EPROM Status                   | 211 |
| C2 Register Definition 27.8. EPADDRH: C2 EPROM Address High Byte       | 212 |
| C2 Register Definition 27.9. EPADDRL: C2 EPROM Address Low Byte        | 212 |
| C2 Register Definition 27.10. CRC0: CRC Byte 0                         | 213 |
| C2 Register Definition 27.11. CRC1: CRC Byte 1                         | 213 |
| C2 Register Definition 27.12. CRC2: CRC Byte 2                         | 214 |
| C2 Register Definition 27.13. CRC3: CRC Byte 3                         | 214 |





Figure 3.1. LQFP-32 Pinout Diagram (Top View)





Figure 5.2. QFN-28 Recommended PCB Land Pattern

| Dimension | Min  | Мах  |  |  |
|-----------|------|------|--|--|
| C1        | 4.8  | 80   |  |  |
| C2        | 4.80 |      |  |  |
| E         | 0.:  | 50   |  |  |
| X1        | 0.20 | 0.30 |  |  |

| ······································ | <b>Fable 5.2.</b> | QFN-28 PCB | Land Pattern | Dimesions |
|----------------------------------------|-------------------|------------|--------------|-----------|
|----------------------------------------|-------------------|------------|--------------|-----------|

| Dimension | Min  | Max  |
|-----------|------|------|
| X2        | 3.20 | 3.30 |
| Y1        | 0.85 | 0.95 |
| Y2        | 3.20 | 3.30 |

#### Notes:

General

- 1. All dimensions shown are in millimeters (mm) unless otherwise noted.
- 2. Dimensioning and Tolerancing is per the ANSI Y14.5M-1994 specification.
- 3. This Land Pattern Design is based on the IPC-7351 guidelines.

#### Solder Mask Design

**4.** All metal pads are to be non-solder mask defined (NSMD). Clearance between the solder mask and the metal pad is to be 60μm minimum, all the way around the pad.

#### Stencil Design

- **5.** A stainless steel, laser-cut and electro-polished stencil with trapezoidal walls should be used to assure good solder paste release.
- 6. The stencil thickness should be 0.125mm (5 mils).
- 7. The ratio of stencil aperture to land pad size should be 1:1 for all perimeter pins.
- **8.** A 3x3 array of 0.90mm openings on a 1.1mm pitch should be used for the center pad to assure the proper paste volume.

Card Assembly

- 9. A No-Clean, Type-3 solder paste is recommended.
- **10.** The recommended card reflow profile is per the JEDEC/IPC J-STD-020C specification for Small Body Components.





Figure 9.2. Temperature Sensor Error with 1-Point Calibration at 0 Celsius



# 11. Voltage Regulator (REG0)

C8051T610/1/2/3/4/5/6/7 devices include an internal voltage regulator (REG0) to regulate the internal core supply to 1.8 V from a  $V_{DD}$  supply of 1.8 to 3.6 V. Two power-saving modes are built into the regulator to help reduce current consumption in low-power applications. These modes are accessed through the REG0CN register (SFR Definition 11.1). Electrical characteristics for the on-chip regulator are specified in Table 7.5 on page 34

If an external regulator is used to power the device, the internal regulator may be put into bypass mode using the BYPASS bit. The internal regulator should never be placed in bypass mode unless an external 1.8 V regulator is used to supply  $V_{DD}$ . Doing so could cause permanent damage to the device.

Under default conditions, when the device enters STOP mode the internal regulator will remain on. This allows any enabled reset source to generate a reset for the device and bring the device out of STOP mode. For additional power savings, the STOPCF bit can be used to shut down the regulator and the internal power network of the device when the part enters STOP mode. When STOPCF is set to 1, the RST pin or a full power cycle of the device are the only methods of generating a reset.



# 13. CIP-51 Microcontroller

The MCU system controller core is the CIP-51 microcontroller. The CIP-51 is fully compatible with the MCS-51<sup>™</sup> instruction set; standard 803x/805x assemblers and compilers can be used to develop software. The MCU family has a superset of all the peripherals included with a standard 8051. The CIP-51 also includes on-chip debug hardware (see description in Section 27), and interfaces directly with the analog and digital subsystems providing a complete data acquisition or control-system solution in a single integrated circuit.

The CIP-51 Microcontroller core implements the standard 8051 organization and peripherals as well as additional custom peripherals and functions to extend its capability (see Figure 13.1 for a block diagram). The CIP-51 includes the following features:

Fully Compatible with MCS-51 Instruction Set
 25 MIPS Peak Throughput with 25 MHz Clock
 to 25 MHz Clock Frequency
 Extended Interrupt Handler

Reset Input
 Power Management Modes
 On-chip Debug Logic
 Program and Data Memory Security

#### Performance

The CIP-51 employs a pipelined architecture that greatly increases its instruction throughput over the standard 8051 architecture. In a standard 8051, all instructions except for MUL and DIV take 12 or 24 system clock cycles to execute, and usually have a maximum system clock of 12 MHz. By contrast, the CIP-51 core executes 70% of its instructions in one or two system clock cycles, with no instructions taking more than eight system clock cycles.



Figure 13.1. CIP-51 Block Diagram



### 13.2. CIP-51 Register Descriptions

Following are descriptions of SFRs related to the operation of the CIP-51 System Controller. Reserved bits should always be written to the value indicated in the SFR description. Future product versions may use these bits to implement new features in which case the reset value of the bit will be the indicated value, selecting the feature's default state. Detailed descriptions of the remaining SFRs are included in the sections of the data sheet associated with their corresponding system function.

### SFR Definition 13.1. DPL: Data Pointer Low Byte

| Bit   | 7                  | 6           | 5      | 4 | 3 | 2 | 1 | 0 |
|-------|--------------------|-------------|--------|---|---|---|---|---|
| Nam   | e                  | DPL[7:0]    |        |   |   |   |   |   |
| Туре  | •                  | R/W         |        |   |   |   |   |   |
| Rese  | et 0               | 0           | 0      | 0 | 0 | 0 | 0 | 0 |
| SFR A | SFR Address = 0x82 |             |        |   |   |   |   |   |
| Bit   | Name               | ne Function |        |   |   |   |   |   |
| 7:0   | DPL[7:0]           | Data Pointe | r Low. |   |   |   |   |   |

# The DPL register is the low byte of the 16-bit DPTR.

### SFR Definition 13.2. DPH: Data Pointer High Byte

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

| Bit | Name     | Function                                              |  |  |
|-----|----------|-------------------------------------------------------|--|--|
| 7:0 | DPH[7:0] | Data Pointer High.                                    |  |  |
|     |          | The DPH register is the high byte of the 16-bit DPTR. |  |  |



## SFR Definition 13.3. SP: Stack Pointer

| Bit                | 7    | 6       | 5 | 4 | 3                     | 2 | 1 | 0 |  |  |
|--------------------|------|---------|---|---|-----------------------|---|---|---|--|--|
| Nam                | е    | SP[7:0] |   |   |                       |   |   |   |  |  |
| Туре               | 9    | R/W     |   |   |                       |   |   |   |  |  |
| Rese               | et 0 | 0       | 0 | 0 | 0                     | 1 | 1 | 1 |  |  |
| SFR Address = 0x81 |      |         |   |   |                       |   |   |   |  |  |
| Bit                | Name |         |   |   | Name         Function |   |   |   |  |  |

| -   |         |                                                                                                                                                                                |
|-----|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | SP[7:0] | Stack Pointer.                                                                                                                                                                 |
|     |         | The Stack Pointer holds the location of the top of the stack. The stack pointer is incre-<br>mented before every PUSH operation. The SP register defaults to 0x07 after reset. |

## SFR Definition 13.4. ACC: Accumulator

| Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 7             | 6             | 5     | 4 | 3 | 2 | 1 | 0 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|---------------|-------|---|---|---|---|---|
| Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Name ACC[7:0] |               |       |   |   |   |   |   |
| Туре                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R/W           |               |       |   |   |   |   |   |
| Reset         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0 |               |               |       |   |   |   |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | droop - OvE   | 0. Dit Addroc | aabla |   |   |   |   |   |

SFR Address = 0xE0; Bit-Addressable

| Bit | Name     | Function                                                    |
|-----|----------|-------------------------------------------------------------|
| 7:0 | ACC[7:0] | Accumulator.                                                |
|     |          | This register is the accumulator for arithmetic operations. |

### SFR Definition 13.5. B: B Register

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

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

| Bit | Name   | Function                                                                        |
|-----|--------|---------------------------------------------------------------------------------|
| 7:0 | B[7:0] | B Register.                                                                     |
|     |        | This register serves as a second accumulator for certain arithmetic operations. |



### 14.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, RS0 (PSW.3) and RS1 (PSW.4), select the active register bank (see description of the PSW in SFR Definition 13.6). This allows fast context switching when entering subroutines and interrupt service routines. Indirect addressing modes use registers R0 and R1 as index registers.

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

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

#### 14.2.2. External RAM

There are 1024 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. If the MOVX instruction is used with an 8-bit address operand (such as @R1), then the high byte of the 16-bit address is provided by the External Memory Interface Control Register (EMIOCN as shown in SFR Definition 14.1).

For a 16-bit MOVX operation (@DPTR), the upper 7 bits of the 16-bit external data memory address word are "don't cares". As a result, the 1024-byte RAM is 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 0x0400, 0x0800, 0x0C00, 0x1000, etc. This is a useful feature when performing a linear memory fill, as the address pointer doesn't have to be reset when reaching the RAM block boundary.



# **15. Special Function Registers**

The direct-access data memory locations from 0x80 to 0xFF constitute the special function registers (SFRs). The SFRs provide control and data exchange with the C8051T610/1/2/3/4/5/6/7's resources and peripherals. The CIP-51 controller core duplicates the SFRs found in a typical 8051 implementation as well as implementing additional SFRs used to configure and access the sub-systems unique to the C8051T610/1/2/3/4/5/6/7. This allows the addition of new functionality while retaining compatibility with the MCS-51™ instruction set. Table 15.1 lists the SFRs implemented in the C8051T610/1/2/3/4/5/6/7 device family.

The SFR registers are accessed anytime the direct addressing mode is used to access memory locations from 0x80 to 0xFF. SFRs with addresses ending in 0x0 or 0x8 (e.g. P0, TCON, SCON0, IE, etc.) are bitaddressable as well as byte-addressable. All other SFRs are byte-addressable only. Unoccupied addresses in the SFR space are reserved for future use. Accessing these areas will have an indeterminate effect and should be avoided. Refer to the corresponding pages of the data sheet, as indicated in Table 15.2, for a detailed description of each register.

| F8 | SPI0CN            | PCA0L         | PCA0H    | PCA0CPL0 | PCA0CPH0 | PCA0CPL4 | PCA0CPH4 | VDM0CN  |
|----|-------------------|---------------|----------|----------|----------|----------|----------|---------|
| F0 | В                 | POMDIN        | P1MDIN   | P2MDIN   | P3MDIN   |          | EIP1     |         |
| E8 | ADC0CN            | PCA0CPL1      | PCA0CPH1 | PCA0CPL2 | PCA0CPH2 | PCA0CPL3 | PCA0CPH3 | RSTSRC  |
| E0 | ACC               | XBR0          | XBR1     |          | IT01CF   |          | EIE1     |         |
| D8 | PCA0CN            | PCA0MD        | PCA0CPM0 | PCA0CPM1 | PCA0CPM2 | PCA0CPM3 | PCA0CPM4 |         |
| D0 | PSW               | <b>REF0CN</b> |          |          | P0SKIP   | P1SKIP   | P2SKIP   |         |
| C8 | TMR2CN            |               | TMR2RLL  | TMR2RLH  | TMR2L    | TMR2H    |          |         |
| C0 | SMB0CN            | SMB0CF        | SMB0DAT  | ADC0GTL  | ADC0GTH  | ADC0LTL  | ADC0LTH  | REG0CN  |
| B8 | IP                |               |          | AMX0P    | ADC0CF   | ADC0L    | ADC0H    |         |
| B0 | P3                | OSCXCN        | OSCICN   | OSCICL   |          |          |          |         |
| A8 | IE                | CLKSEL        | EMIOCN   |          |          |          |          |         |
| A0 | P2                | SPI0CFG       | SPI0CKR  | SPI0DAT  | POMDOUT  | P1MDOUT  | P2MDOUT  | P3MDOUT |
| 98 | SCON0             | SBUF0         | CPT1CN   | CPT0CN   | CPT1MD   | CPT0MD   | CPT1MX   | CPT0MX  |
| 90 | P1                | TMR3CN        | TMR3RLL  | TMR3RLH  | TMR3L    | TMR3H    |          |         |
| 88 | TCON              | TMOD          | TL0      | TL1      | TH0      | TH1      | CKCON    |         |
| 80 | P0                | SP            | DPL      | DPH      |          | TOFFL    | TOFFH    | PCON    |
|    | 0(8)              | 1(9)          | 2(A)     | 3(B)     | 4(C)     | 5(D)     | 6(E)     | 7(F)    |
|    | (bit addressable) |               |          |          |          |          |          |         |

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

(bit addressable)



# Table 15.2. Special Function Registers (Continued)

| Register | Address | Description                      | Page |
|----------|---------|----------------------------------|------|
| P0SKIP   | 0xD4    | Port 0 Skip                      | 126  |
| P1       | 0x90    | Port 1 Latch                     | 126  |
| P1MDIN   | 0xF2    | Port 1 Input Mode Configuration  | 127  |
| P1MDOUT  | 0xA5    | Port 1 Output Mode Configuration | 127  |
| P1SKIP   | 0xD5    | Port 1 Skip                      | 128  |
| P2       | 0xA0    | Port 2 Latch                     | 128  |
| P2MDIN   | 0xF3    | Port 2 Input Mode Configuration  | 129  |
| P2MDOUT  | 0xA6    | Port 2 Output Mode Configuration | 129  |
| P2SKIP   | 0xD6    | Port 2 Skip                      | 130  |
| P3       | 0xB0    | Port 3 Latch                     | 130  |
| P3MDIN   | 0xF4    | Port 3 Input Mode Configuration  | 131  |
| P3MDOUT  | 0xA7    | Port 3 Output Mode Configuration | 131  |
| PCA0CN   | 0xD8    | PCA Control                      | 203  |
| PCA0CPH0 | 0xFC    | PCA Capture 0 High               | 207  |
| PCA0CPH1 | 0xEA    | PCA Capture 1 High               | 207  |
| PCA0CPH2 | 0xEC    | PCA Capture 2 High               | 207  |
| PCA0CPH3 | 0xEE    | PCA Capture 3 High               | 207  |
| PCA0CPH4 | 0xFE    | PCA Capture 4 High               | 207  |
| PCA0CPL0 | 0xFB    | PCA Capture 0 Low                | 207  |
| PCA0CPL1 | 0xE9    | PCA Capture 1 Low                | 207  |
| PCA0CPL2 | 0xEB    | PCA Capture 2 Low                | 207  |
| PCA0CPL3 | 0xED    | PCA Capture 3 Low                | 207  |
| PCA0CPL4 | 0xFD    | PCA Capture 4 Low                | 207  |
| PCA0CPM0 | 0xDA    | PCA Module 0 Mode Register       | 205  |
| PCA0CPM1 | 0xDB    | PCA Module 1 Mode Register       | 205  |
| PCA0CPM2 | 0xDC    | PCA Module 2 Mode Register       | 205  |
| PCA0CPM3 | 0xDD    | PCA Module 3 Mode Register       | 205  |
| PCA0CPM4 | 0xDE    | PCA Module 4 Mode Register       | 205  |
| PCA0H    | 0xFA    | PCA Counter High                 | 206  |
| PCA0L    | 0xF9    | PCA Counter Low                  | 206  |
| PCA0MD   | 0xD9    | PCA Mode                         | 204  |
| PCON     | 0x87    | Power Control                    | 99   |
| PSW      | 0xD0    | Program Status Word              | 76   |
| REF0CN   | 0xD1    | Voltage Reference Control        | 55   |



# 20. Oscillators and Clock Selection

C8051T610/1/2/3/4/5/6/7 devices include a programmable internal high-frequency oscillator and an external oscillator drive circuit. The internal high-frequency oscillator can be enabled/disabled and calibrated using the OSCICN and OSCICL registers, as shown in Figure 20.1. The system clock can be sourced by the external oscillator circuit or the internal oscillator. The internal oscillator also offers a selectable postscaling feature.



Figure 20.1. Oscillator Options

### 20.1. System Clock Selection

The CLKSL0 bit in register CLKSEL selects which oscillator source is used as the system clock. CLKSL0 must be set to 1 for the system clock to run from the external oscillator; however the external oscillator may still clock certain peripherals (timers, PCA) when the internal oscillator is selected as the system clock. The system clock may be switched on-the-fly between the internal oscillator and external oscillator, so long as the selected clock source is enabled and running.

The internal high-frequency oscillator requires little start-up time and may be selected as the system clock immediately following the register write which enables the oscillator. The external RC and C modes also typically require no startup time.



### SFR Definition 21.14. P2SKIP: Port 2 Skip

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

SFR Address = 0xD6

| Bit   | Name                                                   | Function                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|-------|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7:4   | Unused                                                 | Unused. Read = 0000b; Write = Don't Care.                                                                                                                                                                                                                                                                          |  |  |  |  |  |
| 3:0   | P2SKIP[3:0]                                            | Port 2 Crossbar Skip Enable Bits.                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|       |                                                        | <ul> <li>These bits select Port 2 pins to be skipped by the Crossbar Decoder. Port pins used for analog, special functions or GPIO should be skipped by the Crossbar.</li> <li>0: Corresponding P2.n pin is not skipped by the Crossbar.</li> <li>1: Corresponding P2.n pin is skipped by the Crossbar.</li> </ul> |  |  |  |  |  |
| Note: | Note: Only P2.0-P2.3 are associated with the crossbar. |                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |

## SFR Definition 21.15. P3: Port 3

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

SFR Address = 0xB0; Bit-Addressable

| Bit   | Name                                                                                            | Description                                                                                                                                   | Write                                                                         | Read                                                                    |  |  |
|-------|-------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|-------------------------------------------------------------------------|--|--|
| 7:5   | Unused                                                                                          | Unused. Read = 000b; Write :                                                                                                                  | = Don't Care.                                                                 |                                                                         |  |  |
| 4:0   | P3[4:0]                                                                                         | <b>Port 3 Data.</b><br>Sets the Port latch logic<br>value or reads the Port pin<br>logic state in Port cells con-<br>figured for digital I/O. | 0: Set output latch to logic<br>LOW.<br>1: Set output latch to logic<br>HIGH. | 0: P3.n Port pin is logic<br>LOW.<br>1: P3.n Port pin is logic<br>HIGH. |  |  |
| Note: | ote: P3.1-P3.4 are not connected to external pins on the C8051T611/3/5 and C8051T616/7 devices. |                                                                                                                                               |                                                                               |                                                                         |  |  |



#### 23.2.2. 9-Bit UART

9-bit UART mode uses a total of eleven bits per data byte: a start bit, 8 data bits (LSB first), a programmable ninth data bit, and a stop bit. The state of the ninth transmit data bit is determined by the value in TB80 (SCON0.3), which is assigned by user software. It can be assigned the value of the parity flag (bit P in register PSW) for error detection, or used in multiprocessor communications. On receive, the ninth data bit goes into RB80 (SCON0.2) and the stop bit is ignored.

Data transmission begins when an instruction writes a data byte to the SBUF0 register. The TI0 Transmit Interrupt Flag (SCON0.1) is set at the end of the transmission (the beginning of the stop-bit time). Data reception can begin any time after the REN0 Receive Enable bit (SCON0.4) is set to 1. After the stop bit is received, the data byte will be loaded into the SBUF0 receive register if the following conditions are met: (1) RI0 must be logic 0, and (2) if MCE0 is logic 1, the 9th bit must be logic 1 (when MCE0 is logic 0, the state of the ninth data bit is unimportant). If these conditions are met, the eight bits of data are stored in SBUF0, the ninth bit is stored in RB80, and the RI0 flag is set to 1. If the above conditions are not met, SBUF0 and RB80 will not be loaded and the RI0 flag will not be set to 1. A UART0 interrupt will occur if enabled when either TI0 or RI0 is set to 1.



Figure 23.5. 9-Bit UART Timing Diagram



## SFR Definition 23.1. SCON0: Serial Port 0 Control

| Bit   | 7      | 6 | 5    | 4    | 3    | 2    | 1   | 0   |
|-------|--------|---|------|------|------|------|-----|-----|
| Name  | SOMODE |   | MCE0 | REN0 | TB80 | RB80 | T10 | RI0 |
| Туре  | R/W    | R | R/W  | R/W  | R/W  | R/W  | R/W | R/W |
| Reset | 0      | 1 | 0    | 0    | 0    | 0    | 0   | 0   |

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

| Bit | Name   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | SOMODE | Serial Port 0 Operation Mode.<br>Selects the UART0 Operation Mode.<br>0: 8-bit UART with Variable Baud Rate.<br>1: 9-bit UART with Variable Baud Rate.                                                                                                                                                                                                                                                                                                                                                         |
| 6   | Unused | Unused. Read = 1b, Write = Don't Care.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 5   | MCE0   | <ul> <li>Multiprocessor Communication Enable.</li> <li>The function of this bit is dependent on the Serial Port 0 Operation Mode:</li> <li>Mode 0: Checks for valid stop bit.</li> <li>0: Logic level of stop bit is ignored.</li> <li>1: RI0 will only be activated if stop bit is logic level 1.</li> <li>Mode 1: Multiprocessor Communications Enable.</li> <li>0: Logic level of ninth bit is ignored.</li> <li>1: RI0 is set and an interrupt is generated only when the ninth bit is logic 1.</li> </ul> |
| 4   | REN0   | Receive Enable.<br>0: UART0 reception disabled.<br>1: UART0 reception enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3   | TB80   | Ninth Transmission Bit.<br>The logic level of this bit will be sent as the ninth transmission bit in 9-bit UART Mode<br>(Mode 1). Unused in 8-bit mode (Mode 0).                                                                                                                                                                                                                                                                                                                                               |
| 2   | RB80   | Ninth Receive Bit.<br>RB80 is assigned the value of the STOP bit in Mode 0; it is assigned the value of the<br>9th data bit in Mode 1.                                                                                                                                                                                                                                                                                                                                                                         |
| 1   | TIO    | <b>Transmit Interrupt Flag.</b><br>Set by hardware when a byte of data has been transmitted by UART0 (after the 8th bit in 8-bit UART Mode, or at the beginning of the STOP bit in 9-bit UART Mode). When the UART0 interrupt is enabled, setting this bit causes the CPU to vector to the UART0 interrupt service routine. This bit must be cleared manually by software.                                                                                                                                     |
| 0   | RI0    | <b>Receive Interrupt Flag.</b><br>Set to 1 by hardware when a byte of data has been received by UART0 (set at the STOP bit sampling time). When the UART0 interrupt is enabled, setting this bit to 1 causes the CPU to vector to the UART0 interrupt service routine. This bit must be cleared manually by software.                                                                                                                                                                                          |



### 24.2. SPI0 Master Mode Operation

A SPI master device initiates all data transfers on a SPI bus. SPI0 is placed in master mode by setting the Master Enable flag (MSTEN, SPI0CN.6). Writing a byte of data to the SPI0 data register (SPI0DAT) when in master mode writes to the transmit buffer. If the SPI shift register is empty, the byte in the transmit buffer is moved to the shift register, and a data transfer begins. The SPI0 master immediately shifts out the data serially on the MOSI line while providing the serial clock on SCK. The SPIF (SPI0CN.7) flag is set to logic 1 at the end of the transfer. If interrupts are enabled, an interrupt request is generated when the SPIF flag is set. While the SPI0 master transfers data to a slave on the MOSI line, the addressed SPI slave device simultaneously transfers the contents of its shift register to the SPI master on the MISO line in a full-duplex operation. Therefore, the SPIF flag serves as both a transmit-complete and receive-data-ready flag. The data byte received from the slave is transferred MSB-first into the master's shift register. When a byte is fully shifted into the register, it is moved to the receive buffer where it can be read by the processor by reading SPI0DAT.

When configured as a master, SPI0 can operate in one of three different modes: multi-master mode, 3-wire single-master mode, and 4-wire single-master mode. The default, multi-master mode is active when NSS-MD1 (SPI0CN.3) = 0 and NSSMD0 (SPI0CN.2) = 1. In this mode, NSS is an input to the device, and is used to disable the master SPI0 when another master is accessing the bus. When NSS is pulled low in this mode, MSTEN (SPI0CN.6) and SPIEN (SPI0CN.0) are set to 0 to disable the SPI master device, and a Mode Fault is generated (MODF, SPI0CN.5 = 1). Mode Fault will generate an interrupt if enabled. SPI0 must be manually re-enabled in software under these circumstances. In multi-master systems, devices will typically default to being slave devices while they are not acting as the system master device. In multi-master mode, slave devices can be addressed individually (if needed) using general-purpose I/O pins. Figure 24.2 shows a connection diagram between two master devices in multiple-master mode.

3-wire single-master mode is active when NSSMD1 (SPI0CN.3) = 0 and NSSMD0 (SPI0CN.2) = 0. In this mode, NSS is not used, and is not mapped to an external port pin through the crossbar. Any slave devices that must be addressed in this mode should be selected using general-purpose I/O pins. Figure 24.3 shows a connection diagram between a master device in 3-wire master mode and a slave device.

4-wire single-master mode is active when NSSMD1 (SPI0CN.3) = 1. In this mode, NSS is configured as an output pin, and can be used as a slave-select signal for a single SPI device. In this mode, the output value of NSS is controlled (in software) with the bit NSSMD0 (SPI0CN.2). Additional slave devices can be addressed using general-purpose I/O pins. Figure 24.4 shows a connection diagram for a master device in 4-wire master mode and two slave devices.



Figure 24.2. Multiple-Master Mode Connection Diagram





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





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



## SFR Definition 26.4. PCA0L: PCA Counter/Timer Low Byte

|       | [         |     | [   | [   | [   |     | [   |     |
|-------|-----------|-----|-----|-----|-----|-----|-----|-----|
| Bit   | 7         | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Name  | PCA0[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 | WDTE bit is set to 1, the PCA0L register cannot be modified by software. To change the contents on L register, the Watchdog Timer must first be disabled. |  |  |  |

### SFR Definition 26.5. PCA0H: PCA 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 26.1). |  |  |  |  |
| Note: | When the WDTE bit is set to 1, the PCA0H register cannot be modified by software. To change the contents of the PCA0H register, the Watchdog Timer must first be disabled. |                                                                                                                                                                                                                                                     |  |  |  |  |



# 27. C2 Interface

C8051T610/1/2/3/4/5/6/7 devices include an on-chip Silicon Labs 2-Wire (C2) debug interface to allow EPROM programming and in-system debugging with the production part installed in the end application. The C2 interface operates using only two pins: a bi-directional data signal (C2D), and a clock input (C2CK). See the C2 Interface Specification for details on the C2 protocol.

### 27.1. C2 Interface Registers

The following describes the C2 registers necessary to perform EPROM programming functions through the C2 interface. All C2 registers are accessed through the C2 interface as described in the C2 Interface Specification.

### C2 Register Definition 27.1. C2ADD: C2 Address

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

| Bit                                                                                                                                                                                         | Name       | Function                                                                                                        |          |                                                                                                                                           |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----------------------------------------------------------------------------------------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7:0                                                                                                                                                                                         | C2ADD[7:0] | Write: C2 Address.                                                                                              |          |                                                                                                                                           |  |  |  |  |  |
|                                                                                                                                                                                             |            | Selects the target Data register for C2 Data Read and Data Write commands accord-<br>ing to the following list. |          |                                                                                                                                           |  |  |  |  |  |
|                                                                                                                                                                                             |            | Address                                                                                                         | Name     | e Description                                                                                                                             |  |  |  |  |  |
|                                                                                                                                                                                             |            | 0x00                                                                                                            | DEVICEID | Selects the Device ID Register (read only)                                                                                                |  |  |  |  |  |
|                                                                                                                                                                                             |            | 0x01                                                                                                            | REVID    | Selects the Revision ID Register (read only)                                                                                              |  |  |  |  |  |
|                                                                                                                                                                                             |            | 0x02                                                                                                            | DEVCTL   | Selects the C2 Device Control Register                                                                                                    |  |  |  |  |  |
|                                                                                                                                                                                             |            | 0xDF                                                                                                            | EPCTL    | Selects the C2 EPROM Programming Control Register                                                                                         |  |  |  |  |  |
|                                                                                                                                                                                             |            | 0xBF                                                                                                            | EPDAT    | Selects the C2 EPROM Data Register                                                                                                        |  |  |  |  |  |
|                                                                                                                                                                                             |            | 0xB7                                                                                                            | EPSTAT   | Selects the C2 EPROM Status Register                                                                                                      |  |  |  |  |  |
|                                                                                                                                                                                             |            | 0xAF                                                                                                            | EPADDRH  | H Selects the C2 EPROM Address High Byte Register                                                                                         |  |  |  |  |  |
|                                                                                                                                                                                             |            | 0xAE                                                                                                            | EPADDRL  | Selects the C2 EPROM Address Low Byte Register                                                                                            |  |  |  |  |  |
|                                                                                                                                                                                             |            | 0xA9                                                                                                            | CRC0     | Selects the CRC0 Register                                                                                                                 |  |  |  |  |  |
|                                                                                                                                                                                             |            | 0xAA                                                                                                            | CRC1     | Selects the CRC1 Register                                                                                                                 |  |  |  |  |  |
|                                                                                                                                                                                             |            | 0xAB                                                                                                            | CRC2     | Selects the CRC2 Register                                                                                                                 |  |  |  |  |  |
|                                                                                                                                                                                             |            | 0xAC                                                                                                            | CRC3     | Selects the CRC3 Register                                                                                                                 |  |  |  |  |  |
|                                                                                                                                                                                             |            | Read: C2 Status                                                                                                 |          |                                                                                                                                           |  |  |  |  |  |
| Returns status information on the current programming operation.<br>When the MSB (bit 7) is set to '1', a read or write operation is in progrebits can be ignored by the programming tools. |            |                                                                                                                 |          | tion on the current programming operation.<br>s set to '1', a read or write operation is in progress. All other<br>the programming tools. |  |  |  |  |  |

