# E·XFL



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Active                                                         |
|----------------------------|----------------------------------------------------------------|
| Core Processor             | 8051                                                           |
| Core Size                  | 8-Bit                                                          |
| Speed                      | 25MHz                                                          |
| Connectivity               | SMBus (2-Wire/I <sup>2</sup> C), SPI, UART/USART               |
| Peripherals                | POR, PWM, Temp Sensor, WDT                                     |
| Number of I/O              | 17                                                             |
| Program Memory Size        | 16KB (16K x 8)                                                 |
| Program Memory Type        | FLASH                                                          |
| EEPROM Size                | ·                                                              |
| RAM Size                   | 768 x 8                                                        |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 3.6V                                                    |
| Data Converters            | A/D 16x10b; D/A 1x10b                                          |
| Oscillator Type            | Internal                                                       |
| Operating Temperature      | -40°C ~ 85°C (TA)                                              |
| Mounting Type              | Surface Mount                                                  |
| Package / Case             | 20-VFQFN Exposed Pad                                           |
| Supplier Device Package    | 20-QFN (4x4)                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/silicon-labs/c8051f336-gm |
|                            |                                                                |

Email: info@E-XFL.COM

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



Figure 1.1. C8051F336/7 Block Diagram





Figure 1.2. C8051F338/9 Block Diagram



## SFR Definition 13.1. EMI0CN: External Memory Interface Control

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

SFR Address = 0xAA

| Bit | Name   | Function                                                                                                                                                                                                                                                                                                                                                                      |
|-----|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:1 | UNUSED | Unused. Read = 0000000b; Write = Don't Care                                                                                                                                                                                                                                                                                                                                   |
| 0   | PGSEL  | XRAM Page Select.                                                                                                                                                                                                                                                                                                                                                             |
|     |        | The EMI0CN register provides the high byte of the 16-bit external data memory address when using an 8-bit MOVX command, effectively selecting a 256-byte page of RAM. Since the upper (unused) bits of the register are always zero, the PGSEL determines which page of XRAM is accessed.<br>For Example: If EMI0CN = 0x01, addresses 0x0100 through 0x01FF will be accessed. |



### 15.1. MCU Interrupt Sources and Vectors

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

### **15.1.1. Interrupt Priorities**

Each interrupt source can be individually programmed to one of two priority levels: low or high. A low priority interrupt service routine can be preempted by a high priority interrupt. A high priority interrupt cannot be preempted. Each interrupt has an associated interrupt priority bit in an SFR (IP or EIP1) used to configure its priority level. Low priority is the default. If two interrupts are recognized simultaneously, the interrupt with the higher priority is serviced first. If both interrupts have the same priority level, a fixed priority order is used to arbitrate, given in Table 15.1.

### 15.1.2. Interrupt Latency

Interrupt response time depends on the state of the CPU when the interrupt occurs. Pending interrupts are sampled and priority decoded each system clock cycle. Therefore, the fastest possible response time is 5 system clock cycles: 1 clock cycle to detect the interrupt and 4 clock cycles to complete the LCALL to the ISR. If an interrupt is pending when a RETI is executed, a single instruction is executed before an LCALL is made to service the pending interrupt. Therefore, the maximum response time for an interrupt (when no other interrupt is currently being serviced or the new interrupt is of greater priority) occurs when the CPU is performing an RETI instruction followed by a DIV as the next instruction. In this case, the response time is 18 system clock cycles: 1 clock cycle to detect the interrupt, 5 clock cycles to execute the RETI, 8 clock cycles to complete the DIV instruction and 4 clock cycles to execute the LCALL to the ISR. If the CPU is executing an ISR for an interrupt with equal or higher priority, the new interrupt will not be serviced until the current ISR completes, including the RETI and following instruction.



## SFR Definition 15.1. IE: Interrupt Enable

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

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

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



## SFR Definition 15.2. IP: Interrupt Priority

| Bit   | 7 | 6     | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|---|-------|-----|-----|-----|-----|-----|-----|
| Name  |   | PSPI0 | PT2 | PS0 | PT1 | PX1 | PT0 | PX0 |
| Туре  | R | R/W   | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset | 1 | 0     | 0   | 0   | 0   | 0   | 0   | 0   |

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

| Bit | Name   | Function                                                                                      |
|-----|--------|-----------------------------------------------------------------------------------------------|
| 7   | UNUSED | Unused. Read = 1, Write = Don't Care.                                                         |
| 6   | PSPI0  | Serial Peripheral Interface (SPI0) Interrupt Priority Control.                                |
|     |        | This bit sets the priority of the SPI0 interrupt.                                             |
|     |        | 0: SPI0 interrupt set to low priority level.<br>1: SPI0 interrupt set to high priority level. |
|     | PT2    |                                                                                               |
| 5   | PIZ    | Timer 2 Interrupt Priority Control.                                                           |
|     |        | This bit sets the priority of the Timer 2 interrupt.                                          |
|     |        | 0: Timer 2 interrupt set to low priority level.                                               |
|     | 500    | 1: Timer 2 interrupt set to high priority level.                                              |
| 4   | PS0    | UART0 Interrupt Priority Control.                                                             |
|     |        | This bit sets the priority of the UART0 interrupt.                                            |
|     |        | 0: UART0 interrupt set to low priority level.                                                 |
|     |        | 1: UART0 interrupt set to high priority level.                                                |
| 3   | PT1    | Timer 1 Interrupt Priority Control.                                                           |
|     |        | This bit sets the priority of the Timer 1 interrupt.                                          |
|     |        | 0: Timer 1 interrupt set to low priority level.                                               |
|     |        | 1: Timer 1 interrupt set to high priority level.                                              |
| 2   | PX1    | External Interrupt 1 Priority Control.                                                        |
|     |        | This bit sets the priority of the External Interrupt 1 interrupt.                             |
|     |        | 0: External Interrupt 1 set to low priority level.                                            |
|     |        | 1: External Interrupt 1 set to high priority level.                                           |
| 1   | PT0    | Timer 0 Interrupt Priority Control.                                                           |
|     |        | This bit sets the priority of the Timer 0 interrupt.                                          |
|     |        | 0: Timer 0 interrupt set to low priority level.                                               |
|     |        | 1: Timer 0 interrupt set to high priority level.                                              |
| 0   | PX0    | External Interrupt 0 Priority Control.                                                        |
|     |        | This bit sets the priority of the External Interrupt 0 interrupt.                             |
|     |        | 0: External Interrupt 0 set to low priority level.                                            |
|     |        | 1: External Interrupt 0 set to high priority level.                                           |



### SFR Definition 15.4. EIP1: Extended Interrupt Priority 1

| Bit   | 7   | 6        | 5    | 4     | 3     | 2      | 1    | 0     |
|-------|-----|----------|------|-------|-------|--------|------|-------|
| Name  | PT3 | Reserved | PCP0 | PPCA0 | PADC0 | PWADC0 | PMAT | PSMB0 |
| Туре  | 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 = 0xF6

| Bit | Name     | Function                                                                                                                                                                                                                                                                                                     |
|-----|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | PT3      | Timer 3 Interrupt Priority Control.This bit sets the priority of the Timer 3 interrupt.0: Timer 3 interrupts set to low priority level.1: Timer 3 interrupts set to high priority level.                                                                                                                     |
| 6   | Reserved | Reserved. Must Write 0.                                                                                                                                                                                                                                                                                      |
| 5   | PCP0     | Comparator0 (CP0) Interrupt Priority Control.<br>This bit sets the priority of the CP0 interrupt.<br>0: CP0 interrupt set to low priority level.<br>1: CP0 interrupt set to high priority level.                                                                                                             |
| 4   | PPCA0    | <ul> <li>Programmable Counter Array (PCA0) Interrupt Priority Control.</li> <li>This bit sets the priority of the PCA0 interrupt.</li> <li>0: PCA0 interrupt set to low priority level.</li> <li>1: PCA0 interrupt set to high priority level.</li> </ul>                                                    |
| 3   | PADC0    | <ul> <li>ADC0 Conversion Complete Interrupt Priority Control.</li> <li>This bit sets the priority of the ADC0 Conversion Complete interrupt.</li> <li>0: ADC0 Conversion Complete interrupt set to low priority level.</li> <li>1: ADC0 Conversion Complete interrupt set to high priority level.</li> </ul> |
| 2   | PWADC0   | <ul> <li>ADC0 Window Comparator Interrupt Priority Control.</li> <li>This bit sets the priority of the ADC0 Window interrupt.</li> <li>0: ADC0 Window interrupt set to low priority level.</li> <li>1: ADC0 Window interrupt set to high priority level.</li> </ul>                                          |
| 1   | PMAT     | Port Match Interrupt Priority Control.<br>This bit sets the priority of the Port Match Event interrupt.<br>0: Port Match interrupt set to low priority level.<br>1: Port Match interrupt set to high priority level.                                                                                         |
| 0   | PSMB0    | SMBus (SMB0) Interrupt Priority Control.This bit sets the priority of the SMB0 interrupt.0: SMB0 interrupt set to low priority level.1: SMB0 interrupt set to high priority level.                                                                                                                           |



### 19.4. External Oscillator Drive Circuit

The external oscillator circuit may drive an external crystal, ceramic resonator, capacitor, or RC network. A CMOS clock may also provide a clock input. For a crystal or ceramic resonator configuration, the crystal/resonator must be wired across the XTAL1 and XTAL2 pins as shown in Option 1 of Figure 19.1. A 10 M $\Omega$  resistor also must be wired across the XTAL2 and XTAL1 pins for the crystal/resonator configuration. In RC, capacitor, or CMOS clock configuration, the clock source should be wired to the XTAL2 pin as shown in Option 2, 3, or 4 of Figure 19.1. The type of external oscillator must be selected in the OSCXCN register, and the frequency control bits (XFCN) must be selected appropriately (see SFR Definition 19.5).

**Important Note on External Oscillator Usage:** Port pins must be configured when using the external oscillator circuit. When the external oscillator drive circuit is enabled in crystal/resonator mode, Port pins P0.2 and P0.3 are used as XTAL1 and XTAL2 respectively. When the external oscillator drive circuit is enabled in capacitor, RC, or CMOS clock mode, Port pin P0.3 is used as XTAL2. The Port I/O Crossbar should be configured to skip the Port pins used by the oscillator circuit; see Section "20.3. Priority Crossbar Decoder" on page 124 for Crossbar configuration. Additionally, when using the external oscillator circuit in crystal/resonator, capacitor, or RC mode, the associated Port pins should be configured as analog inputs. In CMOS clock mode, the associated pin should be configured as a digital input. See Section "20.4. Port I/O Initialization" on page 126 for details on Port input mode selection.



## SFR Definition 20.2. XBR1: Port I/O Crossbar Register 1

| Bit   | 7       | 6     | 5   | 4   | 3    | 2 | 1           | 0   |
|-------|---------|-------|-----|-----|------|---|-------------|-----|
| Name  | WEAKPUD | XBARE | T1E | T0E | ECIE |   | PCA0ME[1:0] |     |
| Туре  | R/W     | R/W   | R/W | R/W | R/W  | R | R/W         | R/W |
| Reset | 0       | 0     | 0   | 0   | 0    | 0 | 0           | 0   |

SFR Address = 0xE2

| Bit | Name        | Function                                                                                                                                                                                     |
|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | WEAKPUD     | Port I/O Weak Pullup Disable.<br>0: Weak Pullups enabled (except for Ports whose I/O are configured for analog mode).<br>1: Weak Pullups disabled.                                           |
| 6   | XBARE       | Crossbar Enable.<br>0: Crossbar disabled.<br>1: Crossbar enabled.                                                                                                                            |
| 5   | T1E         | <b>T1 Enable.</b><br>0: T1 unavailable at Port pin.<br>1: T1 routed to Port pin.                                                                                                             |
| 4   | TOE         | <b>T0 Enable.</b><br>0: T0 unavailable at Port pin.<br>1: T0 routed to Port pin.                                                                                                             |
| 3   | ECIE        | PCA0 External Counter Input Enable.<br>0: ECI unavailable at Port pin.<br>1: ECI routed to Port pin.                                                                                         |
| 2   | UNUSED      | Unused. Read = 0b; Write = Don't Care.                                                                                                                                                       |
| 1:0 | PCA0ME[1:0] | PCA Module I/O Enable Bits.<br>00: All PCA I/O unavailable at Port pins.<br>01: CEX0 routed to Port pin.<br>10: CEX0, CEX1 routed to Port pins.<br>11: CEX0, CEX1, CEX2 routed to Port pins. |



## SFR Definition 20.7. P0: Port 0

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

SFR Address = 0x80; Bit Addressable

| Bit | Name    | Description                                                                                                                                   | Write                                | Read                                                                    |
|-----|---------|-----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-------------------------------------------------------------------------|
| 7:0 | P0[7:0] | <b>Port 0 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. | LOW.<br>1: Set output latch to logic | 0: P0.n Port pin is logic<br>LOW.<br>1: P0.n Port pin is logic<br>HIGH. |

### SFR Definition 20.8. P0MDIN: Port 0 Input Mode

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

SFR Address = 0xF1

| Bit | Name        | Function                                                                                                    |
|-----|-------------|-------------------------------------------------------------------------------------------------------------|
| 7:0 | P0MDIN[7:0] | Analog Configuration Bits for P0.7–P0.0 (respectively).                                                     |
|     |             | Port pins configured for analog mode have their weak pullup, digital driver, and digital receiver disabled. |
|     |             | 0: Corresponding P0.n pin is configured for analog mode.                                                    |
|     |             | 1: Corresponding P0.n pin is not configured for analog mode.                                                |



| SMBCS1 | SMBCS0 | SMBus Clock Source         |
|--------|--------|----------------------------|
| 0      | 0      | Timer 0 Overflow           |
| 0      | 1      | Timer 1 Overflow           |
| 1      | 0      | Timer 2 High Byte Overflow |
| 1      | 1      | Timer 2 Low Byte Overflow  |

### Table 21.1. SMBus Clock Source Selection

The SMBCS1–0 bits select the SMBus clock source, which is used only when operating as a master or when the Free Timeout detection is enabled. When operating as a master, overflows from the selected source determine the absolute minimum SCL low and high times as defined in Equation 21.1. Note that the selected clock source may be shared by other peripherals so long as the timer is left running at all times. For example, Timer 1 overflows may generate the SMBus and UART baud rates simultaneously. Timer configuration is covered in Section "24. Timers" on page 180.

$$T_{HighMin} = T_{LowMin} = \frac{1}{f_{ClockSourceOverflow}}$$

### Equation 21.1. Minimum SCL High and Low Times

The selected clock source should be configured to establish the minimum SCL High and Low times as per Equation 21.1. When the interface is operating as a master (and SCL is not driven or extended by any other devices on the bus), the typical SMBus bit rate is approximated by Equation 21.2.

$$BitRate = \frac{f_{ClockSourceOverflow}}{3}$$

### Equation 21.2. Typical SMBus Bit Rate

Figure 21.4 shows the typical SCL generation described by Equation 21.2. Notice that  $T_{HIGH}$  is typically twice as large as  $T_{LOW}$ . The actual SCL output may vary due to other devices on the bus (SCL may be extended low by slower slave devices, or driven low by contending master devices). The bit rate when operating as a master will never exceed the limits defined by equation Equation 21.1.





Setting the EXTHOLD bit extends the minimum setup and hold times for the SDA line. The minimum SDA setup time defines the absolute minimum time that SDA is stable before SCL transitions from low-to-high. The minimum SDA hold time defines the absolute minimum time that the current SDA value remains stable



### 24.1.3. Mode 2: 8-bit Counter/Timer with Auto-Reload

Mode 2 configures Timer 0 and Timer 1 to operate as 8-bit counter/timers with automatic reload of the start value. TL0 holds the count and TH0 holds the reload value. When the counter in TL0 overflows from all ones to 0x00, the timer overflow flag TF0 in the TCON register is set and the counter in TL0 is reloaded from TH0. If Timer 0 interrupts are enabled, an interrupt will occur when the TF0 flag is set. The reload value in TH0 is not changed. TL0 must be initialized to the desired value before enabling the timer for the first count to be correct. When in Mode 2, Timer 1 operates identically to Timer 0.

Both counter/timers are enabled and configured in Mode 2 in the same manner as Mode 0. Setting the TR0 bit (TCON.4) enables the timer when either GATE0 in the TMOD register is logic 0 or when the input signal INT0 is active as defined by bit IN0PL in register IT01CF (see Section "15.3. External Interrupts /INT0 and /INT1" on page 89 for details on the external input signals INT0 and INT1).



Figure 24.2. T0 Mode 2 Block Diagram



### SFR Definition 24.6. TH0: Timer 0 High Byte

| Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 7             | 6                                                        | 5 | 4 | 3        | 2 | 1 | 0 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|----------------------------------------------------------|---|---|----------|---|---|---|
| Nam                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Name TH0[7:0] |                                                          |   |   |          |   |   |   |
| Туре                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | e R/W         |                                                          |   |   |          |   |   |   |
| Reset         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0 <td>0</td> <td>0</td> <td>0</td> <td>0</td> |               | 0                                                        | 0 | 0 | 0        |   |   |   |
| SFR A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ddress = 0x8  | С                                                        |   |   |          |   |   |   |
| Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Name          |                                                          |   |   | Function |   |   |   |
| 7:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | TH0[7:0]      | Timer 0 High Byte.                                       |   |   |          |   |   |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |               | The TH0 register is the high byte of the 16-bit Timer 0. |   |   |          |   |   |   |

### SFR Definition 24.7. TH1: Timer 1 High Byte

| Bit     | 7               | 6   | 5 | 4 | 3 | 2 | 1 | 0 |  |
|---------|-----------------|-----|---|---|---|---|---|---|--|
| Name    | TH1[7:0]        |     |   |   |   |   |   |   |  |
| Туре    |                 | R/W |   |   |   |   |   |   |  |
| Reset   | 0 0 0 0 0 0 0 0 |     |   |   |   |   |   |   |  |
| SFR Add | idress = 0x8D   |     |   |   |   |   |   |   |  |

| 01107 |          |                                                          |
|-------|----------|----------------------------------------------------------|
| Bit   | Name     | Function                                                 |
| 7:0   | TH1[7:0] | Timer 1 High Byte.                                       |
|       |          | The TH1 register is the high byte of the 16-bit Timer 1. |



### 24.2.3. Low-Frequency Oscillator (LFO) Capture Mode

The Low-Frequency Oscillator Capture Mode allows the LFO clock to be measured against the system clock or an external oscillator source. Timer 2 can be clocked from the system clock, the system clock divided by 12, or the external oscillator divided by 8, depending on the T2ML (CKCON.4), and T2XCLK settings.

Setting TF2CEN to 1 enables the LFO Capture Mode for Timer 2. In this mode, T2SPLIT should be set to 0, as the full 16-bit timer is used. Upon a falling edge of the low-frequency oscillator, the contents of Timer 2 (TMR2H:TMR2L) are loaded into the Timer 2 reload registers (TMR2RLH:TMR2RLL) and the TF2H flag is set. By recording the difference between two successive timer capture values, the LFO clock frequency can be determined with respect to the Timer 2 clock. The Timer 2 clock should be much faster than the LFO to achieve an accurate reading.



Figure 24.6. Timer 2 Low-Frequency Oscillation Capture Mode Block Diagram



## SFR Definition 24.9. TMR2RLL: Timer 2 Reload Register Low Byte

| Bit   | 7             | 6            | 5                                 | 4  | 3 | 2 | 1 | 0 |  |  |
|-------|---------------|--------------|-----------------------------------|----|---|---|---|---|--|--|
| Nam   | e             | TMR2RLL[7:0] |                                   |    |   |   |   |   |  |  |
| Туре  | )             |              |                                   | R/ | W |   |   |   |  |  |
| Rese  | et O          | 0            | 0                                 | 0  | 0 | 0 | 0 | 0 |  |  |
| SFR A | ddress = 0xCA | A.           |                                   |    |   |   |   |   |  |  |
| Bit   | Name          |              | Function                          |    |   |   |   |   |  |  |
| 7:0   | TMR2RLL[7:0   | ] Timer 2 I  | Timer 2 Reload Register Low Byte. |    |   |   |   |   |  |  |

TMR2RLL holds the low byte of the reload value for Timer 2.

### SFR Definition 24.10. TMR2RLH: Timer 2 Reload Register High Byte

| Bit                  | 7                 | 6 | 5                                                                                                        | 4  | 3 | 2 | 1 | 0 |  |
|----------------------|-------------------|---|----------------------------------------------------------------------------------------------------------|----|---|---|---|---|--|
| Nam                  | Name TMR2RLH[7:0] |   |                                                                                                          |    |   |   |   |   |  |
| Туре                 | e                 |   |                                                                                                          | R/ | W |   |   |   |  |
| <b>Reset</b> 0 0 0 0 |                   | 0 | 0                                                                                                        | 0  | 0 | 0 |   |   |  |
| SFR /                | Address = 0xCB    |   |                                                                                                          |    |   |   |   |   |  |
| Bit                  | Name              |   | Function                                                                                                 |    |   |   |   |   |  |
| 7:0                  | TMR2RLH[7:0]      |   | <b>Timer 2 Reload Register High Byte.</b><br>MR2RLH holds the high byte of the reload value for Timer 2. |    |   |   |   |   |  |

### SFR Definition 24.11. TMR2L: Timer 2 Low Byte

| Bit    | 7             | 6          | 5 | 4  | 3 | 2 | 1 | 0 |  |  |
|--------|---------------|------------|---|----|---|---|---|---|--|--|
| Name   |               | TMR2L[7:0] |   |    |   |   |   |   |  |  |
| Туре   |               |            |   | R/ | W |   |   |   |  |  |
| Reset  | 0             | 0          | 0 | 0  | 0 | 0 | 0 | 0 |  |  |
| SFR Ad | ddress = 0xCC |            |   |    |   |   |   |   |  |  |
| Bit    | Name          | Function   |   |    |   |   |   |   |  |  |

| BIt | Name       | Function                                                                                                                                          |
|-----|------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | TMR2L[7:0] | Timer 2 Low Byte.                                                                                                                                 |
|     |            | In 16-bit mode, the TMR2L register contains the low byte of the 16-bit Timer 2. In 8-<br>bit mode, TMR2L contains the 8-bit low byte timer value. |



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

When T3SPLIT is set, Timer 3 operates as two 8-bit timers (TMR3H and TMR3L). Both 8-bit timers operate in auto-reload mode as shown in Figure 24.8. TMR3RLL holds the reload value for TMR3L; TMR3RLH holds the reload value for TMR3H. The TR3 bit in TMR3CN handles the run control for TMR3H. TMR3L is always running when configured for 8-bit Mode.

Each 8-bit timer may be configured to use SYSCLK, SYSCLK divided by 12, the external oscillator clock source divided by 8, or the internal Low-frequency Oscillator. The Timer 3 Clock Select bits (T3MH and T3ML in CKCON) select either SYSCLK or the clock defined by the Timer 3 External Clock Select bits (T3XCLK[1:0] in TMR3CN), as follows:

| ТЗМН | T3XCLK[1:0] | TMR3H Clock<br>Source |
|------|-------------|-----------------------|
| 0    | 00          | SYSCLK / 12           |
| 0    | 01          | External Clock / 8    |
| 0    | 10          | Reserved              |
| 0    | 11          | Internal LFO          |
| 1    | Х           | SYSCLK                |

| T3ML | T3XCLK[1:0] | TMR3L Clock<br>Source |
|------|-------------|-----------------------|
| 0    | 00          | SYSCLK / 12           |
| 0    | 01          | External Clock / 8    |
| 0    | 10          | Reserved              |
| 0    | 11          | Internal LFO          |
| 1    | Х           | SYSCLK                |

The TF3H bit is set when TMR3H overflows from 0xFF to 0x00; the TF3L bit is set when TMR3L overflows from 0xFF to 0x00. When Timer 3 interrupts are enabled, an interrupt is generated each time TMR3H overflows. If Timer 3 interrupts are enabled and TF3LEN (TMR3CN.5) is set, an interrupt is generated each time either TMR3L or TMR3H overflows. When TF3LEN is enabled, software must check the TF3H and TF3L flags to determine the source of the Timer 3 interrupt. The TF3H and TF3L interrupt flags are not cleared by hardware and must be manually cleared by software.



Figure 24.8. Timer 3 8-Bit Mode Block Diagram



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

| Bit   | 7              | 6            | 5                                 | 4  | 3 | 2 | 1 | 0 |
|-------|----------------|--------------|-----------------------------------|----|---|---|---|---|
| Nam   | e              | TMR3RLL[7:0] |                                   |    |   |   |   |   |
| Туре  | 9              |              |                                   | R/ | W |   |   |   |
| Rese  | et O           | 0            | 0                                 | 0  | 0 | 0 | 0 | 0 |
| SFR A | Address = 0x92 |              |                                   |    |   |   |   |   |
| Bit   | Name           |              | Function                          |    |   |   |   |   |
| 7:0   | TMR3RLL[7:0]   | Timer 3 F    | Timer 3 Reload Register Low Byte. |    |   |   |   |   |

TMR3RLL holds the low byte of the reload value for Timer 3.

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

| Bit               | 7               | 6         | 5          | 4              | 3        | 2             | 1     | 0 |
|-------------------|-----------------|-----------|------------|----------------|----------|---------------|-------|---|
| Name TMR3RLH[7:0] |                 |           |            |                |          |               | 1     |   |
| Туре              | kype R/W        |           |            |                |          |               |       |   |
| Rese              | et <sup>0</sup> | 0         | 0          | 0              | 0        | 0             | 0     | 0 |
| SFR A             | Address = 0x93  |           |            |                |          |               |       |   |
| Bit               | Name            |           |            |                | Function |               |       |   |
| 7:0               | TMR3RLH[7:0]    | Timer 3 R | eload Regi | ster High B    | yte.     |               |       |   |
|                   |                 |           |            | high byte of t |          | alue for Time | er 3. |   |

### SFR Definition 24.16. TMR3L: Timer 3 Low Byte

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

### SFR Address = 0x94

| Bit | Name       | Function                                                                                                                                      |
|-----|------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | TMR3L[7:0] | Timer 3 Low Byte.                                                                                                                             |
|     |            | In 16-bit mode, the TMR3L register contains the low byte of the 16-bit Timer 3. In 8-bit mode, TMR3L contains the 8-bit low byte timer value. |



## C2 Register Definition 26.2. DEVICEID: C2 Device ID

| Bit   | 7            | 6         | 5              | 4              | 3              | 2             | 1           | 0      |
|-------|--------------|-----------|----------------|----------------|----------------|---------------|-------------|--------|
| Nam   | е            |           |                | DEVICE         | EID[7:0]       | I             |             |        |
| Туре  | e            |           |                | R/             | W              |               |             |        |
| Rese  | et 0         | 0         | 0              | 1              | 0              | 1             | 0           | 0      |
| C2 Ac | dress: 0x00  |           |                |                |                |               | •           |        |
| Bit   | Name         |           |                |                | Function       |               |             |        |
| 7:0   | DEVICEID[7:0 | Device I  | D.             |                |                |               |             |        |
|       |              | This read | I-only registe | er returns the | e 8-bit device | e ID: 0x14 (0 | 28051F336/7 | /8/9). |

### C2 Register Definition 26.3. REVID: C2 Revision ID

| Bit   | 7           | 6                  | 5               | 4             | 3              | 2           | 1           | 0           |
|-------|-------------|--------------------|-----------------|---------------|----------------|-------------|-------------|-------------|
| Nam   | е           | REVID[7:0]         |                 |               |                |             |             |             |
| Туре  | e           | R/W                |                 |               |                |             |             |             |
| Rese  | et Varies   | Varies             | Varies          | Varies        | Varies         | Varies      | Varies      | Varies      |
| C2 Ad | dress: 0x01 |                    |                 |               |                |             |             |             |
| Bit   | Name        |                    |                 |               | Function       |             |             |             |
| 7:0   | REVID[7:0]  | <b>Revision ID</b> |                 |               |                |             |             |             |
|       |             | This read-or       | nly register re | eturns the 8- | bit revision I | D. For exam | ple: 0x00 = | Revision A. |



## C2 Register Definition 26.4. FPCTL: C2 Flash Programming Control

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

C2 Address: 0x02

| Bit | Name       | Function                                                                                                                                                                                                                                                                    |
|-----|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | FPCTL[7:0] | Flash Programming Control Register.                                                                                                                                                                                                                                         |
|     |            | This register is used to enable Flash programming via the C2 interface. To enable C2 Flash programming, the following codes must be written in order: 0x02, 0x01. Note that once C2 Flash programming is enabled, a system reset must be issued to resume normal operation. |

### C2 Register Definition 26.5. FPDAT: C2 Flash Programming Data

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

C2 Address: 0xB4

| Bit | Name       |                  | Function                                                                                                                     |  |  |  |  |
|-----|------------|------------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 7:0 | FPDAT[7:0] | C2 Flash Program | C2 Flash Programming Data Register.                                                                                          |  |  |  |  |
|     |            | •                | nis register is used to pass Flash commands, addresses, and data during C2 Flas<br>ccesses. Valid commands are listed below. |  |  |  |  |
|     |            | Code             | Command                                                                                                                      |  |  |  |  |
|     |            | 0x06             | Flash Block Read                                                                                                             |  |  |  |  |
|     |            | 0x07             | Flash Block Write                                                                                                            |  |  |  |  |
|     |            | 0x08             | Flash Page Erase                                                                                                             |  |  |  |  |
|     |            | 0x03             | Device Erase                                                                                                                 |  |  |  |  |





#### Disclaimer

Silicon Laboratories intends to provide customers with the latest, accurate, and in-depth documentation of all peripherals and modules available for system and software implementers using or intending to use the Silicon Laboratories products. Characterization data, available modules and peripherals, memory sizes and memory addresses refer to each specific device, and "Typical" parameters provided can and do vary in different applications. Application examples described herein are for illustrative purposes only. Silicon Laboratories reserves the right to make changes without further notice and limitation to product information, specifications, and descriptions herein, and does not give warranties as to the accuracy or completeness of the included information. Silicon Laboratories shall have no liability for the consequences of use of the information supplied herein. This document does not imply or express copyright licenses granted hereunder to design or fabricate any integrated circuits. The products must not be used within any Life Support System without the specific to result in significant personal injury or death. Silicon Laboratories products are generally not intended to support or sustain life and/or health, which, if it fails, can be reasonably expected to result in significant personal injury or death. Silicon Laboratories products are generally not intended for military applications. Silicon Laboratories products shall under no circumstances be used in weapons of mass destruction including (but not limited to) nuclear, biological or chemical weapons, or missiles capable of delivering such weapons.

#### **Trademark Information**

Silicon Laboratories Inc., Silicon Laboratories, Silicon Labs, SiLabs and the Silicon Labs logo, CMEMS®, EFM, EFM32, EFR, Energy Micro, Energy Micro logo and combinations thereof, "the world's most energy friendly microcontrollers", Ember®, EZLink®, EZMac®, EZRadio®, EZRadioPRO®, DSPLL®, ISOmodem ®, Precision32®, ProSLIC®, SiPHY®, USBXpress® and others are trademarks or registered trademarks of Silicon Laboratories Inc. ARM, CORTEX, Cortex-M3 and THUMB are trademarks or registered trademarks of ARM Holdings. Keil is a registered trademark of ARM Limited. All other products or brand names mentioned herein are trademarks of their respective holders.



Silicon Laboratories Inc. 400 West Cesar Chavez Austin, TX 78701 USA

### http://www.silabs.com