



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Not For New Designs                                              |
|----------------------------|------------------------------------------------------------------|
| Core Processor             | 8051                                                             |
| Core Size                  | 8-Bit                                                            |
| Speed                      | 25MHz                                                            |
| Connectivity               | SMBus (2-Wire/I <sup>2</sup> C), SPI, UART/USART                 |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, Temp Sensor, WDT               |
| Number of I/O              | 16                                                               |
| Program Memory Size        | 16KB (16K x 8)                                                   |
| Program Memory Type        | FLASH                                                            |
| EEPROM Size                | -                                                                |
| RAM Size                   | 768 × 8                                                          |
| Voltage - Supply (Vcc/Vdd) | 0.9V ~ 3.6V                                                      |
| Data Converters            | A/D 15x10b                                                       |
| Oscillator Type            | Internal                                                         |
| Operating Temperature      | -40°C ~ 85°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/c8051f911-d-gm |

Email: info@E-XFL.COM

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

| Table 22.2. Minimum SDA Setup and Hold Times231Table 22.3. Sources for Hardware Changes to SMB0CN235Table 22.4. Hardware Address Recognition Examples (EHACK = 1)236 |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Table 22.5. SMBus Status Decoding With Hardware ACK Generation Disabled                                                                                              |
| (EHACK = 0)                                                                                                                                                          |
| Table 22.6. SMBus Status Decoding With Hardware ACK Generation Enabled                                                                                               |
| (EHACK = 1)                                                                                                                                                          |
| Table 23.1. Timer Settings for Standard Baud Rates                                                                                                                   |
| Using The Internal 24.5 MHz Oscillator                                                                                                                               |
| Table 23.2. Timer Settings for Standard Baud Rates                                                                                                                   |
| Using an External 22.1184 MHz Oscillator                                                                                                                             |
| Table 24.1. SPI Slave Timing Parameters    269                                                                                                                       |
| Table 25.1. Timer 0 Running Modes         272                                                                                                                        |
| Table 26.1. PCA Timebase Input Options293                                                                                                                            |
| Table 26.2. PCA0CPM and PCA0PWM Bit Settings for PCA                                                                                                                 |
| Capture/Compare Modules                                                                                                                                              |
| Table 26.3. Watchdog Timer Timeout Intervals    305                                                                                                                  |





Figure 3.6. QSOP-24 Landing Diagram

## Table 3.5. PCB Land Pattern

| Dimension | MIN       | MAX  |
|-----------|-----------|------|
| С         | 5.20 5.30 |      |
| E         | 0.635     | BSC  |
| Х         | 0.30      | 0.40 |
| Y         | 1.50      | 1.60 |

## Notes:

#### General

- 1. All dimensions shown are in millimeters (mm) unless otherwise noted.
- 2. This land pattern is based on the IPC-7351 guidelines.

#### Solder Mask Design

1. All metal pads are to be non-solder mask defined (NMSD). Clearance between the solder mask and the metal pad is to be  $60 \ \mu m$  minimum, all the way around the pad.

#### Stencil Design

- 1. A stainless steel, laser-cut and electro-polished stencil with trapezoidal walls should be used to assure good solder paste release.
- 2. The stencil thickness should be 0.125 mm (5 mils).
- 3. The ratio of stencil aperture to land pad size should be 1:1 for all perimeter pads.

#### Card Assembly

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





Figure 4.3. Typical DC-DC Converter Efficiency (High Current, VDD/DC+ = 2 V)



## Table 4.12. Voltage Reference Electrical Characteristics

 $V_{DD}$  = 1.8 to 3.6 V, -40 to +85 °C unless otherwise specified.

| Parameter                         | Conditions                                                     | Min   | Тур   | Max      | Units |
|-----------------------------------|----------------------------------------------------------------|-------|-------|----------|-------|
| Internal High Speed Referenc      | e (REFSL[1:0] = 11)                                            |       |       |          |       |
|                                   | –40 to +85 °C,                                                 | 1.60  | 1.65  | 1.70     | V     |
| Oulput voltage                    | V <sub>DD</sub> = 1.8–3.6 V                                    |       |       |          |       |
| VREF Turn-on Time                 |                                                                | _     | _     | 1.5      | μs    |
| Supply Current                    | Normal Power Mode                                              | _     | 260   | —        | μA    |
| Supply Current                    | Low Power Mode                                                 | —     | 140   | —        |       |
| Internal Precision Reference      | (REFSL[1:0] = 00, REFOE = 1)                                   |       |       |          |       |
|                                   | –40 to +85 °C,                                                 | 1.645 | 1.680 | 1.715    | V     |
| Oulput voltage                    | V <sub>DD</sub> = 1.8–3.6 V                                    |       |       |          |       |
| VREF Short-Circuit Current        |                                                                | _     | 10    | —        | mA    |
| Load Regulation                   | Load = 0 to 200 µA to AGND                                     | _     | 400   | —        | μV/μΑ |
| VREF Turn-on Time 1               | 4.7 μF tantalum, 0.1 μF ceramic<br>bypass, settling to 0.5 LSB | _     | 15    | —        | ms    |
| VREF Turn-on Time 2               | 0.1 µF ceramic bypass, settling to 0.5 LSB                     | _     | 300   | —        | μs    |
| VREF Turn-on Time 3               | no bypass cap, settling to 0.5 LSB                             | —     | 25    | —        | μs    |
| Supply Current                    |                                                                | _     | 15    | —        | μΑ    |
| External Reference (REFSL[1       | :0] = 00, REFOE = 0)                                           |       |       |          |       |
| Input Voltage Range               |                                                                | 0     |       | $V_{DD}$ | V     |
| Input Current                     | Sample Rate = 300 ksps; VREF = 3.0 V                           | —     | 5.25  | —        | μA    |
| Note: Blue indicates a feature on | ly available on 'F912 and 'F902 devices                        |       |       |          |       |



whether the CPU accesses the upper 128 bytes of data memory space or the SFRs. Instructions that use direct addressing will access the SFR space. Instructions using indirect addressing above 0x7F access the upper 128 bytes of data memory. Figure 9.1 illustrates the data memory organization of the C8051F91x-C8051F90x.

#### 9.2.1.1. General Purpose Registers

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

#### 9.2.1.2. Bit Addressable Locations

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

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

MOV C, 22.3h

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



## SFR Definition 11.1. SFR Page: SFR Page

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

SFR Page = All Pages; SFR Address = 0xA7

| Bit | Name         | Function                                                                                    |
|-----|--------------|---------------------------------------------------------------------------------------------|
| 7:0 | SFRPAGE[7:0] | SFR Page.                                                                                   |
|     |              | Specifies the SFR Page used when reading, writing, or modifying special function registers. |

## Table 11.3. Special Function Registers

SFRs are listed in alphabetical order. All undefined SFR locations are reserved. SFRs highlighted in **blue** are only available on 'F912 and 'F902 devices.

| Register | Address | SFR Page | Description                      | Page |
|----------|---------|----------|----------------------------------|------|
| ACC      | 0xE0    | All      | Accumulator                      | 105  |
| ADC0AC   | 0xBA    | 0x0      | ADC0 Accumulator Configuration   | 71   |
| ADC0CF   | 0xBC    | 0x0      | ADC0 Configuration               | 70   |
| ADC0CN   | 0xE8    | 0x0      | ADC0 Control                     | 69   |
| ADC0GTH  | 0xC4    | 0x0      | ADC0 Greater-Than Compare High   | 75   |
| ADC0GTL  | 0xC3    | 0x0      | ADC0 Greater-Than Compare Low    | 75   |
| ADC0H    | 0xBE    | 0x0      | ADC0 High                        | 74   |
| ADC0L    | 0xBD    | 0x0      | ADC0 Low                         | 74   |
| ADC0LTH  | 0xC6    | 0x0      | ADC0 Less-Than Compare Word High | 76   |
| ADC0LTL  | 0xC5    | 0x0      | ADC0 Less-Than Compare Word Low  | 76   |
| ADC0MX   | 0xBB    | 0x0      | AMUX0 Channel Select             | 79   |
| ADC0PWR  | 0xBA    | 0xF      | ADC0 Burst Mode Power-Up Time    | 72   |
| ADC0TK   | 0xBD    | 0xF      | ADC0 Tracking Control            | 73   |
| В        | 0xF0    | All      | B Register                       | 105  |
| CKCON    | 0x8E    | 0x0      | Clock Control                    | 271  |
| CLKSEL   | 0xA9    | All      | Clock Select                     | 185  |
| CPT0CN   | 0x9B    | 0x0      | Comparator0 Control              | 92   |
| CPT0MD   | 0x9D    | 0x0      | Comparator0 Mode Selection       | 92   |
| CPT0MX   | 0x9F    | 0x0      | Comparator0 Mux Selection        | 96   |
| CPT1CN   | 0x9A    | 0x0      | Comparator1 Control              | 93   |



## SFR Definition 12.3. EIE1: Extended Interrupt Enable 1

| Bit   | 7   | 6    | 5    | 4     | 3     | 2      | 1      | 0     |
|-------|-----|------|------|-------|-------|--------|--------|-------|
| Name  | ET3 | ECP1 | ECP0 | EPCA0 | EADC0 | EWADC0 | ERTC0A | ESMB0 |
| Туре  | 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 Page = All Pages; SFR Address = 0xE6

| Bit | Name   | Function                                                                                                                                                                                                                                                                          |
|-----|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | ET3    | Enable Timer 3 Interrupt.<br>This bit sets the masking of the Timer 3 interrupt.<br>0: Disable Timer 3 interrupts.<br>1: Enable interrupt requests generated by the TF3L or TF3H flags.                                                                                           |
| 6   | ECP1   | Enable Comparator1 (CP1) Interrupt.<br>This bit sets the masking of the CP1 interrupt.<br>0: Disable CP1 interrupts.<br>1: Enable interrupt requests generated by the CP1RIF or CP1FIF flags.                                                                                     |
| 5   | ECP0   | Enable Comparator0 (CP0) Interrupt.<br>This bit sets the masking of the CP0 interrupt.<br>0: Disable CP0 interrupts.<br>1: Enable interrupt requests generated by the CP0RIF or CP0FIF flags.                                                                                     |
| 4   | EPCA0  | <ul> <li>Enable Programmable Counter Array (PCA0) Interrupt.</li> <li>This bit sets the masking of the PCA0 interrupts.</li> <li>0: Disable all PCA0 interrupts.</li> <li>1: Enable interrupt requests generated by PCA0.</li> </ul>                                              |
| 3   | EADC0  | Enable ADC0 Conversion Complete Interrupt.<br>This bit sets the masking of the ADC0 Conversion Complete interrupt.<br>0: Disable ADC0 Conversion Complete interrupt.<br>1: Enable interrupt requests generated by the AD0INT flag.                                                |
| 2   | EWADC0 | <ul> <li>Enable Window Comparison ADC0 Interrupt.</li> <li>This bit sets the masking of ADC0 Window Comparison interrupt.</li> <li>0: Disable ADC0 Window Comparison interrupt.</li> <li>1: Enable interrupt requests generated by ADC0 Window Compare flag (AD0WINT).</li> </ul> |
| 1   | ERTC0A | Enable SmaRTClock Alarm Interrupts.<br>This bit sets the masking of the SmaRTClock Alarm interrupt.<br>0: Disable SmaRTClock Alarm interrupts.<br>1: Enable interrupt requests generated by a SmaRTClock Alarm.                                                                   |
| 0   | ESMB0  | Enable SMBus (SMB0) Interrupt.<br>This bit sets the masking of the SMB0 interrupt.<br>0: Disable all SMB0 interrupts.<br>1: Enable interrupt requests generated by SMB0.                                                                                                          |



## 13.5. Flash Write and Erase Guidelines

Any system which contains routines which write or erase Flash memory from software involves some risk that the write or erase routines will execute unintentionally if the CPU is operating outside its specified operating range of VDD, system clock frequency, or temperature. This accidental execution of Flash modifying code can result in alteration of Flash memory contents causing a system failure that is only recoverable by re-Flashing the code in the device.

To help prevent the accidental modification of Flash by firmware, the VDD Monitor must be enabled and enabled as a reset source on C8051F91x-C8051F90x devices for the Flash to be successfully modified. If either the VDD Monitor or the VDD Monitor reset source is not enabled, a Flash Error Device Reset will be generated when the firmware attempts to modify the Flash.

The following guidelines are recommended for any system that contains routines which write or erase Flash from code.

#### 13.5.1. VDD Maintenance and the VDD Monitor

- 1. If the system power supply is subject to voltage or current "spikes," add sufficient transient protection devices to the power supply to ensure that the supply voltages listed in the Absolute Maximum Ratings table are not exceeded.
- 2. Make certain that the minimum VDD rise time specification of 1 ms is met. If the system cannot meet this rise time specification, then add an external VDD brownout circuit to the RST pin of the device that holds the device in reset until VDD reaches the minimum device operating voltage and re-asserts RST if VDD drops below the minimum device operating voltage.
- 3. Keep the on-chip VDD Monitor enabled and enable the VDD Monitor as a reset source as early in code as possible. This should be the first set of instructions executed after the Reset Vector. For C-based systems, this will involve modifying the startup code added by the C compiler. See your compiler documentation for more details. Make certain that there are no delays in software between enabling the VDD Monitor and enabling the VDD Monitor as a reset source. Code examples showing this can be found in "AN201: Writing to Flash from Firmware," available from the Silicon Laboratories website.

**Note:** On C8051F91x-C8051F90x devices, both the VDD Monitor and the VDD Monitor reset source must be enabled to write or erase Flash without generating a Flash Error Device Reset.

**Note:** On C8051F91x-C8051F90x devices, both the VDD Monitor and the VDD Monitor reset source are enabled by hardware after a power-on reset.

- 4. As an added precaution, explicitly enable the VDD Monitor and enable the VDD Monitor as a reset source inside the functions that write and erase Flash memory. The VDD Monitor enable instructions should be placed just after the instruction to set PSWE to a 1, but before the Flash write or erase operation instruction.
- Make certain that all writes to the RSTSRC (Reset Sources) register use direct assignment operators and explicitly DO NOT use the bit-wise operators (such as AND or OR). For example, "RSTSRC = 0x02" is correct, but "RSTSRC |= 0x02" is incorrect.
- 6. Make certain that all writes to the RSTSRC register explicitly set the PORSF bit to a 1. Areas to check are initialization code which enables other reset sources, such as the Missing Clock Detector or Comparator, for example, and instructions which force a Software Reset. A global search on "RSTSRC" can quickly verify this.



## SFR Definition 16.2. DC0CF: DC-DC Converter Configuration

| Bit   | 7    | 6    | 5       | 4        | 3      | 2      | 1      | 0      |
|-------|------|------|---------|----------|--------|--------|--------|--------|
| Name  | LPEN | CLKD | IV[1:0] | AD0CKINV | CLKINV | ILIMIT | VDDSLP | CLKSEL |
| Туре  | 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 Page = 0x0; SFR Address = 0x96

| Bit | Name        | Function                                                                                                                                                                                           |  |  |  |  |  |
|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7   | LPEN        | Low Power Mode Enable.                                                                                                                                                                             |  |  |  |  |  |
|     |             | Enables the dc-dc low power mode which reduces bias currents, reduces peak inductor current, and increases efficiency for low load currents. Only available on 'F912 and 'F902 devices.            |  |  |  |  |  |
|     |             | : Low Power Mode Disabled.<br>: Low Power Mode Enabled.                                                                                                                                            |  |  |  |  |  |
| 6:5 | CLKDIV[1:0] | DC-DC Clock Divider.                                                                                                                                                                               |  |  |  |  |  |
|     |             | Divides the dc-dc converter clock when the system clock is selected as the clock source for dc-dc converter. These bits are ignored when the dc-dc converter is clocked from its local oscillator. |  |  |  |  |  |
|     |             | 00: The dc-dc converter clock is system clock divided by 1.                                                                                                                                        |  |  |  |  |  |
|     |             | 01: The dc-dc converter clock is system clock divided by 2.                                                                                                                                        |  |  |  |  |  |
|     |             | 10: The dc-dc converter clock is system clock divided by 4.                                                                                                                                        |  |  |  |  |  |
| Δ   |             | ADC0 Clock Inversion (Clock Invert During Sync)                                                                                                                                                    |  |  |  |  |  |
| -   | ADUCKINV    | Inverte the ADCO SAR clock derived from the de-de converter clock when the SVNC                                                                                                                    |  |  |  |  |  |
|     |             | bit (DC0CN.3) is enabled. This bit is ignored when the SYNC bit is set to zero.                                                                                                                    |  |  |  |  |  |
|     |             | 0: ADC0 SAR clock is inverted.                                                                                                                                                                     |  |  |  |  |  |
|     |             | 1: ADC0 SAR clock is not inverted.                                                                                                                                                                 |  |  |  |  |  |
| 3   | CLKINV      | DC-DC Converter Clock Invert.                                                                                                                                                                      |  |  |  |  |  |
|     |             | Inverts the system clock used as the input to the dc-dc clock divider.                                                                                                                             |  |  |  |  |  |
|     |             | 0: The dc-dc converter clock is not inverted.                                                                                                                                                      |  |  |  |  |  |
|     |             | 1: The dc-dc converter clock is inverted.                                                                                                                                                          |  |  |  |  |  |
| 2   | ILIMIT      | Peak Current Limit Threshold.                                                                                                                                                                      |  |  |  |  |  |
|     |             | Sets the threshold for the maximum allowed peak inductor current according to Table 16.1.                                                                                                          |  |  |  |  |  |
| 1   | VDDSLP      | VDD-DC+ Sleep Mode Connection.                                                                                                                                                                     |  |  |  |  |  |
|     |             | Specifies the power source for VDD/DC+ in Sleep Mode when the dc-dc converter is enabled.                                                                                                          |  |  |  |  |  |
|     |             | 1: VDD-DC+ is floating in Sleep Mode.                                                                                                                                                              |  |  |  |  |  |
| 0   | CLKSEL      | DC-DC Converter Clock Source Select.                                                                                                                                                               |  |  |  |  |  |
|     |             | Specifies the dc-dc converter clock source.                                                                                                                                                        |  |  |  |  |  |
|     |             | 0: The dc-dc converter is clocked from its local oscillator.                                                                                                                                       |  |  |  |  |  |
|     |             | 1: The dc-dc converter is clocked from the system clock.                                                                                                                                           |  |  |  |  |  |



### 19.3.4. External CMOS Clock Mode

If an external CMOS clock is used as the external oscillator, the clock should be directly routed into XTAL2. The XTAL2 pin should be configured as a digital input. XTAL1 is not used in external CMOS clock mode. The external oscillator valid detector will always return zero when the external oscillator is configured to External CMOS Clock mode.



| Analog Function                    | Potentially<br>Assignable Port Pins | SFR(s) used for<br>Assignment |
|------------------------------------|-------------------------------------|-------------------------------|
| Voltage Reference (VREF0)          | P0.0                                | REF0CN, PnSKIP                |
| Analog Ground Reference (AGND)     | P0.1                                | REF0CN, PnSKIP                |
| Current Reference (IREF0)          | P0.7                                | IREF0CN, PnSKIP               |
| External Oscillator Input (XTAL1)  | P0.2                                | OSCXCN, PnSKIP                |
| External Oscillator Output (XTAL2) | P0.3                                | OSCXCN, PnSKIP                |

## Table 21.1. Port I/O Assignment for Analog Functions

## 21.2.2. Assigning Port I/O Pins to Digital Functions

Any Port pins not assigned to analog functions may be assigned to digital functions or used as GPIO. Most digital functions rely on the Crossbar for pin assignment; however, some digital functions bypass the Crossbar in a manner similar to the analog functions listed above. **Port pins used by these digital func-tions and any Port pins selected for use as GPIO should have their corresponding bit in PnSKIP set to 1.** Table 21.2 shows all available digital functions and the potential mapping of Port I/O to each digital function.

## Table 21.2. Port I/O Assignment for Digital Functions

| Digital Function                                                                                                           | Potentially Assignable Port Pins                                                                                                                                                                                           | SFR(s) used for<br>Assignment |
|----------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|
| UART0, SPI1, SPI0, SMBus,<br>CP0 and CP1 Outputs, Sys-<br>tem Clock Output, PCA0,<br>Timer0 and Timer1 External<br>Inputs. | Any Port pin available for assignment by the<br>Crossbar. This includes P0.0–P1.6 pins which<br>have their PnSKIP bit set to 0.<br><b>Note:</b> The Crossbar will always assign UART0<br>and SPI1 pins to fixed locations. | XBR0, XBR1, XBR2              |
| Any pin used for GPIO                                                                                                      | P0.0–P1.6, P2.7                                                                                                                                                                                                            | P0SKIP, P1SKIP                |

## 21.2.3. Assigning Port I/O Pins to External Digital Event Capture Functions

External digital event capture functions can be used to trigger an interrupt or wake the device from a low power mode when a transition occurs on a digital I/O pin. The digital event capture functions do not require dedicated pins and will function on both GPIO pins (PnSKIP = 1) and pins in use by the Crossbar (PnSKIP = 0). External digital even capture functions cannot be used on pins configured for analog I/O. Table 21.3 shows all available external digital event capture functions.

## Table 21.3. Port I/O Assignment for External Digital Event Capture Functions

| Digital Function     | Potentially Assignable Port Pins | SFR(s) used for<br>Assignment  |
|----------------------|----------------------------------|--------------------------------|
| External Interrupt 0 | P0.0-P0.7                        | IT01CF                         |
| External Interrupt 1 | P0.0-P0.7                        | IT01CF                         |
| Port Match           | P0.0-P1.6                        | P0MASK, P0MAT<br>P1MASK, P1MAT |



## SFR Definition 21.12. P0DRV: Port0 Drive Strength

| Bit   | 7                                  | 6                                                               | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|------------------------------------|-----------------------------------------------------------------|---|---|---|---|---|---|
| Nam   | P0DRV[7:0]                         |                                                                 |   |   |   |   |   |   |
| Туре  | R/W                                |                                                                 |   |   |   |   |   |   |
| Rese  | <b>t</b> 0                         | 0                                                               | 0 | 0 | 0 | 0 | 0 | 0 |
| SFR F | SFR Page = 0xF; SFR Address = 0xA4 |                                                                 |   |   |   |   |   |   |
| Bit   | Name                               | Function                                                        |   |   |   |   |   |   |
| 7:0   | P0DRV[7:0]                         | Drive Strength Configuration Bits for P0.7–P0.0 (respectively). |   |   |   |   |   |   |

| 7:0 | P0DRV[7:0] | Drive Strength Configuration Bits for P0.7–P0.0 (respectively).         |
|-----|------------|-------------------------------------------------------------------------|
|     |            | Configures digital I/O Port cells to high or low output drive strength. |
|     |            | 0: Corresponding P0.n Output has low output drive strength.             |
|     |            | 1: Corresponding P0.n Output has high output drive strength.            |



## 23.2. Operational Modes

UART0 provides standard asynchronous, full duplex communication. The UART mode (8-bit or 9-bit) is selected by the S0MODE bit (SCON0.7). Typical UART connection options are shown below.



Figure 23.3. UART Interconnect Diagram

### 23.2.1. 8-Bit UART

8-Bit UART mode uses a total of 10 bits per data byte: one start bit, eight data bits (LSB first), and one stop bit. Data are transmitted LSB first from the TX0 pin and received at the RX0 pin. On receive, the eight data bits are stored in SBUF0 and the stop bit goes into RB80 (SCON0.2).

Data transmission begins when software 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 the following conditions are met: RI0 must be logic 0, and if MCE0 is logic 1, the stop bit must be logic 1. In the event of a receive data overrun, the first received 8 bits are latched into the SBUF0 receive register and the following overrun data bits are lost.

If these conditions are met, the eight bits of data is stored in SBUF0, the stop 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 is set.



Figure 23.4. 8-Bit UART Timing Diagram



## 24.1. Signal Descriptions

The four signals used by each SPIn (MOSI, MISO, SCK, NSS) are described below.

#### 24.1.1. Master Out, Slave In (MOSI)

The master-out, slave-in (MOSI) signal is an output from a master device and an input to slave devices. It is used to serially transfer data from the master to the slave. This signal is an output when SPIn is operating as a master anSPInd an input when SPIn is operating as a slave. Data is transferred most-significant bit first. When configured as a master, MOSI is driven by the MSB of the shift register in both 3- and 4-wire mode.

### 24.1.2. Master In, Slave Out (MISO)

The master-in, slave-out (MISO) signal is an output from a slave device and an input to the master device. It is used to serially transfer data from the slave to the master. This signal is an input when SPIn is operating as a master and an output when SPIn is operating as a slave. Data is transferred most-significant bit first. The MISO pin is placed in a high-impedance state when the SPI module is disabled and when the SPI operates in 4-wire mode as a slave that is not selected. When acting as a slave in 3-wire mode, MISO is always driven by the MSB of the shift register.

#### 24.1.3. Serial Clock (SCK)

The serial clock (SCK) signal is an output from the master device and an input to slave devices. It is used to synchronize the transfer of data between the master and slave on the MOSI and MISO lines. SPIn generates this signal when operating as a master. The SCK signal is ignored by a SPI slave when the slave is not selected (NSS = 1) in 4-wire slave mode.

#### 24.1.4. Slave Select (NSS)

The function of the slave-select (NSS) signal is dependent on the setting of the NSSnMD1 and NSSnMD0 bits in the SPInCN register. There are three possible modes that can be selected with these bits:

- NSSMD[1:0] = 00: 3-Wire Master or 3-Wire Slave Mode: SPIn operates in 3-wire mode, and NSS is disabled. When operating as a slave device, SPIn is always selected in 3-wire mode. Since no select signal is present, SPIn must be the only slave on the bus in 3-wire mode. This is intended for point-to-point communication between a master and one slave.
- 2. NSSMD[1:0] = 01: 4-Wire Slave or Multi-Master Mode: SPIn operates in 4-wire mode, and NSS is enabled as an input. When operating as a slave, NSS selects the SPIn device. When operating as a master, a 1-to-0 transition of the NSS signal disables the master function of SPIn so that multiple master devices can be used on the same SPI bus.
- NSSMD[1:0] = 1x: 4-Wire Master Mode: SPIn operates in 4-wire mode, and NSS is enabled as an output. The setting of NSSMD0 determines what logic level the NSS pin will output. This configuration should only be used when operating SPIn as a master device.

See Figure 24.2, Figure 24.3, and Figure 24.4 for typical connection diagrams of the various operational modes. **The setting of NSSMD bits affects the pinout of the device.** When in 3-wire master or 3-wire slave mode, the NSS pin will not be mapped by the crossbar. In all other modes, the NSS signal will be mapped to a pin on the device. See Section "21. Port Input/Output" on page 205 for general purpose port I/ O and crossbar information.



## SFR Definition 24.4. SPInDAT: SPI Data

| Bit                                                                                      | 7   | 6 | 5 | 4     | 3       | 2 | 1 | 0 |
|------------------------------------------------------------------------------------------|-----|---|---|-------|---------|---|---|---|
| Name                                                                                     |     |   |   | SPInD | AT[7:0] |   |   |   |
| Туре                                                                                     | R/W |   |   |       |         |   |   |   |
| Reset                                                                                    | 0   | 0 | 0 | 0     | 0       | 0 | 0 | 0 |
| SFR Addresses: SPI0DAT = 0xA3, SPI1DAT = 0x86<br>SFR Pages: SPI0DAT = 0x0, SPI1DAT = 0x0 |     |   |   |       |         |   |   |   |

| Bit | Name    | Function                                                                                                                                                                                                                                     |
|-----|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | SPInDAT | SPIn Transmit and Receive Data.                                                                                                                                                                                                              |
|     |         | The SPInDAT register is used to transmit and receive SPIn data. Writing data to SPInDAT places the data into the transmit buffer and initiates a transfer when in Master Mode. A read of SPInDAT returns the contents of the receive buffer. |



## 25.1. Timer 0 and Timer 1

Each timer is implemented as a 16-bit register accessed as two separate bytes: a low byte (TL0 or TL1) and a high byte (TH0 or TH1). The Counter/Timer Control register (TCON) is used to enable Timer 0 and Timer 1 as well as indicate status. Timer 0 interrupts can be enabled by setting the ET0 bit in the IE register (Section "12.5. Interrupt Register Descriptions" on page 123); Timer 1 interrupts can be enabled by setting the ET1 bit in the IE register (Section "12.5. Interrupt Register (Section "12.5. Interrupt Register (Section "12.5. Interrupt Register Descriptions" on page 123); Both counter/timers operate in one of four primary modes selected by setting the Mode Select bits T1M1–T0M0 in the Counter/Timer Mode register (TMOD). Each timer can be configured independently. Each operating mode is described below.

### 25.1.1. Mode 0: 13-bit Counter/Timer

Timer 0 and Timer 1 operate as 13-bit counter/timers in Mode 0. The following describes the configuration and operation of Timer 0. However, both timers operate identically, and Timer 1 is configured in the same manner as described for Timer 0.

The TH0 register holds the eight MSBs of the 13-bit counter/timer. TL0 holds the five LSBs in bit positions TL0.4–TL0.0. The three upper bits of TL0 (TL0.7–TL0.5) are indeterminate and should be masked out or ignored when reading. As the 13-bit timer register increments and overflows from 0x1FFF (all ones) to 0x0000, the timer overflow flag TF0 (TCON.5) is set and an interrupt will occur if Timer 0 interrupts are enabled.

The C/T0 bit (TMOD.2) selects the counter/timer's clock source. When C/T0 is set to logic 1, high-to-low transitions at the selected Timer 0 input pin (T0) increment the timer register (Refer to Section "21.3. Priority Crossbar Decoder" on page 209 for information on selecting and configuring external I/O pins). Clearing C/T selects the clock defined by the T0M bit (CKCON.3). When T0M is set, Timer 0 is clocked by the system clock. When T0M is cleared, Timer 0 is clocked by the source selected by the Clock Scale bits in CKCON (see SFR Definition 25.1).

Setting the TR0 bit (TCON.4) enables the timer when either GATE0 (TMOD.3) is logic 0 or the input signal INT0 is active as defined by bit IN0PL in register IT01CF (see SFR Definition 12.7). Setting GATE0 to 1 allows the timer to be controlled by the external input signal INT0 (see Section "12.5. Interrupt Register Descriptions" on page 123), facilitating pulse width measurements

| TR0                  | GATE0 | ΙΝΤΟ | Counter/Timer |  |
|----------------------|-------|------|---------------|--|
| 0                    | Х     | Х    | Disabled      |  |
| 1                    | 0     | Х    | Enabled       |  |
| 1                    | 1 1   |      | Disabled      |  |
| 1                    | 1     | 1    | Enabled       |  |
| Note: X = Don't Care |       |      |               |  |

## Table 25.1. Timer 0 Running Modes

Setting TR0 does not force the timer to reset. The timer registers should be loaded with the desired initial value before the timer is enabled.

TL1 and TH1 form the 13-bit register for Timer 1 in the same manner as described above for TL0 and TH0. Timer 1 is configured and controlled using the relevant TCON and TMOD bits just as with Timer 0. The input signal INT1 is used with Timer 1; the INT1 polarity is defined by bit IN1PL in register IT01CF (see SFR Definition 12.7).



### 25.2.2. 8-bit Timers with Auto-Reload

When T2SPLIT is set, Timer 2 operates as two 8-bit timers (TMR2H and TMR2L). Both 8-bit timers operate in auto-reload mode as shown in Figure 25.5. TMR2RLL holds the reload value for TMR2L; TMR2RLH holds the reload value for TMR2H. The TR2 bit in TMR2CN handles the run control for TMR2H. TMR2L is always running when configured for 8-bit Mode.

Each 8-bit timer may be configured to use SYSCLK, SYSCLK divided by 12, SmaRTClock divided by 8 or Comparator 0 output. The Timer 2 Clock Select bits (T2MH and T2ML in CKCON) select either SYSCLK or the clock defined by the Timer 2 External Clock Select bits (T2XCLK[1:0] in TMR2CN), as follows:

| T2MH | T2XCLK[1:0] | TMR2H Clock<br>Source |
|------|-------------|-----------------------|
| 0    | 00          | SYSCLK / 12           |
| 0    | 01          | SmaRTClock / 8        |
| 0    | 10          | Reserved              |
| 0    | 11          | Comparator 0          |
| 1    | Х           | SYSCLK                |

| T2ML | T2XCLK[1:0] | TMR2L Clock<br>Source |
|------|-------------|-----------------------|
| 0    | 00          | SYSCLK / 12           |
| 0    | 01          | SmaRTClock / 8        |
| 0    | 10          | Reserved              |
| 0    | 11          | Comparator 0          |
| 1    | Х           | SYSCLK                |

The TF2H bit is set when TMR2H overflows from 0xFF to 0x00; the TF2L bit is set when TMR2L overflows from 0xFF to 0x00. When Timer 2 interrupts are enabled (IE.5), an interrupt is generated each time TMR2H overflows. If Timer 2 interrupts are enabled and TF2LEN (TMR2CN.5) is set, an interrupt is generated each time either TMR2L or TMR2H overflows. When TF2LEN is enabled, software must check the TF2H and TF2L flags to determine the source of the Timer 2 interrupt. The TF2H and TF2L interrupt flags are not cleared by hardware and must be manually cleared by software.



Figure 25.5. Timer 2 8-Bit Mode Block Diagram



### 26.3.6. 16-Bit Pulse Width Modulator Mode

A PCA module may also be operated in 16-Bit PWM mode. 16-bit PWM mode is independent of the other (8/9/10/11-bit) PWM modes. In this mode, the 16-bit capture/compare module defines the number of PCA clocks for the low time of the PWM signal. When the PCA counter matches the module contents, the output on CEXn is asserted high; when the 16-bit counter overflows, CEXn is asserted low. To output a varying duty cycle, new value writes should be synchronized with PCA CCFn match interrupts. 16-Bit PWM Mode is enabled by setting the ECOMn, PWMn, and PWM16n bits in the PCA0CPMn register. For a varying duty cycle, match interrupts should be enabled (ECCFn = 1 AND MATn = 1) to help synchronize the capture/compare register writes. If the MATn bit is set to 1, the CCFn flag for the module will be set each time a 16-bit comparator match (rising edge) occurs. The CF flag in PCA0CN can be used to detect the overflow (falling edge). The duty cycle for 16-Bit PWM Mode is given by Equation 26.4.

**Important Note About Capture/Compare Registers**: When writing a 16-bit value to the PCA0 Capture/Compare registers, the low byte should always be written first. Writing to PCA0CPLn clears the ECOMn bit to 0; writing to PCA0CPHn sets ECOMn to 1.

$$Duty Cycle = \frac{(65536 - PCA0CPn)}{65536}$$

Equation 26.4. 16-Bit PWM Duty Cycle

Using Equation 26.4, the largest duty cycle is 100% (PCA0CPn = 0), and the smallest duty cycle is 0.0015% (PCA0CPn = 0xFFFF). A 0% duty cycle may be generated by clearing the ECOMn bit to 0.



Figure 26.10. PCA 16-Bit PWM Mode



The 8-bit offset held in PCA0CPH5 is compared to the upper byte of the 16-bit PCA counter. This offset value is the number of PCA0L overflows before a reset. Up to 256 PCA clocks may pass before the first PCA0L overflow occurs, depending on the value of the PCA0L when the update is performed. The total offset is then given (in PCA clocks) by Equation 26.5, where PCA0L is the value of the PCA0L register at the time of the update.

### $Offset = (256 \times PCA0CPL5) + (256 - PCA0L)$

#### Equation 26.5. Watchdog Timer Offset in PCA Clocks

The WDT reset is generated when PCA0L overflows while there is a match between PCA0CPH5 and PCA0H. Software may force a WDT reset by writing a 1 to the CCF5 flag (PCA0CN.5) while the WDT is enabled.

#### 26.4.2. Watchdog Timer Usage

To configure the WDT, perform the following tasks:

- Disable the WDT by writing a 0 to the WDTE bit.
- Select the desired PCA clock source (with the CPS2–CPS0 bits).
- Load PCA0CPL5 with the desired WDT update offset value.
- Configure the PCA Idle mode (set CIDL if the WDT should be suspended while the CPU is in Idle mode).
- Enable the WDT by setting the WDTE bit to 1.
- Reset the WDT timer by writing to PCA0CPH5.

The PCA clock source and Idle mode select cannot be changed while the WDT is enabled. The watchdog timer is enabled by setting the WDTE or WDLCK bits in the PCA0MD register. When WDLCK is set, the WDT cannot be disabled until the next system reset. If WDLCK is not set, the WDT is disabled by clearing the WDTE bit.

The WDT is enabled following any reset. The PCA0 counter clock defaults to the system clock divided by 12, PCA0L defaults to 0x00, and PCA0CPL5 defaults to 0x00. Using Equation 26.5, this results in a WDT timeout interval of 256 PCA clock cycles, or 3072 system clock cycles. Table 26.3 lists some example timeout intervals for typical system clocks.

| System Clock (Hz)                                                          | PCA0CPL5 | Timeout Interval (ms) |  |  |  |
|----------------------------------------------------------------------------|----------|-----------------------|--|--|--|
| 24,500,000                                                                 | 255      | 32.1                  |  |  |  |
| 24,500,000                                                                 | 128      | 16.2                  |  |  |  |
| 24,500,000                                                                 | 32       | 4.1                   |  |  |  |
| 3,062,500*                                                                 | 255      | 257                   |  |  |  |
| 3,062,500*                                                                 | 128      | 129.5                 |  |  |  |
| 3,062,500*                                                                 | 32       | 33.1                  |  |  |  |
| 32,000                                                                     | 255      | 24576                 |  |  |  |
| 32,000                                                                     | 128      | 12384                 |  |  |  |
| 32,000                                                                     | 32       | 3168                  |  |  |  |
| *Note: Internal SYSCLK reset frequency = Internal Oscillator divided by 8. |          |                       |  |  |  |
|                                                                            |          |                       |  |  |  |

### Table 26.3. Watchdog Timer Timeout Intervals



## SFR Definition 26.3. PCA0PWM: PCA PWM Configuration

| Bit   | 7     | 6    | 5    | 4 | 3 | 2 | 1    | 0      |
|-------|-------|------|------|---|---|---|------|--------|
| Name  | ARSEL | ECOV | COVF |   |   |   | CLSE | L[1:0] |
| Туре  | R/W   | R/W  | R/W  | R | R | R | R/   | W      |
| Reset | 0     | 0    | 0    | 0 | 0 | 0 | 0    | 0      |

#### SFR Page = 0x0; SFR Address = 0xDF

| Bit | Name       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | ARSEL      | Auto-Reload Register Select.<br>This bit selects whether to read and write the normal PCA capture/compare registers<br>(PCA0CPn), or the Auto-Reload registers at the same SFR addresses. This function<br>is used to define the reload value for 9, 10, and 11-bit PWM modes. In all other<br>modes, the Auto-Reload registers have no function.<br>0: Read/Write Capture/Compare Registers at PCA0CPHn and PCA0CPLn.<br>1: Read/Write Auto-Reload Registers at PCA0CPHn and PCA0CPLn.    |
| 6   | ECOV       | <b>Cycle Overflow Interrupt Enable.</b><br>This bit sets the masking of the Cycle Overflow Flag (COVF) interrupt.<br>0: COVF will not generate PCA interrupts.<br>1: A PCA interrupt will be generated when COVF is set.                                                                                                                                                                                                                                                                   |
| 5   | COVF       | <ul> <li>Cycle Overflow Flag.</li> <li>This bit indicates an overflow of the 8th, 9th, 10th, or 11th bit of the main PCA counter (PCA0). The specific bit used for this flag depends on the setting of the Cycle Length Select bits. The bit can be set by hardware or software, but must be cleared by software.</li> <li>0: No overflow has occurred since the last time this bit was cleared.</li> <li>1: An overflow has occurred since the last time this bit was cleared.</li> </ul> |
| 4:2 | Unused     | <b>Unused.</b><br>Read = 000b; Write = don't care.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1:0 | CLSEL[1:0] | Cycle Length Select.<br>When 16-bit PWM mode is not selected, these bits select the length of the PWM<br>cycle, between 8, 9, 10, or 11 bits. This affects all channels configured for PWM which<br>are not using 16-bit PWM mode. These bits are ignored for individual channels config-<br>ured to16-bit PWM mode.<br>00: 8 bits.<br>01: 9 bits.<br>10: 10 bits.<br>11: 11 bits.                                                                                                         |

