

Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Obsolete                                                       |
|----------------------------|----------------------------------------------------------------|
| Core Processor             | 8051                                                           |
| Core Size                  | 8-Bit                                                          |
| Speed                      | 25MHz                                                          |
| Connectivity               | EBI/EMI, SMBus (2-Wire/I <sup>2</sup> C), SPI, UART/USART      |
| Peripherals                | Cap Sense, POR, PWM, WDT                                       |
| Number of I/O              | 54                                                             |
| Program Memory Size        | 8KB (8K x 8)                                                   |
| Program Memory Type        | FLASH                                                          |
| EEPROM Size                | -                                                              |
| RAM Size                   | 512 x 8                                                        |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                                    |
| Data Converters            | -                                                              |
| Oscillator Type            | Internal                                                       |
| Operating Temperature      | -40°C ~ 85°C (TA)                                              |
| Mounting Type              | Surface Mount                                                  |
| Package / Case             | 64-TQFP                                                        |
| Supplier Device Package    | 64-TQFP (10x10)                                                |
| Purchase URL               | https://www.e-xfl.com/product-detail/silicon-labs/c8051f711-gq |

Email: info@E-XFL.COM

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

| Figure 18.3. EMIF Operating Modes                                             | 117   |
|-------------------------------------------------------------------------------|-------|
| Figure 18.4. Non-multiplexed 16-bit MOVX Timing                               | 120   |
| Figure 18.5. Non-multiplexed 8-bit MOVX without Bank Select Timing            | 121   |
| Figure 18.6. Non-Multiplexed 8-Bit MOVX with Bank Select Timing               | 122   |
| Figure 18.7. Multiplexed 16-bit MOVX Timing                                   | 123   |
| Figure 18.8. Multiplexed 8-Bit MOVX without Bank Select Timing                | 124   |
| Figure 18.9. Multiplexed 8-Bit MOVX with Bank Select Timing                   | 125   |
| Figure 23.1. EEPROM Block Diagram                                             | 155   |
| Figure 25.1. Reset Sources                                                    | 163   |
| Figure 25.2. Power-On and VDD Monitor Reset Timing                            | 164   |
| Figure 27.1. Oscillator Options                                               | 171   |
| Figure 27.2. External 32.768 kHz Quartz Crystal Oscillator Connection Diagram | 178   |
| Figure 28.1. Port I/O Functional Block Diagram                                | 180   |
| Figure 28.2. Port I/O Cell Block Diagram                                      | 181   |
| Figure 28.3. Port I/O Overdrive Current                                       | 182   |
| Figure 28.4. Crossbar Priority Decoder—Possible Pin Assignments               | 186   |
| Figure 28.5. Crossbar Priority Decoder in Example Configuration—              |       |
| No Pins Skipped                                                               | 187   |
| Figure 28.6. Crossbar Priority Decoder in Example Configuration—              |       |
| 3 Pins Skipped                                                                | 188   |
| Figure 29.1. CRC0 Block Diagram                                               | 211   |
| Figure 30.1. SMBus Block Diagram                                              | 219   |
| Figure 30.2. Typical SMBus Configuration                                      | 220   |
| Figure 30.3. SMBus Transaction                                                | . 221 |
| Figure 30.4. Typical SMBus SCL Generation                                     | 223   |
| Figure 30.5. Typical Master Write Sequence                                    | 232   |
| Figure 30.6. Typical Master Read Sequence                                     | 233   |
| Figure 30.7. Typical Slave Write Sequence                                     | 234   |
| Figure 30.8. Typical Slave Read Sequence                                      | 235   |
| Figure 31.1. SPI Block Diagram                                                | 241   |
| Figure 31.2. Multiple-Master Mode Connection Diagram                          | 243   |
| Figure 31.3. 3-Wire Single Master and Single Slave Mode Connection Diagram .  | 243   |
| Figure 31.4. 4-Wire Single Master Mode and Slave Mode Connection Diagram      | 244   |
| Figure 31.5. Master Mode Data/Clock Timing                                    | 246   |
| Figure 31.6. Slave Mode Data/Clock Timing (CKPHA = 0)                         | 246   |
| Figure 31.7. Slave Mode Data/Clock Timing (CKPHA = 1)                         | 247   |
| Figure 31.8. SPI Master Timing (CKPHA = 0)                                    | 251   |
| Figure 31.9. SPI Master Timing (CKPHA = 1)                                    | 251   |
| Figure 31.10. SPI Slave Timing (CKPHA = 0)                                    | 252   |
| Figure 31.11. SPI Slave Timing (CKPHA = 1)                                    | 252   |
| Figure 32.1. UART0 Block Diagram                                              | 254   |
| Figure 32.2. UART0 Baud Rate Logic                                            | 255   |
| Figure 32.3. UART Interconnect Diagram                                        | 256   |
| Figure 32.4. 8-Bit UART Timing Diagram                                        | 256   |
| Figure 32.5. 9-Bit UART Timing Diagram                                        | 257   |



| Table 30.4. Hardware Address Recognition Examples (EHACK = 1)        | 229 |
|----------------------------------------------------------------------|-----|
| Table 30.5. SMBus Status Decoding: Hardware ACK Disabled (EHACK = 0) | 236 |
| Table 30.6. SMBus Status Decoding: Hardware ACK Enabled (EHACK = 1)  | 238 |
| Table 31.1. SPI Slave Timing Parameters                              | 253 |
| Table 32.1. Timer Settings for Standard Baud Rates                   |     |
| Using The Internal 24.5 MHz Oscillator                               | 261 |
| Table 32.2. Timer Settings for Standard Baud Rates                   |     |
| Using an External 22.1184 MHz Oscillator                             | 261 |
| Table 34.1. PCA Timebase Input Options                               | 285 |
| Table 34.2. PCA0CPM and PCA0PWM Bit Settings for PCA Modules         | 287 |





# 5. TQFP-48 Package Specifications

Figure 5.1. TQFP-48 Package Drawing

| Dimension | Min       | Nom       | Max  |  | Dimension | Min       | Nom       | Max  |
|-----------|-----------|-----------|------|--|-----------|-----------|-----------|------|
| A         | _         | —         | 1.20 |  | E         | 9.00 BSC. |           |      |
| A1        | 0.05      | —         | 0.15 |  | E1        |           | 7.00 BSC. |      |
| A2        | 0.95      | 1.00      | 1.05 |  | L         | 0.45      | 0.60      | 0.75 |
| b         | 0.17      | 0.22      | 0.27 |  | aaa       |           | 0.20      |      |
| С         | 0.09      | —         | 0.20 |  | bbb       |           | 0.20      |      |
| D         | 9.00 BSC. |           |      |  | CCC       |           | 0.08      |      |
| D1        | 7.00 BSC. |           |      |  | ddd       |           | 0.08      |      |
| е         |           | 0.50 BSC. |      |  | Θ         | 0°        | 3.5°      | 7°   |

## Table 5.1. TQFP-48 Package Dimensions

#### Notes:

1. All dimensions shown are in millimeters (mm) unless otherwise noted.

2. Dimensioning and Tolerancing per ANSI Y14.5M-1994.

- 3. This drawing conforms to JEDEC outline MS-026, variation ABC.
- **4.** Recommended card reflow profile is per the JEDEC/IPC J-STD-020 specification for Small Body Components.



# 8. QFN-24 Package Specifications



## Figure 8.1. QFN-24 Package Drawing

| Dimension | Min       | Тур       | Max  | Dimension | Min  | Тур  | Max  |
|-----------|-----------|-----------|------|-----------|------|------|------|
| A         | 0.70      | 0.75      | 0.80 | L         | 0.30 | 0.40 | 0.50 |
| A1        | 0.00      | 0.02      | 0.05 | L1        | 0.00 |      | 0.15 |
| b         | 0.18      | 0.25      | 0.30 | aaa       | _    |      | 0.15 |
| D         |           | 4.00 BSC. |      | bbb       | _    | —    | 0.10 |
| D2        | 2.55      | 2.70      | 2.80 | ddd       | _    | —    | 0.05 |
| е         | 0.50 BSC. |           |      | eee       | _    | —    | 0.08 |
| E         | 4.00 BSC. |           |      | Z         | _    | 0.24 | —    |
| E2        | 2.55      | 2.70      | 2.80 | Y         | _    | 0.18 |      |

#### Table 8.1. QFN-24 Package Dimensions

Notes:

1. All dimensions shown are in millimeters (mm) unless otherwise noted.

2. Dimensioning and Tolerancing per ANSI Y14.5M-1994.

**3.** This drawing conforms to JEDEC Solid State Outline MO-220, variation WGGD except for custom features D2, E2, Z, Y, and L which are toleranced per supplier designation.

4. Recommended card reflow profile is per the JEDEC/IPC J-STD-020 specification for Small Body Components.



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

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

| Parameters          | Conditions                                   | Min                    | Тур                   | Max | Units |
|---------------------|----------------------------------------------|------------------------|-----------------------|-----|-------|
| Output High Voltage | High Drive Strength                          |                        |                       |     |       |
|                     | I <sub>OH</sub> = −3 mA, Port I/O push-pull  | V <sub>DD</sub> – 0.7  | —                     | —   | V     |
|                     | I <sub>OH</sub> = –10 μA, Port I/O push-pull | V <sub>DD</sub> – 0.1  | —                     | —   | V     |
|                     | I <sub>OH</sub> = –10 mA, Port I/O push-pull | —                      | V <sub>DD</sub> – 0.8 | —   | V     |
|                     | Low Drive Strength                           |                        |                       |     |       |
|                     | I <sub>OH</sub> = −1 mA, Port I/O push-pull  | V <sub>DD</sub> – 0.7  | —                     | —   | V     |
|                     | I <sub>OH</sub> = –10 μA, Port I/O push-pull | V <sub>DD</sub> – 0.1  | —                     | —   | V     |
|                     | I <sub>OH</sub> = –3 mA, Port I/O push-pull  | —                      | V <sub>DD</sub> – 0.8 | —   | V     |
| Output Low Voltage  | High Drive Strength                          |                        |                       |     |       |
|                     | l <sub>OL</sub> = 8.5 mA                     |                        | —                     | 0.6 | V     |
|                     | I <sub>OL</sub> = 10 μΑ                      |                        | —                     | 0.1 | V     |
|                     | I <sub>OL</sub> = 25 mA                      |                        | 1.0                   |     | V     |
|                     | Low Drive Strength                           |                        |                       |     |       |
|                     | I <sub>OL</sub> = 1.4 mA                     |                        | —                     | 0.6 | V     |
|                     | I <sub>OL</sub> = 10 μA                      |                        | —                     | 0.1 | V     |
|                     | I <sub>OL</sub> = 4 mA                       |                        | 1.0                   | —   | V     |
| Input High Voltage  |                                              | 0.75 x V <sub>DD</sub> |                       | _   | V     |
| Input Low Voltage   |                                              | —                      | _                     | 0.6 | V     |
| Input Leakage       | Weak Pullup Off                              | -1                     |                       | 1   | μA    |
| Current             | Weak Pullup On, V <sub>IN</sub> = 0 V        |                        | 25                    | 50  | μA    |

#### **Table 9.4. Reset Electrical Characteristics**

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

| Parameter                                       | Conditions                                                                            | Min                    | Тур  | Max                   | Units    |
|-------------------------------------------------|---------------------------------------------------------------------------------------|------------------------|------|-----------------------|----------|
| RST Output Low Voltage                          | I <sub>OL</sub> = 8.5 mA,<br>V <sub>DD</sub> = 1.8 V to 3.6 V                         | —                      |      | 0.6                   | V        |
| RST Input High Voltage                          |                                                                                       | 0.75 x V <sub>DD</sub> |      |                       | V        |
| RST Input Low Voltage                           |                                                                                       | _                      |      | 0.3 x V <sub>DD</sub> | $V_{DD}$ |
| RST Input Pullup Current                        | RST = 0.0 V                                                                           | —                      | 25   | 50                    | μA       |
| V <sub>DD</sub> POR Ramp Time                   |                                                                                       | —                      |      | 1                     | ms       |
| $V_{DD}$ Monitor Threshold ( $V_{RST}$ )        |                                                                                       | 1.7                    | 1.75 | 1.8                   | V        |
| Missing Clock Detector<br>Timeout               | Time from last system clock rising edge to reset initiation                           | 100                    | 500  | 1000                  | μs       |
| Reset Time Delay                                | Delay between release of any<br>reset source and code<br>execution at location 0x0000 | _                      |      | 30                    | μs       |
| Minimum RST Low Time to Generate a System Reset |                                                                                       | 15                     |      |                       | μs       |
| V <sub>DD</sub> Monitor Turn-on Time            | $V_{DD} = V_{RST} - 0.1 V$                                                            |                        | 50   |                       | μs       |
| V <sub>DD</sub> Monitor Supply Current          |                                                                                       | _                      | 25   | 30                    | μA       |



# C8051F70x/71x

The Comparator response time may be configured in software via the CPT0MD register (see SFR Definition 14.2). Selecting a longer response time reduces the Comparator supply current.



Figure 14.2. Comparator Hysteresis Plot

The Comparator hysteresis is software-programmable via its Comparator Control register CPT0CN. The user can program both the amount of hysteresis voltage (referred to the input voltage) and the positive and negative-going symmetry of this hysteresis around the threshold voltage.

The Comparator hysteresis is programmed using Bits3–0 in the Comparator Control Register CPT0CN (shown in SFR Definition 14.1). The amount of negative hysteresis voltage is determined by the settings of the CP0HYN bits. As shown in Figure 14.2, settings of 20, 10 or 5 mV of negative hysteresis can be programmed, or negative hysteresis can be disabled. In a similar way, the amount of positive hysteresis is determined by the setting the CP0HYP bits.

Comparator interrupts can be generated on both rising-edge and falling-edge output transitions. (For Interrupt enable and priority control, see Section "21.1. MCU Interrupt Sources and Vectors" on page 138). The CP0FIF flag is set to logic 1 upon a Comparator falling-edge occurrence, and the CP0RIF flag is set to logic 1 upon the Comparator rising-edge occurrence. Once set, these bits remain set until cleared by software. The Comparator rising-edge interrupt mask is enabled by setting CP0RIE to a logic 1. The Comparator0 falling-edge interrupt mask is enabled by setting CP0FIE to a logic 1.

The output state of the Comparator can be obtained at any time by reading the CP0OUT bit. The Comparator is enabled by setting the CP0EN bit to logic 1, and is disabled by clearing this bit to logic 0.

Note that false rising edges and falling edges can be detected when the comparator is first powered on or if changes are made to the hysteresis or response time control bits. Therefore, it is recommended that the rising-edge and falling-edge flags be explicitly cleared to logic 0 a short time after the comparator is enabled or its mode bits have been changed.



# C8051F70x/71x

#### 15.8. Adjusting CS0 For Special Situations

There are several configuration options in the CS0 module designed to modify the operation of the circuit and address special situations. In particular, any circuit with more than 500  $\Omega$  of series impedance between the sensor and the device pin may require adjustments for optimal performance. Typical applications which may require adjustments include the following:

- Touch panel sensors fabricated using a resistive conductor such as indium-tin-oxide (ITO).
- Circuits using a high-value series resistor to isolate the sensor element for high ESD protection.

# Most systems will require no fine tuning, and the default settings for CS0DT, CS0DR, and CS0IA should be used.



## SFR Definition 15.9. CS0PM: Capacitive Sense Pin Monitor

| Bit   | 7    | 6     | 5     | 4     | 3     | 2     | 1    | 0       |
|-------|------|-------|-------|-------|-------|-------|------|---------|
| Name  | UAPM | SPIPM | SMBPM | PCAPM | PIOPM | CP0PM | CSPM | MD[1:0] |
| Туре  | 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 = 0x9F; SFR Page = F

| Bit | Name        | Description                                                          |
|-----|-------------|----------------------------------------------------------------------|
| 7   | UAPM        | UART Pin Monitor Enable.                                             |
|     |             | Enables monitoring of the UART TX pin.                               |
| 6   | SPIPM       | SPI Pin Monitor Enable.                                              |
|     |             | Enables monitoring SPI output pins.                                  |
| 5   | SMBPM       | SMBus Pin Monitor Enable.                                            |
|     |             | Enables monitoring of the SMBus pins.                                |
| 4   | PCAPM       | PCA Pin Monitor Enable.                                              |
|     |             | Enables monitoring of PCA output pins.                               |
| 3   | PIOPM       | Port I/O Pin Monitor Enable.                                         |
|     |             | Enables monitoring of writes to the port latch registers.            |
| 2   | CP0PM       | CP0 Pin Monitor Enable.                                              |
|     |             | Enables monitoring of the comparator CP0 (synchronous) output.       |
| 1:0 | CSPMMD[1:0] | CS0 Pin Monitor Mode.                                                |
|     |             | Selects the operation to take when a monitored signal changes state. |
|     |             | 00: Always retry bit cycles on a pin state change.                   |
|     |             | 01: Retry up to twice on consecutive bit cycles.                     |
|     |             | 10: Retry up to four times on consecutive bit cycles.                |
|     |             | 11: Reserved.                                                        |



# 16. CIP-51 Microcontroller

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

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

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

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

#### Performance

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



Figure 16.1. CIP-51 Block Diagram



## Table 20.2. Special Function Registers (Continued)

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

| Register | Address | Page      | Description                        | Page |
|----------|---------|-----------|------------------------------------|------|
| CS0CN    | 0x9A    | 0         | CS0 Control                        | 88   |
| CS0DH    | 0xAA    | 0         | CS0 Data High                      | 90   |
| CS0DL    | 0xA9    | 0         | CS0 Data Low                       | 90   |
| CS0CF    | 0x9E    | 0         | CS0 Configuration                  | 89   |
| CS0MD1   | 0xAD    | 0         | CS0 Mode 1                         | 94   |
| CS0MD2   | 0xBE    | F         | CS0 Mode 2                         | 95   |
| CSOMX    | 0x9C    | 0         | CS0 Mux                            | 97   |
| CS0PM    | 0x9F    | F         | CS0 Pin Monitor                    | 93   |
| CS0SE    | 0x93    | F         | Auto Scan End Channel              | 91   |
| CS0SS    | 0x92    | F         | Auto Scan Start Channel            | 91   |
| CS0THH   | 0x97    | 0         | CS0 Digital Compare Threshold High | 92   |
| CS0THL   | 0x96    | 0         | CS0 Digital Compare Threshold Low  | 92   |
| DERIVID  | 0xEC    | F         | Derivative Identification          | 128  |
| DPH      | 0x83    | All Pages | Data Pointer High                  | 104  |
| DPL      | 0x82    | All Pages | Data Pointer Low                   | 104  |
| EEADDR   | 0xB6    | All Pages | EEPROM Byte Address                | 156  |
| EECNTL   | 0xC5    | F         | EEPROM Control                     | 158  |
| EEDATA   | 0xD1    | All Pages | EEPROM Byte Data                   | 157  |
| EEKEY    | 0xC6    | F         | EEPROM Protect Key                 | 159  |
| EIE1     | 0xE6    | All Pages | Extended Interrupt Enable 1        | 142  |
| EIE2     | 0xE7    | All Pages | Extended Interrupt Enable 2        | 143  |
| EIP1     | 0xCE    | F         | Extended Interrupt Priority 1      | 144  |
| EIP2     | 0xCF    | F         | Extended Interrupt Priority 2      | 145  |
| EMIOCF   | 0xC7    | F         | EMIF Configuration                 | 114  |
| EMIOCN   | 0xAA    | F         | EMIF Control                       | 113  |
| EMIOTC   | 0xEE    | F         | EMIF Timing Control                | 119  |
| FLKEY    | 0xB7    | All Pages | Flash Lock And Key                 | 154  |
| HWID     | 0xC4    | F         | Hardware Identification            | 128  |
| IE       | 0xA8    | All Pages | Interrupt Enable                   | 140  |
| IP       | 0xB8    | All Pages | Interrupt Priority                 | 141  |
| IT01CF   | 0xE4    | F         | INT0/INT1 Configuration            | 147  |
| OSCICL   | 0xBF    | F         | Internal Oscillator Calibration    | 173  |
| OSCICN   | 0xA9    | F         | Internal Oscillator Control        | 174  |
| OSCXCN   | 0xB5    | F         | External Oscillator Control        | 176  |
| P0       | 0x80    | All Pages | Port 0 Latch                       | 195  |
| P0DRV    | 0xF9    | F         | Port 0 Drive Strength              | 197  |
| POMASK   | 0xF4    | 0         | Port 0 Mask                        | 192  |
| POMAT    | 0xF3    | 0         | Port 0 Match                       | 193  |



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

| Bit   | 7   | 6        | 5    | 4     | 3     | 2      | 1    | 0     |
|-------|-----|----------|------|-------|-------|--------|------|-------|
| Name  | ET3 | Reserved | ECP0 | EPCA0 | EADC0 | EWADC0 | EMAT | 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 Address = 0xE6; SFR Page = All Pages

| Bit | Name     | Function                                                                                                                                                                                                                                                                          |
|-----|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | ET3      | Enable Timer 3 Interrupt.                                                                                                                                                                                                                                                         |
|     |          | This bit sets the masking of the Timer 3 interrupt.                                                                                                                                                                                                                               |
|     |          | 1: Enable interrupt requests generated by the TF3L or TF3H flags.                                                                                                                                                                                                                 |
| 6   | Reserved | Must write 0.                                                                                                                                                                                                                                                                     |
| 5   | ECP0     | Enable Comparator0 (CP0) Interrupt.<br>This bit sets the masking of the CP0 rising edge or falling edge interrupt.<br>0: Disable CP0 interrupts.<br>1: Enable interrupt requests generated by the CP0RIF and CP0FIF flags.                                                        |
| 4   | EPCA0    | Enable Programmable Counter Array (PCA0) Interrupt.<br>This bit sets the masking of the PCA0 interrupts.                                                                                                                                                                          |
|     |          | 1: Enable interrupt requests generated by PCA0.                                                                                                                                                                                                                                   |
| 3   | EADC0    | <ul> <li>Enable ADC0 Conversion Complete Interrupt.</li> <li>This bit sets the masking of the ADC0 Conversion Complete interrupt.</li> <li>0: Disable ADC0 Conversion Complete interrupt.</li> <li>1: Enable interrupt requests generated by the AD0INT flag.</li> </ul>          |
| 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   | EMAT     | <ul> <li>Enable Port Match Interrupts.</li> <li>This bit sets the masking of the Port Match event interrupt.</li> <li>0: Disable all Port Match interrupts.</li> <li>1: Enable interrupt requests generated by a Port Match.</li> </ul>                                           |
| 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.                                                                                                          |



# 22. Flash Memory

On-chip, re-programmable Flash memory is included for program code and non-volatile data storage. The Flash memory can be programmed in-system through the C2 interface or by software using the MOVX write instruction. Once cleared to logic 0, a Flash bit must be erased to set it back to logic 1. Flash bytes would typically be erased (set to 0xFF) before being reprogrammed. The write and erase operations are automatically timed by hardware for proper execution; data polling to determine the end of the write/erase operations is not required. Code execution is stalled during Flash write/erase operations. Refer to Table 9.6 for complete Flash memory electrical characteristics.

## 22.1. Programming The Flash Memory

The simplest means of programming the Flash memory is through the C2 interface using programming tools provided by Silicon Laboratories or a third party vendor. This is the only means for programming a non-initialized device. For details on the C2 commands to program Flash memory, see Section "35. C2 Interface" on page 301.

The Flash memory can be programmed by software using the MOVX write instruction with the address and data byte to be programmed provided as normal operands. Before programming Flash memory using MOVX, Flash programming operations must be enabled by: (1) setting the PSWE Program Store Write Enable bit (PSCTL.0) to logic 1 (this directs the MOVX writes to target Flash memory); and (2) Writing the Flash key codes in sequence to the Flash Lock register (FLKEY). The PSWE bit remains set until cleared by software.

**Note:** A minimum SYSCLK frequency is required for writing or erasing Flash memory, as detailed in Section "Table 9.6. Flash Electrical Characteristics" on page 50.

For detailed guidelines on programming Flash from firmware, please see Section "22.4. Flash Write and Erase Guidelines" on page 150.

To ensure the integrity of the Flash contents, the on-chip VDD Monitor must be enabled and enabled as a reset source in any system that includes code that writes and/or erases Flash memory from software. Furthermore, there should be no delay between enabling the  $V_{DD}$  Monitor and enabling the  $V_{DD}$  Monitor as a reset source. Any attempt to write or erase Flash memory while the  $V_{DD}$  Monitor is disabled, or not enabled as a reset source, will cause a Flash Error device reset.

#### 22.1.1. Flash Lock and Key Functions

Flash writes and erases by user software are protected with a lock and key function. The Flash Lock and Key Register (FLKEY) must be written with the correct key codes, in sequence, before Flash operations may be performed. The key codes are: 0xA5, 0xF1. The timing does not matter, but the codes must be written in order. If the key codes are written out of order, or the wrong codes are written, Flash writes and erases will be disabled until the next system reset. Flash writes and erases will also be disabled if a Flash write or erase is attempted before the key codes have been written properly. The Flash lock resets after each write or erase; the key codes must be written again before a following Flash operation can be performed. The FLKEY register is detailed in SFR Definition 22.2.

#### 22.1.2. Flash Erase Procedure

The Flash memory is organized in 512-byte pages. The erase operation applies to an entire page (setting all bytes in the page to 0xFF). To erase an entire 512-byte page, perform the following steps:

- 1. Save current interrupt state and disable interrupts.
- 2. Set the PSEE bit (register PSCTL).
- 3. Set the PSWE bit (register PSCTL).
- 4. Write the first key code to FLKEY: 0xA5.
- 5. Write the second key code to FLKEY: 0xF1.



## SFR Definition 25.2. RSTSRC: Reset Source

| Bit   | 7 | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|-------|---|--------|--------|--------|--------|--------|--------|--------|
| Name  |   | FERROR | CORSEF | SWRSF  | WDTRSF | MCDRSF | PORSF  | PINRSF |
| Туре  | R | R      | R/W    | R/W    | R      | R/W    | R/W    | R      |
| Reset | 0 | Varies |

SFR Address = 0xEF; SFR Page = All Pages

| Bit   | Name       | Description                                                                                    | Write                                                                                                                                                                | Read                                                                                                                                           |
|-------|------------|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 7     | Unused     | Unused.                                                                                        | Don't care.                                                                                                                                                          | 0                                                                                                                                              |
| 6     | FERROR     | Flash Error Reset Flag.                                                                        | N/A                                                                                                                                                                  | Set to 1 if Flash<br>read/write/erase error<br>caused the last reset.                                                                          |
| 5     | CORSEF     | Comparator0 Reset Enable and Flag.                                                             | Writing a 1 enables<br>Comparator0 as a reset<br>source (active-low).                                                                                                | Set to 1 if Comparator0 caused the last reset.                                                                                                 |
| 4     | SWRSF      | Software Reset Force and Flag.                                                                 | Writing a 1 forces a sys-<br>tem reset.                                                                                                                              | Set to 1 if last reset was<br>caused by a write to<br>SWRSF.                                                                                   |
| 3     | WDTRSF     | Watchdog Timer Reset Flag.                                                                     | N/A                                                                                                                                                                  | Set to 1 if Watchdog Timer<br>overflow caused the last<br>reset.                                                                               |
| 2     | MCDRSF     | Missing Clock Detector<br>Enable and Flag.                                                     | Writing a 1 enables the<br>Missing Clock Detector.<br>The MCD triggers a reset<br>if a missing clock condition<br>is detected.                                       | Set to 1 if Missing Clock<br>Detector timeout caused<br>the last reset.                                                                        |
| 1     | PORSF      | Power-On / V <sub>DD</sub> Monitor<br>Reset Flag, and V <sub>DD</sub> monitor<br>Reset Enable. | Writing a 1 enables the $V_{DD}$ monitor as a reset source.<br>Writing 1 to this bit before the $V_{DD}$ monitor is enabled and stabilized may cause a system reset. | Set to 1 anytime a power-<br>on or V <sub>DD</sub> monitor reset<br>occurs.<br>When set to 1 all other<br>RSTSRC flags are inde-<br>terminate. |
| 0     | PINRSF     | HW Pin Reset Flag.                                                                             | N/A                                                                                                                                                                  | Set to 1 if RST pin caused the last reset.                                                                                                     |
| Note: | Do not use | read-modify-write operations on this                                                           | s register                                                                                                                                                           | 1                                                                                                                                              |



# 26. Watchdog Timer

The MCU includes a programmable Watchdog Timer (WDT) running off the system clock. A WDT overflow will force the MCU into the reset state. To prevent the reset, the WDT must be restarted by application software before overflow. If the system experiences a software or hardware malfunction preventing the software from restarting the WDT, the WDT will overflow and cause a reset.

Following a reset the WDT is automatically enabled and running with the default maximum time interval. If desired the WDT can be disabled by system software or locked on to prevent accidental disabling. Once locked, the WDT cannot be disabled until the next system reset. The state of the /RST pin is unaffected by this reset.

The WDT consists of a 21-bit timer running from the programmed system clock. The timer measures the period between specific writes to its control register. If this period exceeds the programmed limit, a WDT reset is generated. The WDT can be enabled and disabled as needed in software, or can be permanently enabled if desired. Watchdog features are controlled via the Watchdog Timer Control Register (WDTCN) shown in SFR Definition 26.1.

#### 26.1. Enable/Reset WDT

The watchdog timer is both enabled and reset by writing 0xA5 to the WDTCN register. The user's application software should include periodic writes of 0xA5 to WDTCN as needed to prevent a watchdog timer overflow. The WDT is enabled and reset as a result of any system reset.

## 26.2. Disable WDT

Writing 0xDE followed by 0xAD to the WDTCN register disables the WDT. The following code segment illustrates disabling the WDT:

CLR EA ; disable all interrupts MOV WDTCN,#0DEh ; disable software watchdog timer MOV WDTCN,#0ADh SETB EA ; re-enable interrupts

The writes of 0xDE and 0xAD must occur within 4 clock cycles of each other, or the disable operation is ignored. Interrupts should be disabled during this procedure to avoid delay between the two writes.

## 26.3. Disable WDT Lockout

Writing 0xFF to WDTCN locks out the disable feature. Once locked out, the disable operation is ignored until the next system reset. Writing 0xFF does not enable or reset the watchdog timer. Applications always intending to use the watchdog should write 0xFF to WDTCN in the initialization code.

#### 26.4. Setting WDT Interval

WDTCN.[2:0] control the watchdog timeout interval. The interval is given by the following equation:

4^(3+WDTCN[2-0]) x Tsysclk ;where Tsysclk is the system clock period.

For a 3 MHz system clock, this provides an interval range of 0.021 to 349.5 ms. WDTCN.7 must be logic 0 when setting this interval. Reading WDTCN returns the programmed interval. WDTCN.[2:0] reads 111b after a system reset.



#### 27.3.3. External Capacitor Example

If a capacitor is used as an external oscillator for the MCU, the circuit should be configured as shown in Figure 27.1, Option 3. The capacitor should be no greater than 100 pF; however for very small capacitors, the total capacitance may be dominated by parasitic capacitance in the PCB layout. To determine the required External Oscillator Frequency Control value (XFCN) in the OSCXCN Register, select the capacitor to be used and find the frequency of oscillation according to Equation , where f = the frequency of oscillation in MHz, C = the capacitor value in pF, and V<sub>DD</sub> = the MCU power supply in Volts.

 $f = (KF)/(R \times V_{DD})$ 

#### Equation 27.2. C Mode Oscillator Frequency

For example: Assume  $V_{DD} = 3.0$  V and f = 150 kHz:

f = KF / (C x VDD) 0.150 MHz = KF / (C x 3.0)

Since the frequency of roughly 150 kHz is desired, select the K Factor from the table in SFR Definition 27.4 (OSCXCN) as KF = 22:

0.150 MHz = 22 / (C x 3.0) C x 3.0 = 22 / 0.150 MHz C = 146.6 / 3.0 pF = 48.8 pF

Therefore, the XFCN value to use in this example is 011b and C = 50 pF.



## SFR Definition 28.33. P5DRV: Port 5 Drive Strength

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

SFR Address = 0xFE; SFR Page = F

| Bit | Name       | Function                                                                                                                                                                                               |
|-----|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | P5DRV[7:0] | Drive Strength Configuration Bits for P5.7–P5.0 (respectively).                                                                                                                                        |
|     |            | Configures digital I/O Port cells to high or low output drive strength.<br>0: Corresponding P5.n Output has low output drive strength.<br>1: Corresponding P5.n Output has high output drive strength. |

#### SFR Definition 28.34. P6: Port 6

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

SFR Address = 0xB2; SFR Page = All Pages

| Bit | Name    | Description                                                                                                                                   | Write                                                                                                     | Read                                                                    |
|-----|---------|-----------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| 7:6 | Unused  | Read = 00b; Write = Don't Ca                                                                                                                  | re                                                                                                        | L                                                                       |
| 5:0 | P6[5:0] | <b>Port 6 Data.</b><br>Sets the Port latch logic<br>value or reads the Port pin<br>logic state in Port cells con-<br>figured for digital I/O. | <ol> <li>O: Set output latch to logic<br/>LOW.</li> <li>1: Set output latch to logic<br/>HIGH.</li> </ol> | 0: P6.n Port pin is logic<br>LOW.<br>1: P6.n Port pin is logic<br>HIGH. |



# SFR Definition 31.2. SPI0CN: SPI0 Control

| Bit   | 7    | 6    | 5    | 4      | 3          | 2 | 1     | 0     |
|-------|------|------|------|--------|------------|---|-------|-------|
| Name  | SPIF | WCOL | MODF | RXOVRN | NSSMD[1:0] |   | TXBMT | SPIEN |
| Туре  | R/W  | R/W  | R/W  | R/W    | R/W        |   | R     | R/W   |
| Reset | 0    | 0    | 0    | 0      | 0          | 1 | 1     | 0     |

#### SFR Address = 0xF8; SFR Page = All Pages; Bit-Addressable

| Bit | Name       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | SPIF       | <b>SPI0 Interrupt Flag.</b><br>This bit is set to logic 1 by hardware at the end of a data transfer. If SPI interrupts are enabled, an interrupt will be generated. This bit is not automatically cleared by hardware, and must be cleared by software.                                                                                                                                                                                                          |
| 6   | WCOL       | Write Collision Flag.<br>This bit is set to logic 1 if a write to SPI0DAT is attempted when TXBMT is 0. When<br>this occurs, the write to SPI0DAT will be ignored, and the transmit buffer will not be<br>written. If SPI interrupts are enabled, an interrupt will be generated. This bit is not<br>automatically cleared by hardware, and must be cleared by software.                                                                                         |
| 5   | MODF       | <b>Mode Fault Flag.</b><br>This bit is set to logic 1 by hardware when a master mode collision is detected (NSS is low, MSTEN = 1, and NSSMD[1:0] = 01). If SPI interrupts are enabled, an interrupt will be generated. This bit is not automatically cleared by hardware, and must be cleared by software.                                                                                                                                                      |
| 4   | RXOVRN     | <b>Receive Overrun Flag (valid in slave mode only).</b><br>This bit is set to logic 1 by hardware when the receive buffer still holds unread data from a previous transfer and the last bit of the current transfer is shifted into the SPI0 shift register. If SPI interrupts are enabled, an interrupt will be generated. This bit is not automatically cleared by hardware, and must be cleared by software.                                                  |
| 3:2 | NSSMD[1:0] | <ul> <li>Slave Select Mode.</li> <li>Selects between the following NSS operation modes:<br/>(See Section 31.2 and Section 31.3).</li> <li>00: 3-Wire Slave or 3-Wire Master Mode. NSS signal is not routed to a port pin.</li> <li>01: 4-Wire Slave or Multi-Master Mode (Default). NSS is an input to the device.</li> <li>1x: 4-Wire Single-Master Mode. NSS signal is mapped as an output from the<br/>device and will assume the value of NSSMD0.</li> </ul> |
| 1   | ТХВМТ      | <b>Transmit Buffer Empty.</b><br>This bit will be set to logic 0 when new data has been written to the transmit buffer.<br>When data in the transmit buffer is transferred to the SPI shift register, this bit will<br>be set to logic 1, indicating that it is safe to write a new byte to the transmit buffer.                                                                                                                                                 |
| 0   | SPIEN      | SPI0 Enable.<br>0: SPI disabled.<br>1: SPI enabled.                                                                                                                                                                                                                                                                                                                                                                                                              |



## SFR Definition 33.3. TMOD: Timer Mode

| Bit   | 7                 | 6                                         | 5                                                                                | 4            | 3                                         | 2             | 1             | 0                                   |  |  |  |  |  |  |  |
|-------|-------------------|-------------------------------------------|----------------------------------------------------------------------------------|--------------|-------------------------------------------|---------------|---------------|-------------------------------------|--|--|--|--|--|--|--|
| Nam   | e GATE1           | C/T1                                      | T1M                                                                              | 1[1:0]       | GATE0                                     | C/T0          | TOM           | [1:0]                               |  |  |  |  |  |  |  |
| Туре  | R/W               | R/W                                       | R                                                                                | /W           | R/W                                       | R/W R/W R/W   |               |                                     |  |  |  |  |  |  |  |
| Rese  | t O               | 0                                         | 0                                                                                | 0            | 0                                         | 0             | 0             | 0                                   |  |  |  |  |  |  |  |
| SFR A | ddress = 0x8      | 9; SFR Page                               | = All Pages                                                                      | 6            |                                           |               |               |                                     |  |  |  |  |  |  |  |
| Bit   | Bit Name Function |                                           |                                                                                  |              |                                           |               |               |                                     |  |  |  |  |  |  |  |
| 7     | GATE1             | Timer 1 Ga                                | te Control.                                                                      |              |                                           |               |               |                                     |  |  |  |  |  |  |  |
|       |                   | 0: Timer 1 e                              | nabled whe                                                                       | n TR1 = 1 ii | rrespective of                            | INT1 logic le | evel.         |                                     |  |  |  |  |  |  |  |
|       |                   | 1: Timer 1 e<br>register IT0 <sup>-</sup> | nabled only<br>1CF (see SF                                                       | when TR1     | = 1 AND INT1<br>n 21.7).                  | is active as  | defined by I  | oit IN1PL in                        |  |  |  |  |  |  |  |
| 6     | C/T1              | Counter/Tir                               | ner 1 Selec                                                                      | :t.          |                                           |               |               |                                     |  |  |  |  |  |  |  |
|       |                   | 0: Timer: Tir                             | mer 1 incren                                                                     | nented by c  | lock defined b                            | y T1M bit in  | register CK   | er CKCON.                           |  |  |  |  |  |  |  |
|       |                   | 1: Counter:                               | 1: Counter: Timer 1 incremented by high-to-low transitions on external pin (T1). |              |                                           |               |               |                                     |  |  |  |  |  |  |  |
| 5:4   | T1M[1:0]          | Timer 1 Mo                                | de Select.                                                                       |              |                                           |               |               |                                     |  |  |  |  |  |  |  |
|       |                   | These bits s                              | elect the Tir                                                                    | mer 1 opera  | tion mode.                                |               |               |                                     |  |  |  |  |  |  |  |
|       |                   | 00: Mode 0,                               | 13-bit Cour                                                                      | nter/Timer   |                                           |               |               |                                     |  |  |  |  |  |  |  |
|       |                   | 01: Mode 1,                               | 16-bit Court                                                                     | nter/Timer   |                                           | لم            |               |                                     |  |  |  |  |  |  |  |
|       |                   | 10: Mode 2,                               | Timer 1 Ina                                                                      | er/ I mer wi | in Auto-Reioa                             | a             |               |                                     |  |  |  |  |  |  |  |
| 3     | GATEO             |                                           |                                                                                  |              |                                           |               |               |                                     |  |  |  |  |  |  |  |
| 5     | OAILU             |                                           | nabled whe                                                                       | n TR0 – 1 ii | respective of                             |               | امريد         |                                     |  |  |  |  |  |  |  |
|       |                   | 1: Timer 0 e                              | nabled only                                                                      | when TR0     | $= 1 \text{ AND } \overline{\text{INTC}}$ | is active as  | defined by b  | oit IN0PL in                        |  |  |  |  |  |  |  |
|       |                   | register IT0                              | 1CF (see SF                                                                      | R Definition | n 21.7).                                  |               | , <b>,</b>    |                                     |  |  |  |  |  |  |  |
| 2     | C/T0              | Counter/Tir                               | ner 0 Selec                                                                      | :t.          |                                           |               |               |                                     |  |  |  |  |  |  |  |
|       |                   | 0: Timer: Tir                             | mer 0 incren                                                                     | nented by c  | lock defined b                            | y T0M bit in  | register CK   | CON.                                |  |  |  |  |  |  |  |
|       |                   | 1: Counter:                               | Timer 0 incr                                                                     | emented by   | / high-to-low t                           | ransitions or | n external pi | n (T0).                             |  |  |  |  |  |  |  |
| 1:0   | T0M[1:0]          | Timer 0 Mo                                | de Select.                                                                       |              |                                           |               |               |                                     |  |  |  |  |  |  |  |
|       |                   | These bits s                              | elect the Ti                                                                     | mer 0 opera  | tion mode.                                |               |               |                                     |  |  |  |  |  |  |  |
|       |                   | 00: Mode 0,                               | 13-bit Cour                                                                      | nter/Timer   |                                           |               |               |                                     |  |  |  |  |  |  |  |
|       |                   | U1: Mode 1,                               | 16-bit Court                                                                     | nter/Timer   | h Auto Poloo                              | Ч             |               |                                     |  |  |  |  |  |  |  |
|       |                   | 11: Mode 3                                | Two 8-bit C                                                                      | ounter/Time  | in Auto-Reioa<br>ers                      | u             |               |                                     |  |  |  |  |  |  |  |
|       |                   | 11. 10000 3,                              |                                                                                  |              | 515                                       |               |               | 1: Mode 3, Two 8-bit Counter/Timers |  |  |  |  |  |  |  |



#### 33.2.3. Comparator 0 Capture Mode

The capture mode in Timer 2 allows Comparator 0 rising edges to be captured with the timer clocking from the system clock or the system clock divided by 12. Timer 2 capture mode is enabled by setting TF2CEN to 1 and T2SPLIT to 0.

When capture mode is enabled, a capture event will be generated on every Comparator 0 rising edge. When the capture event occurs, the contents of Timer 2 (TMR2H:TMR2L) are loaded into the Timer 2 reload registers (TMR2RLH:TMR2RLL) and the TF2H flag is set (triggering an interrupt if Timer 2 interrupts are enabled). By recording the difference between two successive timer capture values, the Comparator 0 period can be determined with respect to the Timer 2 clock. The Timer 2 clock should be much faster than the capture clock to achieve an accurate reading.

This mode allows software to determine the time between consecutive Comparator 0 rising edges, which can be used for detecting changes in the capacitance of a capacitive switch, or measuring the frequency of a low-level analog signal.



Figure 33.6. Timer 2 Capture Mode Block Diagram



# C8051F70x/71x

#### 34.3.5.2. 9/10/11-bit Pulse Width Modulator Mode

The duty cycle of the PWM output signal in 9/10/11-bit PWM mode should be varied by writing to an "Auto-Reload" Register, which is dual-mapped into the PCA0CPHn and PCA0CPLn register locations. The data written to define the duty cycle should be right-justified in the registers. The auto-reload registers are accessed (read or written) when the bit ARSEL in PCA0PWM is set to 1. The capture/compare registers are accessed when ARSEL is set to 0.

When the least-significant N bits of the PCA0 counter match the value in the associated module's capture/compare register (PCA0CPn), the output on CEXn is asserted high. When the counter overflows from the Nth bit, CEXn is asserted low (see Figure 34.9). Upon an overflow from the Nth bit, the COVF flag is set, and the value stored in the module's auto-reload register is loaded into the capture/compare register. The value of N is determined by the CLSEL bits in register PCA0PWM.

The 9, 10 or 11-bit PWM mode is selected by setting the ECOMn and PWMn bits in the PCA0CPMn register, and setting the CLSEL bits in register PCA0PWM to the desired cycle length (other than 8-bits). If the MATn bit is set to 1, the CCFn flag for the module will be set each time a comparator match (rising edge) occurs. The COVF flag in PCA0PWM can be used to detect the overflow (falling edge), which will occur every 512 (9-bit), 1024 (10-bit) or 2048 (11-bit) PCA clock cycles. The duty cycle for 9/10/11-Bit PWM Mode is given in Equation 34.2, where N is the number of bits in the PWM cycle.

**Important Note About PCA0CPHn and PCA0CPLn Registers**: When writing a 16-bit value to the PCA0CPn 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{(2^N - PCA0CPn)}{2^N}$$



Equation 34.3. 9, 10, and 11-Bit PWM Duty Cycle

A 0% duty cycle may be generated by clearing the ECOMn bit to 0.

Figure 34.9. PCA 9, 10 and 11-Bit PWM Mode Diagram

