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

| Product Status             | Not For New Designs                                               |
|----------------------------|-------------------------------------------------------------------|
| Core Processor             | 8051                                                              |
| Core Size                  | 8-Bit                                                             |
| Speed                      | 25MHz                                                             |
| Connectivity               | CANbus, EBI/EMI, SMBus (2-Wire/I <sup>2</sup> C), SPI, UART/USART |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, Temp Sensor, WDT                |
| Number of I/O              | 59                                                                |
| Program Memory Size        | 64KB (64K x 8)                                                    |
| Program Memory Type        | FLASH                                                             |
| EEPROM Size                | -                                                                 |
| RAM Size                   | 4.25K x 8                                                         |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 3.6V                                                       |
| Data Converters            | A/D 2x16b, 8x10b; D/A 2x12b                                       |
| Oscillator Type            | Internal                                                          |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                 |
| Mounting Type              | Surface Mount                                                     |
| Package / Case             | 100-TQFP                                                          |
| Supplier Device Package    | 100-TQFP (14x14)                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/silicon-labs/c8051f062-gq    |

Email: info@E-XFL.COM

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

|          | 7.2 Programmable Window Datastar                         |                | 07        |
|----------|----------------------------------------------------------|----------------|-----------|
|          | 7.3. Flogrammable Window Detector                        | •••            | 97        |
|          | 7.3.1. Window Detector In Single-Ended Mode              | <br>1          | 99        |
| Q        | DACs 12-Bit Voltage Mode (DAC0 and DAC1 C8051E060/1/2/3) | 1              | 00        |
| 0.       | 8.1 DAC Output Scheduling                                | 1              | 03        |
|          | 8.1.1 Update Output On-Demand                            | 1              | 04        |
|          | 8.1.2. Update Output Based on Timer Overflow             | 1              | 04        |
|          | 8.2 DAC Output Scaling/Justification                     | 1              | 04        |
| ٩        | Voltage Reference 2 (C8051E060/2)                        | 1              | 11        |
| 9.<br>10 | Voltage Reference 2 (C8051F060/2)                        | . I<br>1       | 11<br>12  |
| 11       | Voltage Reference 2 (C8051F061/5) $\frac{1}{100}$        | 1              | 15        |
| 12       | Comparators                                              | 1              | 17        |
| 12       | 12.1 Comparator Inputs                                   | 1              | 10        |
| 12       | CIP-51 Microcontroller                                   | 1              | 23        |
| 15       | 13.1 Instruction Set                                     | . 1.<br>1      | <b>25</b> |
|          | 13.1.1 Instruction and CPU Timing                        | 1              | 25        |
|          | 13.1.2 MOV/X Instruction and Program Memory              | 1              | 25        |
|          | 13.2 Memory Organization                                 | 1              | 20        |
|          | 13.2.1 Program Memory                                    | 1 <sup>.</sup> | 30        |
|          | 13.2.7.1 Togram Memory                                   | 1              | 31        |
|          | 13.2.2. Data Merriory                                    | 1 <sup>.</sup> | 31        |
|          | 13.2.4 Rit Addressable Locations                         | 1              | 31        |
|          | 13 2 5 Stack                                             | 1              | 31        |
|          | 13.2.6 Special Function Registers                        | 1              | 32        |
|          | 13 2 6 1 SFR Paging                                      | 1              | 32        |
|          | 13 2 6 2 Interrupts and SFR Paging                       | 1              | 32        |
|          | 13 2 6 3 SER Page Stack Example                          | 1              | 34        |
|          | 13 2 7 Register Descriptions                             | 1              | 48        |
|          | 13.3 Interrunt Handler                                   | 1              | 51        |
|          | 13.3.1 MCU Interrupt Sources and Vectors                 | 1              | 51        |
|          | 13.3.2.External Interrupts                               | 1              | 51        |
|          | 13.3.3. Interrupt Priorities                             | 1              | 53        |
|          | 13.3.4. Interrupt Latency                                | 1              | 53        |
|          | 13.3.5. Interrupt Register Descriptions                  | 1              | 54        |
|          | 13.4. Power Management Modes                             | 1              | 60        |
|          | 13.4.1.Idle Mode                                         | . 1            | 60        |
|          | 13.4.2.Stop Mode                                         | . 1            | 61        |
| 14       | .Reset Sources                                           | . 1            | 63        |
|          | 14.1.Power-on Reset                                      | 1              | 64        |
|          | 14.2.Power-fail Reset                                    | 1              | 64        |
|          | 14.3.External Reset                                      | . 1            | 64        |
|          | 14.4.Missing Clock Detector Reset                        | 1              | 65        |
|          | 14.5.Comparator0 Reset                                   | 1              | 65        |
|          | 14.6.External CNVSTR2 Pin Reset                          | 1              | 65        |
|          | 14.7.Watchdog Timer Reset                                | 1              | 65        |



### List of Figures

| 1. | System Overview                                             | 19 |
|----|-------------------------------------------------------------|----|
|    | Figure 1.1. C8051F060 / C8051F062 Block Diagram             | 21 |
|    | Figure 1.2. C8051F061 / C8051F063 Block Diagram             | 22 |
|    | Figure 1.3. C8051F064 / C8051F066 Block Diagram             | 23 |
|    | Figure 1.4. C8051F065 / C8051F067 Block Diagram             | 24 |
|    | Figure 1.5. Comparison of Peak MCU Execution Speeds         | 25 |
|    | Figure 1.6. On-Board Clock and Reset                        | 26 |
|    | Figure 1.7. On-Chip Memory Map                              | 27 |
|    | Figure 1.8. Development/In-System Debug Diagram             | 28 |
|    | Figure 1.9. Digital Crossbar Diagram                        | 29 |
|    | Figure 1.10. PCA Block Diagram                              | 30 |
|    | Figure 1.11. CAN Controller Overview                        | 31 |
|    | Figure 1.12. 16-Bit ADC Block Diagram                       | 33 |
|    | Figure 1.13. 10-Bit ADC Diagram                             | 34 |
|    | Figure 1.14. DAC System Block Diagram                       | 35 |
|    | Figure 1.15. Comparator Block Diagram                       | 36 |
| 2. | Absolute Maximum Ratings                                    | 37 |
| 3. | Global DC Electrical Characteristics                        | 38 |
| 4. | Pinout and Package Definitions                              | 39 |
|    | Figure 4.1. C8051F060 / C8051F062 Pinout Diagram (TQFP-100) | 45 |
|    | Figure 4.2. C8051F064 / C8051F066 Pinout Diagram (TQFP-100) | 46 |
|    | Figure 4.3. TQFP-100 Package Drawing                        | 47 |
|    | Figure 4.4. C8051F061 / C8051F063 Pinout Diagram (TQFP-64)  | 48 |
|    | Figure 4.5. C8051F065 / C8051F067 Pinout Diagram (TQFP-64)  | 49 |
|    | Figure 4.6. TQFP-64 Package Drawing                         | 50 |
| 5. | 16-Bit ADCs (ADC0 and ADC1)                                 | 51 |
|    | Figure 5.1. 16-Bit ADC0 and ADC1 Control Path Diagram       | 51 |
|    | Figure 5.2. 16-bit ADC0 and ADC1 Data Path Diagram          | 52 |
|    | Figure 5.3. Voltage Reference Block Diagram                 | 53 |
|    | Figure 5.4. ADC Track and Conversion Example Timing         | 55 |
|    | Figure 5.5. ADC0 and ADC1 Equivalent Input Circuits         | 56 |
|    | Figure 5.6. AMX0SL: AMUX Configuration Register             | 57 |
|    | Figure 5.7. ADC0CF: ADC0 Configuration Register             | 58 |
|    | Figure 5.8. ADC1CF: ADC1 Configuration Register             | 59 |
|    | Figure 5.9. ADC0CN: ADC0 Control Register                   | 60 |
|    | Figure 5.10. ADC1CN: ADC1 Control Register                  | 61 |
|    | Figure 5.11. REF0CN: Reference Control Register 0           | 62 |
|    | Figure 5.12. REF1CN: Reference Control Register 1           | 62 |
|    | Figure 5.13. ADC0H: ADC0 Data Word MSB Register             | 63 |
|    | Figure 5.14. ADC0L: ADC0 Data Word LSB Register             | 63 |
|    | Figure 5.15. ADC0 Data Word Example                         | 64 |
|    | Figure 5.16. ADC1H: ADC1 Data Word MSB Register             | 65 |





Figure 4.6. TQFP-64 Package Drawing





Figure 5.2. 16-bit ADC0 and ADC1 Data Path Diagram

### 5.1. Single-Ended or Differential Operation

ADC0 and ADC1 can be programmed to operate independently as single-ended ADCs, or together to accept a differential input. In single-ended mode, the ADCs can be configured to sample simultaneously, or to use different conversion speeds. In differential mode, ADC1 is a slave to ADC0, and its configuration is based on ADC0 settings, except during offset or gain calibrations. The DIFFSEL bit in the Channel Select Register AMX0SL (Figure 5.6) selects between single-ended and differential mode.

#### 5.1.1. Pseudo-Differential Inputs

The inputs to the ADCs are pseudo-differential. The actual voltage measured by each ADC is equal to the voltage between the AINn pin and the AINnG pin. AINnG must be a DC signal between -0.2 and 0.6 V. In most systems, AINnG will be connected to AGND. If not tied to AGND, the AINnG signal can be used to negate a limited amount of fixed offset, but it is recommended that the internal offset calibration features of the device be used for this purpose. When operating in differential mode, AIN0G and AIN1G should be tied together. AINn must remain above AINnG in both modes for accurate conversion results.



#### 5.2. Voltage Reference

The voltage reference circuitries for ADC0 and ADC1 allow for many different voltage reference configurations. Each ADC has the capability to use its own dedicated, on-chip voltage reference, or an off-chip reference circuit. A block diagram of the reference circuitry for one ADC is shown in Figure 5.3.

The internal voltage reference circuit for each ADC consists of an independent, temperature stable 1.2 V bandgap voltage reference generator, with an output buffer amplifier which multiplies the bandgap reference by 2. The maximum load seen by the VREFn (VREF0 or VREF1) pin must be less than 100  $\mu$ A to AGND. Bypass capacitors of 0.1  $\mu$ F and 47  $\mu$ F are recommended from the VREFn pin to VRGNDn.

The voltage reference circuitry for each ADC is controlled in the Reference Control Registers. REF0CN (defined in Figure 5.11) is the Reference Control Register for ADC1. The REFnCN registers are used to enable/disable the internal reference and bias generator circuitry for each ADC independently. The BIASEn bits enable the on-board bias generators for each ADC, while the REFBEn bits enable the 2x buffer amplifiers which drive the VREFn pins. When disabled, the supply current drawn by the bandgap and buffer amplifier falls to less than 1  $\mu$ A (typical) and the output of the buffer amplifier enters a high impedance state (approximately 25 k Ohms). If the internal voltage reference for an ADC is used, the REFBEn bit should be set to logic 0. Note that the BIASEn bit for an ADC must be set to logic 1 to enable that ADC, regardless of the voltage reference that is used. If an ADC is not being used, the BIASEn bit can be set to logic 0 to conserve power. The electrical specifications for the Voltage References are given in Table 5.3.



Figure 5.3. Voltage Reference Block Diagram



| R/W       | R/W                                                           | R/W                                                                                                                      | R/W                               | R/W                       | R/W           | R/W        | R/W                     | Reset Value     |  |
|-----------|---------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|-----------------------------------|---------------------------|---------------|------------|-------------------------|-----------------|--|
| INCR      | ADCSEL                                                        | CPTR5                                                                                                                    | CPTR4                             | CPTR3                     | CPTR2         | CPTR1      | CPTR0                   | 11010111        |  |
| Bit7      | Bit6                                                          | Bit5                                                                                                                     | Bit4                              | Bit3                      | Bit2          | Bit1       | Bit0                    | _               |  |
|           |                                                               |                                                                                                                          |                                   |                           |               |            | SFR Address<br>SFR Page | :: 0xBA<br>:: F |  |
| Bit 7:    | INCR: Pointe<br>0: Disable Au<br>1: Enable Au<br>write to ADC | er Address<br>uto-Increme<br>ito-Increme                                                                                 | Automatic I<br>ent.<br>nt. CPTR5- | ncrement.<br>0 will autom | natically be  | incremente | d after eac             | h read or       |  |
| Bit 6:    | ADCSEL: AE<br>0: Reads and<br>1: Reads and                    | ADCSEL: ADC Calibration Coefficient Select.<br>0: Reads and Writes of ADC0CCF will access ADC0 Calibration Coefficients. |                                   |                           |               |            |                         |                 |  |
| Bits 5-0: | CPTR5-0: C<br>Select which<br>written.                        | alibration C<br>Calibratior                                                                                              | oefficent Po<br>Coefficien        | binter.<br>t location wi  | ill be access | sed when A | DC0CCF is               | s read or       |  |

#### Figure 5.22. ADC0CPT: ADC Calibration Pointer Register

#### Figure 5.23. ADC0CCF: ADC Calibration Coefficient Register







#### Figure 6.8. DMA0BND: DMA0 Instruction Boundary Register







### 7. 10-Bit ADC (ADC2, C8051F060/1/2/3)

The ADC2 subsystem for the C8051F060/1/2/3 consists of an analog multiplexer (referred to as AMUX2), and a 200 ksps, 10-bit successive-approximation-register ADC with integrated track-and-hold and programmable window detector (see block diagram in Figure 7.1). The AMUX2, data conversion modes, and window detector can all be configured from within software via the Special Function Registers shown in Figure 7.1. ADC2 operates in both Single-ended and Differential modes, and may be configured to measure any of the pins on Port 1, or the Temperature Sensor output. The ADC2 subsystem is enabled only when the AD2EN bit in the ADC2 Control register (ADC2CN) is set to logic 1. The ADC2 subsystem is in low power shutdown when this bit is logic 0.







| A D D R E S S | SFR<br>P<br>A<br>G<br>E | 0(8)                             | 1(9)                       | 2(A)                       | 3(B)                        | 4(C)                       | 5(D)                    | 6(E)                       | 7(F)                    |
|---------------|-------------------------|----------------------------------|----------------------------|----------------------------|-----------------------------|----------------------------|-------------------------|----------------------------|-------------------------|
|               | 0<br>1                  | SPI0CN<br>CAN0CN                 | PCA0L                      | PCA0H                      | PCA0CPL0                    | PCA0CPH0                   | PCA0CPL1                | PCA0CPH1                   | WDTCN                   |
| F8            | 2<br>3<br>F             | DMA0CF<br>P7                     | DMA0CTL                    | DMA0CTH                    | DMA0CSL                     | DMA0CSH                    | DMA0BND                 | DMA0ISW                    | (ALL PAGES)             |
| F0            | 0<br>1<br>2<br>3<br>F   | B<br>(ALL PAGES)                 |                            |                            |                             |                            |                         | EIP1<br><b>(ALL PAGES)</b> | EIP2<br>(ALL PAGES)     |
| E8            | 0<br>1<br>2<br>3<br>F   | ADC0CN<br>ADC1CN<br>ADC2CN<br>P6 | PCA0CPL2                   | PCA0CPH2                   | PCA0CPL3                    | PCA0CPH3                   | PCA0CPL4                | PCA0CPH4                   | RSTSRC                  |
| E0            | 0<br>1<br>2<br>3<br>F   | ACC<br>(ALL PAGES)               | PCA0CPL5                   | PCA0CPH5                   | XBR2                        | XBR3                       |                         | EIE1<br>(ALL PAGES)        | EIE2<br>(ALL PAGES)     |
|               | 0                       | PCA0CN                           | PCA0MD                     | PCA0CPM0                   | PCA0CPM1                    | PCA0CPM2                   | PCA0CPM3                | PCA0CPM4                   | PCA0CPM5                |
| D8            | 2<br>3<br>F             | DMA0CN<br>P5                     | DMA0DAL                    | DMA0DAH                    | DMA0DSL                     | DMA0DSH                    | DMA0IPT                 | DMA0IDT                    |                         |
| D0            | 0<br>1<br>2<br>3<br>F   | PSW<br>(ALL PAGES)               | REF0CN<br>REF1CN<br>REF2CN | DAC0L<br>DAC1L             | DAC0H<br>DAC1H              | DAC0CN<br>DAC1CN           |                         |                            |                         |
| C8            | 0<br>1<br>2<br>3<br>F   | TMR2CN<br>TMR3CN<br>TMR4CN<br>P4 | TMR2CF<br>TMR3CF<br>TMR4CF | RCAP2L<br>RCAP3L<br>RCAP4L | RCAP2H<br>RCAP3H<br>RCAP4H  | TMR2L<br>TMR3L<br>TMR4L    | TMR2H<br>TMR3H<br>TMR4H |                            | SMB0CR                  |
|               | 0<br>1                  | SMB0CN<br>CAN0STA                | SMB0STA                    | SMB0DAT                    | SMB0ADR                     | ADC0GTL                    | ADC0GTH                 | ADC0LTL                    | ADC0LTH                 |
| C0            | 2<br>3<br>F             |                                  |                            |                            |                             | ADC2GTL                    | ADC2GTH                 | ADC2LTL                    | ADC2LTH                 |
| B8            | 0<br>1<br>2<br>3<br>F   | IP<br>(ALL PAGES)                | SADEN0                     | AMX2CF<br>ADC0CPT          | AMX0SL<br>AMX2SL<br>ADC0CCF | ADC0CF<br>ADC1CF<br>ADC2CF |                         | ADC0L<br>ADC1L<br>ADC2L    | ADC0H<br>ADC1H<br>ADC2H |
|               |                         | 0(8)                             | 1(9)                       | 2(A)                       | 3(B)                        | 4(C)                       | 5(D)                    | 6(E)                       | 7(F)                    |

Table 13.2. Special Function Register (SFR) Memory Map



#### 13.3. Interrupt Handler

The CIP-51 includes an extended interrupt system supporting a total of 22 interrupt sources with two priority levels. The allocation of interrupt sources between on-chip peripherals and external inputs pins varies according to the specific version of the device. Each interrupt source has one or more associated interruptpending flag(s) located in an SFR. When a peripheral or external source meets a valid interrupt condition, the associated interrupt-pending flag is set to logic 1.

If interrupts are enabled for the source, an interrupt request is generated when the interrupt-pending flag is set. As soon as execution of the current instruction is complete, the CPU generates an LCALL to a predetermined address to begin execution of an interrupt service routine (ISR). Each ISR must end with an RETI instruction, which returns program execution to the next instruction that would have been executed if the interrupt request had not occurred. If interrupts are not enabled, the interrupt-pending flag is ignored by the hardware and program execution continues as normal. (The interrupt-pending flag is set to logic 1 regard-less of the interrupt's enable/disable state.)

Each interrupt source can be individually enabled or disabled through the use of an associated interrupt enable bit in an SFR (IE-EIE2). However, interrupts must first be globally enabled by setting the EA bit (IE.7) to logic 1 before the individual interrupt enables are recognized. Setting the EA bit to logic 0 disables all interrupt sources regardless of the individual interrupt-enable settings.

Some interrupt-pending flags are automatically cleared by the hardware when the CPU vectors to the ISR. However, most are not cleared by the hardware and must be cleared by software before returning from the ISR. If an interrupt-pending flag remains set after the CPU completes the return-from-interrupt (RETI) instruction, a new interrupt request will be generated immediately and the CPU will re-enter the ISR after the completion of the next instruction.

#### 13.3.1. MCU Interrupt Sources and Vectors

The MCUs support 22 interrupt sources. Software can simulate an interrupt event by setting any interruptpending flag to logic 1. If interrupts are enabled for the flag, an interrupt request will be generated and the CPU will vector to the ISR address associated with the interrupt-pending flag. MCU interrupt sources, associated vector addresses, priority order and control bits are summarized in Table 13.4. Refer to the datasheet section associated with a particular on-chip peripheral for information regarding valid interrupt conditions for the peripheral and the behavior of its interrupt-pending flag(s).

#### 13.3.2. External Interrupts

The external interrupt sources (/INT0 and /INT1) are configurable as active-low level-sensitive or activelow edge-sensitive inputs depending on the setting of bits IT0 (TCON.0) and IT1 (TCON.2). IE0 (TCON.1) and IE1 (TCON.3) serve as the interrupt-pending flag for the /INT0 and /INT1 external interrupts, respectively. If an /INT0 or /INT1 external interrupt is configured as edge-sensitive, the corresponding interruptpending flag is automatically cleared by the hardware when the CPU vectors to the ISR. When configured as level sensitive, the interrupt-pending flag follows the state of the external interrupt's input pin. The external interrupt source must hold the input active until the interrupt request is recognized. It must then deactivate the interrupt request before execution of the ISR completes or another interrupt request will be generated.



### 17.6. Timing

The timing parameters of the External Memory Interface can be configured to enable connection to devices having different setup and hold time requirements. The Address Setup time, Address Hold time, / RD and /WR strobe widths, and in multiplexed mode, the width of the ALE pulse are all programmable in units of SYSCLK periods through EMI0TC, shown in Figure 17.6, and EMI0CF[1:0].

The timing for an off-chip MOVX instruction can be calculated by adding 4 SYSCLK cycles to the timing parameters defined by the EMI0TC register. Assuming non-multiplexed operation, the minimum execution time for an off-chip XRAM operation is 5 SYSCLK cycles (1 SYSCLK for /RD or /WR pulse + 4 SYSCLKs). For multiplexed operations, the Address Latch Enable signal will require a minimum of 2 additional SYSCLK cycles. Therefore, the minimum execution time for an off-chip XRAM operation in multiplexed mode is 7 SYSCLK cycles (2 for /ALE + 1 for /RD or /WR + 4). The programmable setup and hold times default to the maximum delay settings after a reset.

| R/W      | R/W               | R/W         | R/W            | R/W         | R/W         | R/W  | R/W      | Reset Value |
|----------|-------------------|-------------|----------------|-------------|-------------|------|----------|-------------|
| EAS1     | EAS0              | ERW3        | EWR2           | EWR1        | EWR0        | EAH1 | EAH0     | 11111111    |
| Bit7     | Bit6              | Bit5        | Bit4           | Bit3        | Bit2        | Bit1 | Bit0     |             |
|          | SFR Address: 0xA1 |             |                |             |             |      | :: 0xA1  |             |
|          |                   |             |                |             |             |      | SFR Page | e: 0        |
| Rite7-6. | EAS1-0. EM        | IF Address  | Setup Time     | Rite        |             |      |          |             |
| Dit37 0. | 00: Address       | setup time  | = 0.SYSCI      | K cycles    |             |      |          |             |
|          | 01: Address       | setup time  | = 1  SYSCL     | K cycle.    |             |      |          |             |
|          | 10: Address       | setup time  | = 2 SYSCL      | K cycles.   |             |      |          |             |
|          | 11: Address       | setup time  | = 3 SYSCL      | K cýcles.   |             |      |          |             |
| Bits5-2: | EWR3-0: EN        | /IF /WR an  | d /RD Pulse    | e-Width Cor | ntrol Bits. |      |          |             |
|          | 0000: /WR a       | nd /RD pul  | se width = 1   | SYSCLK      | cycle.      |      |          |             |
|          | 0001: /WR a       | nd /RD pul  | se width = 2   | 2 SYSCLK (  | cycles.     |      |          |             |
|          | 0010: /WR a       | nd /RD pul  | se width = 3   | B SYSCLK (  | cycles.     |      |          |             |
|          | 0011: /WR a       | nd /RD put  | se width = $4$ |             | ycles.      |      |          |             |
|          | 0100: /WR a       | na /RD pui: | se width = 5   |             | cycles.     |      |          |             |
|          | 0101./WR a        | nd /RD puls | se width = 7   |             | ycles.      |      |          |             |
|          | 0110.7WR a        | nd /RD puik | se width – 8   | SYSCIK      | vcles.      |      |          |             |
|          | 1000: /WR a       | nd /RD pul  | se width = $9$ | SYSCLK (    | vcles.      |      |          |             |
|          | 1001: /WR a       | nd /RD pul  | se width = 1   | 0 SYSCLK    | cycles.     |      |          |             |
|          | 1010: /WR a       | nd /RD pul  | se width = 1   | 1 SYSCLK    | cycles.     |      |          |             |
|          | 1011: /WR a       | nd /RD puls | se width = 1   | 2 SYSCLK    | cycles.     |      |          |             |
|          | 1100: /WR a       | nd /RD puls | se width = 1   | 3 SYSCLK    | cycles.     |      |          |             |
|          | 1101: /WR a       | nd /RD puls | se width = 1   | 4 SYSCLK    | cycles.     |      |          |             |
|          | 1110: /WR a       | nd /RD puls | se width = $1$ | 5 SYSCLK    | cycles.     |      |          |             |
|          | 1111: /WR ai      | nd /RD puls | se width = 1   | 6 SYSCLK    | cycles.     |      |          |             |
| Bits1-0: | EAH1-0: EM        | IF Address  | Hold Lime      | Bits.       |             |      |          |             |
|          | 00: Address       | hold time = | 1 SYSCLA       | Cycles.     |             |      |          |             |
|          | 10. Address       | hold time - | 2 SYSCI k      | Coveles     |             |      |          |             |
|          | 11: Address       | hold time = | 3 SYSCI K      | cvcles.     |             |      |          |             |
|          |                   |             | C C COEN       |             |             |      |          |             |

#### Figure 17.6. EMI0TC: External Memory Timing Control



### 18. Port Input/Output

The C8051F06x family of devices are fully integrated mixed-signal System on a Chip MCUs with 59 digital I/O pins (C8051F060/2/4/6) or 24 digital I/O pins (C8051F061/3/5/7), organized as 8-bit Ports. All ports are both bit- and byte-addressable through their corresponding Port Data registers. All Port pins support configurable Open-Drain or Push-Pull output modes and weak pull-ups. Additionally, Port 0 pins are 5 V-tolerant. A block diagram of the Port I/O cell is shown in Figure 18.1. Complete Electrical Specifications for the Port I/O pins are given in Table 18.1.





#### Table 18.1. Port I/O DC Electrical Characteristics

VDD = 2.7 to 3.6 V, -40 to +85 °C unless otherwise specified.

| Parameter                                 | Conditions                                                                                  | Min                    | Тур | Max        | Units    |
|-------------------------------------------|---------------------------------------------------------------------------------------------|------------------------|-----|------------|----------|
| Output High Voltage<br>(V <sub>OH</sub> ) | I <sub>OH</sub> = -3 mA, Port I/O Push-Pull<br>I <sub>OH</sub> = -10 μA, Port I/O Push-Pull | VDD - 0.7<br>VDD - 0.1 |     |            | V        |
| Output Low Voltage<br>(V <sub>OL</sub> )  | I <sub>OL</sub> = 8.5 mA<br>I <sub>OL</sub> = 10 μA                                         |                        |     | 0.6<br>0.1 | V        |
| Input High Voltage (VIH)                  |                                                                                             | 0.7 x VDD              |     |            |          |
| Input Low Voltage (VIL)                   |                                                                                             |                        |     | 0.3 x VDD  |          |
| Input Leakage Current                     | DGND < Port Pin < VDD, Pin Tri-state<br>Weak Pull-up Off<br>Weak Pull-up On                 |                        | 10  | ± 1        | μA<br>μA |
| Input Capacitance                         |                                                                                             |                        | 5   |            | pF       |



#### 20.3.3. Slave Transmitter Mode

Serial data is transmitted on SDA while the serial clock is received on SCL. The SMBus0 interface receives a START followed by data byte containing the slave address and direction bit. If the received slave address matches the address held in register SMB0ADR, the SMBus0 interface generates an ACK. SMBus0 will also ACK if the general call address (0x00) is received and the General Call Address Enable bit (SMB0ADR.0) is set to logic 1. In this case the data direction bit (R/W) will be logic 1 to indicate a "READ" operation. The SMBus0 interface receives the clock on SCL and transmits one or more bytes of serial data, waiting for an ACK from the master after each byte. SMBus0 exits slave mode after receiving a STOP condition from the master.



Figure 20.6. Typical Slave Transmitter Sequence

#### 20.3.4. Slave Receiver Mode

Serial data is received on SDA while the serial clock is received on SCL. The SMBus0 interface receives a START followed by data byte containing the slave address and direction bit. If the received slave address matches the address held in register SMB0ADR, the interface generates an ACK. SMBus0 will also ACK if the general call address (0x00) is received and the General Call Address Enable bit (SMB0ADR.0) is set to logic 1. In this case the data direction bit (R/W) will be logic 0 to indicate a "WRITE" operation. The SMBus0 interface receives one or more bytes of serial data; after each byte is received, the interface transmits an ACK or NACK depending on the state of the AA bit in SMB0CN. SMBus0 exits Slave Receiver



### 21.5. Serial Clock Timing

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

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



#### 22.1.3. Mode 2: 9-Bit UART, Fixed Baud Rate

Mode 2 provides asynchronous, full-duplex communication using 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. Mode 2 supports multiprocessor communications and hardware address recognition (see Section 22.2). On transmit, the ninth data bit is determined by the value in TB80 (SCON0.3). It can be assigned the value of the parity flag P in the PSW 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 logic 1. After the stop bit is received, the data byte will be loaded into the SBUF0 receive register if RI0 is logic 0 and one of the following requirements are met:

- 1. SM20 is logic 0
- 2. SM20 is logic 1, the received 9th bit is logic 1, and the received address matches the UART0 address as described in Section 22.2.

If the above conditions are satisfied, the eight bits of data are stored in SBUF0, the ninth bit is stored in RB80 and the RI0 flag is set. If these conditions are not met, SBUF0 and RB80 will not be loaded and the RI0 flag will not be set. An interrupt will occur if enabled when either TI0 or RI0 are set.

The baud rate in Mode 2 is either SYSCLK / 32 or SYSCLK / 64, according to the value of the SMOD0 bit in register SSTA0.

#### Equation 22.5. Mode 2 Baud Rate

$$BaudRate = 2^{SMOD0} \times \left(\frac{SYSCLK}{64}\right)$$



#### Figure 22.5. UART0 Modes 2 and 3 Timing Diagram



#### 22.2. Multiprocessor Communications

Modes 2 and 3 support multiprocessor communication between a master processor and one or more slave processors by special use of the ninth data bit and the built-in UART0 address recognition hardware. When a master processor wants to transmit to one or more slaves, it first sends an address byte to select the target(s). An address byte differs from a data byte in that its ninth bit is logic 1; in a data byte, the ninth bit is always set to logic 0. UART0 will recognize as "valid" (i.e., capable of causing an interrupt) **two** types of addresses: (1) a *masked* address and (2) a *broadcast* address **at any given time**. Both are described below.

#### 22.2.1. Configuration of a Masked Address

The UART0 address is configured via two SFRs: SADDR0 (Serial Address) and SADEN0 (Serial Address Enable). SADEN0 sets the bit mask for the address held in SADDR0: bits set to logic 1 in SADEN0 correspond to bits in SADDR0 that are checked against the received address byte; bits set to logic 0 in SADEN0 correspond to "don't care" bits in SADDR0.

| Example 1, S  | LAVE #1    | Example 2, S  | LAVE #2    | Example 3, S  | LAVE #3    |
|---------------|------------|---------------|------------|---------------|------------|
| SADDR0        | = 00110101 | SADDR0        | = 00110101 | SADDR0        | = 00110101 |
| SADEN0        | = 00001111 | SADEN0        | = 11110011 | SADEN0        | = 11000000 |
| UART0 Address | = xxxx0101 | UART0 Address | = 0011xx01 | UART0 Address | = 00xxxxxx |

Setting the SM20 bit (SCON0.5) configures UART0 such that when a stop bit is received, UART0 will generate an interrupt only if the ninth bit is logic 1 (RB80 = '1') and the received data byte matches the UART0 slave address. Following the received address interrupt, the slave will clear its SM20 bit to enable interrupts on the reception of the following data byte(s). Once the entire message is received, the addressed slave resets its SM20 bit to ignore all transmissions until it receives the next address byte. While SM20 is logic 1, UART0 ignores all bytes that do not match the UART0 address and include a ninth bit that is logic 1.

#### 22.2.2. Broadcast Addressing

Multiple addresses can be assigned to a single slave and/or a single address can be assigned to multiple slaves, thereby enabling "broadcast" transmissions to more than one slave simultaneously. The broadcast address is the logical OR of registers SADDR0 and SADEN0, and '0's of the result are treated as "don't cares". Typically a broadcast address of 0xFF (hexadecimal) is acknowledged by all slaves, assuming "don't care" bits as '1's. The master processor can be configured to receive all transmissions or a protocol can be implemented such that the master/slave role is temporarily reversed to enable half-duplex transmission between the original master and slave(s)..

| Example 4, SLAVE #1  |            | Example 5,           | SLAVE #2   | Example 6, SLAVE #3  |            |  |
|----------------------|------------|----------------------|------------|----------------------|------------|--|
| SADDR0               | = 00110101 | SADDR0               | = 00110101 | SADDR0               | = 00110101 |  |
| SADEN0               | = 00001111 | SADEN0               | = 11110011 | SADEN0               | = 11000000 |  |
| Broadcast<br>Address | = 00111111 | Broadcast<br>Address | = 11110111 | Broadcast<br>Address | = 11110101 |  |

Where all ZEROES in the Broadcast address are don't cares.

Note in the above examples 4, 5, and 6, each slave would recognize as "valid" an address of 0xFF as a broadcast address. Also note that examples 4, 5, and 6 uses the same SADDR0 and SADEN0 register values as shown in the examples 1, 2, and 3 respectively (slaves #1, 2, and 3). Thus, a master could address each slave device individually using a masked address, and also broadcast to all three slave devices. For example, if a Master were to send an address "11110101", only slave #1 would recognize the



address as valid. If a master were to then send an address of "11111111", all three slave devices would recognize the address as a valid broadcast address.





#### 22.3. Frame and Transmission Error Detection

#### All Modes:

The Transmit Collision bit (TXCOL0 bit in register SCON0) reads '1' if user software writes data to the SBUF0 register while a transmit is in progress. Note that the TXCOL0 bit is also used as the SM20 bit when written by user software. This bit does not generate an interrupt.

#### Modes 1, 2, and 3:

The Receive Overrun bit (RXOV0 in register SCON0) reads '1' if a new data byte is latched into the receive buffer before software has read the previous byte. Note that the RXOV0 bit is also used as the SM10 bit when written by user software. The Frame Error bit (FE0 in register SSTA0) reads '1' if an invalid (low) STOP bit is detected. Note that the FE0 bit is also used as the SM00 bit when written by user software. The RXOV0 and FE0 bits do not generate interrupts.



#### 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 TB81 (SCON1.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 RB81 (SCON1.2) and the stop bit is ignored.

Data transmission begins when an instruction writes a data byte to the SBUF1 register. The TI1 Transmit Interrupt Flag (SCON1.1) is set at the end of the transmission (the beginning of the stop-bit time). Data reception can begin any time after the REN1 Receive Enable bit (SCON1.4) is set to '1'. After the stop bit is received, the data byte will be loaded into the SBUF1 receive register if the following conditions are met: (1) RI1 must be logic 0, and (2) if MCE1 is logic 1, the 9th bit must be logic 1 (when MCE1 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 SBUF1, the ninth bit is stored in RB81, and the RI1 flag is set to '1'. A UART1 interrupt will occur if enabled when either TI1 or RI1 is set to '1'.







| R/W            | R/W                                                                                                                                                                                                                                                                                                                                                                                | R/W                                                      | R/W                                                           | R/W                                          | R/W                                          | R/W                                        | R/W                                        | Reset Value                                |  |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------|----------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--|
| S1MOD          | = -                                                                                                                                                                                                                                                                                                                                                                                | MCE1                                                     | REN1                                                          | TB81                                         | RB81                                         | TI1                                        | RI1                                        | 01000000                                   |  |
| Bit7           | Bit6                                                                                                                                                                                                                                                                                                                                                                               | Bit5                                                     | Bit4                                                          | Bit3                                         | Bit2                                         | Bit1                                       | Bit0                                       | Bit<br>Addressable                         |  |
|                |                                                                                                                                                                                                                                                                                                                                                                                    |                                                          |                                                               |                                              |                                              |                                            | SFR Addres<br>SFR Page                     | s: 0x98<br>e: 1                            |  |
| Bit7:          | S1MODE: Serial Port 1 Operation Mode.<br>This bit selects the UART1 Operation Mode.<br>0: 8-bit UART with Variable Baud Rate.                                                                                                                                                                                                                                                      |                                                          |                                                               |                                              |                                              |                                            |                                            |                                            |  |
| Bit6:<br>Bit5: | 1: 9-bit UART with Variable Baud Rate.<br>UNUSED. Read = 1b. Write = don't care.<br>MCE1: Multiprocessor Communication Enable.<br>The function of this bit is dependent on the Serial Port 0 Operation Mode.<br>S1MODE = 0: Checks for valid stop bit.<br>0: Logic level of stop bit is ignored.                                                                                   |                                                          |                                                               |                                              |                                              |                                            |                                            |                                            |  |
|                | S1MODE =<br>0: Lo<br>1: R                                                                                                                                                                                                                                                                                                                                                          | 1: Multiproc<br>ogic level of<br>I1 is set and           | e activated<br>essor Com<br>f ninth bit is<br>d an interru    | munications<br>ignored.<br>pt is genera      | s Enable.<br>ted only wh                     | en the nint                                | h bit is logi                              | c 1.                                       |  |
| Bit4:          | REN1: Rece<br>This bit enab<br>0: UART1 re<br>1: UART1 re                                                                                                                                                                                                                                                                                                                          | ive Enable<br>bles/disable<br>ception dis<br>ception ena | s the UART<br>abled.<br>abled.                                | receiver.                                    |                                              |                                            |                                            |                                            |  |
| Bit3:          | TB81: Ninth<br>The logic lev<br>is not used in                                                                                                                                                                                                                                                                                                                                     | Transmissi<br>rel of this bi<br>n 8-bit UAR              | on Bit.<br>t will be ass<br>T Mode. S                         | igned to the<br>Set or cleare                | e ninth trans<br>ed by softwa                | mission bit<br>ire as requi                | in 9-bit UA<br>ired.                       | RT Mode. It                                |  |
| Bit2:          | RB81: Ninth<br>RB81 is assi<br>data bit in M                                                                                                                                                                                                                                                                                                                                       | Receive Bi<br>igned the va<br>ode 1.                     | t.<br>alue of the S                                           | STOP bit in                                  | Mode 0; it i                                 | s assigned                                 | the value o                                | of the 9th                                 |  |
| Bit1:          | TI1: Transmit Interrupt Flag.<br>Set by hardware when a byte of data has been transmitted by UART1 (after the 8th bit in 8-<br>bit UART Mode, or at the beginning of the STOP bit in 9-bit UART Mode). When the UART1<br>interrupt is enabled, setting this bit causes the CPU to vector to the UART1 interrupt service<br>routine. This bit must be cleared manually by software. |                                                          |                                                               |                                              |                                              |                                            |                                            |                                            |  |
| Bit0:          | RI1: Receive<br>Set to '1' by<br>sampling tim<br>to vector to t<br>ware.                                                                                                                                                                                                                                                                                                           | e Interrupt F<br>hardware w<br>ie). When tl<br>he UART1  | <sup>-</sup> lag.<br>hen a byte<br>he UART1 i<br>interrupt se | of data has<br>nterrupt is e<br>rvice routin | been receiv<br>enabled, set<br>e. This bit m | ed by UAR<br>ting this bit<br>nust be clea | T1 (set at th<br>to '1' caus<br>ared manua | ne STOP bit<br>es the CPU<br>ally by soft- |  |

#### Figure 23.7. SCON1: Serial Port 1 Control Register



### 25.1. PCA Counter/Timer

The 16-bit PCA counter/timer consists of two 8-bit SFRs: PCA0L and PCA0H. PCA0H is the high byte (MSB) of the 16-bit counter/timer and PCA0L is the low byte (LSB). Reading PCA0L automatically latches the value of PCA0H into a "snapshot" register; the following PCA0H read accesses this "snapshot" register. Reading the PCA0L Register first guarantees an accurate reading of the entire 16-bit PCA0 counter. Reading PCA0H or PCA0L does not disturb the counter operation. The CPS2-CPS0 bits in the PCA0MD register select the timebase for the counter/timer as shown in Table 25.1.

When the counter/timer overflows from 0xFFFF to 0x0000, the Counter Overflow Flag (CF) in PCA0MD is set to logic 1 and an interrupt request is generated if CF interrupts are enabled. Setting the ECF bit in PCA0MD to logic 1 enables the CF flag to generate an interrupt request. The CF bit is not automatically cleared by hardware when the CPU vectors to the interrupt service routine, and must be cleared by software (Note: PCA0 interrupts must be globally enabled before CF interrupts are recognized. PCA0 interrupts are globally enabled by setting the EA bit (IE.7) and the EPCA0 bit in EIE1 to logic 1). Clearing the CIDL bit in the PCA0MD register allows the PCA to continue normal operation while the CPU is in Idle mode.

| CPS2 | CPS1 | CPS0 | Timebase                                                                 |
|------|------|------|--------------------------------------------------------------------------|
| 0    | 0    | 0    | System clock divided by 12                                               |
| 0    | 0    | 1    | System clock divided by 4                                                |
| 0    | 1    | 0    | Timer 0 overflow                                                         |
| 0    | 1    | 1    | High-to-low transitions on ECI (max rate = system clock divided by 4)    |
| 1    | 0    | 0    | System clock                                                             |
| 1    | 0    | 1    | External oscillator source divided by 8 (synchronized with system clock) |

#### Figure 25.2. PCA Counter/Timer Block Diagram



