

Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Not For New Designs                                               |
|----------------------------|-------------------------------------------------------------------|
| Core Processor             | 8051                                                              |
| Core Size                  | 8-Bit                                                             |
| Speed                      | 100MHz                                                            |
| Connectivity               | SMBus (2-Wire/I <sup>2</sup> C), SPI, UART/USART                  |
| Peripherals                | POR, PWM, WDT                                                     |
| Number of I/O              | 25                                                                |
| Program Memory Size        | 32KB (32K x 8)                                                    |
| Program Memory Type        | FLASH                                                             |
| EEPROM Size                | -                                                                 |
| RAM Size                   | 1K x 8                                                            |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 3.6V                                                         |
| Data Converters            | -                                                                 |
| Oscillator Type            | Internal                                                          |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                 |
| Mounting Type              | Surface Mount                                                     |
| Package / Case             | 28-VFQFN Exposed Pad                                              |
| Supplier Device Package    | 28-QFN (5x5)                                                      |
| Purchase URL               | https://www.e-xfl.com/product-detail/silicon-labs/c8051f365-c-gmr |

Email: info@E-XFL.COM

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



Figure 1.13. Comparator1 Block Diagram

### 1.9. 10-bit Current Output DAC

The C8051F360/1/2/6/7/8/9 devices includes a 10-bit current-mode Digital-to-Analog Converter (IDA0). The maximum current output of the IDA0 can be adjusted for three different current settings; 0.5 mA, 1 mA, and 2 mA. IDA0 features a flexible output update mechanism which allows for seamless full-scale changes and supports jitter-free updates for waveform generation. Three update modes are provided, allowing IDA0 output updates on a write to IDA0H, on a Timer overflow, or on an external pin edge.



# 3. Global Electrical Characteristics

#### **Table 3.1. Global Electrical Characteristics**

-40 to +85 °C, 25 MHz system clock unless otherwise specified.

| Parameter                                            | Conditions                                      | Min        | Тур        | Max        | Units      |
|------------------------------------------------------|-------------------------------------------------|------------|------------|------------|------------|
| Digital Supply Voltage                               | SYSCLK = 0 to 50 MHz<br>SYSCLK > 50 MHz         | 2.7<br>3.0 | 3.0<br>3.3 | 3.6<br>3.6 | V          |
| Digital Supply RAM Data<br>Retention Voltage         |                                                 | _          | 1.5        |            | V          |
| SYSCLK (System Clock) <sup>1,2</sup>                 | C8051F360/1/2/3/4/5<br>C8051F366/7/8/9          | 0<br>0     | _          | 100<br>50  | MHz<br>MHz |
| Specified Operating<br>Temperature Range             |                                                 | -40        |            | +85        | °C         |
| Digital Supply Current—CP                            | U Active (Normal Mode, fetching instruction     | ns fron    | n Flash    | )          |            |
| I <sub>DD</sub> <sup>2</sup>                         | V <sub>DD</sub> = 3.6 V, F = 100 MHz            | —          | 68         | 75         | mA         |
|                                                      | V <sub>DD</sub> = 3.6 V, F = 25 MHz             | —          | 21         | 25         | mA         |
|                                                      | V <sub>DD</sub> = 3.0 V, F = 100 MHz            | —          | 54         | 60         | mA         |
|                                                      | V <sub>DD</sub> = 3.0 V, F = 25 MHz             | —          | 16         | 18         | mA         |
|                                                      | V <sub>DD</sub> = 3.0 V, F = 1 MHz              | —          | 0.48       | —          | mA         |
|                                                      | V <sub>DD</sub> = 3.0 V, F = 80 kHz             | —          | 36         | —          | μA         |
| I <sub>DD</sub> Supply Sensitivity <sup>3</sup>      | F = 25 MHz                                      | —          | 56         | —          | %/V        |
|                                                      | F = 1 MHz                                       | —          | 57         | —          | %/V        |
| I <sub>DD</sub> Frequency Sensitivity <sup>3,4</sup> | V <sub>DD</sub> = 3.0 V, F <= 20 MHz, T = 25 °C | —          | 0.45       | _          | mA/MHz     |
|                                                      | V <sub>DD</sub> = 3.0 V, F > 20 MHz, T = 25 °C  | —          | 0.38       | —          | mA/MHz     |
|                                                      | V <sub>DD</sub> = 3.6 V, F <= 20 MHz, T = 25 °C | —          | 0.61       | —          | mA/MHz     |
|                                                      | V <sub>DD</sub> = 3.6 V, F > 20 MHz, T = 25 °C  | —          | 0.51       | —          | mA/MHz     |



| Name | Pin<br>'F360/3<br>(48-pin) | Pin<br>'F361/4/6/8<br>(32-pin) | Pin<br>'F362/5/7/9<br>(28-pin) | Туре             | Description                                          |
|------|----------------------------|--------------------------------|--------------------------------|------------------|------------------------------------------------------|
| P3.1 | 24                         | 7                              | _                              | D I/O or<br>A In | Port 3.1. See Section 17 for a complete description. |
| P3.2 | 23                         | 8                              | _                              | D I/O or<br>A In | Port 3.2. See Section 17 for a complete description. |
| P3.3 | 22                         | 9                              | _                              | D I/O or<br>A In | Port 3.3. See Section 17 for a complete description. |
| P3.4 | 21                         | 10                             | _                              | D I/O or<br>A In | Port 3.4. See Section 17 for a complete description. |
| P3.5 | 20                         | _                              | _                              | D I/O or<br>A In | Port 3.5. See Section 17 for a complete description. |
| P3.6 | 17                         | —                              | _                              | D I/O or<br>A In | Port 3.6. See Section 17 for a complete description. |
| P3.7 | 16                         | _                              | _                              | D I/O or<br>A In | Port 3.7. See Section 17 for a complete description. |
| P4.0 | 15                         | _                              | _                              | D I/O or<br>A In | Port 4.0. See Section 17 for a complete description. |
| P4.1 | 14                         | _                              | _                              | D I/O            | Port 4.1. See Section 17 for a complete description. |
| P4.2 | 13                         | —                              | _                              | D I/O            | Port 4.2. See Section 17 for a complete description. |
| P4.3 | 12                         | _                              |                                | D I/O            | Port 4.3. See Section 17 for a complete description. |
| P4.4 | 11                         | —                              | _                              | D I/O            | Port 4.4. See Section 17 for a complete description. |
| P4.5 | 10                         | _                              | _                              | D I/O            | Port 4.5. See Section 17 for a complete description. |

Table 4.1. Pin Definitions for the C8051F36x (Continued)

# C8051F360/1/2/3/4/5/6/7/8/9



Figure 4.3. LQFP-32 Pinout Diagram (Top View)



# 6. 10-Bit Current Mode DAC (IDA0, C8051F360/1/2/6/7/8/9)

The C8051F360/1/2/6/7/8/9 devices include a 10-bit current-mode Digital-to-Analog Converter (IDAC). The maximum current output of the IDAC can be adjusted for three different current settings; 0.5 mA, 1 mA, and 2 mA. The IDAC is enabled or disabled with the IDA0EN bit in the IDA0 Control Register (see SFR Definition 6.1). When IDA0EN is set to '0', the IDAC port pin (P0.4 for C8051F360, P0.1 for C8051F361/2/6/7/8/9) behaves as a normal GPIO pin. When IDA0EN is set to '1', the digital output drivers and weak pullup for the IDAC pin are automatically disabled, and the pin is connected to the IDAC output. An internal bandgap bias generator is used to generate a reference current for the IDAC whenever it is enabled. When using the IDAC, the appropriate bit in the P0SKIP register should be set to '1' to force the Crossbar to skip the IDAC pin.

#### 6.1. IDA0 Output Scheduling

IDA0 features a flexible output update mechanism which allows for seamless full-scale changes and supports jitter-free updates for waveform generation. Three update modes are provided, allowing IDAC output updates on a write to IDA0H, on a Timer overflow, or on an external pin edge.

#### 6.1.1. Update Output On-Demand

In its default mode (IDA0CN.[6:4] = '111') the IDA0 output is updated "on-demand" on a write to the highbyte of the IDA0 data register (IDA0H). It is important to note that writes to IDA0L are held in this mode, and have no effect on the IDA0 output until a write to IDA0H takes place. If writing a full 10-bit word to the IDAC data registers, the 10-bit data word is written to the low byte (IDA0L) and high byte (IDA0H) data registers. **Data is latched into IDA0 after a write to the IDA0H register, so the write sequence should be IDA0L followed by IDA0H** if the full 10-bit resolution is required. The IDAC can be used in 8-bit mode by initializing IDA0L to the desired value (typically 0x00), and writing data to only IDA0H (see Section 6.2 for information on the format of the 10-bit IDAC data word within the 16-bit SFR space).



Figure 6.1. IDA0 Functional Block Diagram





Figure 8.3. Comparator Hysteresis Plot

The Comparator hysteresis is software-programmable via the Comparator Control registers CPT0CN and CPT1CN. 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 registers CPT0CN and CPT1CN (shown in SFR Definition 8.1 and SFR Definition 8.4). The amount of negative hysteresis voltage is determined by the settings of the CP0HYN and CP1HYN bits. As shown in Figure 8.3, 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 and CP1HYP bits.

Comparator interrupts can be generated on both rising-edge and falling-edge output transitions. (For Interrupt enable and priority control, see Section "10. Interrupt Handler" on page 107). The CP0FIF or CP1FIF flag is set to logic '1' upon a Comparator falling-edge occurrence, and the CP0RIF or CP1RIF 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 or CP1RIE to a logic '1'. The Comparator falling-edge interrupt mask is enabled by setting CP0FIE or CP1FIE to a logic '1'.

The output state of the Comparator can be obtained at any time by reading the CP0OUT or CP1OUT bit. The Comparator is enabled by setting the CP0EN or CP1EN 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. This Power Up Time is specified in Table 8.1 on page 79.



#### **Table 8.1. Comparator Electrical Characteristics**

 $V_{DD}$  = 3.0 V, -40 to +85 °C unless otherwise noted.

| Parameter                                         | Conditions             | Min      | Тур   | Max                    | Units |
|---------------------------------------------------|------------------------|----------|-------|------------------------|-------|
| Response Time:                                    | CPx+-CPx-=100  mV      | —        | 100   |                        | ns    |
| Mode 0, Vcm <sup>*</sup> = 1.5 V                  | CPx+-CPx-=-100  mV     | <u> </u> | 250   | —                      | ns    |
| Response Time:                                    | CPx+-CPx-=100  mV      | <u> </u> | 175   | —                      | ns    |
| Mode 1, Vcm <sup>*</sup> = 1.5 V                  | CPx+-CPx-=-100  mV     | <u> </u> | 500   | —                      | ns    |
| Response Time:                                    | CPx+ - CPx- = 100 mV   | <u> </u> | 320   | —                      | ns    |
| Mode 2, Vcm <sup>*</sup> = 1.5 V                  | CPx+-CPx-=-100  mV     | <u> </u> | 1100  | —                      | ns    |
| Response Time:                                    | CPx+ - CPx- = 100 mV   | <u> </u> | 1050  | —                      | ns    |
| Mode 3, Vcm <sup>*</sup> = 1.5 V                  | CPx+-CPx-=-100  mV     | <u> </u> | 5200  | —                      | ns    |
| Common-Mode Rejection Ratio                       |                        | <u> </u> | 1.26  | 5                      | mV/V  |
| Positive Hysteresis 1                             | CPxHYP1–0 = 00         | <u> </u> | 0     | 1                      | mV    |
| Positive Hysteresis 2                             | CPxHYP1-0 = 01         | 1        | 5     | 10                     | mV    |
| Positive Hysteresis 3                             | CPxHYP1–0 = 10         | 6        | 10    | 20                     | mV    |
| Positive Hysteresis 4                             | CPxHYP1–0 = 11         | 12       | 20    | 30                     | mV    |
| Negative Hysteresis 1                             | CPxHYN1–0 = 00         | <u> </u> | 0     | 1                      | mV    |
| Negative Hysteresis 2                             | CPxHYN1-0 = 01         | 1        | 5     | 10                     | mV    |
| Negative Hysteresis 3                             | CPxHYN1–0 = 10         | 6        | 10    | 20                     | mV    |
| Negative Hysteresis 4                             | CPxHYN1–0 = 11         | 12       | 20    | 30                     | mV    |
| Inverting or Non-Inverting Input<br>Voltage Range |                        | -0.25    |       | V <sub>DD</sub> + 0.25 | V     |
| Input Capacitance                                 |                        | —        | 4     |                        | pF    |
| Input Bias Current                                |                        | —        | 0.001 | —                      | nA    |
| Input Offset Voltage                              |                        | -5       | —     | +5                     | mV    |
| Power Supply                                      |                        |          |       |                        |       |
| Power Supply Rejection                            |                        | —        | 0.3   | —                      | mV/V  |
| Power-up Time                                     |                        | <u> </u> | 10    | —                      | μs    |
|                                                   | Mode 0                 | <u> </u> | 11.4  | 20                     | μA    |
| Supply Current at DC                              | Mode 1                 | <u> </u> | 4.6   | 10                     | μA    |
|                                                   | Mode 2                 | <u> </u> | 1.9   | 5                      | μA    |
|                                                   | Mode 3                 | <u> </u> | 0.4   | 2.5                    | μA    |
| *Note: Vcm is the common-mode vo                  | Jltage on CPx+ and CPx |          |       | <u> </u>               |       |



#### 9.3. Instruction Set

The instruction set of the CIP-51 System Controller is fully compatible with the standard MCS-51<sup>™</sup> instruction set; standard 8051 development tools can be used to develop software for the CIP-51. All CIP-51 instructions are the binary and functional equivalent of their MCS-51<sup>™</sup> counterparts, including opcodes, addressing modes and effect on PSW flags. However, instruction timing is different than that of the standard 8051.

#### 9.3.1. Instruction and CPU Timing

In many 8051 implementations, a distinction is made between machine cycles and clock cycles, with machine cycles varying from 2 to 12 clock cycles in length. However, the CIP-51 implementation is based solely on clock cycle timing. All instruction timings are specified in terms of clock cycles.

Due to the pipelined architecture of the CIP-51, most instructions execute in the same number of clock cycles as there are program bytes in the instruction. Conditional branch instructions take one less clock cycle to complete when the branch is not taken as opposed to when the branch is taken. Table 9.1 is the CIP-51 Instruction Set Summary, which includes the mnemonic, number of bytes, and number of clock cycles for each instruction.

#### 9.3.2. MOVX Instruction and Program Memory

In the CIP-51, the MOVX instruction serves three purposes: accessing on-chip XRAM, accessing off-chip XRAM, and accessing on-chip program Flash memory. The Flash access feature provides a mechanism for user software to update program code and use the program memory space for non-volatile data storage (see Section "13. Flash Memory" on page 135). The External Memory Interface provides a fast access to off-chip XRAM (or memory-mapped peripherals) via the MOVX instruction. Refer to Section "15. External Data Memory Interface and On-Chip XRAM" on page 152 for details.

| Mnemonic       | Description                              | Bytes | Clock<br>Cycles |
|----------------|------------------------------------------|-------|-----------------|
|                | Arithmetic Operations                    |       | •               |
| ADD A, Rn      | Add register to A                        | 1     | 1               |
| ADD A, direct  | Add direct byte to A                     | 2     | 2               |
| ADD A, @Ri     | Add indirect RAM to A                    | 1     | 2               |
| ADD A, #data   | Add immediate to A                       | 2     | 2               |
| ADDC A, Rn     | Add register to A with carry             | 1     | 1               |
| ADDC A, direct | Add direct byte to A with carry          | 2     | 2               |
| ADDC A, @Ri    | Add indirect RAM to A with carry         | 1     | 2               |
| ADDC A, #data  | Add immediate to A with carry            | 2     | 2               |
| SUBB A, Rn     | Subtract register from A with borrow     | 1     | 1               |
| SUBB A, direct | Subtract direct byte from A with borrow  | 2     | 2               |
| SUBB A, @Ri    | Subtract indirect RAM from A with borrow | 1     | 2               |
| SUBB A, #data  | Subtract immediate from A with borrow    | 2     | 2               |
| INC A          | Increment A                              | 1     | 1               |
| INC Rn         | Increment register                       | 1     | 1               |
| INC direct     | Increment direct byte                    | 2     | 2               |
| INC @Ri        | Increment indirect RAM                   | 1     | 2               |

| Table 9.1. CIP-51 | Instruction | Set Summary |
|-------------------|-------------|-------------|
|-------------------|-------------|-------------|



#### 9.4.7. Register Descriptions

Following are descriptions of SFRs related to the operation of the CIP-51 System Controller. Reserved bits should not be set to logic '1'. Future product versions may use these bits to implement new features in which case the reset value of the bit will be logic '0', selecting the feature's default state. Detailed descriptions of the remaining SFRs are included in the sections of the data sheet associated with their corresponding system function.









# SFR Definition 9.7. DPH: Data Pointer High Byte





# C8051F360/1/2/3/4/5/6/7/8/9

| SFR Page:        | all pages                                                                                                                                                                                                                                                                       |                                                                      |                                                                       |                                                   |            |            |       |             |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|-----------------------------------------------------------------------|---------------------------------------------------|------------|------------|-------|-------------|--|
| R/W              | R/W                                                                                                                                                                                                                                                                             | R/W                                                                  | R/W                                                                   | R/W                                               | R/W        | R/W        | R/W   | Reset Value |  |
| ET3              | ECP1                                                                                                                                                                                                                                                                            | ECP0                                                                 | EPCA0                                                                 | EADC0                                             | EWADC0     | _          | ESMB0 | 00000000    |  |
| Bit7             | Bit6 Bit5 Bit4 Bit3 Bit2 Bit1 Bit0                                                                                                                                                                                                                                              |                                                                      |                                                                       |                                                   |            |            |       |             |  |
| Bit 7:           | <ul> <li>it 7: ET3: Enable Timer 3 Interrupt.</li> <li>This bit sets the masking of the Timer 3 interrupt.</li> <li>0: Disable Timer 3 interrupts.</li> </ul>                                                                                                                   |                                                                      |                                                                       |                                                   |            |            |       |             |  |
| Bit 6:           | 1: Enable Int<br>ECP1: Enab<br>This bit sets<br>0: Disable C<br>1: Enable int                                                                                                                                                                                                   | errupt required<br>le Compara<br>the maskin<br>P1 interrup           | ests generation (CP1) g of the CP ts.                                 | Interrupt.<br>1 interrupt.                        |            | P1EIE flag | 16    |             |  |
| Bit 5:           | ECP0: Enable int<br>ECP0: Enab<br>This bit sets<br>0: Disable C<br>1: Enable int                                                                                                                                                                                                | le Compara<br>the maskin<br>P0 interrup                              | ator0 (CP0)<br>g of the CP<br>ts.                                     | Interrupt.<br>0 interrupt.                        |            |            | jo.   |             |  |
| Bit 4:           | 1: Enable interrupt requests generated by the CPORIF or CPOFIF flags.<br>EPCA0: Enable Programmable Counter Array (PCA0) Interrupt.<br>This bit sets the masking of the PCA0 interrupts.<br>0: Disable all PCA0 interrupts.                                                     |                                                                      |                                                                       |                                                   |            |            |       |             |  |
| Bit 3:           | <ul> <li>EADC0: 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 ADCINE flog.</li> </ul> |                                                                      |                                                                       |                                                   |            |            |       |             |  |
| Bit 2:           | EWADC0: Enable ADC0 Window Comparison Interrupt.<br>This bit sets the masking of the ADC0 Window Comparison interrupt.<br>0: Disable ADC0 Window Comparison interrupt.<br>1: Enable interrupt requests generated by the AD0WINT flag.                                           |                                                                      |                                                                       |                                                   |            |            |       |             |  |
| Bit 1:<br>Bit 0: | UNUSED. R<br>ESMB0: Ena<br>This bit sets<br>0: Disable al<br>1: Enable int                                                                                                                                                                                                      | ead = 0b. V<br>ble SMBus<br>the maskin<br>I SMB0 inte<br>errupt requ | Vrite = don'<br>s (SMB0) In<br>g of the SM<br>errupts.<br>ests genera | t care.<br>terrupt.<br>IB0 interrup<br>ated by SM | ot.<br>B0. | -          |       |             |  |

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



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

#### 13.1.2. Erasing Flash Pages From Software

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 writing to Flash memory using MOVX, Flash write operations must be enabled by: (1) the PSWE and PSEE bits must be set to '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.

A write to Flash memory can clear bits to logic '0' but cannot set them; only an erase operation can set bits to logic '1' in Flash. A byte location to be programmed should be erased before a new value is written. The Flash memory is organized in 1024-byte pages. The erase operation applies to an entire page (setting all bytes in the page to 0xFF). To erase an entire 1024-byte page, perform the following steps:

- Step 1. Disable interrupts (recommended).
- Step 2. Write the first key code to FLKEY: 0xA5.
- Step 3. Write the second key code to FLKEY: 0xF1.
- Step 4. Set PSEE (PSCTL.1) to enable Flash erases.
- Step 5. Set PSWE (PSCTL.0) to redirect MOVX commands to write to Flash.
- Step 6. Use the MOVX instruction to write a data byte to any location within the page to be erased.
- Step 7. Clear PSEE to disable Flash erases.
- Step 8. Clear the PSWE bit to redirect MOVX commands to the XRAM data space.
- Step 9. Re-enable interrupts.

#### 13.1.3. Writing Flash Memory From Software

Bytes in Flash memory can be written one byte at a time, or in small blocks. The CHBLKW bit in register CCH0CN (SFR Definition 14.1) controls whether a single byte or a block of bytes is written to Flash during a write operation. When CHBLKW is cleared to '0', the Flash will be written one byte at a time. When CHBLKW is set to '1', the Flash will be written in blocks of four bytes for addresses in code space. Block writes are performed in the same amount of time as single byte writes, which can save time when storing large amounts of data to Flash memory.

For single-byte writes to Flash, bytes are written individually, and the Flash write is performed after each MOVX write instruction. The recommended procedure for writing Flash in single bytes is as follows:

- Step 1. Disable interrupts.
- Step 2. Clear CHBLKW (register CCH0CN) to select single-byte write mode.
- Step 3. Write the first key code to FLKEY: 0xA5.
- Step 4. Write the second key code to FLKEY: 0xF1.
- Step 5. Set PSWE (register PSCTL) to redirect MOVX commands to write to Flash.
- Step 6. Clear the PSEE bit (register PSCTL).
- Step 7. Use the MOVX instruction to write a data byte to the desired location (repeat as necessary).
- Step 8. Clear the PSWE bit to redirect MOVX commands to the XRAM data space.
- Step 9. Re-enable interrupts.



#### 13.4. Flash Read Timing

On reset, the C8051F36x Flash read timing is configured for operation with system clocks up to 25 MHz. If the system clock will not be increased above 25 MHz, then the Flash timing registers may be left at their reset value.

For every Flash read or fetch, the system provides an internal Flash read strobe to the Flash memory. The Flash read strobe lasts for one or two system clock cycles, based on the FLRT bits (FLSCL.4 and FLSCL.5). If the system clock is greater than 25 MHz, the FLRT bit must be changed to the appropriate setting. Otherwise, data read or fetched from Flash may not represent the actual contents of Flash. When the Flash read strobe is asserted, Flash memory is active. When it is de-asserted, Flash memory is in a low power state.

The recommended procedure for updating FLRT is:

- Step 1. Select SYSCLK to 25 MHz or less.
- Step 2. Disable the prefetch engine (CHPFEN = '0' in CCH0CN register).
- Step 3. Set the FLRT bits to the appropriate setting for the SYSCLK.
- Step 4. Enable the prefetch engine (CHPFEN = '1' in CCH0CN register).

#### SFR Definition 13.3. FLSCL: Flash Memory Control





# C8051F360/1/2/3/4/5/6/7/8/9

|               |        |         | Lock Status |
|---------------|--------|---------|-------------|
|               | TAG 0  | SLOT 0  | UNLOCKED    |
|               | TAG 1  | SLOT 1  | UNLOCKED    |
| Cache Push    | TAG 2  | SLOT 2  | UNLOCKED    |
| Operations    |        |         |             |
|               |        |         | 1           |
| Ť             | TAG 26 | SLOT 26 | UNLOCKED    |
| CHSLOT = 27 — | TAG 27 | SLOT 27 | UNLOCKED    |
| $\bot$        | TAG 28 | SLOT 28 | LOCKED      |
| Cache Pon     | TAG 29 | SLOT 29 | LOCKED      |
| Operations    | TAG 30 | SLOT 30 | LOCKED      |
| Increment     | TAG 31 | SLOT 31 | LOCKED      |
| CHSLOT        |        |         |             |

Figure 14.3. Cache Lock Operation



# 16. Oscillators

The C8051F36x devices include a programmable internal high-frequency oscillator, a programmable internal low-frequency oscillator, and an external oscillator drive circuit. The internal high-frequency oscillator can be enabled, disabled, and calibrated using the OSCICN and OSCICL registers, as shown in Figure 16.1. The internal low-frequency oscillator can be enabled/disabled and calibrated using the OSCLCN register, as shown in SFR Definition 16.3. Both internal oscillators offer a selectable post-scaling feature. The system clock can be sourced by the external oscillator circuit, either internal oscillator, or the on-chip phase-locked loop (PLL). The internal oscillator's electrical specifications are given in Table 16.1 on page 170 and Table 16.2 on page 171.



Figure 16.1. Oscillator Diagram

### 16.1. Programmable Internal High-Frequency (H-F) Oscillator

All devices include a calibrated internal high-frequency oscillator that defaults as the system clock after a system reset. The internal oscillator period can be adjusted via the OSCICL register as defined by SFR Definition 16.1. OSCICL is factory calibrated to obtain a 24.5 MHz frequency.

Electrical specifications for the precision internal oscillator are given in Table 16.1 on page 170 and Table 16.2 on page 171. Note that the system clock may be derived from the programmed internal oscillator divided by 1, 2, 4, or 8, as defined by the IFCN bits in register OSCICN. The divide value defaults to 8 following a reset.



#### 16.2.1. Calibrating the Internal L-F Oscillator

Timers 2 and 3 include capture functions that can be used to capture the oscillator frequency, when running from a known time base. When either Timer 2 or Timer 3 is configured for L-F Oscillator Capture Mode, a falling edge (Timer 2) or rising edge (Timer 3) of the low-frequency oscillator's output will cause a capture event on the corresponding timer. As a capture event occurs, the current timer value (TMRnH:TMRnL) is copied into the timer reload registers (TMRnRLH:TMRnRLL). By recording the difference between two successive timer capture values, the low-frequency oscillator's period can be calculated. The OSCLF bits can then be adjusted to produce the desired oscillator frequency.



# SFR Definition 16.3. OSCLCN: Internal L-F Oscillator Control

### Table 16.2. Internal Low Frequency Oscillator Electrical Characteristics

-40°C to +85°C unless otherwise specified.

| Parameter                                  | Conditions                                      | Min | Тур | Max | Units  |
|--------------------------------------------|-------------------------------------------------|-----|-----|-----|--------|
| Oscillator Frequency                       | OSCLD = 11b                                     | 72  | 80  | 88  | kHz    |
| Oscillator Supply Current (from $V_{DD}$ ) | 25 °C, V <sub>DD</sub> = 3.0 V,<br>OSCLCN.7 = 1 |     | 5.5 | 10  | μA     |
| Power Supply Sensitivity                   | Constant Temperature                            | _   | 2.4 | —   | %/V    |
| Temperature Sensitivity                    | Constant Supply                                 |     | 30  | —   | ppm/°C |



### SFR Definition 17.14. P1MASK: Port1 Mask



# SFR Definition 17.15. P2: Port2

| SFR Page:<br>SFR Address:            | all pages<br>0xA0                                                                                                  | (bit addr                                                                                               | essable)                                                  |                                                |                                             |                                 |                          |             |
|--------------------------------------|--------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|------------------------------------------------|---------------------------------------------|---------------------------------|--------------------------|-------------|
| R/W                                  | R/W                                                                                                                | R/W                                                                                                     | R/W                                                       | R/W                                            | R/W                                         | R/W                             | R/W                      | Reset Value |
| P2.7                                 | P2.6                                                                                                               | P2.5                                                                                                    | P2.4                                                      | P2.3                                           | P2.2                                        | P2.1                            | P2.0                     | 11111111    |
| Bit7                                 | Bit6                                                                                                               | Bit5                                                                                                    | Bit4                                                      | Bit3                                           | Bit2                                        | Bit1                            | Bit0                     |             |
| Lite F 0. 1<br>(<br>1<br>F<br>(<br>1 | Vrite - Outpu<br>D: Logic Low<br>I: Logic High<br>Read - Alway<br>Din when cor<br>D: P2.n pin is<br>I: P2.n pin is | ut appears o<br>Output.<br>n Output (hi<br>ys reads '0'<br>nfigured as<br>s logic low.<br>s logic high. | on I/O pins<br>gh impedar<br>if selected<br>digital input | per Crossb<br>nce if corres<br>as analog i<br> | ar Registers<br>ponding P2<br>nput in regis | s.<br>2MDOUT.n k<br>ster P2MDII | oit = 0).<br>N. Directly | reads Port  |



#### 20.5. Serial Clock Timing

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

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



Figure 20.5. Master Mode Data/Clock Timing



## 21.2. Timer 2

Timer 2 is a 16-bit timer formed by two 8-bit SFRs: TMR2L (low byte) and TMR2H (high byte). Timer 2 may operate in 16-bit auto-reload mode or (split) 8-bit auto-reload mode. The T2SPLIT bit (TMR2CN.3) defines the Timer 2 operation mode.

Timer 2 may be clocked by the system clock, the system clock divided by 12, or the external oscillator source divided by 8. The external clock mode is ideal for real-time clock (RTC) functionality, where the internal oscillator drives the system clock while Timer 2 (and/or the PCA) is clocked by an external precision oscillator. Note that the external oscillator source divided by 8 is synchronized with the system clock.

#### 21.2.1. 16-bit Timer with Auto-Reload

When T2SPLIT (TMR2CN.3) is zero, Timer 2 operates as a 16-bit timer with auto-reload. Timer 2 can be clocked by SYSCLK, SYSCLK divided by 12, or the external oscillator clock source divided by 8. As the 16-bit timer register increments and overflows from 0xFFFF to 0x0000, the 16-bit value in the Timer 2 reload registers (TMR2RLH and TMR2RLL) is loaded into the Timer 2 register as shown in Figure 21.4, and the Timer 2 High Byte Overflow Flag (TMR2CN.7) is set. If Timer 2 interrupts are enabled (if IE.5 is set), an interrupt will be generated on each Timer 2 overflow. Additionally, if Timer 2 interrupts are enabled and the TF2LEN bit is set (TMR2CN.5), an interrupt will be generated each time the lower 8 bits (TMR2L) overflow from 0xFF to 0x00.



Figure 21.4. Timer 2 16-Bit Mode Block Diagram



#### 22.2.4. Frequency Output Mode

Frequency Output Mode produces a programmable-frequency square wave on the module's associated CEXn pin. The capture/compare module high byte holds the number of PCA clocks to count before the output is toggled. The frequency of the square wave is then defined by Equation 22.1.

#### Equation 22.1. Square Wave Frequency Output

$$F_{sqr} = \frac{F_{PCA}}{2 \times PCA0CPHn}$$

**Note:** A value of 0x00 in the PCA0CPHn register is equal to 256 for this equation.

Where  $F_{PCA}$  is the frequency of the clock selected by the CPS2–0 bits in the PCA mode register, PCA0MD. The lower byte of the capture/compare module is compared to the PCA0 counter low byte; on a match, CEXn is toggled and the offset held in the high byte is added to the matched value in PCA0CPLn. Frequency Output Mode is enabled by setting the ECOMn, TOGn, and PWMn bits in the PCA0CPMn register.

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



Figure 22.7. PCA Frequency Output Mode



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

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

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

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

#### 22.3.2. Watchdog Timer Usage

To configure the WDT, perform the following tasks:

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

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

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

