



#### 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             | Discontinued at Digi-Key                                        |
|----------------------------|-----------------------------------------------------------------|
| Core Processor             | 8051                                                            |
| Core Size                  | 8-Bit                                                           |
| Speed                      | 100MHz                                                          |
| Connectivity               | SMBus (2-Wire/I <sup>2</sup> C), SPI, UART/USART                |
| Peripherals                | POR, PWM, Temp Sensor, WDT                                      |
| Number of I/O              | 29                                                              |
| Program Memory Size        | 32KB (32K x 8)                                                  |
| Program Memory Type        | FLASH                                                           |
| EEPROM Size                | -                                                               |
| RAM Size                   | 1K x 8                                                          |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 3.6V                                                       |
| Data Converters            | A/D 21x10b; D/A 1x10b                                           |
| Oscillator Type            | Internal                                                        |
| Operating Temperature      | -40°C ~ 85°C (TA)                                               |
| Mounting Type              | Surface Mount                                                   |
| Package / Case             | 32-LQFP                                                         |
| Supplier Device Package    | 32-LQFP (7x7)                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/silicon-labs/c8051f361-gqr |

Email: info@E-XFL.COM

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

| 18.SMBus                                                       |              |
|----------------------------------------------------------------|--------------|
| Figure 18.1. SMBus Block Diagram                               | 200          |
| Figure 18.2. Typical SMBus Configuration                       | 201          |
| Figure 18.3. SMBus Transaction                                 | 202          |
| Figure 18.4. Typical SMBus SCL Generation                      | 205          |
| Figure 18.5. Typical Master Transmitter Sequence               | 211          |
| Figure 18.6. Typical Master Receiver Sequence                  | 212          |
| Figure 18.7. Typical Slave Receiver Sequence                   | 213          |
| Figure 18.8. Typical Slave Transmitter Sequence                | 214          |
| 19.UART0                                                       |              |
| Figure 19.1. UART0 Block Diagram                               | 218          |
| Figure 19.2. UART0 Baud Rate Logic                             | 219          |
| Figure 19.3. UART Interconnect Diagram                         | 220          |
| Figure 19.4. 8-Bit UART Timing Diagram                         | 220          |
| Figure 19.5. 9-Bit UART Timing Diagram                         | 221          |
| Figure 19.6. UART Multi-Processor Mode Interconnect Diagram    | 222          |
| 20. Enhanced Serial Peripheral Interface (SPI0)                |              |
| Figure 20.1. SPI Block Diagram                                 | 232          |
| Figure 20.2. Multiple-Master Mode Connection Diagram           | 235          |
| Figure 20.3. 3-Wire Single Master and 3-Wire Single Slave Mode |              |
| Connection Diagram                                             | 235          |
| Figure 20.4. 4-Wire Single Master Mode and 4-Wire Slave Mode   |              |
| Connection Diagram                                             | 235          |
| Figure 20.5. Master Mode Data/Clock Timing                     | 237          |
| Figure 20.6. Slave Mode Data/Clock Timing (CKPHA = 0)          | 238          |
| Figure 20.7. Slave Mode Data/Clock Timing (CKPHA = 1)          | 238          |
| Figure 20.8. SPI Master Timing (CKPHA = 0)                     | 242          |
| Figure 20.9. SPI Master Timing (CKPHA = 1)                     | 242          |
| Figure 20.10. SPI Slave Timing (CKPHA = 0)                     | 243          |
| Figure 20.11. SPI Slave Timing (CKPHA = 1)                     | 243          |
| 21. Timers                                                     | o 1 <b>-</b> |
| Figure 21.1. 10 Mode 0 Block Diagram                           | 247          |
| Figure 21.2. TO Mode 2 Block Diagram                           | 248          |
| Figure 21.3. 10 Mode 3 Block Diagram                           | 249          |
| Figure 21.4. Timer 2 16-Bit Mode Block Diagram                 | 254          |
| Figure 21.5. Timer 2 8-Bit Mode Block Diagram                  | 255          |
| Figure 21.6. Timer 3 16-Bit Mode Block Diagram                 | 258          |
| Figure 21.7. Timer 3 8-Bit Mode Block Diagram                  | 259          |
| 22. Programmable Counter Array                                 | 262          |
| Figure 22.1. PCA Block Diagram                                 | 202          |
| Figure 22.2. PCA Lounter/ Limer Block Diagram                  | 203          |
| Figure 22.3. PCA Interrupt Block Diagram                       | 204          |
| Figure 22.4. PCA Capture Mode Diagram                          | 205          |
| Figure 22.5. PCA Software Timer Mode Diagram                   | 200          |
| Figure 22.6. PCA High Speed Output Mode Diagram                | 267          |



cated by a status bit and an interrupt (if enabled). The resulting 10-bit data word is latched into the ADC data SFRs upon completion of a conversion.

Window compare registers for the ADC data can be configured to interrupt the controller when ADC data is either within or outside of a specified range. The ADC can monitor a key voltage continuously in background mode, but not interrupt the controller unless the converted data is within/outside the specified range.





#### 1.8. Comparators

C8051F36x devices include two on-chip voltage comparators that are enabled/disabled and configured via user software. Port I/O pins may be configured as comparator inputs via a selection mux. Two comparator outputs may be routed to a Port pin if desired: a latched output and/or an unlatched (asynchronous) output. Comparator response time is programmable, allowing the user to select between high-speed and low-power modes. Positive and negative hysteresis are also configurable.

Comparator interrupts may be generated on rising, falling, or both edges. When in IDLE mode, these interrupts may be used as a "wake-up" source. Comparator0 may also be configured as a reset source. Figure 1.12 shows the Comparator0 block diagram, and Figure 1.13 shows the Comparator1 block diagram.

**Note:** The first Port I/O pins shown in Figure 1.12 and Figure 1.13 are for the 48-pin (C8051F360/3) devices. The second set of Port I/O pins are for the 32-pin and 28-pin (C8051F361/2/4/5/6/7/8/9) devices. Please refer to the CPTnMX registers (SFR Definition 8.2 and SFR Definition 8.5) for more information.





Figure 4.2. TQFP-48 Package Diagram

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

#### Table 4.2. TQFP-48 Package Dimensions

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

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

3. This drawing conforms to JEDEC outline MS-026, variation ABC.

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







| Dimension | Min  | Nom       | Max  | Dimension | Min  | Nom   | Max  |
|-----------|------|-----------|------|-----------|------|-------|------|
| A         | 0.80 | 0.90      | 1.00 | E2        | 2.90 | 3.15  | 3.35 |
| A1        | 0.03 | 0.07      | 0.11 | L         | 0.45 | 0.55  | 0.65 |
| A3        |      | 0.25 REF  |      | aaa       | 0.15 |       |      |
| b         | 0.18 | 0.25      | 0.30 | bbb       |      | 0.10  |      |
| D         |      | 5.00 BSC. |      | ddd       |      | 0.05  |      |
| D2        | 2.90 | 3.15      | 3.35 | eee       |      | 0.08  |      |
| е         |      | 0.50 BSC. |      | Z         |      | 0.435 |      |
| E         |      | 5.00 BSC. |      | Y         |      | 0.18  |      |

#### Table 4.4. QFN-28 Package Dimensions

Notes:

- 1. All dimensions shown are in millimeters (mm) unless otherwise noted.
- 2. Dimensioning and Tolerancing per ANSI Y14.5M-1994.
- **3.** This drawing conforms to JEDEC outline MO-243, variation VHHD except for custom features D2, E2, L, Z, and Y which are toleranced per supplier designation.
- 4. Recommended card reflow profile is per the JEDEC/IPC J-STD-020C specification for Small Body Components.



| SFR Page:<br>SFR Address            | all pages<br>s: 0xB9                                                                                                                                                                                                        |                                                                                                                                                                                                  |                                                                                                                                                                               |                                                                                                                                                                 |                                    |      |      |             |  |
|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|------|------|-------------|--|
| R/W                                 | R/W                                                                                                                                                                                                                         | R/W                                                                                                                                                                                              | R/W                                                                                                                                                                           | R                                                                                                                                                               | R                                  | R/W  | R/W  | Reset Value |  |
| IDA0EN                              |                                                                                                                                                                                                                             | IDA0CM                                                                                                                                                                                           |                                                                                                                                                                               | -                                                                                                                                                               | -                                  | IDA0 | OMD  | 01110010    |  |
| Bit7                                | Bit6                                                                                                                                                                                                                        | Bit5                                                                                                                                                                                             | Bit4                                                                                                                                                                          | Bit3                                                                                                                                                            | Bit2                               | Bit1 | Bit0 | _           |  |
| Bit 7:                              | Bit 7: IDA0EN: IDA0 Enable.<br>0: IDA0 Disabled.<br>1: IDA0 Enabled.                                                                                                                                                        |                                                                                                                                                                                                  |                                                                                                                                                                               |                                                                                                                                                                 |                                    |      |      |             |  |
| Bits 6–4:<br>Bits 3–2:<br>Bits 1–0: | IDAUCIM[2:0<br>000: DAC o<br>001: DAC o<br>010: DAC o<br>011: DAC o<br>100: DAC o<br>101: DAC o<br>101: DAC o<br>111: DAC o<br>111: DAC o<br>111: DAC o<br>UNUSED. F<br>IDA0OMD[1<br>00: 0.5 mA<br>01: 1.0 mA<br>1x: 2.0 mA | J: IDAO Upd<br>utput update<br>utput update<br>utput update<br>utput update<br>utput update<br>utput update<br>toput update<br>Read = 00b. V<br>:0]: IDAO Ou<br>full-scale out<br>full-scale out | ate Source<br>s on Timer<br>s on Timer<br>s on Timer<br>s on rising<br>s on falling<br>s on any ed<br>s on write t<br>Write = dor<br>toput Mode<br>put current<br>put current | Select bits.<br>0 overflow.<br>1 overflow.<br>2 overflow.<br>3 overflow.<br>edge of CN<br>edge of CN<br>dge of CNVS<br>o IDA0H. (d<br>n't care.<br>Select bits. | VSTR.<br>IVSTR.<br>STR.<br>efault) |      |      |             |  |

# SFR Definition 6.1. IDA0CN: IDA0 Control

# SFR Definition 6.2. IDA0H: IDA0 Data Word MSB





# SFR Definition 6.3. IDA0L: IDA0 Data Word LSB



## **Table 6.1. IDAC Electrical Characteristics**

-40 to +85 °C,  $V_{DD}$  = 3.0 V Full-scale output current set to 2 mA unless otherwise specified.

| Parameter                                               | Conditions                                                                                           | Min | Тур                 | Max                   | Units          |  |  |  |  |  |
|---------------------------------------------------------|------------------------------------------------------------------------------------------------------|-----|---------------------|-----------------------|----------------|--|--|--|--|--|
| Static Performance                                      |                                                                                                      |     |                     |                       |                |  |  |  |  |  |
| Resolution                                              |                                                                                                      |     | 10                  |                       | bits           |  |  |  |  |  |
| Integral Nonlinearity                                   |                                                                                                      |     | ±0.5                | ±2                    | LSB            |  |  |  |  |  |
| Differential Nonlinearity                               | Guaranteed Monotonic                                                                                 |     | ±0.5                | ±1                    | LSB            |  |  |  |  |  |
| Output Compliance Range                                 |                                                                                                      | _   | _                   | V <sub>DD</sub> – 1.2 | V              |  |  |  |  |  |
| Offset Error                                            |                                                                                                      | _   | 0                   | —                     | LSB            |  |  |  |  |  |
| Full Scale Error                                        | 2 mA Full Scale Output Current                                                                       | -15 | 0                   | 15                    | LSB            |  |  |  |  |  |
| Full Scale Error Tempco                                 |                                                                                                      | _   | 30                  | —                     | ppm/°C         |  |  |  |  |  |
| V <sub>DD</sub> Power Supply<br>Rejection Ratio         |                                                                                                      |     | 6.5                 | —                     | µA/V           |  |  |  |  |  |
|                                                         | Dynamic Performance                                                                                  |     |                     |                       |                |  |  |  |  |  |
| Output Settling Time to 1/2<br>LSB                      | IDA0H:L = 0x3FF to 0x000                                                                             | _   | 5                   | —                     | μs             |  |  |  |  |  |
| Startup Time                                            |                                                                                                      | —   | 5                   | —                     | μs             |  |  |  |  |  |
| Gain Variation                                          | 1 mA Full Scale Output Current<br>0.5 mA Full Scale Output Current                                   | _   | ±1<br>±1            | _                     | %<br>%         |  |  |  |  |  |
|                                                         | Power Consumption                                                                                    |     |                     |                       |                |  |  |  |  |  |
| Power Supply Current (V <sub>DD</sub> supplied to IDAC) | 2 mA Full Scale Output Current<br>1 mA Full Scale Output Current<br>0.5 mA Full Scale Output Current |     | 2140<br>1140<br>640 |                       | μΑ<br>μΑ<br>μΑ |  |  |  |  |  |



# 7. Voltage Reference (C8051F360/1/2/6/7/8/9)

The Voltage reference MUX on the C8051F360/1/2/6/7/8/9 devices is configurable to use an externally connected voltage reference, the internal reference voltage generator, or the V<sub>DD</sub> power supply voltage (see Figure 7.1). The REFSL bit in the Reference Control register (REF0CN) selects the reference source. For an external source or the internal reference, REFSL should be set to '0'. To use V<sub>DD</sub> as the reference source, REFSL should be set to '1'.

The BIASE bit enables the internal voltage bias generator, which is used by the ADC, Temperature Sensor, internal oscillators, and Current DAC. This bias is enabled when any of the aforementioned peripherals are enabled. The bias generator may be enabled manually by writing a '1' to the BIASE bit in register REF0CN; see SFR Definition 7.1 for REF0CN register details. The electrical specifications for the voltage reference circuit are given in Table 7.1.

The internal voltage reference circuit consists of a 1.2 V, temperature stable bandgap voltage reference generator and a gain-of-two output buffer amplifier. The internal voltage reference can be driven out on the VREF pin by setting the REFBE bit in register REF0CN to a '1' (see SFR Definition 7.1). The maximum load seen by the VREF pin must be less than 200  $\mu$ A to GND. When using the internal voltage reference, bypass capacitors of 0.1  $\mu$ F and 4.7  $\mu$ F are recommended from the VREF pin to GND. If the internal reference is not used, the REFBE bit should be cleared to '0'. Electrical specifications for the internal voltage reference are given in Table 7.1.

**Important Note about the VREF Pin:** Port pin P0.3 on the C8051F360 device and P0.0 on C8051F361/2/6/7/89 devices is used as the external VREF input and as an output for the internal VREF. When using either an external voltage reference or the internal reference circuitry, the port pin should be configured as an analog pin, and skipped by the Digital Crossbar. To configure the port pin as an analog pin, set the appropriate bit to '0' in register P0MDIN. To configure the Crossbar to skip the VREF port pin, set the appropriate bit to '1' in register P0SKIP. Refer to Section "17. Port Input/Output" on page 182 for



Figure 7.1. Voltage Reference Functional Block Diagram



# 8. Comparators

C8051F36x devices include two on-chip programmable voltage comparators, Comparator0 and Comparator1, shown in Figure 8.1 and Figure 8.2 (**Note:** the port pin Comparator inputs differ between C8051F36x devices. The first Port I/O pin shown is for C8051F360/3 devices).

The comparators offer programmable response time and hysteresis, an analog input multiplexer, and two outputs that are optionally available at the Port pins: a synchronous "latched" output (CP0 and CP1), or an asynchronous "raw" output (CP0A and CP1A). The asynchronous CP0A and CP1A signals are available even when the system clock is not active. This allows the Comparators to operate and generate an output with the device in STOP mode. When assigned to a Port pin, the Comparator outputs may be configured as open drain or push-pull (see Section "17.2. Port I/O Initialization" on page 186). Comparator0 may also be used as a reset source (see Section "12.5. Comparator0 Reset" on page 131).

The Comparator inputs are selected in the CPT0MX and CPT1MX registers (SFR Definition 8.2 and SFR Definition 8.5). The CMXnP1–CMXnP0 bits select the Comparator positive input; the CMXnN1–CMXnN0 bits select the Comparator negative input.

**Important Note About Comparator Inputs:** The Port pins selected as comparator inputs should be configured as analog inputs in their associated Port configuration register, and configured to be skipped by the Crossbar (for details on Port configuration, see Section "17.3. General Purpose Port I/O" on page 189).



Figure 8.1. Comparator0 Functional Block Diagram



### 9.4. Memory Organization

The memory organization of the CIP-51 System Controller is similar to that of a standard 8051. There are two separate memory spaces: program memory and data memory. Program and data memory share the same address space but are accessed via different instruction types. There are 256 bytes of internal data memory and 32k bytes (C8051F360/1/2/3/4/5/6/7) or 16k bytes (C8051F368/9) of internal program memory address space implemented within the CIP-51. The CIP-51 memory organization is shown in Figure 9.2.



Figure 9.2. Memory Map

#### 9.4.1. Program Memory

The CIP-51 core has a 64 kB program memory space. The C8051F360/1/2/3/4/5/6/7 implement 32 kB of this program memory space as in-system, re-programmable Flash memory, organized in a contiguous block from addresses 0x0000 to 0x7BFF. Addresses above 0x7BFF are reserved on the 32 kB devices. The C8051F368/9 implement 16 kB of Flash from addresses 0x0000 to 0x3FFF.

Program memory is normally assumed to be read-only. However, the CIP-51 can write to program memory by setting the Program Store Write Enable bit (PSCTL.0) and using the MOVX instruction. 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 "13. Flash Memory" on page 135 for further details.



#### 9.4.7. Register Descriptions

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









# SFR Definition 9.7. DPH: Data Pointer High Byte





| SFR Page:<br>SFR Addres | all pages<br>ss: 0xA8                                                          | (bit addr                                                                 | essable)                                                             |                                                               |                                          |               |             |              |
|-------------------------|--------------------------------------------------------------------------------|---------------------------------------------------------------------------|----------------------------------------------------------------------|---------------------------------------------------------------|------------------------------------------|---------------|-------------|--------------|
| R/W                     | R/W                                                                            | R/W                                                                       | R/W                                                                  | R/W                                                           | R/W                                      | R/W           | R/W         | Reset Value  |
| EA                      | ESPI0                                                                          | ET2                                                                       | ES0                                                                  | ET1                                                           | EX1                                      | ET0           | EX0         | 00000000     |
| Bit7                    | Bit6                                                                           | Bit5                                                                      | Bit4                                                                 | Bit3                                                          | Bit2                                     | Bit1          | Bit0        |              |
| Bit 7:                  | EA: Global II<br>This bit glob<br>tings.<br>0: Disable al                      | nterrupt Ena<br>ally enables<br>I interrupt s                             | able.<br>s/disables a<br>ources.                                     | ll interrupts                                                 | . It override                            | s the individ | ual interru | pt mask set- |
| Bit 6:                  | 1: Enable ea<br>ESPI0: Enab<br>This bit sets<br>0: Disable al<br>1: Enable int | ch interrup<br>ble Serial Po<br>the maskin<br>I SPI0 inter<br>errupt requ | t according<br>eripheral Int<br>g of the SP<br>rupts.<br>ests genera | to its individ<br>terface (SP<br>10 interrupts<br>ated by SPI | dual mask s<br>I0) Interrupt<br>S.<br>D. | setting.      |             |              |
| Bit 5:                  | ET2: Enable<br>This bit sets<br>0: Disable Ti<br>1: Enable int                 | Timer 2 Int<br>the maskin<br>mer 2 inter<br>errupt requ                   | errupt.<br>g of the Tim<br>rupt.<br>ests genera                      | ner 2 interru                                                 | pt.<br>TF2L or TF                        | 2H flaos.     |             |              |
| Bit 4:                  | ES0: Enable<br>This bit sets<br>0: Disable U<br>1: Enable U                    | UART0 Int<br>the maskin<br>ART0 intern<br>ART0 intern                     | errupt.<br>g of the UA<br>upt.<br>upt.                               | RT0 interru                                                   | pt.                                      |               |             |              |
| Bit 3:                  | ET1: Enable<br>This bit sets<br>0: Disable al<br>1: Enable int                 | Timer 1 Int<br>the maskin<br>I Timer 1 in<br>errupt requ                  | errupt.<br>g of the Tin<br>terrupt.<br>ests genera                   | ner 1 interru<br>ated by the                                  | pt.<br>TF1 flag.                         |               |             |              |
| Bit 2:                  | EX1: Enable<br>This bit sets<br>0: Disable ex<br>1: Enable int                 | External Ir<br>the maskin<br>cternal inter<br>errupt requ                 | iterrupt 1.<br>g of Externa<br>rupt 1.<br>ests genera                | al Interrupt                                                  | 1.<br>/INT1 input.                       |               |             |              |
| Bit 1:                  | ET0: Enable<br>This bit sets<br>0: Disable al<br>1: Enable int                 | Timer 0 Int<br>the maskin<br>I Timer 0 in<br>errupt requ                  | errupt.<br>g of the Tin<br>terrupt.<br>ests genera                   | ner 0 interru<br>ated by the                                  | pt.<br>TF0 flag.                         |               |             |              |
| Bit 0:                  | EX0: Enable<br>This bit sets<br>0: Disable ex<br>1: Enable int                 | External Ir<br>the maskin<br>sternal inter<br>errupt requ                 | terrupt 0.<br>g of Externa<br>rupt 0.<br>ests genera                 | al Interrupt                                                  | 0.<br>/INT0 input.                       |               |             |              |

## SFR Definition 10.1. IE: Interrupt Enable



#### SFR Definition 10.5. EIE2: Extended Interrupt Enable 2



## SFR Definition 10.6. EIP2: Extended Interrupt Priority 2

| SFR Page:<br>SFR Address:           | F<br>0xCF                                                                                   |                                                                                             |                                                                                                |                                                                                          |      |      |      |             |
|-------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|------|------|------|-------------|
| R/W                                 | R/W                                                                                         | R/W                                                                                         | R/W                                                                                            | R/W                                                                                      | R/W  | R/W  | R/W  | Reset Value |
| -                                   | -                                                                                           | _                                                                                           | _                                                                                              | -                                                                                        | _    | PMAT | _    | 00000000    |
| Bit7                                | Bit6                                                                                        | Bit5                                                                                        | Bit4                                                                                           | Bit3                                                                                     | Bit2 | Bit1 | Bit0 |             |
| Bits 7–2: U<br>Bit 1: I<br>Bit 0: U | UNUSED. Ro<br>PMAT: Port M<br>This bit sets<br>D: Port Match<br>1: Port Match<br>UNUSED. Ro | ead = 0000<br>Match Interr<br>the priority<br>n interrupt s<br>n interrupt s<br>ead = 0b. V | 00b. Write :<br>upt Priority<br>of the Port<br>set to low pr<br>set to high p<br>Vrite = don't | = don't care<br>Control.<br>Match intern<br>riority level.<br>priority level.<br>t care. | upt. |      |      |             |



## 11.6. Rounding and Saturation

A Rounding Engine is included, which can be used to provide a rounded result when operating on fractional numbers. MAC0 uses an unbiased rounding algorithm to round the data stored in bits 31–16 of the accumulator, as shown in Table 11.1. Rounding occurs during the third stage of the MAC0 pipeline, after any shift operation, or on a write to the LSB of the accumulator. The rounded results are stored in the rounding registers: MAC0RNDH (SFR Definition 11.12) and MAC0RNDL (SFR Definition 11.13). The accumulator registers are not affected by the rounding engine. Although rounding is primarily used for fractional data, the data in the rounding registers is updated in the same way when operating in integer mode.

| Accumulator Bits 15–0<br>(MAC0ACC1:MAC0ACC0) | Accumulator Bits 31–16<br>(MAC0ACC3:MAC0ACC2) | Rounding<br>Direction | Rounded Results<br>(MAC0RNDH:MAC0RNDL) |
|----------------------------------------------|-----------------------------------------------|-----------------------|----------------------------------------|
| Greater Than 0x8000                          | Anything                                      | Up                    | (MAC0ACC3:MAC0ACC2) + 1                |
| Less Than 0x8000                             | Anything                                      | Down                  | (MAC0ACC3:MAC0ACC2)                    |
| Equal To 0x8000                              | Odd (LSB = 1)                                 | Up                    | (MAC0ACC3:MAC0ACC2) + 1                |
| Equal To 0x8000                              | Even (LSB = 0)                                | Down                  | (MAC0ACC3:MAC0ACC2)                    |

Table 11.1. MAC0 Rounding (MAC0SAT = 0)

The rounding engine can also be used to saturate the results stored in the rounding registers. If the MAC0-SAT bit is set to '1' and the rounding register overflows, the rounding registers will saturate. When a positive overflow occurs, the rounding registers will show a value of 0x7FFF when saturated. For a negative overflow, the rounding registers will show a value of 0x8000 when saturated. If the MAC0SAT bit is cleared to '0', the rounding registers will not saturate.

## 11.7. Usage Examples

This section details some software examples for using MAC0. Section 11.7.1 shows a series of two MAC operations using fractional numbers. Section 11.7.2 shows a single operation in Multiply Only mode with integer numbers. The last example, shown in Section 11.7.3, demonstrates how the left-shift and right-shift operations can be used to modify the accumulator. All of the examples assume that all of the flags in the MAC0STA register are initially set to '0'.

#### 11.7.1. Multiply and Accumulate Example

The example below implements the equation:

 $(0.5 \times 0.25) + (0.5 \times -0.25) \ = \ 0.125 - 0.125 \ = \ 0.0$ 

| l to 0, |
|---------|
| zero    |
| ed      |
|         |



erases will be disabled until the next system reset. Flash writes and erases will also be disabled if a Flash write or erase is attempted before the key codes have been written properly. The Flash lock resets after each write or erase; the key codes must be written again before a following Flash operation can be performed. The FLKEY register is detailed in SFR Definition 13.2.

#### 13.1.2. Erasing Flash Pages From Software

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

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

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

#### 13.1.3. Writing Flash Memory From Software

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

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

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



| SFR Page:<br>SFR Addres | F<br>s: 0xD2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                      |                                                    |                                    |                              |                          |                        |                    |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------|------------------------------------|------------------------------|--------------------------|------------------------|--------------------|
| R/W                     | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R                                                                    | R                                                  | R                                  | R                            | R                        | R                      | Reset Value        |
| CHPUS                   | H CHPOP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RESERVED                                                             |                                                    |                                    | CHSLOT                       |                          |                        | 00011111           |
| Bit7                    | Bit6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Bit5                                                                 | Bit4                                               | Bit3                               | Bit2                         | Bit1                     | Bit0                   |                    |
| Bit 7:                  | <ul> <li>CHPUSH: Cache Push Enable.</li> <li>This bit enables cache push operations, which will lock information in cache slots using MOVC instructions.</li> <li>0: Cache push operations are disabled.</li> <li>1: Cache push operations are enabled. When a MOVC read is executed, the requested 4-byte segment containing the data is locked into the cache at the location indicated by CHSLOT, and CHSLOT is decremented.</li> </ul>                                                          |                                                                      |                                                    |                                    |                              |                          |                        |                    |
| Bit 6:                  | <ul> <li>Note:No more than 30 cache slots should be locked at one time, since the entire cache will be unlocked when CHSLOT is equal to 0.</li> <li>Bit 6: CHPOP: Cache Pop.</li> <li>Writing a '1' to this bit will increment CHSLOT and then unlock that location. This bit always reads '0'. Note that Cache Pop operations should not be performed while CHSLOT = 11110b. "Pop"ing more Cache slots than have been "Push"ed will have indeterminate results on the Cache performance</li> </ul> |                                                                      |                                                    |                                    |                              |                          |                        |                    |
| Bit 5:<br>Bits 4–0:     | RESERVED<br>CHSLOT: C<br>These read-<br>locked, and                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 9. Read = 0b.<br>ache Slot Poir<br>only bits are t<br>will not be ch | Must Write<br>hter.<br>he pointer i<br>anged by th | 0b.<br>nto the cach<br>ne processo | ne lock stac<br>or, except w | k. Location<br>hen CHSL0 | s above C<br>OT equals | CHSLOT are<br>s 0. |

## SFR Definition 14.3. CCH0LC: Cache Lock Control

#### 15.4. Multiplexed and Non-multiplexed Selection

The External Memory Interface is capable of acting in a Multiplexed mode or a Non-multiplexed mode, depending on the state of the EMD2 (EMI0CF.4) bit.

#### 15.4.1. Multiplexed Configuration

In Multiplexed mode, the Data Bus and the lower 8-bits of the Address Bus share the same Port pins: AD[7:0]. In this mode, an external latch (74HC373 or equivalent logic gate) is used to hold the lower 8-bits of the RAM address. The external latch is controlled by the ALE (Address Latch Enable) signal, which is driven by the External Memory Interface logic. An example of a Multiplexed Configuration is shown in Figure 15.1.

In Multiplexed mode, the external MOVX operation can be broken into two phases delineated by the state of the ALE signal. During the first phase, ALE is high and the lower 8-bits of the Address Bus are presented to AD[7:0]. During this phase, the address latch is configured such that the 'Q' outputs reflect the states of the 'D' inputs. When ALE falls, signaling the beginning of the second phase, the address latch outputs remain fixed and are no longer dependent on the latch inputs. Later in the second phase, the Data Bus controls the state of the AD[7:0] port at the time /RD or /WR is asserted.

See Section "15.6.2. Multiplexed Mode" on page 164 for more information.



Figure 15.1. Multiplexed Configuration Example



#### 15.5.3. Split Mode with Bank Select

When EMI0CF.[3:2] are set to '10', the XRAM memory map is split into two areas, on-chip space and off-chip space.

- Effective addresses below the internal XRAM size boundary will access on-chip XRAM space.
- Effective addresses above the internal XRAM size boundary will access off-chip space.
- 8-bit MOVX operations use the contents of EMI0CN to determine whether the memory access is on-chip or off-chip. The upper 8-bits of the Address Bus A[15:8] are determined by EMI0CN, and the lower 8-bits of the Address Bus A[7:0] are determined by R0 or R1. All 16-bits of the Address Bus A[15:0] are driven in "Bank Select" mode.
- 16-bit MOVX operations use the contents of DPTR to determine whether the memory access is on-chip or off-chip, and the full 16-bits of the Address Bus A[15:0] are driven during the off-chip transaction.

#### 15.5.4. External Only

When EMI0CF[3:2] are set to '11', all MOVX operations are directed to off-chip space. On-chip XRAM is not visible to the CPU. This mode is useful for accessing off-chip memory located between 0x0000 and the internal XRAM size boundary.

- 8-bit MOVX operations ignore the contents of EMI0CN. The upper Address bits A[15:8] are not driven (identical behavior to an off-chip access in "Split Mode without Bank Select" described above). This allows the user to manipulate the upper address bits at will by setting the Port state directly. The lower 8-bits of the effective address A[7:0] are determined by the contents of R0 or R1.
- 16-bit MOVX operations use the contents of DPTR to determine the effective address A[15:0]. The full 16-bits of the Address Bus A[15:0] are driven during the off-chip transaction.

#### 15.6. Timing

The timing parameters of the External Memory Interface can be configured to enable connection to devices having different setup and hold time requirements. The Address Setup time, Address Hold time, / RD and /WR strobe widths, and in multiplexed mode, the width of the ALE pulse are all programmable in units of SYSCLK periods through EMI0TC, shown in SFR Definition 15.3, and EMI0CF[1:0].

The timing for an off-chip MOVX instruction can be calculated by adding 4 SYSCLK cycles to the timing parameters defined by the EMI0TC register. Assuming non-multiplexed operation, the minimum execution time for an off-chip XRAM operation is 5 SYSCLK cycles (1 SYSCLK for /RD or /WR pulse + 4 SYSCLKs). For multiplexed operations, the Address Latch Enable signal will require a minimum of 2 additional SYSCLK cycles. Therefore, the minimum execution time for an off-chip XRAM operation in multiplexed mode is 7 SYSCLK cycles (2 for /ALE + 1 for /RD or /WR + 4). The programmable setup and hold times default to the maximum delay settings after a reset. Table 15.2 lists the AC parameters for the External Memory Interface, and Figure 15.4 through Figure 15.9 show the timing diagrams for the different External Memory Interface modes and MOVX operations.



## SFR Definition 16.8. PLL0MUL: PLL Clock Scaler

| SFR Page:<br>SFR Address:  | F<br>0xB1                                                 |                                                              |                                                         |                                                |                                              |                            |                           |                           |
|----------------------------|-----------------------------------------------------------|--------------------------------------------------------------|---------------------------------------------------------|------------------------------------------------|----------------------------------------------|----------------------------|---------------------------|---------------------------|
| R/W                        | R/W                                                       | R/W                                                          | R/W                                                     | R/W                                            | R/W                                          | R/W                        | R/W                       | Reset Value               |
| PLLN7                      | PLLN6                                                     | PLLN5                                                        | PLLN4                                                   | PLLN3                                          | PLLN2                                        | PLLN1                      | PLLN0                     | 00000001                  |
| Bit7                       | Bit6                                                      | Bit5                                                         | Bit4                                                    | Bit3                                           | Bit2                                         | Bit1                       | Bit0                      | -                         |
| Bits 7–0: F<br>7<br>2<br>t | PLLN7–0: P<br>These bits s<br>any non-zero<br>o '00000000 | LL Multiplie<br>elect the mu<br>o value, the<br>0b', the mul | r.<br>ultiplication<br>multiplication<br>tiplication fa | factor of the<br>on factor wi<br>actor will be | e divided PL<br>Il be equal t<br>equal to 25 | L reference<br>o the value | ∋ clock. Wł<br>in PLLN7-( | ien set to<br>0. When set |

## SFR Definition 16.9. PLL0FLT: PLL Filter

| R/W       | R/W                                    | R/W                                                                                  | R/W                                                                | R/W                  | R/W                                        | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R/W          | Reset Value |
|-----------|----------------------------------------|--------------------------------------------------------------------------------------|--------------------------------------------------------------------|----------------------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------------|
| _         | -                                      | PLLICO1                                                                              | PLLICO0                                                            | PLLLP3               | PLLLP2                                     | PLLLP1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | PLLLP0       | 00110001    |
| Bit7      | Bit6                                   | Bit5                                                                                 | Bit4                                                               | Bit3                 | Bit2                                       | Bit1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Bit0         |             |
| Bits 7–6: | UNUSED. R                              | ead = 00b.                                                                           | Write = don                                                        | 't care.             |                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |             |
| Bits 5-4: | PLLICO1-0:                             | PLL Currer                                                                           | nt-Controlled                                                      | d Oscillator         | Control Bits                               | i.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |              |             |
|           | Selection is                           | based on th                                                                          | ne desired o                                                       | utput freque         | ency, accore                               | ding to the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | following ta | able:       |
|           | PLL Output Clock                       |                                                                                      |                                                                    |                      | PLLICO1-0                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |             |
|           | 65–100 MHz                             |                                                                                      |                                                                    |                      | 00                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |             |
|           | 45–80 MHz                              |                                                                                      |                                                                    |                      | 01                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |             |
|           | 30–60 MHz                              |                                                                                      |                                                                    |                      | 10                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |             |
|           | 25–50 MHz                              |                                                                                      |                                                                    |                      | 11                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |             |
|           |                                        |                                                                                      |                                                                    |                      |                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |             |
| Bits 3-0  | PIIIP3-0. F                            | PILLOOD Fi                                                                           | lter Control                                                       | Bits                 |                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |             |
| Bits 3–0: | PLLLP3-0: F<br>Selection is            | LL Loop Fi<br>based on th                                                            | lter Control<br>ne divided P                                       | Bits.<br>LL referenc | e clock, aco                               | cording to t                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | he followin  | g table:    |
| Bits 3–0: | PLLLP3-0: F<br>Selection is<br>Divided | PLL Loop Fi<br>based on th<br><b>PLL Refer</b> e                                     | lter Control<br>ne divided P<br>ence Clock                         | Bits.<br>LL referenc | e clock, acc                               | cording to the cording to the cording to the cordination of the cordin | he followin  | g table:    |
| Bits 3–0: | PLLLP3-0: F<br>Selection is<br>Divided | PLL Loop Fi<br>based on th<br>PLL Refer<br>19–30 MH                                  | lter Control<br>ne divided P<br>ence Clock<br>Iz                   | Bits.<br>LL referenc | e clock, acc<br>PLLLF<br>000               | cording to th<br><b>'3-0</b><br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | he followin  | g table:    |
| Bits 3–0: | PLLLP3-0: F<br>Selection is<br>Divided | PLL Loop Fi<br>based on th<br>PLL Refer<br>19–30 MH<br>12.2–19.5 N                   | Iter Control<br>ne divided P<br>ence Clock<br>Iz<br>Iz             | Bits.<br>LL referenc | e clock, acc<br>PLLLF<br>000<br>001        | cording to t<br><b>23-0</b> 1 1 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | he followin  | g table:    |
| Bits 3–0: | PLLLP3-0: F<br>Selection is<br>Divided | PLL Loop Fi<br>based on th<br>PLL Reference<br>19–30 MH<br>12.2–19.5 M<br>7.8–12.5 M | Iter Control<br>ne divided P<br>ence Clock<br>Iz<br>II<br>Hz<br>Hz | Bits.<br>LL referenc | e clock, acc<br>PLLLF<br>000<br>001<br>011 | cording to th<br>•3-0<br>1<br>1<br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | he followin  | g table:    |





# SFR Definition 17.6. P0SKIP: Port0 Skip

# SFR Definition 17.7. P0MAT: Port0 Match



# SFR Definition 17.8. P0MASK: Port0 Mask





## 18.5. SMBus Transfer Modes

The SMBus interface may be configured to operate as master and/or slave. At any particular time, it will be operating in one of the following four modes: Master Transmitter, Master Receiver, Slave Transmitter, or Slave Receiver. The SMBus interface enters Master Mode any time a START is generated, and remains in Master Mode until it loses an arbitration or generates a STOP. An SMBus interrupt is generated at the end of all SMBus byte frames; however, note that the interrupt is generated before the ACK cycle when operating as a receiver, and after the ACK cycle when operating as a transmitter.

#### 18.5.1. Master Transmitter Mode

Serial data is transmitted on SDA while the serial clock is output on SCL. The SMBus interface generates the START condition and transmits the first byte containing the address of the target slave and the data direction bit. In this case the data direction bit (R/W) will be logic '0' (WRITE). The master then transmits one or more bytes of serial data. After each byte is transmitted, an acknowledge bit is generated by the slave. The transfer is ended when the STO bit is set and a STOP is generated. Note that the interface will switch to Master Receiver Mode if SMB0DAT is not written following a Master Transmitter interrupt. Figure 18.5 shows a typical Master Transmitter sequence. Two transmit data bytes are shown, though any number of bytes may be transmitted. Notice that the 'data byte transferred' interrupts occur **after** the ACK cycle in this mode.



Figure 18.5. Typical Master Transmitter Sequence

