



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             | Last Time Buy                                                   |
|----------------------------|-----------------------------------------------------------------|
| Core Processor             | 8051                                                            |
| Core Size                  | 8-Bit                                                           |
| Speed                      | 25MHz                                                           |
| Connectivity               | SMBus (2-Wire/I <sup>2</sup> C), UART/USART                     |
| Peripherals                | POR, PWM, WDT                                                   |
| Number of I/O              | 8                                                               |
| Program Memory Size        | 4KB (4K x 8)                                                    |
| Program Memory Type        | FLASH                                                           |
| EEPROM Size                | -                                                               |
| RAM Size                   | 256 x 8                                                         |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 3.6V                                                     |
| Data Converters            | -                                                               |
| Oscillator Type            | Internal                                                        |
| Operating Temperature      | -40°C ~ 85°C (TA)                                               |
| Mounting Type              | Surface Mount                                                   |
| Package / Case             | 14-SOIC (0.154", 3.90mm Width)                                  |
| Supplier Device Package    | 14-SOIC                                                         |
| Purchase URL               | https://www.e-xfl.com/product-detail/silicon-labs/c8051f304-gsr |

Email: info@E-XFL.COM

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

# 5.3. Modes of Operation

ADC0 has a maximum conversion speed of 500 ksps. The ADC0 conversion clock is a divided version of the system clock, determined by the AD0SC bits in the ADC0CF register (system clock divided by (AD0SC + 1) for  $0 \le AD0SC \le 31$ ).

#### 5.3.1. Starting a Conversion

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

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

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

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



# SFR Definition 5.1. AMX0SL: AMUX0 Channel Select (C8051F300/2)

| R/W          | R/W          | R/W        | R/W                  | R/W             | R/W           | R/W           | R/W          | Reset Value  |
|--------------|--------------|------------|----------------------|-----------------|---------------|---------------|--------------|--------------|
| AMX0N        | 3 AMX0N2     | AMX0N1     | AMX0N0               | AMX0P3          | AMX0P2        | AMX0P1        | AMX0P0       | 00000000     |
| Bit7         | Bit6         | Bit5       | Bit4                 | Bit3            | Bit2          | Bit1          | Bit0         | SFR Address: |
|              |              |            |                      |                 |               |               |              | 0xBB         |
|              |              |            |                      |                 |               |               |              |              |
| Bits7–4:     | AMX0N3–0:    | AMUX0 Ne   | egative Inpu         | t Selection.    |               |               |              |              |
|              | Note that wr | IEN GND IS | selected as          | the Negati      |               | JCU operation | es in Single | e-enaea      |
|              | 0000_1000h   |            | ative Input          | selected n      | ar the chart  |               |              | ie.          |
|              | 0000 10000   | . ADOUNC   | gauve input          | Sciected p      |               | DCIOW.        |              |              |
|              | AMX0N        | 3–0        | ADC                  | ) Negative      | Input         |               |              |              |
|              | 0000         | )          |                      | P0.0            |               |               |              |              |
|              | 0001         |            |                      | P0.1            |               |               |              |              |
|              | 0010         | )          |                      | P0.2            |               |               |              |              |
|              | 0011         |            |                      | P0.3            |               |               |              |              |
|              | 0100         | )          |                      | P0.4            |               |               |              |              |
|              | 0101         |            |                      | P0.5            |               |               |              |              |
|              | 0110         | 0110       |                      | P0.6            |               |               |              |              |
|              | 0111         | 0111       |                      | P0.7            |               | <u> </u>      |              |              |
|              | 1xxx         | (          | GND (ADC             | in Single-E     | nded Mode     | )             |              |              |
| D:4-0.0.     |              |            |                      | O a la ati a a  |               |               |              |              |
| DIIS $3-0$ . | AIVIAUP3-0.  |            | sitive Input         | Selection.      | r the chart h |               |              |              |
|              | 1010–1111b   |            | Silive Input :<br>-D | selected pe     |               |               |              |              |
|              |              |            |                      |                 |               |               |              |              |
|              | AMX0P        | 3–0        | ADC                  | 0 Positive      | Input         |               |              |              |
|              | 0000         | )          |                      | P0.0            |               |               |              |              |
|              | 0001         |            |                      | P0.1            |               |               |              |              |
|              | 0010         | )          |                      | P0.2            |               |               |              |              |
|              | 0011         |            |                      | P0.3            |               |               |              |              |
|              | 0100         |            |                      | P0.4            |               |               |              |              |
|              | 0101         |            |                      | P0.5            |               |               |              |              |
|              | 0110         | )          |                      | P0.6            |               |               |              |              |
|              | 0111         |            |                      | P0.7            |               |               |              |              |
|              | 1000         | )          | Tem                  | perature Se     | ensor         |               |              |              |
|              | 1001         |            |                      | V <sub>DD</sub> |               |               |              |              |
|              |              |            |                      |                 |               |               |              |              |



**CIP-51 Instruction Set Summary**, which includes the mnemonic, number of bytes, and number of clock cycles for each instruction.

#### 8.1.2. MOVX Instruction and Program Memory

The MOVX instruction is typically used to access external data memory (Note: the C8051F300/1/2/3/4/5 does not support external data or program memory). In the CIP-51, the MOVX instruction accesses the onchip program memory space implemented as re-programmable Flash memory. This feature provides a mechanism for the CIP-51 to update program code and use the program memory space for non-volatile data storage. Refer to **Section "10. Flash Memory" on page 89** for further 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               |  |  |  |  |  |
| DEC A                 | Decrement A                              | 1     | 1               |  |  |  |  |  |
| DEC Rn                | Decrement register                       | 1     | 1               |  |  |  |  |  |
| DEC direct            | Decrement direct byte                    | 2     | 2               |  |  |  |  |  |
| DEC @Ri               | Decrement indirect RAM                   | 1     | 2               |  |  |  |  |  |
| INC DPTR              | Increment Data Pointer                   | 1     | 1               |  |  |  |  |  |
| MUL AB                | Multiply A and B                         | 1     | 4               |  |  |  |  |  |
| DIV AB                | Divide A by B                            | 1     | 8               |  |  |  |  |  |
| DA A                  | Decimal adjust A                         | 1     | 1               |  |  |  |  |  |
|                       | Logical Operations                       |       |                 |  |  |  |  |  |
| ANL A, Rn             | AND Register to A                        | 1     | 1               |  |  |  |  |  |
| ANL A, direct         | AND direct byte to A                     | 2     | 2               |  |  |  |  |  |
| ANLA, @Ri             | AND indirect RAM to A                    | 1     | 2               |  |  |  |  |  |
| ANL A, #data          | AND immediate to A                       | 2     | 2               |  |  |  |  |  |

# Table 8.1. CIP-51 Instruction Set Summary



#### 8.2.4. Bit Addressable Locations

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

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

MOV C, 22.3h

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

#### 8.2.5. Stack

A programmer's stack can be located anywhere in the 256-byte data memory. The stack area is designated using the Stack Pointer (SP, 0x81) SFR. The SP will point to the last location used. The next value pushed on the stack is placed at SP+1 and then SP is incremented. A reset initializes the stack pointer to location 0x07. Therefore, the first value pushed on the stack is placed at location 0x08, which is also the first register (R0) of register bank 1. Thus, if more than one register bank is to be used, the SP should be initialized to a location in the data memory not being used for data storage. The stack depth can extend up to 256 bytes.

#### 8.2.6. Special Function Registers

The direct-access data memory locations from 0x80 to 0xFF constitute the special function registers (SFRs). The SFRs provide control and data exchange with the CIP-51's resources and peripherals. The CIP-51 duplicates the SFRs found in a typical 8051 implementation as well as implementing additional SFRs used to configure and access the subsystems unique to the MCU. This allows the addition of new functionality while retaining compatibility with the MCS-51<sup>™</sup> instruction set. Table 8.2 lists the SFRs implemented in the CIP-51 System Controller.

The SFR registers are accessed anytime the direct addressing mode is used to access memory locations from 0x80 to 0xFF. SFRs with addresses ending in 0x0 or 0x8 (e.g. P0, TCON, SCON0, IE, etc.) are bit-addressable as well as byte-addressable. All other SFRs are byte-addressable only. Unoccupied addresses in the SFR space are reserved for future use. Accessing these areas will have an indeterminate effect and should be avoided. Refer to the corresponding pages of the datasheet, as indicated in Table 8.3, for a detailed description of each register.



| Interrupt Source              | Interrupt<br>Vector | Priority<br>Order | Pending Flag                             | Bit addressable? | Cleared by HW? | Enable<br>Flag     | Priority<br>Control |
|-------------------------------|---------------------|-------------------|------------------------------------------|------------------|----------------|--------------------|---------------------|
| Reset                         | 0x0000              | Тор               | None                                     | N/A              | N/A            | Always<br>Enabled  | Always<br>Highest   |
| External Interrupt 0 (/INT0)  | 0x0003              | 0                 | IE0 (TCON.1)                             | Y                | Y              | EX0 (IE.0)         | PX0 (IP.0)          |
| Timer 0 Overflow              | 0x000B              | 1                 | TF0 (TCON.5)                             | Y                | Y              | ET0 (IE.1)         | PT0 (IP.1)          |
| External Interrupt 1 (/INT1)  | 0x0013              | 2                 | IE1 (TCON.3)                             | Y                | Y              | EX1 (IE.2)         | PX1 (IP.2)          |
| Timer 1 Overflow              | 0x001B              | 3                 | TF1 (TCON.7)                             | Y                | Y              | ET1 (IE.3)         | PT1 (IP.3)          |
| UART0                         | 0x0023              | 4                 | RI0 (SCON0.0)<br>TI0 (SCON0.1)           | Y                | N              | ES0 (IE.4)         | PS0 (IP.4)          |
| Timer 2 Overflow              | 0x002B              | 5                 | TF2H<br>(TMR2CN.7)<br>TF2L<br>(TMR2CN.6) | Y                | N              | ET2 (IE.5)         | PT2 (IP.5)          |
| SMBus Interface               | 0x0033              | 6                 | SI (SMB0CN.0)                            | Y                | N              | ESMB0<br>(EIE1.0)  | PSMB0<br>(EIP1.0)   |
| ADC0 Window Compare           | 0x003B              | 7                 | AD0WINT<br>(ADC0CN.3)                    | Y                | N              | EWADC0<br>(EIE1.1) | PWADC0<br>(EIP1.1)  |
| ADC0 Conversion Com-<br>plete | 0x0043              | 8                 | AD0INT<br>(ADC0CN.5)                     | Y                | N              | EADC0C<br>(EIE1.2) | PADC0C<br>(EIP1.2)  |
| Programmable Counter<br>Array | 0x004B              | 9                 | CF (PCA0CN.7)<br>CCFn<br>(PCA0CN.n)      | Y                | N              | EPCA0<br>(EIE1.3)  | PPCA0<br>(EIP1.3)   |
| Comparator0 Falling Edge      | 0x0053              | 10                | CP0FIF<br>(CPT0CN.4)                     | N                | N              | ECP0F<br>(EIE1.4)  | PCP0F<br>(EIP1.4)   |
| Comparator0 Rising Edge       | 0x005B              | 11                | CP0RIF<br>(CPT0CN.5)                     | N                | N              | ECP0R<br>(EIE1.5)  | PCP0R<br>(EIP1.5)   |

Table 8.4. Interrupt Summary



# 8.4. Power Management Modes

The CIP-51 core has two software programmable power management modes: Idle and Stop. Idle mode halts the CPU while leaving the peripherals and clocks active. In Stop mode, the CPU is halted, all interrupts and timers (except the Missing Clock Detector) are inactive, and the system clock is stopped (analog peripherals remain in their selected states). Since clocks are running in Idle mode, power consumption is dependent upon the system clock frequency and the number of peripherals left in active mode before entering Idle. Stop mode consumes the least power. SFR Definition 8.12 describes the Power Control Register (PCON) used to control the CIP-51's power management modes.

Although the CIP-51 has Idle and Stop modes built in (as with any standard 8051 architecture), power management of the entire MCU is better accomplished by enabling/disabling individual peripherals as needed. Each analog peripheral can be disabled when not in use and placed in low power mode. Digital peripherals, such as timers or serial buses, draw little power when they are not in use. Turning off the oscillators lowers power consumption considerably; however a reset is required to restart the MCU.

#### 8.4.1. Idle Mode

Setting the Idle Mode Select bit (PCON.0) causes the CIP-51 to halt the CPU and enter Idle mode as soon as the instruction that sets the bit completes execution. All internal registers and memory maintain their original data. All analog and digital peripherals can remain active during Idle mode.

Idle mode is terminated when an enabled interrupt is asserted or a reset occurs. The assertion of an enabled interrupt will cause the Idle Mode Selection bit (PCON.0) to be cleared and the CPU to resume operation. The pending interrupt will be serviced and the next instruction to be executed after the return from interrupt (RETI) will be the instruction immediately following the one that set the Idle Mode Select bit. If Idle mode is terminated by an internal or external reset, the CIP-51 performs a normal reset sequence and begins program execution at address 0x0000.

If enabled, the Watchdog Timer (WDT) will eventually cause an internal watchdog reset and thereby terminate the Idle mode. This feature protects the system from an unintended permanent shutdown in the event of an inadvertent write to the PCON register. If this behavior is not desired, the WDT may be disabled by software prior to entering the Idle mode if the WDT was initially configured to allow this operation. This provides the opportunity for additional power savings, allowing the system to remain in the Idle mode indefinitely, waiting for an external stimulus to wake up the system. Refer to **Section "16.3. Watchdog Timer Mode" on page 164** for more information on the use and configuration of the WDT.

# Note: Any instruction that sets the IDLE bit should be immediately followed by an instruction that has 2 or more opcode bytes. For example:

| // in 'C':              |                                            |
|-------------------------|--------------------------------------------|
| PCON $  = 0 \times 01;$ | // set IDLE bit                            |
| PCON = PCON;            | // followed by a 3-cycle dummy instruction |
| ; in assembly:          |                                            |
| ORL PCON, #01h          | ; set IDLE bit                             |
| MOV PCON, PCON          | ; followed by a 3-cycle dummy instruction  |

If the instruction following the write of the IDLE bit is a single-byte instruction and an interrupt occurs during the execution phase of the instruction that sets the IDLE bit, the CPU may not wake from IDLE mode when a future interrupt occurs.



# C8051F300/1/2/3/4/5

NOTES:



# 9. Reset Sources

Reset circuitry allows the controller to be easily placed in a predefined default condition. On entry to this reset state, the following occur:

- CIP-51 halts program execution
- Special Function Registers (SFRs) are initialized to their defined reset values
- External Port pins are forced to a known state
- Interrupts and timers are disabled.

All SFRs are reset to the predefined values noted in the SFR detailed descriptions. The contents of internal data memory are unaffected during a reset; any previously stored data is preserved. However, since the stack pointer SFR is reset, the stack is effectively lost even though the data on the stack is not altered.

The Port I/O latches are reset to 0xFF (all logic ones) in open-drain mode. Weak pullups are enabled during and after the reset. For  $V_{DD}$  Monitor and power-on resets, the  $\overrightarrow{RST}$  pin is driven low until the device exits the reset state.

On exit from the reset state, the program counter (PC) is reset, and the system clock defaults to the internal oscillator. Refer to **Section "11. Oscillators" on page 97** for information on selecting and configuring the system clock source. The Watchdog Timer is enabled with the system clock divided by 12 as its clock source (**Section "16.3. Watchdog Timer Mode" on page 164** details the use of the Watchdog Timer). Once the system clock source is stable, program execution begins at location 0x0000.



Figure 9.1. Reset Sources



Accessing Flash from user firmware executing from an unlocked page:

- 1. Any unlocked page except the page containing the Lock Byte may be read, written, or erased.
- 2. Locked pages cannot be read, written, or erased. An erase attempt on the page containing the Lock Byte will result in a Flash Error device reset.
- 3. The page containing the Lock Byte cannot be erased. It may be read or written only if it is unlocked. An erase attempt on the page containing the Lock Byte will result in a Flash Error device reset.
- 4. Reading the contents of the Lock Byte is always permitted.
- 5. Locking additional pages (changing '1's to '0's in the Lock Byte) is not permitted.
- 6. Unlocking Flash pages (changing '0's to '1's in the Lock Byte) is not permitted.
- 7. The Reserved Area cannot be read, written, or erased. Any attempt to access the reserved area, or any other locked page, will result in a Flash Error device reset.

Accessing Flash from user firmware executing from a locked page:

- 1. Any unlocked page except the page containing the Lock Byte may be read, written, or erased.
- 2. Any locked page except the page containing the Lock Byte may be read, written, or erased. An erase attempt on the page containing the Lock Byte will result in a Flash Error device reset.
- 3. The page containing the Lock Byte cannot be erased. It may only be read or written. An erase attempt on the page containing the Lock Byte will result in a Flash Error device reset.
- 4. Reading the contents of the Lock Byte is always permitted.
- 5. Locking additional pages (changing '1's to '0's in the Lock Byte) is not permitted.
- 6. Unlocking Flash pages (changing '0's to '1's in the Lock Byte) is not permitted.
- 7. The Reserved Area cannot be read, written, or erased. Any attempt to access the reserved area, or any other locked page, will result in a Flash Error device reset.

| R/W                        | R/W                                                                                                                                                                                           | R/W                                                                                                                                                                                      | R/W                                                                                                                                                                 | R/W                                                                                                                                                                      | R/W                                                                                                          | R/W                                                                                                   | R/W                                                                                  | Reset Value                                                                                |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|
| —                          | _                                                                                                                                                                                             |                                                                                                                                                                                          | —                                                                                                                                                                   | —                                                                                                                                                                        | —                                                                                                            | PSEE                                                                                                  | PSWE                                                                                 | 00000000                                                                                   |
| Bit7                       | Bit6                                                                                                                                                                                          | Bit5                                                                                                                                                                                     | Bit4                                                                                                                                                                | Bit3                                                                                                                                                                     | Bit2                                                                                                         | Bit1                                                                                                  | Bit0                                                                                 | SFR Address:                                                                               |
|                            |                                                                                                                                                                                               |                                                                                                                                                                                          |                                                                                                                                                                     |                                                                                                                                                                          |                                                                                                              |                                                                                                       |                                                                                      | 0x8F                                                                                       |
| Bits7–2:<br>Bit1:<br>Bit0: | UNUSED: R<br>PSEE: Prog<br>Setting this k<br>to be erased<br>Flash memo<br>tion address<br>0: Flash prog<br>1: Flash prog<br>PSWE: Prog<br>Setting this k<br>instruction. 1<br>0: Writes to 1 | ead = 0000<br>ram Store E<br>bit (in comb<br>I. If this bit i<br>rry using the<br>ed by the N<br>gram memo<br>gram Store 1<br>bit allows w<br>The Flash lo<br>Flash progr<br>Flash progr | 000b, Write<br>Erase Enab<br>ination with<br>s logic 1 ar<br>e MOVX instru-<br>ory erasure<br>ory erasure<br>Write Enab<br>riting a byte<br>ocation sho<br>am memor | = don't car<br>le<br>PSWE) all<br>d Flash wr<br>struction wil<br>uction. The<br>disabled.<br>e nabled.<br>le<br>e of data to<br>uld be eras<br>y disabled.<br>y enabled; | e.<br>ows an enti<br>ites are ena<br>I erase the<br>value of the<br>the Flash p<br>ed before w<br>the MOVX i | re page of F<br>bled (PSW<br>entire page<br>a data byte<br>rogram me<br>rriting data.<br>nstruction t | Flash prog<br>E is logic 1<br>that conta<br>written doe<br>mory using<br>argets Flas | ram memory<br>), a write to<br>ins the loca-<br>es not matter.<br>g the MOVX<br>sh memory. |

# SFR Definition 10.1. PSCTL: Program Store R/W Control



# SFR Definition 12.4. P0: Port0 Register

| R/W      | R/W                                                                                                                      | R/W                                                                                                    | R/W                                                          | R/W                                       | R/W                                    | R/W<br>P0.1                              | R/W                             | Reset Value  |  |
|----------|--------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|-------------------------------------------|----------------------------------------|------------------------------------------|---------------------------------|--------------|--|
| Bit7     | Bit6                                                                                                                     | Bit5                                                                                                   | Bit4                                                         | Bit3                                      | Bit2                                   | Bit1                                     | Bit0                            | SFR Address  |  |
| Biti     | bito bito bito bito bito bito bito bito                                                                                  |                                                                                                        |                                                              |                                           |                                        |                                          |                                 |              |  |
| Bits7–0: | P0.[7:0]<br>Write - Outp<br>0: Logic Low<br>1: Logic Hig<br>Read - Alwa<br>pin when co<br>0: P0.n pin i<br>1: P0.n pin i | out appears<br>v Output.<br>h Output (o<br>nys reads '1<br>nfigured as<br>s logic low.<br>s logic high | on I/O pins<br>pen-drain if<br>' if selected<br>digital inpu | per XBR0,<br>correspon<br>as analog<br>t. | XBR1, and<br>ding P0MD<br>input in reg | ∃ XBR2 Reថ<br>OUT.n bit =<br>jister P0MD | gisters<br>: 0)<br>PIN. Directl | y reads Port |  |

# SFR Definition 12.5. P0MDIN: Port0 Input Mode



| R/W                                                                                                                                                                                                                                                       | R/W                      | R/W                   | R/W               | R/W         | R/W          | R/W         | R/W      | Reset Value 0000000  |  |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-----------------------|-------------------|-------------|--------------|-------------|----------|----------------------|--|--|--|--|--|--|
| Bit7                                                                                                                                                                                                                                                      | Bit6                     | Bit5                  | Bit4              | Bit3        | Bit2         | Bit1        | Bit0     | SFR Address:<br>0xA4 |  |  |  |  |  |  |
| <ul> <li>Bits7–0: Output Configuration Bits for P0.7–P0.0 (respectively): ignored if corresponding bit in register P0MDIN is logic 0.</li> <li>0: Corresponding P0.n Output is open-drain.</li> <li>1: Corresponding P0.n Output is push-pull.</li> </ul> |                          |                       |                   |             |              |             |          |                      |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                           | (Note: Wher of the value | n SDA and<br>of P0MDC | SCL appea<br>UT). | r on any of | the Port I/C | D, each are | open-dra | in regardless        |  |  |  |  |  |  |

# Table 12.1. Port I/O DC Electrical Characteristics

| Parameters            | Conditions                                   | Min                   | Тур                  | Max | Units |
|-----------------------|----------------------------------------------|-----------------------|----------------------|-----|-------|
| Output High Voltage   | I <sub>OH</sub> = –3 mA, Port I/O push-pull  | $V_{DD} - 0.7$        |                      | —   | V     |
|                       | I <sub>OH</sub> = –10 μA, Port I/O push-pull | V <sub>DD</sub> – 0.1 |                      |     |       |
|                       | I <sub>OH</sub> = –10 mA, Port I/O push-pull |                       | V <sub>DD</sub> -0.8 |     |       |
| Output Low Voltage    | I <sub>OL</sub> = 8.5 mA                     |                       | _                    | 0.6 |       |
|                       | I <sub>OL</sub> = 10 μA                      | —                     | —                    | 0.1 | V     |
|                       | $I_{OL} = 25 \text{ mA}$                     | —                     | 1.0                  | —   |       |
| Input High Voltage    |                                              | 2.0                   | _                    |     | V     |
| Input Low Voltage     |                                              | —                     |                      | 0.8 | V     |
| Input Leakage Current | Weak Pull-up Off                             |                       |                      | ±1  | μA    |
|                       | Weak Pull-up On, V <sub>IN</sub> = 0 V       |                       | 25                   | 40  |       |

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





# Figure 13.4. Typical SMBus SCL Generation

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 after SCL transitions from high-to-low. EXTHOLD should be set so that the minimum setup and hold times meet the SMBus Specification requirements of 250 ns and 300 ns, respectively. Table 13.2 shows the minimum setup and hold times for the two EXTHOLD settings. Setup and hold time extensions are typically necessary when SYSCLK is above 10 MHz.

| EXTHOLD | Minimum SDA Setup Time                                                              | Minimum SDA Hold Time |
|---------|-------------------------------------------------------------------------------------|-----------------------|
| 0       | T <sub>low</sub> – 4 system clocks<br>OR<br>1 system clock + s/w delay <sup>*</sup> | 3 system clocks       |
| 1       | 11 system clocks                                                                    | 12 system clocks      |

Table 13.2. Minimum SDA Setup and Hold Times

\*Note: Setup Time for ACK bit transmissions and the MSB of all data transfers. The s/w delay occurs between the time SMB0DAT or ACK is written and when SI is cleared. Note that if SI is cleared in the same write that defines the outgoing ACK value, s/w delay is zero.

With the SMBTOE bit set, Timer 2 should be configured to overflow after 25 ms in order to detect SCL low timeouts (see **Section "13.3.3. SCL Low Timeout" on page 114**). The SMBus interface will force Timer 2 to reload while SCL is high, and allow Timer 2 to count when SCL is low. The Timer 2 interrupt service routine should be used to reset SMBus communication by disabling and reenabling the SMBus. Timer 2 configuration is described in **Section "15.2. Timer 2" on page 151**.

SMBus Free Timeout detection can be enabled by setting the SMBFTE bit. When this bit is set, the bus will be considered free if SDA and SCL remain high for more than 10 SMBus clock source periods (see Figure 13.4). When a Free Timeout is detected, the interface will respond as if a STOP was detected (an interrupt will be generated, and STO will be set).



#### 13.4.2. SMB0CN Control Register

SMB0CN is used to control the interface and to provide status information (see SFR Definition 13.2). The higher four bits of SMB0CN (MASTER, TXMODE, STA, and STO) form a status vector that can be used to jump to service routines. MASTER and TXMODE indicate the master/slave state and transmit/receive modes, respectively.

The STA bit indicates that a START has been detected or generated since the last SMBus interrupt. When set to '1', the STA bit will cause the SMBus to enter Master mode and generate a START when the bus becomes free. STA is not cleared by hardware after the START is generated; it must be cleared by software.

As a master, writing the STO bit will cause the hardware to generate a STOP condition and end the current transfer after the next ACK cycle. STO is cleared by hardware after the STOP condition is generated. As a slave, STO indicates that a STOP condition has been detected since the last SMBus interrupt. STO is also used in slave mode to manage the transition from slave receiver to slave transmitter; see **Section 13.5.4** for details on this procedure.

If STO and STA are both set to '1' (while in Master Mode), a STOP followed by a START will be generated.

As a receiver, writing the ACK bit defines the outgoing ACK value; as a transmitter, reading the ACK bit indicates the value received on the last ACK cycle. ACKRQ is set each time a byte is received, indicating that an outgoing ACK value is needed. When ACKRQ is set, software should write the desired outgoing value to the ACK bit before clearing SI. A NACK will be generated if software does not write the ACK bit before clearing SI. SDA will reflect the defined ACK value immediately following a write to the ACK bit; however SCL will remain low until SI is cleared. If a received slave address is not acknowledged, further slave events will be ignored until the next START is detected.

The ARBLOST bit indicates that the interface has lost an arbitration. This may occur anytime the interface is transmitting (master or slave). A lost arbitration while operating as a slave indicates a bus error condition. ARBLOST is cleared by hardware each time SI is cleared.

The SI bit (SMBus Interrupt Flag) is set at the beginning and end of each transfer, after each byte frame, or when an arbitration is lost; see Table 13.3 for more details.

**Important Note About the SI Bit:** The SMBus interface is stalled while SI is set; thus SCL is held low, and the bus is stalled until software clears SI.

Table 13.3 lists all sources for hardware changes to the SMB0CN bits. Refer to Table 13.4 for SMBus status decoding using the SMB0CN register.



#### 13.5.3. Slave Receiver Mode

Serial data is received on SDA and the clock is received on SCL. When slave events are enabled (INH = 0), the interface enters Slave Receiver Mode when a START followed by a slave address and direction bit (WRITE in this case) is received. Upon entering Slave Receiver Mode, an interrupt is generated and the ACKRQ bit is set. Software responds to the received slave address with an ACK, or ignores the received slave address with a NACK. If the received slave address is ignored, slave interrupts will be inhibited until the next START is detected. If the received slave address is acknowledged, zero or more data bytes are received. Software must write the ACK bit after each received byte to ACK or NACK the received byte. The interface exits Slave Receiver Mode after receiving a STOP. Note that the interface will switch to Slave Transmitter Mode if SMB0DAT is written while an active Slave Receiver; see **Section 13.5.4** for details on this procedure. Figure 13.7 shows a typical Slave Receiver sequence. Two received data bytes are shown, though any number of bytes may be received. Notice that the 'data byte transferred' interrupts occur **before** the ACK cycle in this mode.



Figure 13.7. Typical Slave Receiver Sequence



## 14.3. Multiprocessor Communications

9-Bit UART mode supports multiprocessor communication between a master processor and one or more slave processors by special use of the ninth data bit. When a master processor wants to transmit to one or more slaves, it first sends an address byte to select the target(s). An address byte differs from a data byte in that its ninth bit is logic 1; in a data byte, the ninth bit is always set to logic 0.

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

Multiple addresses can be assigned to a single slave and/or a single address can be assigned to multiple slaves, thereby enabling "broadcast" transmissions to more than one slave simultaneously. The master processor can be configured to receive all transmissions or a protocol can be implemented such that the master/slave role is temporarily reversed to enable half-duplex transmission between the original master and slave(s).



Figure 14.6. UART Multi-Processor Mode Interconnect Diagram



|               | Frequency: 11.0592 MHz       |                      |                                |                       |                                                 |                  |                                  |  |  |  |  |
|---------------|------------------------------|----------------------|--------------------------------|-----------------------|-------------------------------------------------|------------------|----------------------------------|--|--|--|--|
|               | Target<br>Baud Rate<br>(bps) | Baud Rate<br>% Error | Oscillator<br>Divide<br>Factor | Timer Clock<br>Source | SCA1-SCA0<br>(pre-scale<br>select) <sup>1</sup> | T1M <sup>1</sup> | Timer 1<br>Reload<br>Value (hex) |  |  |  |  |
|               | 230400                       | 0.00%                | 48                             | SYSCLK                | XX <sup>2</sup>                                 | 1                | 0xE8                             |  |  |  |  |
|               | 115200                       | 0.00%                | 96                             | SYSCLK                | XX <sup>2</sup>                                 | 1                | 0xD0                             |  |  |  |  |
| om<br>sc.     | 57600                        | 0.00%                | 192                            | SYSCLK                | XX <sup>2</sup>                                 | 1                | 0xA0                             |  |  |  |  |
| K fr<br>al O  | 28800                        | 0.00%                | 384                            | SYSCLK                | XX <sup>2</sup>                                 | 1                | 0x40                             |  |  |  |  |
| sCL<br>erná   | 14400                        | 0.00%                | 768                            | SYSCLK / 12           | 00                                              | 0                | 0xE0                             |  |  |  |  |
| SYS<br>Ext    | 9600                         | 0.00%                | 1152                           | SYSCLK / 12           | 00                                              | 0                | 0xD0                             |  |  |  |  |
|               | 2400                         | 0.00%                | 4608                           | SYSCLK / 12           | 00                                              | 0                | 0x40                             |  |  |  |  |
|               | 1200                         | 0.00%                | 9216                           | SYSCLK / 48           | 10                                              | 0                | 0xA0                             |  |  |  |  |
|               | 230400                       | 0.00%                | 48                             | EXTCLK / 8            | 11                                              | 0                | 0xFD                             |  |  |  |  |
| om<br>sc.     | 115200                       | 0.00%                | 96                             | EXTCLK / 8            | 11                                              | 0                | 0xFA                             |  |  |  |  |
| K fr<br>al O: | 57600                        | 0.00%                | 192                            | EXTCLK / 8            | 11                                              | 0                | 0xF4                             |  |  |  |  |
| SCL           | 28800                        | 0.00%                | 384                            | EXTCLK / 8            | 11                                              | 0                | 0xE8                             |  |  |  |  |
| SY5<br>Inte   | 14400                        | 0.00%                | 768                            | EXTCLK / 8            | 11                                              | 0                | 0xD0                             |  |  |  |  |
|               | 9600                         | 0.00%                | 1152                           | EXTCLK / 8            | 11                                              | 0                | 0xB8                             |  |  |  |  |

# Table 14.5. Timer Settings for Standard Baud Rates Using an External 11.0592 MHzOscillator

Notes:

1. SCA1–SCA0 and T1M bit definitions can be found in **Section 15.1**.

2. X = Don't care



| RW         R         R         R         R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |                                                  |                              |              |      |      |                      |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------------------------------------------------|------------------------------|--------------|------|------|----------------------|
| GATE1         C/T1         T1M1         T1M0         GATE0         C/T0         T0M1         T0M0         00000000           Bit7         Bit6         Bit5         Bit4         Bit3         Bit2         Bit1         Bit0         SFR Address:<br>0X89           Bit7:         GATE1: Timer 1 Gate Control.<br>0: Timer 1 enabled when TR1 = 1 irrespective of /INT1 logic level.<br>1: Timer 1 enabled only when TR1 = 1 AND /INT1 is active as defined by bit IN1PL in register IT01CF (see SFR Definition 8.11).           Bit6:         C/T1: Counter/Timer 1 Select.<br>0: Timer Function: Timer 1 incremented by clock defined by T1M bit (CKCON.4).<br>1: Counter Function: Timer 1 incremented by high-to-low transitions on external input pin<br>(T1).           Bit5-4:         T1M1         T1M0         Mode           0         1         Mode Select.<br>These bits select the Timer 1 operation mode.           Image: T1M1         T1M0         Mode 1: 16-bit counter/timer           1         0         Mode 2: 8-bit counter/timer           1         0         Mode 2: 8-bit counter/timer           1         0         Mode 2: 8-bit counter/timer           1         0         Mode 3: Timer 1 AND /INT0 is active as defined by bit INOPL in register IT01CF (see SFR Definition 8.11).           Bit3:         GATE0: Timer 0 Gate Control.<br>0: Timer 0 enabled when TR0 = 1 AND /INT0 logic level.<br>1: Timere 0 enabled only when TR0 = 1 AND /INT0 logic level.<br>1: Timere 0                                                                                                                                                                                                                                                                                                                                                 | R/W                        | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R/W  | R/W                                              | R/W                          | R/W          | R/W  | R/W  | Reset Value          |
| Bit7       Bit6       Bit5       Bit4       Bit3       Bit2       Bit1       Bit0       SFR Address:<br>0x89         Bit7:       GATE1: Timer 1 Gate Control.<br>0: Timer 1 enabled when TR1 = 1 irrespective of /INT1 logic level.<br>1: Timer 1 enabled only when TR1 = 1 AND /INT1 is active as defined by bit IN1PL in register IT01CF (see SFR Definition 8.11).         Bit6:       C/T1: Counter/Timer 1 Select.<br>0: Timer Function: Timer 1 incremented by clock defined by T1M bit (CKCON.4).<br>1: Counter Function: Timer 1 incremented by high-to-low transitions on external input pin (T1).         Bit5=4:       T1M1 T1M0: Timer 1 Mode Select.<br>These bits select the Timer 1 operation mode.         Image: Timer 0 and the timer 1 mode select.<br>These bits select the Timer 1 operation mode.         Bit3:       GATE0: Timer 0 Gate Control.<br>0: Timer 0 enabled when TR0 = 1 intespective of /INT0 logic level.<br>1: Timer 0 enabled when TR0 = 1 intespective of /INT0 logic level.<br>1: Timer 0 enabled only when TR0 = 1 AND /INT0 is active as defined by bit INOPL in register IT01CF (see SFR Definition 8.11).         Bit2:       C/T0: Counter/Timer Select.<br>0: Timer 0 enabled only when TR0 = 1 AND /INT0 logic level.<br>1: Counter Function: Timer 0 incremented by clock defined by T0M bit (CKCON.3).<br>1: Counter Function: Timer 0 incremented by clock defined by T0M bit (CKCON.3).<br>1: Counter Function: Timer 0 incremented by clock defined by T0M bit (CKCON.3).<br>1: Counter Function: Timer 0 incremented by clock defined by T0M bit (CKCON.3).<br>1: Counter Function: Timer 0 incremented by clock defined by T0M bit (CKCON.3).<br>1: Counter Function: Timer 0 incremented by clock defined by T0M bit (CKCON.3).<br>1: Counter Function: Timer 0 incremented by clock defined by T0M bit (CKC | GATE1                      | C/T1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | T1M1 | I T1M0                                           | GATE0                        | C/T0         | T0M1 | TOMO | 00000000             |
| Bit7:       GATE1: Timer 1 Gate Control.         0: Timer 1 enabled when TR1 = 1 irrespective of /INT1 logic level.         1: Timer 1 enabled only when TR1 = 1 AND /INT1 is active as defined by bit IN1PL in register IT01CF (see SFR Definition 8.11).         Bit6:       C/T1: Counter/Timer 1 Select.         0: Timer Function: Timer 1 incremented by clock defined by T1M bit (CKCON.4).         1: Counter Function: Timer 1 moremented by high-to-low transitions on external input pin (T1).         Bit5=4:       T1M1 T1M0: Timer 1 Mode Select.         These bits select the Timer 1 operation mode.         T1M1 T1M0       Mode 0: 13-bit counter/timer         0       1       Mode 1: 16-bit counter/timer         1       0       Mode 2: 8-bit counter/timer with autoreload         1       1       Mode 3: Timer 1 inactive         Bit3:       GATE0: Timer 0 Gate Control.       0: Timer 0 enabled when TR0 = 1 irrespective of /INT0 logic level.         1: Timer 0 enabled only when TR0 = 1 AND /INT0 is active as defined by bit INOPL in register IT01CF (see SFR Definition 8.11).         Bit2:       C/T0: Counter/Timer 9 incremented by clock defined by T0M bit (CKCON.3).         1: Counter Function: Timer 0 incremented by high-to-low transitions on external input pin (T0).         Bits1-0:       Timer 0 Mode Select.         These bits select the Timer 0 operation mode.         Dittor: Tomin 0 Mode Select. </td <td>Bit7</td> <td>Bit6</td> <td>Bit5</td> <td>Bit4</td> <td>Bit3</td> <td>Bit2</td> <td>Bit1</td> <td>Bit0</td> <td>SFR Address:<br/>0x89</td>                                                                                                                                                                                                                                                | Bit7                       | Bit6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Bit5 | Bit4                                             | Bit3                         | Bit2         | Bit1 | Bit0 | SFR Address:<br>0x89 |
| Bit6:       C/T1: Counter/Timer 1 Select.         0: Timer Function: Timer 1 incremented by clock defined by T1M bit (CKCON.4).         1: Counter Function: Timer 1 incremented by high-to-low transitions on external input pin (T1).         Bits5-4:         T1M1-T1M0: Timer 1 Mode Select.         These bits select the Timer 1 operation mode.         Image: Timer 1 Mode 0:         Image: Timer 0 Mode 0:         Image: Timer 0 Gate Control.         Im                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Bit7:                      | <ul> <li>GATE1: Timer 1 Gate Control.</li> <li>0: Timer 1 enabled when TR1 = 1 irrespective of /INT1 logic level.</li> <li>1: Timer 1 enabled only when TR1 = 1 AND /INT1 is active as defined by bit IN1PL in register IT01CF (see SFR Definition 8.11).</li> </ul>                                                                                                                                                                                                                                                                                                                                      |      |                                                  |                              |              |      |      |                      |
| Bits5-4:       T1M1-T1M0: Timer 1 Mode Select.<br>These bits select the Timer 1 operation mode.         Image: T1M1 T1M0 Mode 0: 13-bit counter/timer         0       0         Mode 0: 13-bit counter/timer         0       1         Mode 2: 8-bit counter/timer         1       0         Mode 2: 8-bit counter/timer with auto-<br>reload         1       1         Mode 3: Timer 1 inactive         Bit3:       GATE0: Timer 0 Gate Control.<br>0: Timer 0 enabled when TR0 = 1 irrespective of /INT0 logic level.<br>1: Timer 0 enabled only when TR0 = 1 AND /INT0 is active as defined by bit INOPL in regis-<br>ter IT01CF (see SFR Definition 8.11).         Bit2:       C/T0: Counter/Timer Select.<br>0: Timer Function: Timer 0 incremented by clock defined by T0M bit (CKCON.3).<br>1: Counter Function: Timer 0 incremented by high-to-low transitions on external input pin<br>(T0).         Bits1-0:       T0M1-T0M0: Timer 0 Mode Select.<br>These bits select the Timer 0 operation mode.         Image: T0M1       T0M0         Mode 0: 13-bit counter/timer         0       1         0       1         0       1         1       0         0       1         0       1         0       1         0       1         0       1         0       1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Bit6:                      | <ul> <li>C/T1: Counter/Timer 1 Select.</li> <li>0: Timer Function: Timer 1 incremented by clock defined by T1M bit (CKCON.4).</li> <li>1: Counter Function: Timer 1 incremented by high-to-low transitions on external input pin (T1).</li> </ul>                                                                                                                                                                                                                                                                                                                                                         |      |                                                  |                              |              |      |      |                      |
| T1M1       T1M0       Mode         0       0       Mode 0: 13-bit counter/timer         0       1       Mode 1: 16-bit counter/timer         1       0       Mode 2: 8-bit counter/timer with auto-<br>reload         1       1       Mode 3: Timer 1 inactive         Bit3:       GATE0: Timer 0 Gate Control.       0: Timer 0 enabled when TR0 = 1 irrespective of /INT0 logic level.         1: Timer 0 enabled only when TR0 = 1 AND /INT0 is active as defined by bit INOPL in regis-<br>ter IT01CF (see SFR Definition 8.11).         Bit2:       C/T0: Counter/Timer Select.         0: Timer Function: Timer 0 incremented by clock defined by T0M bit (CKCON.3).         1: Counter Function: Timer 0 incremented by high-to-low transitions on external input pin<br>(T0).         Bits1-0:       T0M1-T0M0: Timer 0 Mode Select.         These bits select the Timer 0 operation mode.         T0M1       T0M0         Mode 1: 16-bit counter/timer         0       1         1       0         1       0         1       1         1       0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Bits5–4:                   | T1M1–T1M0: Timer 1 Mode Select.<br>These bits select the Timer 1 operation mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |                                                  |                              |              |      |      |                      |
| 0       0       Mode 0: 13-bit counter/timer         0       1       Mode 1: 16-bit counter/timer         1       0       Mode 2: 8-bit counter/timer with auto-<br>reload         1       1       Mode 3: Timer 1 inactive         Bit3:       GATE0: Timer 0 Gate Control.<br>0: Timer 0 enabled when TR0 = 1 irrespective of /INT0 logic level.<br>1: Timer 0 enabled only when TR0 = 1 AND /INT0 is active as defined by bit IN0PL in regis-<br>ter IT01CF (see SFR Definition 8.11).         Bit2:       C/T0: Counter/Timer Select.<br>0: Timer Function: Timer 0 incremented by clock defined by T0M bit (CKCON.3).<br>1: Counter Function: Timer 0 incremented by high-to-low transitions on external input pin<br>(T0).         Bits1-0:       T0M1-T0M0: Timer 0 Mode Select.<br>These bits select the Timer 0 operation mode.         T0M1       T0M0         Mode 0: 13-bit counter/timer         0       1         1       0         1       0         Mode 2: 8-bit counter/timer         1       1         1       1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                            | T1M1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | T1M0 |                                                  | Mode                         |              |      |      |                      |
| 0       1       Mode 1: 16-bit counter/timer         1       0       Mode 2: 8-bit counter/timer with auto-reload         1       1       Mode 3: Timer 1 inactive         Bit3:       GATE0: Timer 0 Gate Control.       0: Timer 0 enabled when TR0 = 1 irrespective of /INT0 logic level.         1: Timer 0 enabled only when TR0 = 1 AND /INT0 is active as defined by bit IN0PL in register IT01CF (see SFR Definition 8.11).         Bit2:       C/T0: Counter/Timer Select.         0: Timer Function: Timer 0 incremented by clock defined by T0M bit (CKCON.3).         1: Counter Function: Timer 0 incremented by high-to-low transitions on external input pin (T0).         Bits1-0:       T0M1-T0M0: Timer 0 Mode Select.         These bits select the Timer 0 operation mode.         1       0         Mode 1: 16-bit counter/timer         0       1         1       0         Mode 2: 8-bit counter/timer         1       0         1       1         1       0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                            | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0    | Mode 0: 13-b                                     | it counter/tir               | ner          |      |      |                      |
| 1       0       Mode 2: 8-bit counter/timer with auto-reload         1       1       Mode 3: Timer 1 inactive         Bit3:       GATE0: Timer 0 Gate Control.<br>0: Timer 0 enabled when TR0 = 1 irrespective of /INT0 logic level.<br>1: Timer 0 enabled only when TR0 = 1 AND /INT0 is active as defined by bit INOPL in register IT01CF (see SFR Definition 8.11).         Bit2:       C/T0: Counter/Timer Select.<br>0: Timer Function: Timer 0 incremented by clock defined by T0M bit (CKCON.3).<br>1: Counter Function: Timer 0 incremented by high-to-low transitions on external input pin (T0).         Bits1-0:       T0M1-T0M0: Timer 0 Mode Select.<br>These bits select the Timer 0 operation mode.         1       0       Mode 1: 16-bit counter/timer         0       1       Mode 1: 16-bit counter/timer         1       0       Mode 2: 8-bit counter/timer with auto-reload         1       1       Mode 3: Two 8-bit counter/timers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                            | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1    | Mode 1: 16-b                                     | Mode 1: 16-bit counter/timer |              |      |      |                      |
| 1       1       Mode 3: Timer 1 inactive         Bit3:       GATE0: Timer 0 Gate Control.       0: Timer 0 enabled when TR0 = 1 irrespective of /INT0 logic level.         1: Timer 0 enabled only when TR0 = 1 AND /INT0 is active as defined by bit INOPL in register IT01CF (see SFR Definition 8.11).         Bit2:       C/T0: Counter/Timer Select.         0: Timer Function: Timer 0 incremented by clock defined by T0M bit (CKCON.3).         1: Counter Function: Timer 0 incremented by high-to-low transitions on external input pin (T0).         Bits1-0:       T0M1 T0M0 Mode Select.         These bits select the Timer 0 operation mode.         1       0         Mode 1: 16-bit counter/timer         1       0         Mode 2: 8-bit counter/timer         1       1         1       1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                            | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0    | Mode 2: 8-bit counter/timer with auto-<br>reload |                              |              |      |      |                      |
| Bit3:       GATE0: Timer 0 Gate Control.         0: Timer 0 enabled when TR0 = 1 irrespective of /INT0 logic level.         1: Timer 0 enabled only when TR0 = 1 AND /INT0 is active as defined by bit IN0PL in register IT01CF (see SFR Definition 8.11).         Bit2:       C/T0: Counter/Timer Select.         0: Timer Function: Timer 0 incremented by clock defined by T0M bit (CKCON.3).         1: Counter Function: Timer 0 incremented by high-to-low transitions on external input pin (T0).         Bits1-0:       T0M1-T0M0: Timer 0 Mode Select.         These bits select the Timer 0 operation mode.         Image: Comparison of the time of time of times the time of the times of times the time of times the times times t                 |                            | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1    | Mode 3: Timer 1 inactive                         |                              |              |      |      |                      |
| T0M1T0M0Mode00Mode 0: 13-bit counter/timer01Mode 1: 16-bit counter/timer10Mode 2: 8-bit counter/timer with auto-<br>reload11Mode 3: Two 8-bit counter/timers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Bit3:<br>Bit2:<br>Bits1–0: | <ul> <li>GATE0: Timer 0 Gate Control.</li> <li>0: Timer 0 enabled when TR0 = 1 irrespective of /INT0 logic level.</li> <li>1: Timer 0 enabled only when TR0 = 1 AND /INT0 is active as defined by bit IN0PL in register IT01CF (see SFR Definition 8.11).</li> <li>C/T0: Counter/Timer Select.</li> <li>0: Timer Function: Timer 0 incremented by clock defined by T0M bit (CKCON.3).</li> <li>1: Counter Function: Timer 0 incremented by high-to-low transitions on external input pin (T0).</li> <li>T0M1-T0M0: Timer 0 Mode Select.</li> <li>These bits select the Timer 0 operation mode.</li> </ul> |      |                                                  |                              |              |      |      |                      |
| 00Mode 0: 13-bit counter/timer01Mode 1: 16-bit counter/timer10Mode 2: 8-bit counter/timer with auto-<br>reload11Mode 3: Two 8-bit counter/timers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                            | T0M1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | T0M0 |                                                  | Mode                         |              |      |      |                      |
| 01Mode 1: 16-bit counter/timer10Mode 2: 8-bit counter/timer with auto-<br>reload11Mode 3: Two 8-bit counter/timers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                            | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0    | Mode 0: 13-b                                     | it counter/tir               | ner          |      |      |                      |
| 10Mode 2: 8-bit counter/timer with auto-<br>reload11Mode 3: Two 8-bit counter/timers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                            | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1    | Mode 1: 16-b                                     | it counter/tir               | ner          |      |      |                      |
| 1 1 Mode 3: Two 8-bit counter/timers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                            | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0    | Mode 2: 8-bit reload                             | counter/tim                  | er with auto | 0-   |      |                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                            | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1    | Mode 3: Two                                      | 8-bit counte                 | er/timers    |      |      |                      |

# SFR Definition 15.2. TMOD: Timer Mode



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

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

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

| T2MH | T2XCLK | TMR2H Clock Source |
|------|--------|--------------------|
| 0    | 0      | SYSCLK / 12        |
| 0    | 1      | External Clock / 8 |
| 1    | Х      | SYSCLK             |

| T2ML | T2XCLK | TMR2L Clock Source |
|------|--------|--------------------|
| 0    | 0      | SYSCLK / 12        |
| 0    | 1      | External Clock / 8 |
| 1    | Х      | SYSCLK             |

Note: External clock divided by 8 is synchronized with the system clock, and the external clock must be less than or equal to the system clock to operate in this mode.

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



Figure 15.5. Timer 2 8-Bit Mode Block Diagram



# 16. Programmable Counter Array

The Programmable Counter Array (PCA0) provides enhanced timer functionality while requiring less CPU intervention than the standard 8051 counter/timers. The PCA consists of a dedicated 16-bit counter/timer and three 16-bit capture/compare modules. Each capture/compare module has its own associated I/O line (CEXn) which is routed through the Crossbar to Port I/O when enabled (See Section "12.1. Priority Crossbar Decoder" on page 104 for details on configuring the Crossbar). The counter/timer is driven by a programmable timebase that can select between six sources: system clock, system clock divided by four, system clock divided by twelve, the external oscillator clock source divided by 8, Timer 0 overflow, or an external clock signal on the ECI input pin. Each capture/compare module may be configured to operate independently in one of six modes: Edge-Triggered Capture, Software Timer, High-Speed Output, Frequency Output, 8-Bit PWM, or 16-Bit PWM (each mode is described in Section "16.2. Capture/Compare Modules" on page 157). The external oscillator clock option is ideal for real-time clock (RTC) functionality, allowing the PCA to be clocked by a precision external oscillator while the internal oscillator drives the system clock. The PCA is configured and controlled through the system controller's Special Function Registers. The basic PCA block diagram is shown in Figure 16.1.

**Important Note:** The PCA Module 2 may be used as a watchdog timer (WDT), and is enabled in this mode following a system reset. Access to certain PCA registers is restricted while WDT mode is enabled. See **Section 16.3** for details.



Figure 16.1. PCA Block Diagram



# C8051F300/1/2/3/4/5

#### 16.2.5. 8-Bit Pulse Width Modulator Mode

Each module can be used independently to generate a pulse width modulated (PWM) output on its associated CEXn pin. The frequency of the output is dependent on the timebase for the PCA counter/timer. The duty cycle of the PWM output signal is varied using the module's PCA0CPLn capture/compare register. When the value in the low byte of the PCA counter/timer (PCA0L) is equal to the value in PCA0CPLn, the output on the CEXn pin will be set to '1'. When the count value in PCA0L overflows, the CEXn output will be set to '0' (see Figure 16.8). Also, when the counter/timer low byte (PCA0L) overflows from 0xFF to 0x00, PCA0CPLn is reloaded automatically with the value stored in the module's capture/compare high byte (PCA0CPHn) without software intervention. Setting the ECOMn and PWMn bits in the PCA0CPMn register enables 8-bit Pulse Width Modulator mode. The duty cycle for 8-bit PWM Mode is given by Equation 16.2.

**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'.

$$DutyCycle = \frac{(256 - PCA0CPHn)}{256}$$

### Equation 16.2. 8-Bit PWM Duty Cycle

Using Equation 16.2, the largest duty cycle is 100% (PCA0CPHn = 0), and the smallest duty cycle is 0.39% (PCA0CPHn = 0xFF). A 0% duty cycle may be generated by clearing the ECOMn bit to '0'.



Figure 16.8. PCA 8-Bit PWM Mode Diagram

