

Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Active                                                          |
|----------------------------|-----------------------------------------------------------------|
| Core Processor             | 8051                                                            |
| Core Size                  | 8-Bit                                                           |
| Speed                      | 50MHz                                                           |
| Connectivity               | SMBus (2-Wire/I <sup>2</sup> C), LINbus, SPI, UART/USART        |
| Peripherals                | POR, PWM, Temp Sensor, WDT                                      |
| Number of I/O              | 18                                                              |
| Program Memory Size        | 32KB (32K x 8)                                                  |
| Program Memory Type        | FLASH                                                           |
| EEPROM Size                | -                                                               |
| RAM Size                   | 2.25K x 8                                                       |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 5.25V                                                    |
| Data Converters            | A/D 18x12b                                                      |
| Oscillator Type            | Internal                                                        |
| Operating Temperature      | -40°C ~ 125°C (TA)                                              |
| Mounting Type              | Surface Mount                                                   |
| Package / Case             | 24-WFQFN Exposed Pad                                            |
| Supplier Device Package    | 24-QFN (4x4)                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/silicon-labs/c8051f552-imr |

Email: info@E-XFL.COM

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

| 17.6. Timina                                                                | 151 |
|-----------------------------------------------------------------------------|-----|
| 17.6.1. Multiplexed Mode                                                    | 153 |
| 18. Oscillators and Clock Selection                                         | 157 |
| 18.1. System Clock Selection                                                | 157 |
| 18.2. Programmable Internal Oscillator                                      | 159 |
| 18.2.1. Internal Oscillator Suspend Mode                                    | 159 |
| 18.3. Clock Multiplier                                                      | 162 |
| 18.4. External Oscillator Drive Circuit                                     | 164 |
| 18.4.1. External Crystal Example                                            | 166 |
| 18.4.2. External RC Example                                                 | 167 |
| 18.4.3. External Capacitor Example                                          | 167 |
| 19. Port Input/Output                                                       | 169 |
| 19.1. Port I/O Modes of Operation                                           | 170 |
| 19.1.1. Port Pins Configured for Analog I/O                                 | 170 |
| 19.1.2. Port Pins Configured For Digital I/O                                | 170 |
| 19.1.3. Interfacing Port I/O in a Multi-Voltage System                      | 171 |
| 19.2. Assigning Port I/O Pins to Analog and Digital Functions.              | 171 |
| 19.2.1. Assigning Port I/O Pins to Analog Functions                         | 171 |
| 19.2.2. Assigning Port I/O Pins to Digital Functions                        | 171 |
| 19.2.3. Assigning Port I/O Pins to External Digital Event Capture Functions | 172 |
| 19.3. Priority Crossbar Decoder                                             | 172 |
| 19.4. Port I/O Initialization                                               | 174 |
| 19.5. Port Match                                                            | 179 |
| 19.6. Special Function Registers for Accessing and Configuring Port I/O     | 183 |
| 20. Local Interconnect Network (LIN0)                                       | 193 |
| 20.1. Software Interface with the LIN Controller                            | 194 |
| 20.2. LIN Interface Setup and Operation                                     | 194 |
| 20.2.1. Mode Definition                                                     | 194 |
| 20.2.2. Baud Rate Options: Manual or Autobaud                               | 194 |
| 20.2.3. Baud Rate Calculations: Manual Mode                                 | 194 |
| 20.2.4. Baud Rate Calculations—Automatic Mode                               | 196 |
| 20.3. LIN Master Mode Operation                                             | 197 |
| 20.4. LIN Slave Mode Operation                                              | 198 |
| 20.5. Sleep Mode and Wake-Up                                                | 199 |
| 20.6. Error Detection and Handling                                          | 199 |
| 20.7. LIN Registers                                                         | 200 |
| 20.7.1. LIN Direct Access SFR Registers Definitions                         | 200 |
| 20.7.2. LIN Indirect Access SFR Registers Definitions                       | 202 |
| 21. Controller Area Network (CAN0)                                          | 210 |
| 21.1. Bosch CAN Controller Operation                                        | 211 |
| 21.1.1. CAN Controller Timing                                               | 211 |
| 21.1.2. CAN Register Access                                                 | 212 |
| 21.1.3. Example Timing Calculation for 1 Mbit/Sec Communication             | 212 |
| 21.2. CAN Registers                                                         | 214 |
| 21.2.1. CAN Controller Protocol Registers                                   | 214 |



| Figure 25.1 TO Mode 0 Block Diagram                                 | 262 |
|---------------------------------------------------------------------|-----|
| Figure 25.2. To Mode 2 Block Diagram                                | 202 |
| Figure 25.2. TO Mode 2 Block Diagram                                | 203 |
|                                                                     | 204 |
| Figure 25.4. Timer 2 16-Bit Mode Block Diagram                      | 269 |
| Figure 25.5. Timer 2 8-Bit Mode Block Diagram                       | 270 |
| Figure 25.6. Timer 2 External Oscillator Capture Mode Block Diagram | 271 |
| Figure 25.7. Timer 3 16-Bit Mode Block Diagram                      | 275 |
| Figure 25.8. Timer 3 8-Bit Mode Block Diagram                       | 276 |
| Figure 25.9. Timer 3 External Oscillator Capture Mode Block Diagram | 277 |
| Figure 26.1. PCA Block Diagram                                      | 281 |
| Figure 26.2. PCA Counter/Timer Block Diagram                        | 282 |
| Figure 26.3. PCA Interrupt Block Diagram                            | 283 |
| Figure 26.4. PCA Capture Mode Diagram                               | 285 |
| Figure 26.5. PCA Software Timer Mode Diagram                        | 286 |
| Figure 26.6. PCA High-Speed Output Mode Diagram                     | 287 |
| Figure 26.7. PCA Frequency Output Mode                              | 288 |
| Figure 26.8. PCA 8-Bit PWM Mode Diagram                             | 289 |
| Figure 26.9. PCA 9, 10 and 11-Bit PWM Mode Diagram                  | 290 |
| Figure 26.10. PCA 16-Bit PWM Mode                                   | 291 |
| Figure 26.11. PCA Module 2 with Watchdog Timer Enabled              | 292 |
| Figure 27.1. Typical C2 Pin Sharing                                 | 303 |

#### Table 5.6. Internal High-Frequency Oscillator Electrical Characteristics

V<sub>DD</sub> = 1.8 to 2.75 V, -40 to +125 °C unless otherwise specified; Using factory-calibrated settings.

| Parameter                                                     | Conditions                                                | Min              | Тур             | Max       | Units                         |
|---------------------------------------------------------------|-----------------------------------------------------------|------------------|-----------------|-----------|-------------------------------|
| Oscillator Frequency                                          | IFCN = 111b; $24 - 0.5\%$ VDD $\geq$ VREGMIN <sup>1</sup> |                  | 24 <sup>2</sup> | 24 + 0.5% | MHz                           |
|                                                               | IFCN = 111b;<br>VDD < VREGMIN <sup>1</sup>                | 24 – 1.0%        | 24 <sup>2</sup> | 24 + 1.0% |                               |
| Oscillator Supply Current<br>(from V <sub>DD</sub> )          | Internal Oscillator On<br>OSCICN[7:6] = 11b               | _                | 880             | 1300      | μA                            |
| Internal Oscillator Suspend<br>OSCICN[7:6] = 00b<br>ZTCEN = 1 | Temp = 25 °C<br>Temp = 85 °C<br>Temp = 125 °C             |                  | 67<br>90<br>130 | _         |                               |
| Wake-up Time From Suspend                                     | OSCICN[7:6] = 00b                                         | —                | 1               | —         | μs                            |
| Power Supply Sensitivity                                      | Constant Temperature                                      | —                | 0.11            | —         | %/V                           |
| Temperature Sensitivity <sup>3</sup>                          | Constant Supply<br>TC <sub>1</sub><br>TC <sub>2</sub>     |                  | 5.0<br>0.65     |           | ppm/°C<br>ppm/°C <sup>2</sup> |
| 1 VREGMIN is the minimum                                      | output of the voltage regulator for                       | r its low settin | REGO            |           | = 0h See                      |

 VREGMIN is the minimum output of the voltage regulator for its low setting (REG0CN: REG0MD = 0b). See Table 5.8, "Voltage Regulator Electrical Characteristics," on page 43.

2. This is the average frequency across the operating temperature range

3. Use temperature coefficients TC<sub>1</sub> and TC<sub>2</sub> to calculate the new internal oscillator frequency using the following equation:

 $f(T) = f0 x (1 + TC_1 x (T - T0) + TC_2 x (T - T0)^2)$ 

where f0 is the internal oscillator frequency at 25 °C and T0 is 25 °C.



#### 6.1. Modes of Operation

In a typical system, ADC0 is configured using the following steps:

- 1. If a gain adjustment is required, refer to Section "6.3. Selectable Gain" on page 53.
- 2. Choose the start of conversion source.
- 3. Choose Normal Mode or Burst Mode operation.
- 4. If Burst Mode, choose the ADC0 Idle Power State and set the Power-up Time.
- 5. Choose the tracking mode. Note that Pre-Tracking Mode can only be used with Normal Mode.
- 6. Calculate the required settling time and set the post convert-start tracking time using the AD0TK bits.
- 7. Choose the repeat count.
- 8. Choose the output word justification (Right-Justified or Left-Justified).
- 9. Enable or disable the End of Conversion and Window Comparator Interrupts.

#### 6.1.1. Starting a Conversion

A conversion can be initiated in one of four ways, depending on the programmed states of the ADC0 Start of Conversion Mode bits (AD0CM1–0) in register ADC0CN. Conversions may be initiated by one of the following:

- Writing a 1 to the AD0BUSY bit of register ADC0CN
- A rising edge on the CNVSTR input signal (pin P0.1)
- A Timer 1 overflow (i.e., timed continuous conversions)
- A Timer 2 overflow (i.e., timed continuous conversions)

Writing a 1 to AD0BUSY provides software control of ADC0 whereby conversions are performed "ondemand." During conversion, the AD0BUSY bit is set to logic 1 and reset to logic 0 when the conversion is complete. The falling edge of AD0BUSY triggers an interrupt (when enabled) and sets the ADC0 interrupt flag (AD0INT). Note: When polling for ADC conversion completions, the ADC0 interrupt flag (AD0INT) should be used. Converted data is available in the ADC0 data registers, ADC0H:ADC0L, when bit AD0INT is logic 1. Note that when Timer 2 overflows are used as the conversion source, Low Byte overflows are used if Timer2 is in 8-bit mode; High byte overflows are used if Timer 2 is in 16-bit mode. See Section "25. Timers" on page 259 for timer configuration.

**Important Note About Using CNVSTR:** The CNVSTR input pin also functions as Port pin P0.1. When the CNVSTR input is used as the ADC0 conversion source, Port pin P0.1 should be skipped by the Digital Crossbar. To configure the Crossbar to skip P0.1, set to 1 Bit1 in register P0SKIP. See Section "19. Port Input/Output" on page 169 for details on Port I/O configuration.

#### 6.1.2. Tracking Modes

Each ADC0 conversion must be preceded by a minimum tracking time for the converted result to be accurate. ADC0 has three tracking modes: Pre-Tracking, Post-Tracking, and Dual-Tracking. Pre-Tracking Mode provides the minimum delay between the convert start signal and end of conversion by tracking continuously before the convert start signal. This mode requires software management in order to meet minimum tracking requirements. In Post-Tracking Mode, a programmable tracking time starts after the convert start signal and is managed by hardware. Dual-Tracking Mode maximizes tracking time by tracking before and after the convert start signal. Figure 6.2 shows examples of the three tracking modes.

Pre-Tracking Mode is selected when AD0TM is set to 10b. Conversions are started immediately following the convert start signal. ADC0 is tracking continuously when not performing a conversion. Software must allow at least the minimum tracking time between each end of conversion and the next convert start signal. The minimum tracking time must also be met prior to the first convert start signal after ADC0 is enabled.



Post-Tracking Mode is selected when AD0TM is set to 01b. A programmable tracking time based on AD0TK is started immediately following the convert start signal. Conversions are started after the programmed tracking time ends. After a conversion is complete, ADC0 does not track the input. Rather, the sampling capacitor remains disconnected from the input making the input pin high-impedance until the next convert start signal.

Dual-Tracking Mode is selected when AD0TM is set to 11b. A programmable tracking time based on AD0TK is started immediately following the convert start signal. Conversions are started after the programmed tracking time ends. After a conversion is complete, ADC0 tracks continuously until the next conversion is started.

Depending on the output connected to the ADC input, additional tracking time, more than is specified in Table 5.9, may be required after changing MUX settings. See the settling time requirements described in Section "6.2.1. Settling Time Requirements" on page 52.



Figure 6.2. ADC0 Tracking Modes

#### 6.1.3. Timing

ADC0 has a maximum conversion speed specified in Table 5.9. ADC0 is clocked from the ADC0 Subsystem Clock (FCLK). The source of FCLK is selected based on the BURSTEN bit. When BURSTEN is logic 0, FCLK is derived from the current system clock. When BURSTEN is logic 1, FCLK is derived from the Burst Mode Oscillator, an independent clock source with a maximum frequency of 25 MHz.

When ADC0 is performing a conversion, it requires a clock source that is typically slower than FCLK. The ADC0 SAR conversion clock (SAR clock) is a divided version of FCLK. The divide ratio can be configured using the AD0SC bits in the ADC0CF register. The maximum SAR clock frequency is listed in Table 5.9.

ADC0 can be in one of three states at any given time: tracking, converting, or idle. Tracking time depends on the tracking mode selected. For Pre-Tracking Mode, tracking is managed by software and ADC0 starts conversions immediately following the convert start signal. For Post-Tracking and Dual-Tracking Modes, the tracking time after the convert start signal is equal to the value determined by the AD0TK bits plus 2 FCLK cycles. Tracking is immediately followed by a conversion. The ADC0 conversion time is always 13 SAR clock cycles plus an additional 2 FCLK cycles to start and complete a conversion. Figure 6.3 shows timing diagrams for a conversion in Pre-Tracking Mode and tracking plus conversion in Post-Tracking or Dual-Tracking Mode. In this example, repeat count is set to one.



### Gain Register Definition 6.1. ADC0GNH: ADC0 Selectable Gain High Byte

| Bit    | 7                                                                                                    | 6                                                                         | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|--------|------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|---|---|---|---|---|---|--|--|
| Nam    | е                                                                                                    | GAINH[7:0]                                                                |   |   |   |   |   |   |  |  |
| Тур    | 9                                                                                                    | W                                                                         |   |   |   |   |   |   |  |  |
| Rese   | et 1                                                                                                 | 1                                                                         | 1 | 1 | 1 | 1 | 0 | 0 |  |  |
| Indire | ct Address = (                                                                                       | )x04;                                                                     |   |   |   |   |   |   |  |  |
| Bit    | Name                                                                                                 | Name Function                                                             |   |   |   |   |   |   |  |  |
| 7:0    | GAINH[7:0]                                                                                           | GAINH[7:0] ADC0 Gain High Byte.                                           |   |   |   |   |   |   |  |  |
|        |                                                                                                      | See Section 6.3.1 for details on calculating the value for this register. |   |   |   |   |   |   |  |  |
| Note:  | Note: This register is accessed indirectly; See Section 6.3.2 for details for writing this register. |                                                                           |   |   |   |   |   |   |  |  |

#### Gain Register Definition 6.2. ADC0GNL: ADC0 Selectable Gain Low Byte

| Bit   | 7 | 6    | 5      | 4 | 3        | 2        | 1        | 0        |
|-------|---|------|--------|---|----------|----------|----------|----------|
| Name  |   | GAIN | L[3:0] |   | Reserved | Reserved | Reserved | Reserved |
| Туре  |   | V    | V      |   | W        | W        | W        | W        |
| Reset | 0 | 0    | 0      | 0 | 0        | 0        | 0        | 0        |

Indirect Address = 0x07;

| Bit   | Name                                                                                                 | Function                                                                        |  |  |  |  |  |
|-------|------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|--|--|--|--|--|
| 7:4   | GAINL[3:0]                                                                                           | ADC0 Gain Lower 4 Bits.                                                         |  |  |  |  |  |
|       |                                                                                                      | See Figure 6.3.1 for details for setting this register.                         |  |  |  |  |  |
|       |                                                                                                      | This register is only accessed indirectly through the ADC0H and ADC0L register. |  |  |  |  |  |
| 3:0   | Reserved                                                                                             | Must Write 0000b                                                                |  |  |  |  |  |
| Note: | Note: This register is accessed indirectly; See Section 6.3.2 for details for writing this register. |                                                                                 |  |  |  |  |  |



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

| 7        | 6      | 5                                 | 4                                                     | 3                                                                                         | 2                                                                                                                              | 1                                                                                                                                        | 0                                                                                                                                                                      |
|----------|--------|-----------------------------------|-------------------------------------------------------|-------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DPL[7:0] |        |                                   |                                                       |                                                                                           |                                                                                                                                |                                                                                                                                          |                                                                                                                                                                        |
| R/W      |        |                                   |                                                       |                                                                                           |                                                                                                                                |                                                                                                                                          |                                                                                                                                                                        |
| 0        | 0      | 0                                 | 0                                                     | 0                                                                                         | 0                                                                                                                              | 0                                                                                                                                        | 0                                                                                                                                                                      |
|          | 7<br>0 | 7         6           0         0 | 7         6         5           0         0         0 | 7         6         5         4           DPL         DPL           0         0         0 | 7         6         5         4         3           DPL[7:0]           R/W           0         0         0         0         0 | 7         6         5         4         3         2           DPL[7:0]           R/W           0         0         0         0         0 | 7         6         5         4         3         2         1           DPL[7:0]           R/W           0         0         0         0         0         0         0 |

SFR Address = 0x82; SFR Page = All Pages

| Bit | Name     | Function                                                                                                                    |
|-----|----------|-----------------------------------------------------------------------------------------------------------------------------|
| 7:0 | DPL[7:0] | Data Pointer Low.                                                                                                           |
|     |          | The DPL register is the low byte of the 16-bit DPTR. DPTR is used to access indi-<br>rectly addressed Flash memory or XRAM. |

### SFR Definition 10.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 |

SFR Address = 0x83; SFR Page = All Pages

| Bit | Name     | Function                                                                                                                     |
|-----|----------|------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | DPH[7:0] | Data Pointer High.                                                                                                           |
|     |          | The DPH register is the high byte of the 16-bit DPTR. DPTR is used to access indi-<br>rectly addressed Flash memory or XRAM. |



## SFR Definition 10.3. SP: Stack Pointer

| Bit                                      | 7          | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
|------------------------------------------|------------|---|---|---|---|---|---|---|--|
| Name                                     | ne SP[7:0] |   |   |   |   |   |   |   |  |
| Туре                                     | R/W        |   |   |   |   |   |   |   |  |
| Reset                                    | 0          | 0 | 0 | 0 | 0 | 1 | 1 | 1 |  |
| SFR Address = 0x81; SFR Page = All Pages |            |   |   |   |   |   |   |   |  |

| Bit | 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 10.4. ACC: Accumulator

| Bit    | 7           | 6           | 5             | 4            | 3           | 2 | 1 | 0 |
|--------|-------------|-------------|---------------|--------------|-------------|---|---|---|
| Name   | ACC[7:0]    |             |               |              |             |   |   |   |
| Туре   |             | R/W         |               |              |             |   |   |   |
| Reset  | 0           | 0           | 0             | 0            | 0           | 0 | 0 | 0 |
| SFR Ad | dress = 0xE | 0; SFR Page | e = All Pages | ; Bit-Addres | sable       |   |   |   |
|        |             |             |               |              | <b>–</b> /· |   |   |   |

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

#### SFR Definition 10.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; SFR Page = All Pages; Bit-Addressable

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



On exit from the PCA interrupt service routine, the CIP-51 will return to the CAN0 ISR. On execution of the RETI instruction, SFR Page 0x00 used to access the PCA registers will be automatically popped off of the SFR Page Stack, and the contents of the SFRNEXT register will be moved to the SFRPAGE register. Software in the CAN0 ISR can continue to access SFRs as it did prior to the PCA interrupt. Likewise, the contents of SFRLAST are moved to the SFRNEXT register. Recall this was the SFR Page value 0x00 being used to access SPI0DAT before the CAN0 interrupt occurred. See Figure 12.5.



Figure 12.5. SFR Page Stack Upon Return From PCA Interrupt



#### Table 12.3. Special Function Registers (Continued)

SFRs are listed in alphabetical order. All undefined SFR locations are reserved

| Register | Address | Description                       |     |  |  |  |
|----------|---------|-----------------------------------|-----|--|--|--|
| PCA0CPH1 | 0xEA    | PCA Capture 1 High                | 299 |  |  |  |
| PCA0CPH2 | 0xEC    | PCA Capture 2 High                | 299 |  |  |  |
| PCA0CPH3 | 0xEE    | CA Capture 3 High                 |     |  |  |  |
| PCA0CPH4 | 0xFE    | PCA Capture 4 High                | 299 |  |  |  |
| PCA0CPH5 | 0xCF    | PCA Capture 5 High                | 299 |  |  |  |
| PCA0CPL0 | 0xFB    | PCA Capture 0 Low                 | 299 |  |  |  |
| PCA0CPL1 | 0xE9    | PCA Capture 1 Low                 | 299 |  |  |  |
| PCA0CPL2 | 0xEB    | PCA Capture 2 Low                 | 299 |  |  |  |
| PCA0CPL3 | 0xED    | PCA Capture 3 Low                 | 299 |  |  |  |
| PCA0CPL4 | 0xFD    | PCA Capture 4 Low                 | 299 |  |  |  |
| PCA0CPL5 | 0xCE    | PCA Capture 5 Low                 | 299 |  |  |  |
| PCA0CPM0 | 0xDA    | PCA Module 0 Mode Register        | 297 |  |  |  |
| PCA0CPM1 | 0xDB    | PCA Module 1 Mode Register        | 297 |  |  |  |
| PCA0CPM2 | 0xDC    | PCA Module 2 Mode Register        | 297 |  |  |  |
| PCA0CPM3 | 0xDD    | PCA Module 3 Mode Register        | 297 |  |  |  |
| PCA0CPM4 | 0xDE    | PCA Module 4 Mode Register        | 297 |  |  |  |
| PCA0CPM5 | 0xDF    | PCA Module 5 Mode Register        | 297 |  |  |  |
| PCA0H    | 0xFA    | PCA Counter High                  | 298 |  |  |  |
| PCA0L    | 0xF9    | PCA Counter Low                   | 298 |  |  |  |
| PCA0MD   | 0xD9    | PCA Mode                          | 295 |  |  |  |
| PCA0PWM  | 0xD9    | PCA PWM Configuration             | 296 |  |  |  |
| PCON     | 0x87    | Power Control                     | 137 |  |  |  |
| PSCTL    | 0x8F    | Program Store R/W Control         | 131 |  |  |  |
| PSW      | 0xD0    | Program Status Word               | 90  |  |  |  |
| REF0CN   | 0xD1    | Voltage Reference Control         | 69  |  |  |  |
| REG0CN   | 0xC9    | Voltage Regulator Control         | 80  |  |  |  |
| RSTSRC   | 0xEF    | Reset Source Configuration/Status | 143 |  |  |  |
| SBCON0   | 0xAB    | UART0 Baud Rate Generator Control | 244 |  |  |  |
| SBRLH0   | 0xAD    | UART0 Baud Rate Reload High Byte  | 245 |  |  |  |
| SBRLL0   | 0xAC    | UART0 Baud Rate Reload Low Byte   | 245 |  |  |  |
| SBUF0    | 0x99    | UART0 Data Buffer                 | 244 |  |  |  |
| SCON0    | 0x98    | UART0 Control                     | 241 |  |  |  |
| SFR0CN   | 0x84    | SFR Page Control                  | 102 |  |  |  |
| SFRLAST  | 0x86    | SFR Stack Last Page               | 105 |  |  |  |
| SFRNEXT  | 0x85    | SFR Stack Next Page               | 104 |  |  |  |
| SFRPAGE  | 0xA7    | SFR Page Select                   | 103 |  |  |  |



## SFR Definition 13.1. IE: Interrupt Enable

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

SFR Address = 0xA8; Bit-Addressable; SFR Page = All Pages

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



### SFR Definition 13.5. EIE2: Extended Interrupt Enable 2

| Bit   | 7 | 6 | 5 | 4 | 3 | 2    | 1     | 0     |
|-------|---|---|---|---|---|------|-------|-------|
| Name  |   |   |   |   |   | EMAT | ECAN0 | EREG0 |
| Туре  | R | R | R | R | R | R/W  | R/W   | R/W   |
| Reset | 0 | 0 | 0 | 0 | 0 | 0    | 0     | 0     |

#### SFR Address = 0xE7; SFR Page = All Pages

| Bit | Name   | Function                                                              |
|-----|--------|-----------------------------------------------------------------------|
| 7:3 | Unused | Read = 00000b; Write = Don't Care.                                    |
| 2   | EMAT   | Enable Port Match Interrupt.                                          |
|     |        | This bit sets the masking of the Port Match interrupt.                |
|     |        | 0: Disable all Port Match interrupts.                                 |
|     |        | 1: Enable interrupt requests generated by a Port Match                |
| 1   | ECAN0  | Enable CAN0 Interrupts.                                               |
|     |        | This bit sets the masking of the CAN0 interrupt.                      |
|     |        | 0: Disable all CAN0 interrupts.                                       |
|     |        | 1: Enable interrupt requests generated by CAN0.                       |
| 0   | EREG0  | Enable Voltage Regulator Dropout Interrupt.                           |
|     |        | This bit sets the masking of the Voltage Regulator Dropout interrupt. |
|     |        | 0: Disable the Voltage Regulator Dropout interrupt.                   |
|     |        | 1: Enable the Voltage Regulator Dropout interrupt.                    |



#### 18.3. Clock Multiplier

The Clock Multiplier generates an output clock which is 4 times the input clock frequency scaled by a programmable factor of 1, 2/3, 2/4 (or 1/2), 2/5, 2/6 (or 1/3), or 2/7. The Clock Multiplier's input can be selected from the external oscillator, or the internal or external oscillators divided by 2. This produces three possible base outputs which can be scaled by a programmable factor: Internal Oscillator x 2, External Oscillator x 2, or External Oscillator x 4. See Section 18.1 on page 157 for details on system clock selection.

The Clock Multiplier is configured via the CLKMUL register (SFR Definition 18.5). The procedure for configuring and enabling the Clock Multiplier is as follows:

- 1. Reset the Multiplier by writing 0x00 to register CLKMUL.
- 2. Select the Multiplier input source via the MULSEL bits.
- 3. Select the Multiplier output scaling factor via the MULDIV bits
- 4. Enable the Multiplier with the MULEN bit (CLKMUL | = 0x80).
- 5. Delay for >5 µs.
- 6. Initialize the Multiplier with the MULINIT bit (CLKMUL | = 0xC0).
- 7. Poll for MULRDY  $\geq$  1.

**Important Note**: When using an external oscillator as the input to the Clock Multiplier, the external source must be enabled and stable before the Multiplier is initialized. See "18.4. External Oscillator Drive Circuit" on page 164 for details on selecting an external oscillator source.

The Clock Multiplier allows faster operation of the CIP-51 core and is intended to generate an output frequency between 25 and 50 MHz. The clock multiplier can also be used with slow input clocks. However, if the clock is below the minimum Clock Multiplier input frequency (FCMmin), the generated clock will consist of four fast pulses followed by a long delay until the next input clock rising edge. The average frequency of the output is equal to 4x the input, but the instantaneous frequency may be faster. See Figure 18.2 below for more information.





### SFR Definition 19.6. P1MASK: Port 1 Mask Register

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

#### SFR Address = 0xF4; SFR Page = 0x00

| Bit | Name        | Function                                                                                                                                                                                            |
|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | P1MASK[7:0] | Port 1 Mask Value.                                                                                                                                                                                  |
|     |             | Selects P1 pins to be compared to the corresponding bits in P1MAT.<br>0: P1.n pin logic value is ignored and cannot cause a Port Mismatch event.<br>1: P1.n pin logic value is compared to P1MAT.n. |

## SFR Definition 19.7. P1MAT: Port 1 Match Register

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

SFR Address = 0xF3; SFR Page = 0x00

| Bit | Name       | Function                                                                                                                                                                                   |
|-----|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | P1MAT[7:0] | Port 1 Match Value.                                                                                                                                                                        |
|     |            | Match comparison value used on Port 1 for bits in P1MAT which are set to 1.<br>0: P1.n pin logic value is compared with logic LOW.<br>1: P1.n pin logic value is compared with logic HIGH. |



#### LIN Register Definition 20.6. LIN0ST: LIN0 Status Register

| Bit   | 7      | 6       | 5     | 4     | 3      | 2     | 1      | 0    |
|-------|--------|---------|-------|-------|--------|-------|--------|------|
| Name  | ACTIVE | IDLTOUT | ABORT | DTREQ | LININT | ERROR | WAKEUP | DONE |
| Туре  | R      | R       | R     | R     | R      | R     | R      | R    |
| Reset | 0      | 0       | 0     | 0     | 0      | 0     | 0      | 0    |

#### Indirect Address = 0x09

| Bit | Name   | Function                                                                                                                                                                                                                                                                                                          |
|-----|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | ACTIVE | LIN Active Indicator Bit.                                                                                                                                                                                                                                                                                         |
|     |        | 0: No transmission activity detected on the LIN bus.                                                                                                                                                                                                                                                              |
|     |        |                                                                                                                                                                                                                                                                                                                   |
| 6   | IDLI   | Bus Idle Timeout Bit. (slave mode only)                                                                                                                                                                                                                                                                           |
|     |        | <ul> <li>1: No bus activity has been detected for four seconds, but the bus is not yet in Sleep mode.</li> </ul>                                                                                                                                                                                                  |
| 5   | ABORT  | Aborted Transmission Bit. (slave mode only)                                                                                                                                                                                                                                                                       |
|     |        | <ul> <li>0: The current transmission has not been interrupted or stopped. This bit is reset to 0 after receiving a SYNCH BREAK that does not interrupt a pending transmission.</li> <li>1: New SYNCH BREAK detected before the end of the last transmission or the STOP bit (LIN0CTRL.7) has been set.</li> </ul> |
| 4   | DTREQ  | Data Request Bit. (slave mode only)                                                                                                                                                                                                                                                                               |
|     |        | 0: Data identifier has not been received.                                                                                                                                                                                                                                                                         |
|     |        | 1: Data identifier has been received.                                                                                                                                                                                                                                                                             |
| 3   | LININT | Interrupt Request Bit.                                                                                                                                                                                                                                                                                            |
|     |        | <ul><li>0: An interrupt is not pending. This bit is cleared by setting RSTINT (LIN0CTRL.3)</li><li>1: There is a pending LIN0 interrupt.</li></ul>                                                                                                                                                                |
| 2   | ERROR  | Communication Error Bit.                                                                                                                                                                                                                                                                                          |
|     |        | <ul><li>0: No error has been detected. This bit is cleared by setting RSTERR (LIN0CTRL.2)</li><li>1: An error has been detected.</li></ul>                                                                                                                                                                        |
| 1   | WAKEUP | Wakeup Bit.                                                                                                                                                                                                                                                                                                       |
|     |        | 0: A wakeup signal is not being transmitted and has not been received.                                                                                                                                                                                                                                            |
|     |        | 1: A wakeup signal is being transmitted or has been received                                                                                                                                                                                                                                                      |
| 0   | DONE   | Transmission Complete Bit.                                                                                                                                                                                                                                                                                        |
|     |        | 0: A transmission is not in progress or has not been started. This bit is cleared at the                                                                                                                                                                                                                          |
|     |        | start of a transmission.                                                                                                                                                                                                                                                                                          |
|     |        |                                                                                                                                                                                                                                                                                                                   |



### 21.1. Bosch CAN Controller Operation

The CAN Controller featured in the C8051F550/1/4/5, 'F560/1/4/5/8/9, and 'F572/3 devices is a full implementation of Bosch's full CAN module and fully complies with CAN specification 2.0B. A block diagram of the CAN controller is shown in Figure 21.2. The CAN Core provides shifting (CANTX and CANRX), serial/ parallel conversion of messages, and other protocol related tasks such as transmission of data and acceptance filtering. The message RAM stores 32 message objects which can be received or transmitted on a CAN network. The CAN registers and message handler provide an interface for data transfer and notification between the CAN controller and the CIP-51.

The function and use of the CAN Controller is detailed in the Bosch CAN User's Guide. The User's Guide should be used as a reference to configure and use the CAN controller. This data sheet describes how to access the CAN controller.

All of the CAN controller registers are located on SFR Page 0x0C. Before accessing any of the CAN registers, the SFRPAGE register must be set to 0x0C.

The CAN Controller is typically initialized using the following steps:

- 1. Set the SFRPAGE register to the CAN registers page (page 0x0C).
- 2. Set the INIT and the CCE bits to 1 in CAN0CN. See the CAN User's Guide for bit definitions.
- 3. Set timing parameters in the Bit Timing Register and the BRP Extension Register.
- 4. Initialize each message object or set its MsgVal bit to NOT VALID.
- 5. Reset the INIT bit to 0.





#### 21.1.1. CAN Controller Timing

The CAN controller's clock (fsys) is derived from the CIP-51 system clock (SYSCLK). The internal oscillator is accurate to within 0.5% of 24 MHz across the entire temperature range and for VDD voltages greater than or equal to the minimum output of the on-chip voltage regulator, so an external oscillator is not required for CAN communication for most systems.

Refer to Section "4.10.4 Oscillator Tolerance Range" in the Bosch CAN User's Guide for further information regarding this topic.



the RI0 flag will be set. Note: when MCE0 = 1, RI0 will only be set if the extra bit was equal to 1. Data can be read from the receive FIFO by reading the SBUF0 register. The SBUF0 register represents the oldest byte in the FIFO. After SBUF0 is read, the next byte in the FIFO is immediately loaded into SBUF0, and space is made available in the FIFO for another incoming byte. If enabled, an interrupt will occur when RI0 is set. RI0 can only be cleared to '0' by software when there is no more information in the FIFO. The recommended procedure to empty the FIFO contents is as follows:

- 1. Clear RI0 to 0.
- 2. Read SBUF0.
- 3. Check RI0, and repeat at step 1 if RI0 is set to 1.

If the extra bit function is enabled (XBE0 = 1) and the parity function is disabled (PE0 = 0), the extra bit for the oldest byte in the FIFO can be read from the RBX0 bit (SCON0.2). If the extra bit function is not enabled, the value of the stop bit for the oldest FIFO byte will be presented in RBX0. When the parity function is enabled (PE0 = 1), hardware will check the received parity bit against the selected parity type (selected with S0PT[1:0]) when receiving data. If a byte with parity error is received, the PERR0 flag will be set to 1. This flag must be cleared by software. Note: when parity is enabled, the extra bit function is not available.

**Note:** The UART Receive FIFO pointer can be corrupted if the UART receives a byte and firmware reads a byte from the FIFO at the same time. When this occurs, firmware will lose the received byte and the FIFO receive overrun flag (OVR0) will also be set to 1. Systems using the UART Receive FIFO should ensure that the FIFO isn't accessed by hardware and firmware at the same time. In other words, firmware should ensure to read the FIFO before the next byte is received.



#### 23.3.3. Multiprocessor Communications

UART0 supports multiprocessor communication between a master processor and one or more slave processors by special use of the extra data bit. 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 extra bit is logic 1; in a data byte, the extra bit is always set to logic 0.

Setting the MCE0 bit (SMOD0.7) of a slave processor configures its UART such that when a stop bit is received, the UART will generate an interrupt only if the extra bit is logic 1 (RBX0 = 1) signifying an address byte has been received. In the UART interrupt handler, software will compare the received address with the slave's own assigned address. If the addresses match, the slave will clear its MCE0 bit to enable interrupts on the reception of the following data byte(s). Slaves that weren't addressed leave their MCE0 bits set and do not generate interrupts on the reception of the following data byte(s) bits of the following data bytes, thereby ignoring the data. Once the entire message is received, the addressed slave resets its MCE0 bit to ignore all transmissions until it receives the next address byte.

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 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).



Figure 23.6. UART Multi-Processor Mode Interconnect Diagram











#### 24.6. SPI Special Function Registers

SPI0 is accessed and controlled through four special function registers in the system controller: SPI0CN Control Register, SPI0DAT Data Register, SPI0CFG Configuration Register, and SPI0CKR Clock Rate Register. The four special function registers related to the operation of the SPI0 Bus are described in the following figures.



## SFR Definition 25.14. TMR3RLL: Timer 3 Reload Register Low Byte

| Bit                                 | 7    | 6             | 5 | 4 | 3 | 2 | 1 | 0 |  |
|-------------------------------------|------|---------------|---|---|---|---|---|---|--|
| Nam                                 | e    | TMR3RLL[7:0]  |   |   |   |   |   |   |  |
| Туре                                | •    | R/W           |   |   |   |   |   |   |  |
| Rese                                | et 0 | 0             | 0 | 0 | 0 | 0 | 0 | 0 |  |
| SFR Address = 0x92; SFR Page = 0x00 |      |               |   |   |   |   |   |   |  |
| Bit                                 | Name | Name Function |   |   |   |   |   |   |  |

| ы   | Name         | T unction                                                   |
|-----|--------------|-------------------------------------------------------------|
| 7:0 | TMR3RLL[7:0] | Timer 3 Reload Register Low Byte.                           |
|     |              | TMR3RLL holds the low byte of the reload value for Timer 3. |

### SFR Definition 25.15. TMR3RLH: Timer 3 Reload Register High Byte

| Bit   | 7                                   | 6           | 5                                                            | 4 | 3 | 2 | 1 | 0 |  |
|-------|-------------------------------------|-------------|--------------------------------------------------------------|---|---|---|---|---|--|
| Nam   | Name TMR3RLH[7:0]                   |             |                                                              |   |   |   |   |   |  |
| Тур   | R/W                                 |             |                                                              |   |   |   |   |   |  |
| Rese  | et 0                                | 0           | 0                                                            | 0 | 0 | 0 | 0 | 0 |  |
| SFR / | SFR Address = 0x93; SFR Page = 0x00 |             |                                                              |   |   |   |   |   |  |
| Bit   | Name                                | Function    |                                                              |   |   |   |   |   |  |
| 7:0   | TMR3RLH[7:0]                        | ] Timer 3 F | Timer 3 Reload Register High Byte.                           |   |   |   |   |   |  |
|       |                                     | TMR3RL      | TMR3RLH holds the high byte of the reload value for Timer 3. |   |   |   |   |   |  |

