



Welcome to E-XFL.COM

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

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

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

#### Details

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

Email: info@E-XFL.COM

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

|    | Figure 5.17. ADC1L: ADC1 Data Word LSB Register                      | 65 |
|----|----------------------------------------------------------------------|----|
|    | Figure 5.18. ADC1 Data Word Example                                  | 65 |
|    | Figure 5.19. Calibration Coefficient Locations                       | 66 |
|    | Figure 5.20. Offset and Gain Register Mapping                        | 67 |
|    | Figure 5.21. Offset and Gain Calibration Block Diagram               | 67 |
|    | Figure 5.22. ADC0CPT: ADC Calibration Pointer Register               | 68 |
|    | Figure 5.23. ADC0CCF: ADC Calibration Coefficient Register           | 68 |
|    | Figure 5.24. ADC0GTH: ADC0 Greater-Than Data High Byte Register      | 69 |
|    | Figure 5.25. ADC0GTL: ADC0 Greater-Than Data Low Byte Register       | 69 |
|    | Figure 5.26. ADC0LTH: ADC0 Less-Than Data High Byte Register         | 70 |
|    | Figure 5.27. ADC0LTL: ADC0 Less-Than Data Low Byte Register          | 70 |
|    | Figure 5.28. 16-Bit ADC0 Window Interrupt Example: Single-Ended Data | 71 |
| _  | Figure 5.29. 16-Bit ADC0 Window Interrupt Example: Differential Data | 72 |
| 6. | Direct Memory Access Interface (DMA0)                                | 75 |
|    | Figure 6.1. DMA0 Block Diagram                                       | 75 |
|    | Figure 6.2. DMA Mode 0 Operation                                     | 77 |
|    | Figure 6.3. DMA Mode 1 Operation                                     | 78 |
|    | Figure 6.4. DMA0CN: DMA0 Control Register                            | 80 |
|    | Figure 6.5. DMA0CF: DMA0 Configuration Register                      | 81 |
|    | Figure 6.6. DMA0IPT: DMA0 Instruction Write Address Register         | 82 |
|    | Figure 6.7. DMA0ID1: DMA0 Instruction Write Data Register            | 82 |
|    | Figure 6.8. DMA0BND: DMA0 Instruction Boundary Register              | 83 |
|    | Figure 6.9. DMA0ISW: DMA0 Instruction Status Register                | 83 |
|    | Figure 6.10. DMA0DAH: DMA0 Data Address Beginning MSB Register       | 84 |
|    | Figure 6.11. DMA0DAL: DMA0 Data Address Beginning LSB Register       | 84 |
|    | Figure 6.12. DMA0DSH: DMA0 Data Address Pointer MSB Register         | 84 |
|    | Figure 6.13. DMA0DSL: DMA0 Data Address Pointer LSB Register         | 84 |
|    | Figure 6.14. DMA0CTH: DMA0 Repeat Counter Limit MSB Register         | 85 |
|    | Figure 6.15. DMA0CTL: DMA0 Repeat Counter Limit LSB Register         | 85 |
|    | Figure 6.16. DMA0CSH: DMA0 Repeat Counter MSB Register               | 85 |
| -  | Figure 6.17. DMAUCSL: DMAU Repeat Counter LSB Register               | 85 |
| 1. | 10-Bit ADC (ADC2, C8051F060/1/2/3)                                   | 87 |
|    | Figure 7.1. ADC2 Functional Block Diagram                            | 87 |
|    | Figure 7.2. Temperature Sensor Transfer Function                     | 89 |
|    | Figure 7.3. 10-Bit ADC Track and Conversion Example Timing           | 90 |
|    | Figure 7.4. ADC2 Equivalent input Circuits                           | 91 |
|    | Figure 7.6. AMX2CF: AMUX2 Conliguration Register                     | 92 |
|    | Figure 7.6. AMX2SL: AMUX2 Channel Select Register                    | 93 |
|    | Figure 7.9. ADC2CF: ADC2 Conliguration Register                      | 94 |
|    | Figure 7.8. ADC2H: ADC2 Data Word INSB Register                      | 95 |
|    | FIGURE 7.9. ADUZL: ADUZ Data WOIG LOB REGISTER                       | 90 |
|    | FIGURE 7.10. ADUZUN: ADUZ CONTO KEGISTER                             | 90 |
|    | Figure 7.11. ADC2GTH: ADC2 Greater Than Data High Byte Register      | 91 |
|    | Figure 7.12. ADC2GTL: ADC2 Greater-Than Data Low Byte Register       | 97 |
|    | rigure 7.13. ADUZLTH: ADUZ Less-Than Data High Byte Register         | 98 |



| R/W      | R/W           | R/W          | R/W          | R/W           | R/W             | R/W          | R/W                     | Reset Value     |
|----------|---------------|--------------|--------------|---------------|-----------------|--------------|-------------------------|-----------------|
| -        | -             | -            | -            | -             | -               | BIASE0       | REFBE0                  | 00000000        |
| Bit7     | Bit6          | Bit5         | Bit4         | Bit3          | Bit2            | Bit1         | Bit0                    | _               |
|          |               |              |              |               |                 |              | SFR Address<br>SFR Page | :: 0xD1<br>:: 0 |
| Bits7-2: | RESERVED      | . Read = 00  | 0000b; Wri   | te = 000000   | )b.             |              |                         |                 |
| Bit1:    | BIASE0: AD    | C0 Bias Ge   | enerator Ena | able Bit. (Mu | ust be '1' if i | using ADC(   | )).                     |                 |
|          | 0: ADC0 Inte  | ernal Bias G | Generator O  | ff.           |                 |              |                         |                 |
|          | 1: ADC0 Inte  | ernal Bias G | Generator O  | n.            |                 |              |                         |                 |
| Bit0:    | REFBE0: Int   | ernal Refer  | ence Buffe   | for ADC0 I    | Enable Bit.     |              |                         |                 |
|          | 0: Internal R | eference B   | uffer for AD | C0 Off. Exte  | ernal voltag    | e reference  | can be use              | ed.             |
|          | 1: Internal R | eference Bu  | uffer for AD | C0 On. Inter  | mal voltage     | reference is | s driven on t           | the VREF0       |
|          | pin.          |              |              |               |                 |              |                         |                 |

# Figure 5.11. REF0CN: Reference Control Register 0

Figure 5.12. REF1CN: Reference Control Register 1

| R/W      | R/W                                                                                                          | R/W                                       | R/W                                          | R/W                                          | R/W                                        | R/W                         | R/W                         | Reset Value    |
|----------|--------------------------------------------------------------------------------------------------------------|-------------------------------------------|----------------------------------------------|----------------------------------------------|--------------------------------------------|-----------------------------|-----------------------------|----------------|
| -        | -                                                                                                            | -                                         | -                                            | -                                            | -                                          | BIASE1                      | REFBE1                      | 0000000        |
| Bit7     | Bit6                                                                                                         | Bit5                                      | Bit4                                         | Bit3                                         | Bit2                                       | Bit1                        | Bit0                        | _              |
|          |                                                                                                              |                                           |                                              |                                              |                                            |                             | SFR Address<br>SFR Page     | : 0xD1<br>: 1  |
| Bits7-2: | RESERVED                                                                                                     | . Read = 00                               | 0000b; Wri                                   | ite = 000000                                 | )b.                                        |                             |                             |                |
| Bit1:    | BIASE1: ADC1 Bias Generator Enable Bit. (Must be '1' if using ADC1).<br>0: ADC1 Internal Bias Generator Off. |                                           |                                              |                                              |                                            |                             |                             |                |
| Bit0:    | REFBE1: Int<br>0: Internal R<br>1: Internal R<br>pin.                                                        | ernal Refer<br>eference Bi<br>eference Bi | rence Buffer<br>uffer for AD<br>uffer for AD | r for ADC1 I<br>C1 Off. Exte<br>C1 On. Inter | Enable Bit.<br>ernal voltag<br>mal voltage | e reference<br>reference is | can be use<br>s driven on t | d.<br>he VREF1 |





#### Figure 6.14. DMA0CTH: DMA0 Repeat Counter Limit MSB Register

# Figure 6.15. DMA0CTL: DMA0 Repeat Counter Limit LSB Register



# Figure 6.16. DMA0CSH: DMA0 Repeat Counter MSB Register









# 7.1. Analog Multiplexer

The analog multiplexer (AMUX2) selects the inputs to the ADC, allowing any of the pins on Port 1 to be measured in single-ended mode, or as a differential pair. Additionally, the on-chip temperature sensor may be selected as a single-ended input. The ADC2 input channels are configured and selected in the AMX-2CF and AMX2SL registers as described in Figure 7.5 and Figure 7.6, respectively. In Single-ended Mode, the selected pin is measured with respect to AGND. In Differential Mode, the selected differential pair is measured with respect to one another. The polarity of the differential measurement depends on the setting of the AMX2AD3-0 bits in the AMX2SL register. For example, if pins AIN2.0 and AIN2.1 are configured for differential measurement (AIN01IC = 1), and AMX2AD3-0 = 0000b, the ADC will measure the voltage (AIN2.0 - AIN2.1). If AMX2AD3-0 is changed to 0001b, the ADC will measure the same voltage, with opposite polarity (AIN2.1 - AIN2.0).

The conversion code format differs between Single-ended and Differential modes. The registers ADC2H and ADC2L contain the high and low bytes of the output conversion code from the ADC at the completion of each conversion. Data can be right-justified or left-justified, depending on the setting of the AD2LJST bit (ADC2CN.0). When in Single-ended Mode, conversion codes are represented as 10-bit unsigned integers. Inputs are measured from '0' to VREF \* 1023/1024. Example codes are shown below for both right-justified and left-justified data. Unused bits in the ADC2H and ADC2L registers are set to '0'.

| Input Voltage    | Right-Justified ADC2H:ADC2L<br>(AD2LJST = 0) | Left-Justified ADC2H:ADC2L<br>(AD2LJST = 1) |
|------------------|----------------------------------------------|---------------------------------------------|
| VREF * 1023/1024 | 0x03FF                                       | 0xFFC0                                      |
| VREF * 512/1024  | 0x0200                                       | 0x8000                                      |
| VREF * 256/1024  | 0x0100                                       | 0x4000                                      |
| 0                | 0x0000                                       | 0x0000                                      |

When in Differential Mode, conversion codes are represented as 10-bit signed 2's complement numbers. Inputs are measured from -VREF to VREF \* 511/512. Example codes are shown below for both right-justified and left-justified data. For right-justified data, the unused MSBs of ADC2H are a sign-extension of the data word. For left-justified data, the unused LSBs in the ADC2L register are set to '0'.

| Input Voltage   | Right-Justified ADC2H:ADC2L<br>(AD2LJST = 0) | Left-Justified ADC2H:ADC2L<br>(AD2LJST = 1) |
|-----------------|----------------------------------------------|---------------------------------------------|
| VREF * 511/512  | 0x01FF                                       | 0x7FC0                                      |
| VREF * 256/512  | 0x0100                                       | 0x4000                                      |
| 0               | 0x0000                                       | 0x0000                                      |
| -VREF * 256/512 | 0xFF00                                       | 0xC000                                      |
| - VREF          | 0xFE00                                       | 0x8000                                      |

**Important Note About ADC2 Input Configuration:** Port 1 pins selected as ADC2 inputs should be configured as analog inputs. To configure a Port 1 pin for analog input, set to '1' the corresponding bit in register P1MDIN. Port 1 pins used as ADC2 inputs will be skipped by the crossbar for peripheral assignments. See Section "18. Port Input/Output" on page 203 for more Port I/O configuration details.

The Temperature Sensor transfer function is shown in Figure 7.2 on Page 89. The output voltage ( $V_{TEMP}$ ) is a single-ended input to ADC2 when the Temperature Sensor is selected by bits AMX2AD3-0 in register AMX2SL. Typical values for the Slope and Offset parameters can be found in Table 7.1.



# 7.3. Programmable Window Detector

The ADC Programmable Window Detector continuously compares the ADC2 output registers to user-programmed limits, and notifies the system when a desired condition is detected. This is especially effective in an interrupt-driven system, saving code space and CPU bandwidth while delivering faster system response times. The window detector interrupt flag (AD2WINT in register ADC2CN) can also be used in polled mode. The ADC2 Greater-Than (ADC2GTH, ADC2GTL) and Less-Than (ADC2LTH, ADC2LTL) registers hold the comparison values. The window detector flag can be programmed to indicate when measured data is inside or outside of the user-programmed limits, depending on the contents of the ADC2 Less-Than and ADC2 Greater-Than registers.









# 7.3.1. Window Detector In Single-Ended Mode

Figure 7.15 shows two example window comparisons for right-justified, single-ended data, with ADC2LTH:ADC2LTL = 0x0080 (128d) and ADC2GTH:ADC2GTL = 0x0040 (64d). In single-ended mode, the input voltage can range from '0' to VREF \* (1023/1024) with respect to AGND, and is represented by a 10-bit unsigned integer value. In the left example, an AD2WINT interrupt will be generated if the ADC2 conversion word (ADC2H:ADC2L) is within the range defined by ADC2GTH:ADC2GTL and ADC2LTH:ADC2LTL (if 0x0040 < ADC2H:ADC2L < 0x0080). In the right example, and AD2WINT interrupt will be generated if the ADC2 conversion word is outside of the range defined by the ADC2GT and ADC2LT registers (if ADC2H:ADC2L < 0x0040 or ADC2H:ADC2L > 0x0080). Figure 7.16 shows an example using left-justified data with the same comparison values.



Figure 7.15. ADC Window Compare Example: Right-Justified Single-Ended Data

Figure 7.16. ADC Window Compare Example: Left-Justified Single-Ended Data





#### Table 7.1. ADC2 Electrical Characteristics

VDD = 3.0 V, VREF = 2.40 V (REFSL=0), PGA Gain = 1, -40°C to +85°C unless otherwise specified

| Parameter                                   | Conditions                                               | Min        | Тур     | Max          | Units        |
|---------------------------------------------|----------------------------------------------------------|------------|---------|--------------|--------------|
| DC Accuracy                                 |                                                          |            |         |              |              |
| Resolution                                  |                                                          |            | 10      |              | bits         |
| Integral Nonlinearity                       |                                                          |            | ±0.5    | ±1           | LSB          |
| Differential Nonlinearity                   | Guaranteed Monotonic                                     |            | ±0.5    | ±1           | LSB          |
| Offset Error                                |                                                          | -12        | 1       | 12           | LSB          |
| Full Scale Error                            | Differential mode                                        | -15        | -5      | 5            | LSB          |
| Offset Temperature Coefficient              |                                                          |            | 3.6     |              | ppm/°C       |
| DYNAMIC PERFORMANCE (10 I                   | kHz sine-wave Differential inpu                          | ut, 1 dB   | below F | ull Scal     | e, 200 ksps) |
| Signal-to-Noise Plus Distortion             |                                                          | 53         | 55.5    |              | dB           |
| Total Harmonic Distortion                   | Up to the 5 <sup>th</sup> harmonic                       |            | -67     |              | dB           |
| Spurious-Free Dynamic Range                 |                                                          |            | 78      |              | dB           |
| Conversion Rate                             |                                                          |            | •       |              |              |
| SAR Conversion Clock                        |                                                          |            |         | 3            | MHz          |
| Conversion Time in SAR Clocks               |                                                          | 10         |         |              | clocks       |
| Track/Hold Acquisition Time                 |                                                          | 300        |         |              | ns           |
| Throughput Rate                             |                                                          |            |         | 200          | ksps         |
| Analog Inputs                               |                                                          |            | •       |              |              |
| ADC Input Voltage Range                     | Single Ended (AIN+ - AGND)<br>Differential (AIN+ - AIN-) | 0<br>-VREF |         | VREF<br>VREF | V<br>V       |
| Absolute Pin Voltage with respect to AGND   | Single Ended or Differential                             | 0          |         | AV+          | V            |
| Input Capacitance                           |                                                          |            | 5       |              | pF           |
| Temperature Sensor                          | ·                                                        |            |         |              |              |
| Linearity                                   |                                                          |            | ±0.2    |              | °C           |
| Offset                                      | Temp = 0 °C                                              |            | 776     |              | mV           |
| Offset Error (Note 1)                       | Temp = 0 °C                                              |            | ±8.9    |              | mV           |
| Slope                                       |                                                          |            | 2.89    |              | mV/°C        |
| Slope Error (Note 1)                        |                                                          |            | ±63     |              | μV/°C        |
| Power Specifications                        |                                                          |            |         |              |              |
| Power Supply Current (VDD supplied to ADC2) | Operating Mode, 200 ksps                                 |            | 400     | 900          | μA           |
| Power Supply Rejection                      |                                                          |            | ±0.3    |              | mV/V         |
| Note 1: Represents one standard             | deviation from the mean value.                           |            |         |              |              |



| Mnemonic           | Description                                | Bytes | Clock<br>Cycles |
|--------------------|--------------------------------------------|-------|-----------------|
| XRL direct, #data  | Exclusive-OR immediate to direct byte      | 3     | 3               |
| CLR A              | Clear A                                    | 1     | 1               |
| CPL A              | Complement A                               | 1     | 1               |
| RL A               | Rotate A left                              | 1     | 1               |
| RLC A              | Rotate A left through Carry                | 1     | 1               |
| RR A               | Rotate A right                             | 1     | 1               |
| RRC A              | Rotate A right through Carry               | 1     | 1               |
| SWAP A             | Swap nibbles of A                          | 1     | 1               |
|                    | Data Transfer                              |       |                 |
| MOV A, Rn          | Move Register to A                         | 1     | 1               |
| MOV A, direct      | Move direct byte to A                      | 2     | 2               |
| MOV A, @Ri         | Move indirect RAM to A                     | 1     | 2               |
| MOV A, #data       | Move immediate to A                        | 2     | 2               |
| MOV Rn, A          | Move A to Register                         | 1     | 1               |
| MOV Rn, direct     | Move direct byte to Register               | 2     | 2               |
| MOV Rn, #data      | Move immediate to Register                 | 2     | 2               |
| MOV direct, A      | Move A to direct byte                      | 2     | 2               |
| MOV direct, Rn     | Move Register to direct byte               | 2     | 2               |
| MOV direct, direct | Move direct byte to direct byte            | 3     | 3               |
| MOV direct, @Ri    | Move indirect RAM to direct byte           | 2     | 2               |
| MOV direct, #data  | Move immediate to direct byte              | 3     | 3               |
| MOV @Ri, A         | Move A to indirect RAM                     | 1     | 2               |
| MOV @Ri, direct    | Move direct byte to indirect RAM           | 2     | 2               |
| MOV @Ri, #data     | Move immediate to indirect RAM             | 2     | 2               |
| MOV DPTR, #data16  | Load DPTR with 16-bit constant             | 3     | 3               |
| MOVC A, @A+DPTR    | Move code byte relative DPTR to A          | 1     | 3               |
| MOVC A, @A+PC      | Move code byte relative PC to A            | 1     | 3               |
| MOVX A, @Ri        | Move external data (8-bit address) to A    | 1     | 3               |
| MOVX @Ri, A        | Move A to external data (8-bit address)    | 1     | 3               |
| MOVX A, @DPTR      | Move external data (16-bit address) to A   | 1     | 3               |
| MOVX @DPTR, A      | Move A to external data (16-bit address)   | 1     | 3               |
| PUSH direct        | Push direct byte onto stack                | 2     | 2               |
| POP direct         | Pop direct byte from stack                 | 2     | 2               |
| XCH A, Rn          | Exchange Register with A                   | 1     | 1               |
| XCH A, direct      | Exchange direct byte with A                | 2     | 2               |
| XCH A, @Ri         | Exchange indirect RAM with A               | 1     | 2               |
| XCHD A, @Ri        | Exchange low nibble of indirect RAM with A | 1     | 2               |
|                    | Boolean Manipulation                       |       |                 |
| CLR C              | Clear Carry                                | 1     | 1               |
| CLR bit            | Clear direct bit                           | 2     | 2               |
| SETB C             | Set Carry                                  | 1     | 1               |
| SETB bit           | Set direct bit                             | 2     | 2               |
| CPL C              | Complement Carry                           | 1     | 1               |
| CPL bit            | Complement direct bit                      | 2     | 2               |
| ANL C, bit         | AND direct bit to Carry                    | 2     | 2               |

| Table 13.1. CIP-51 Instruction Set Summary | / ( | (Continued) |
|--------------------------------------------|-----|-------------|
|--------------------------------------------|-----|-------------|



#### 13.2.2. Data Memory

The CIP-51 implements 256 bytes of internal RAM mapped into the data memory space from 0x00 through 0xFF. The lower 128 bytes of data memory are used for general purpose registers and scratch pad memory. Either direct or indirect addressing may be used to access the lower 128 bytes of data memory. Locations 0x00 through 0x1F are addressable as four banks of general purpose registers, each bank consisting of eight byte-wide registers. The next 16 bytes, locations 0x20 through 0x2F, may either be addressed as bytes or as 128 bit locations accessible with the direct addressing mode.

The upper 128 bytes of data memory are accessible only by indirect addressing. This region occupies the same address space as the Special Function Registers (SFRs) but is physically separate from the SFR space. The addressing mode used by an instruction when accessing locations above 0x7F determines whether the CPU accesses the upper 128 bytes of data memory space or the SFRs. Instructions that use direct addressing above 0x7F will access the SFR space. Instructions using indirect addressing above 0x7F access the upper 128 bytes of data memory. Figure 13.2 illustrates the data memory organization of the CIP-51.

# 13.2.3. General Purpose Registers

The lower 32 bytes of data memory, locations 0x00 through 0x1F, may be addressed as four banks of general-purpose registers. Each bank consists of eight byte-wide registers designated R0 through R7. Only one of these banks may be enabled at a time. Two bits in the program status word, RS0 (PSW.3) and RS1 (PSW.4), select the active register bank (see description of the PSW in Figure 13.16). This allows fast context switching when entering subroutines and interrupt service routines. Indirect addressing modes use registers R0 and R1 as index registers.

#### 13.2.4. Bit Addressable Locations

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

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

MOV C, 22.3h

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

# 13.2.5. Stack

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

The MCUs also have built-in hardware for a stack record which is accessed by the debug logic. The stack record is a 32-bit shift register, where each PUSH or increment SP pushes one record bit onto the register,



| R/W               | R/W                   | R/W                                                        | R/W           | R/W          | R/W          | R/W         | R/W    | Reset Value |  |  |
|-------------------|-----------------------|------------------------------------------------------------|---------------|--------------|--------------|-------------|--------|-------------|--|--|
| EADC0             | CP2IE                 | CP1IE                                                      | CP0IE         | EPCA0        | EWADC0       | ESMB0       | ESPI0  | 00000000    |  |  |
| Bit7              | Bit6                  | Bit5                                                       | Bit4          | Bit3         | Bit2         | Bit1        | Bit0   |             |  |  |
|                   |                       | SFR Address: 0xE6                                          |               |              |              |             |        |             |  |  |
|                   |                       |                                                            |               |              |              |             |        |             |  |  |
| Bit7:             | EADC0: Ena            | ADC0: Enable ADC0 End of Conversion Interrupt.             |               |              |              |             |        |             |  |  |
|                   | This bit sets         | the maskin                                                 | g of the AD   | C0 End of (  | Conversion   | Interrupt.  |        |             |  |  |
|                   | 0: Disable A          | DC0 Conve                                                  | ersion Interr | upt.         |              |             |        |             |  |  |
|                   | 1: Enable int         | errupt requ                                                | ests genera   | ated by the  | ADC1 Conv    | ersion Inte | rrupt. |             |  |  |
| Bit6:             | CP2IE: Enat           | ole Compar                                                 | ator (CP2)    | Interrupt.   |              |             |        |             |  |  |
|                   | This bit sets         | the maskin                                                 | g of the CP   | 2 interrupt. |              |             |        |             |  |  |
|                   | 0: Disable C          | P2 Interrup                                                | IS.           | atod by the  |              |             |        |             |  |  |
| Bit6.             | CP1IE: Enab           | enupt requi                                                | ator (CP1)    | Interrunt    | CFZIF liay.  |             |        |             |  |  |
| Dito.             | This bit sets         | the maskin                                                 | a of the CP   | 1 interrupt  |              |             |        |             |  |  |
|                   | 0: Disable C          | P1 interrup                                                | ts.           | i intorrupti |              |             |        |             |  |  |
|                   | 1: Enable int         | errupt requ                                                | ests genera   | ated by the  | CP1IF flag.  |             |        |             |  |  |
| Bit6:             | CP0IE: Enat           | ole Compar                                                 | ator (CP0)    | Interrupt.   | Ū            |             |        |             |  |  |
|                   | This bit sets         | the maskin                                                 | g of the CP   | 0 interrupt. |              |             |        |             |  |  |
|                   | 0: Disable C          | P0 interrup                                                | ts.           |              |              |             |        |             |  |  |
| Dire              | 1: Enable int         | errupt requ                                                | ests genera   | ated by the  | CP0IF flag.  |             |        |             |  |  |
| Bit3:             | EPCA0: Ena            | ble Prograi                                                | mmable Co     | unter Array  | (PCA0) Inte  | errupt.     |        |             |  |  |
|                   | I NIS DIT SETS        | the maskin                                                 | g of the PC   | AU Interrup  | ts.          |             |        |             |  |  |
|                   | 1. Enable int         |                                                            | ests dener    | ated by PC/  | 20           |             |        |             |  |  |
| Bit2 <sup>.</sup> | EWADC0 <sup>.</sup> E | nable Wind                                                 | low Compa     | rison ADC0   | Interrupt    |             |        |             |  |  |
| BREI              | This bit sets         | the maskin                                                 | g of ADC0     | Window Co    | mparison in  | terrupt.    |        |             |  |  |
|                   | 0: Disable Al         | DC0 Windo                                                  | w Compari     | son Interrup | ot.          | •           |        |             |  |  |
|                   | 1: Enable Int         | errupt requ                                                | iests genera  | ated by AD   | C0 Window    | Compariso   | ns.    |             |  |  |
| Bit1:             | ESMB0: Ena            | able System                                                | n Managem     | ent Bus (SM  | MBus0) Inter | rrupt.      |        |             |  |  |
|                   | This bit sets         | This bit sets the masking of the SMBus interrupt.          |               |              |              |             |        |             |  |  |
|                   | 0: Disable al         | ): Disable all SMBus interrupts.                           |               |              |              |             |        |             |  |  |
| D:+O+             | 1: Enable int         | : Enable interrupt requests generated by the SI flag.      |               |              |              |             |        |             |  |  |
| DILU.             | This hit sate         | SPIU: Enable Serial Peripheral Interface (SPIU) Interrupt. |               |              |              |             |        |             |  |  |
|                   | 0: Disable al         | nis bit sets the masking of SPIU interrupt.                |               |              |              |             |        |             |  |  |
|                   | 1: Enable Int         | errupt reau                                                | iests genera  | ated by the  | SPI0 flag.   |             |        |             |  |  |
|                   |                       | 1 1                                                        | 0             | ,            | 5            |             |        |             |  |  |
|                   |                       |                                                            |               |              |              |             |        |             |  |  |

# Figure 13.21. EIE1: Extended Interrupt Enable 1



Step 8. Clear the PSWE bit to redirect MOVX write commands to the XRAM data space.

Step 9. Re-enable interrupts.

Write/Erase timing is automatically controlled by hardware. Note that code execution in the 8051 is stalled while the Flash is being programmed or erased.

| Parameter        | Conditions          | Min  | Тур     | Max | Units       |
|------------------|---------------------|------|---------|-----|-------------|
| Flash Size *     | C8051F060/1/2/3/4/5 |      | 65664 † |     | Bytes       |
| Flash Size *     | C8051F066/7         |      | 32896   |     | Bytes       |
| Endurance        |                     | 20 k | 100 k   |     | Erase/Write |
| Erase Cycle Time |                     | 10   | 12      | 14  | ms          |
| Write Cycle Time |                     | 40   | 50      | 60  | μs          |

| Table 16.1. Flash El | ectrical Characteristics |
|----------------------|--------------------------|
|----------------------|--------------------------|

\* Includes 128-byte Scratch Pad Area

† 1024 Bytes at location 0xFC00 to 0xFFFF are reserved.

# 16.2. Non-volatile Data Storage

The Flash memory can be used for non-volatile data storage as well as program code. This allows data such as calibration coefficients to be calculated and stored at run time. Data is written using the MOVX write instruction (as described in the previous section) and read using the MOVC instruction.

An additional 128-byte sector of Flash memory is included for non-volatile data storage. Its smaller sector size makes it particularly well suited as general purpose, non-volatile scratchpad memory. Even though Flash memory can be written a single byte at a time, an entire sector must be erased first. In order to change a single byte of a multi-byte data set, the data must be moved to temporary storage. The 128-byte sector size facilitates updating data without wasting program memory or RAM space. The 128-byte sector is double-mapped over the normal Flash memory area; its address ranges from 0x00 to 0x7F (see Figure 16.1 and Figure 16.2). To access this 128-byte sector, the SFLE bit in PSCTL must be set to logic 1. Code execution from this 128-byte scratchpad sector is not supported.







Rev. 1.2

eral's enable bits are not set to a logic 1, then its ports are not accessible at the Port pins of the device. Also note that the Crossbar assigns pins to all associated functions when the SMBus, UART0 or UART1 are selected (i.e. SMBus, SPI, UART). It would be impossible, for example, to assign TX0 to a Port pin without assigning RX0 as well. The SPI can operate in 3 or 4-wire mode (with or without NSS). Each combination of enabled peripherals results in a unique device pinout.

All Port pins on Ports 0 through 3 that are not allocated by the Crossbar can be accessed as General-Purpose I/O (GPIO) pins by reading and writing the associated Port Data registers (See Figure 18.9, Figure 18.11, Figure 18.14, and Figure 18.17), a set of SFRs which are both byte- and bit-addressable. The output states of Port pins that are allocated by the Crossbar are controlled by the digital peripheral that is mapped to those pins. Writes to the Port Data registers (or associated Port bits) will have no effect on the states of these pins.

A Read of a Port Data register (or Port bit) will always return the logic state present at the pin itself, regardless of whether the Crossbar has allocated the pin for peripheral use or not. An exception to this occurs during the execution of a *read-modify-write* instruction (ANL, ORL, XRL, CPL, INC, DEC, DJNZ, JBC, CLR, SETB, and the bitwise MOV write operation). During the *read* cycle of the *read-modify-write* instruction, it is the contents of the Port Data register, not the state of the Port pins themselves, which is read.

Because the Crossbar registers affect the pinout of the peripherals of the device, they are typically configured in the initialization code of the system before the peripherals themselves are configured. Once configured, the Crossbar registers are typically left alone.

Once the Crossbar registers have been properly configured, the Crossbar is enabled by setting XBARE (XBR2.4) to a logic 1. Until XBARE is set to a logic 1, the output drivers on Ports 0 through 3 are explicitly disabled in order to prevent possible contention on the Port pins while the Crossbar registers and other registers which can affect the device pinout are being written.

The output drivers on Crossbar-assigned input signals (like RX0, for example) are explicitly disabled; thus the values of the Port Data registers and the PnMDOUT registers have no effect on the states of these pins.

# 18.1.2. Configuring the Output Modes of the Port Pins

The output drivers on Ports 0 through 3 remain disabled until the Crossbar is enabled by setting XBARE (XBR2.4) to a logic 1.

The output mode of each port pin can be configured to be either Open-Drain or Push-Pull. In the Push-Pull configuration, writing a logic 0 to the associated bit in the Port Data register will cause the Port pin to be driven to GND, and writing a logic 1 will cause the Port pin to be driven to VDD. In the Open-Drain configuration, writing a logic 0 to the associated bit in the Port Data register will cause the Port pin to be driven to GND, and a logic 1 will cause the Port pin to assume a high-impedance state. The Open-Drain configuration is useful to prevent contention between devices in systems where the Port pin participates in a shared interconnection in which multiple outputs are connected to the same physical wire (like the SDA signal on an SMBus connection).

The output modes of the Port pins on Ports 0 through 3 are determined by the bits in the associated PnMDOUT registers (See Figure 18.10, Figure 18.13, Figure 18.16, and Figure 18.18). For example, a logic 1 in P3MDOUT.7 will configure the output mode of P3.7 to Push-Pull; a logic 0 in P3MDOUT.7 will configure the output mode of P3.7 to Open-Drain. All Port pins default to Open-Drain output.

Rev. 1.2



| R/W      | R/W                                                                                                                                                                                                                                                                                               | R/W  | R/W  | R/W  | R/W  | R/W  | R/W         | Reset Value        |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|------|------|-------------|--------------------|
| P7.7     | P7.6                                                                                                                                                                                                                                                                                              | P7.5 | P7.4 | P7.3 | P7.2 | P7.1 | P7.0        | 11111111           |
| Bit7     | Bit6                                                                                                                                                                                                                                                                                              | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0        | Bit<br>Addressable |
|          |                                                                                                                                                                                                                                                                                                   |      |      |      |      |      | SFR Address | : 0xF8             |
|          |                                                                                                                                                                                                                                                                                                   |      |      |      |      |      | SFR Page    | : F                |
|          |                                                                                                                                                                                                                                                                                                   |      |      |      |      |      |             |                    |
| Bits7-0: | P7.[7:0]: Port7 Output Latch Bits.                                                                                                                                                                                                                                                                |      |      |      |      |      |             |                    |
|          | <ul> <li>Write - Output appears on I/O pins.</li> <li>0: Logic Low Output.</li> <li>1: Logic High Output (open, if corresponding P7MDOUT bit = 0). See Figure 18.26.</li> <li>Read - Returns states of I/O pins.</li> <li>0: P7.n pin is logic low.</li> <li>1: P7 n pin is logic high</li> </ul> |      |      |      |      |      |             |                    |
|          |                                                                                                                                                                                                                                                                                                   |      |      |      |      |      |             |                    |
|          |                                                                                                                                                                                                                                                                                                   |      |      |      |      |      |             |                    |
|          |                                                                                                                                                                                                                                                                                                   |      |      |      |      |      |             |                    |
|          |                                                                                                                                                                                                                                                                                                   |      |      |      |      |      |             |                    |
|          |                                                                                                                                                                                                                                                                                                   |      |      |      |      |      |             |                    |
|          |                                                                                                                                                                                                                                                                                                   |      | -    |      |      |      |             |                    |
| Note:    | P7.[7:0] can be driven by the External Data Memory Interface (as AD[7:0] in Multiplexed mode, or as D[7:0] in Non-multiplexed mode). See Section "17. External Data Memory Interface and On-Chip XRAM" on page 187 for more information about the External Memory Interface                       |      |      |      |      |      |             |                    |
|          | interface.                                                                                                                                                                                                                                                                                        |      |      |      |      |      |             |                    |

# Figure 18.25. P7: Port7 Data Register

# Figure 18.26. P7MDOUT: Port7 Output Mode Register





# 20.3. SMBus Transfer Modes

The SMBus0 interface may be configured to operate as a master and/or a slave. At any particular time, the interface will be operating in one of the following modes: Master Transmitter, Master Receiver, Slave Transmitter, or Slave Receiver. See Table 20.1 for transfer mode status decoding using the SMB0STA status register. The following mode descriptions illustrate an interrupt-driven SMBus0 application; SMBus0 may alternatively be operated in polled mode.

# 20.3.1. Master Transmitter Mode

Serial data is transmitted on SDA while the serial clock is output on SCL. SMBus0 generates a START condition and then transmits the first byte containing the address of the target slave device and the data direction bit. In this case the data direction bit (R/W) will be logic 0 to indicate a "WRITE" operation. The SMBus0 interface transmits one or more bytes of serial data, waiting for an acknowledge (ACK) from the slave after each byte. To indicate the end of the serial transfer, SMBus0 generates a STOP condition.



#### Figure 20.4. Typical Master Transmitter Sequence

# 20.3.2. Master Receiver Mode

Serial data is received on SDA while the serial clock is output on SCL. The SMBus0 interface generates a START followed by the first data 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 1 to indicate a "READ" operation. The SMBus0 interface receives serial data from the slave and generates the clock on SCL. After each byte is received, SMBus0 generates an ACK or NACK depending on the state of the AA bit in register SMB0CN. SMBus0 generates a STOP condition to indicate the end of the serial transfer.







238



# 21.1. Signal Descriptions

The four signals used by SPI0 (MOSI, MISO, SCK, NSS) are described below.

# 21.1.1. Master Out, Slave In (MOSI)

The master-out, slave-in (MOSI) signal is an output from a master device and an input to slave devices. It is used to serially transfer data from the master to the slave. This signal is an output when SPI0 is operating as a master and an input when SPI0 is operating as a slave. Data is transferred most-significant bit first. When configured as a master, MOSI is driven by the MSB of the shift register in both 3- and 4-wire mode.

# 21.1.2. Master In, Slave Out (MISO)

The master-in, slave-out (MISO) signal is an output from a slave device and an input to the master device. It is used to serially transfer data from the slave to the master. This signal is an input when SPI0 is operating as a master and an output when SPI0 is operating as a slave. Data is transferred most-significant bit first. The MISO pin is placed in a high-impedance state when the SPI module is disabled and when the SPI operates in 4-wire mode as a slave that is not selected. When acting as a slave in 3-wire mode, MISO is always driven by the MSB of the shift register.

# 21.1.3. Serial Clock (SCK)

The serial clock (SCK) signal is an output from the master device and an input to slave devices. It is used to synchronize the transfer of data between the master and slave on the MOSI and MISO lines. SPI0 generates this signal when operating as a master. The SCK signal is ignored by a SPI slave when the slave is not selected (NSS = 1) in 4-wire slave mode.

# 21.1.4. Slave Select (NSS)

The function of the slave-select (NSS) signal is dependent on the setting of the NSSMD1 and NSSMD0 bits in the SPI0CN register. There are three possible modes that can be selected with these bits:

- NSSMD[1:0] = 00: 3-Wire Master or 3-Wire Slave Mode: SPI0 operates in 3-wire mode, and NSS is disabled. When operating as a slave device, SPI0 is always selected in 3-wire mode. Since no select signal is present, SPI0 must be the only slave on the bus in 3-wire mode. This is intended for point-to-point communication between a master and one slave.
- 2. NSSMD[1:0] = 01: 4-Wire Slave or Multi-Master Mode: SPI0 operates in 4-wire mode, and NSS is enabled as an input. When operating as a slave, NSS selects the SPI0 device. When operating as a master, a 1-to-0 transition of the NSS signal disables the master function of SPI0 so that multiple master devices can be used on the same SPI bus.
- 3. NSSMD[1:0] = 1x: 4-Wire Master Mode: SPI0 operates in 4-wire mode, and NSS is enabled as an output. The setting of NSSMD0 determines what logic level the NSS pin will output. This configuration should only be used when operating SPI0 as a master device.

See Figure 21.2, Figure 21.3, and Figure 21.4 for typical connection diagrams of the various operational modes. **Note that the setting of NSSMD bits affects the pinout of the device.** When in 3-wire master or 3-wire slave mode, the NSS pin will not be mapped by the crossbar. In all other modes, the NSS signal will be mapped to a pin on the device. See Section "18. Port Input/Output" on page 203 for general purpose port I/O and crossbar information.



# 24.2. Timer 2, Timer 3, and Timer 4

Timers 2, 3, and 4 are 16-bit counter/timers, each formed by two 8-bit SFRs: TMRnL (low byte) and TMRnH (high byte) where n = 2, 3, and 4 for timers 2, 3, and 4 respectively. These timers feature autoreload, capture, and toggle output modes with the ability to count up or down. Capture Mode and Autoreload mode are selected using bits in the Timer 2, 3, and 4 Control registers (TMRnCN). Toggle output mode is selected using the Timer 2, 3, and 4 Configuration registers (TMRnCF). These timers may also be used to generate a square-wave at an external pin. Timers 2, 3, and 4 can use either the system clock (divided by one, two, or twelve), external clock (divided by eight) or transitions on an external input pin as its clock source. Timer 2 and 3 can be used to start an ADC Data Conversion and Timers 2, 3, and 4 can schedule DAC outputs. Timers 1, 2, 3, or 4 may be used to generate baud rates for UART 0. Only Timer 1 can be used to generate baud rates for UART 1.

The Counter/Timer Select bit C/Tn bit (TMRnCN.1) configures the peripheral as a counter or timer. Clearing C/Tn configures the Timer to be in a timer mode (i.e., the selected timer clock source as the input for the timer). When C/Tn is set to 1, the timer is configured as a counter (i.e., high-to-low transitions at the Tn input pin increment (or decrement) the counter/timer register. Refer to Section "18.1. Ports 0 through 3 and the Priority Crossbar Decoder" on page 205 for information on selecting and configuring external I/O pins for digital peripherals, such as the Tn pin.

Timer 2, 3, and 4 can use either SYSCLK, SYSCLK divided by 2, SYSCLK divided by 12, an external clock divided by 8, or high-to-low transitions on the Tn input pin as its clock source when operating in Counter/ Timer with Capture mode. Clearing the C/Tn bit (TnCON.1) selects the system clock/external clock as the input for the timer. The Timer Clock Select bits TnM0 and TnM1 in TMRnCF can be used to select the system clock undivided, system clock divided by two, system clock divided by 12, or an external clock provided at the XTAL1/XTAL2 pins divided by 8 (see Figure 24.14). When C/Tn is set to logic 1, a high-to-low transition at the Tn input pin increments the counter/timer register (i.e., configured as a counter).

# 24.2.1. Configuring Timer 2, 3, and 4 to Count Down

Timers 2, 3, and 4 have the ability to count down. When the timer's respective Decrement Enable Bit (DCENn) in the Timer Configuration Register (See Figure 24.14) is set to '1', the timer can then count *up* or *down*. When DCENn = 1, the direction of the timer's count is controlled by the TnEX pin's logic level. When TnEX = 1, the counter/timer will count up; when TnEX = 0, the counter/timer will count down. To use this feature, TnEX must be enabled in the digital crossbar and configured as a digital input.

Note: When DCENn = 1, other functions of the TnEX input (i.e., capture and auto-reload) are not available. TnEX will only control the direction of the timer when DCENn = 1.



| D/M/                                                                                                            | D ///                                                                                                      |                                                                                                                          |                                                                                                                                                                                                                              |                                                               | D/M                                        |                                             |                                        | Pocot Valuo                            |
|-----------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|--------------------------------------------|---------------------------------------------|----------------------------------------|----------------------------------------|
| PWM16                                                                                                           | n ECOMn                                                                                                    | CAPPn                                                                                                                    | CAPNn                                                                                                                                                                                                                        | MATn                                                          | TOGn                                       | PWMn                                        | ECCFn                                  |                                        |
| Bit7                                                                                                            | Bit6                                                                                                       | Bit5                                                                                                                     | Bit4                                                                                                                                                                                                                         | Bit3                                                          | Bit2                                       | Bit1                                        | Bit0                                   |                                        |
| SFR Address: 0xDF PCA0CPM0: 0xDA, PCA0CPM1: 0xDB, PCA0CPM2: 0xDC, PCA0CPM3: 0xDD, PCA0CPM4: 0xDE, PCA0CPM5:     |                                                                                                            |                                                                                                                          |                                                                                                                                                                                                                              |                                                               |                                            |                                             |                                        |                                        |
| SFR Page: PCA0CPM0: page 0, PCA0CPM1: page 0, PCA0CPM2: page 0, PCA0CPM3: 0, PCA0CPM4: page 0, PCA0CPM5: page 0 |                                                                                                            |                                                                                                                          |                                                                                                                                                                                                                              |                                                               |                                            |                                             |                                        |                                        |
| Bit7:                                                                                                           | PWM16n: 16<br>This bit selec<br>0: 8-bit PWM<br>1: 16-bit PWI                                              | bit Pulse W<br>ts 16-bit mo<br>selected.<br>M selected.                                                                  | Vidth Modu<br>ode when F                                                                                                                                                                                                     | lation Enabl<br>Pulse Width                                   | e.<br>Modulation                           | mode is en                                  | abled (PW                              | Mn = 1).                               |
| Bit6:                                                                                                           | ECOMn: Cor<br>This bit enab<br>0: Disabled.<br>1: Enabled.                                                 | nparator Fu<br>les/disables                                                                                              | nction Ena<br>the compa                                                                                                                                                                                                      | ble.<br>arator functio                                        | on for PCA                                 | 0 module n.                                 |                                        |                                        |
| Bit5:                                                                                                           | CAPPn: Cap<br>This bit enab<br>0: Disabled.<br>1: Enabled.                                                 | ture Positive<br>les/disables                                                                                            | Function<br>the positive<br>the positive<br>the positive<br>for the positive<br>the positive<br>the positive<br>the positive<br>the positive<br>the positive<br>the positive<br>the positive<br>the positive<br>the positive | Enable.<br>/e edge cap                                        | ture for PC/                               | A0 module r                                 | ٦.                                     |                                        |
| Bit4:                                                                                                           | CAPNn: Cap<br>This bit enab<br>0: Disabled.<br>1: Enabled.                                                 | ture Negativ<br>les/disables                                                                                             | ve Functior<br>the negati                                                                                                                                                                                                    | n Enable.<br>ive edge cap                                     | oture for PC                               | CA0 module                                  | n.                                     |                                        |
| Bit3:                                                                                                           | MATn: Match<br>This bit enab<br>the PCA0 con<br>register to be<br>0: Disabled.<br>1: Enabled.              | Function E<br>les/disables<br>unter with a<br>set to logic                                                               | nable.<br>the match<br>module's c<br>1.                                                                                                                                                                                      | function for<br>apture/com                                    | PCA0 mod<br>pare registe                   | lule n. Wher<br>er cause the                | n enabled,<br>CCFn bit ii              | matches of<br>n PCA0MD                 |
| Bit2:                                                                                                           | TOGn: Toggl<br>This bit enab<br>the PCA0 co<br>CEXn pin to<br>Output Mode<br>0: Disabled.<br>1: Enabled.   | e Function I<br>les/disables<br>unter with a<br>toggle. If the                                                           | ∃nable.<br>a the toggle<br>module's d<br>∌ PWMn bit                                                                                                                                                                          | function for<br>capture/com<br>t is also set t                | PCA0 mod<br>pare registe<br>to logic 1, th | lule n. Wher<br>er cause the<br>ne module o | n enabled,<br>logic leve<br>perates in | matches of<br>I on the<br>Frequency    |
| Bit1:                                                                                                           | PWMn: Pulse<br>This bit enab<br>width modula<br>16-bit mode i<br>Frequency O<br>0: Disabled.<br>1: Enabled | <ul> <li>Width Models</li> <li>les/disables</li> <li>ated signal is</li> <li>used if PV</li> <li>utput Models</li> </ul> | Julation Mc<br>the PWM<br>s output on<br>WM16n log                                                                                                                                                                           | ode Enable.<br>function for<br>a the CEXn p<br>ic 1. If the T | PCA0 mod<br>bin. 8-bit PV<br>OGn bit is a  | ule n. Wher<br>VM is used<br>also set, the  | n enabled,<br>if PWM16r<br>module op   | a pulse<br>n is logic 0;<br>perates in |
| Bit0:                                                                                                           | ECCFn: Cap<br>This bit sets<br>0: Disable Co<br>1: Enable a C                                              | ture/Compa<br>the masking<br>CFn interrup<br>Capture/Cor                                                                 | re Flag Inte<br>of the Cap<br>ots.<br>npare Flag                                                                                                                                                                             | errupt Enabl<br>oture/Compa<br>interrupt red                  | e.<br>are Flag (Co<br>quest when           | CFn) interru<br>CCFn is se                  | pt.<br>:t.                             |                                        |

# Figure 25.12. PCA0CPMn: PCA0 Capture/Compare Mode Registers



# Table 26.2. Boundary Data Register Bit Definitions (C8051F061/3/5/7)

EXTEST provides access to both capture and update actions, while Sample only performs a capture.

| Bit                 | Action  | Target                                                                  |
|---------------------|---------|-------------------------------------------------------------------------|
| 0                   | Capture | Not used                                                                |
|                     | Update  | Not used                                                                |
| 1                   | Capture | Not used                                                                |
|                     | Update  | Not used                                                                |
| 2                   | Capture | CAN RX Output Enable to pin                                             |
|                     | Update  | CAN RX Output Enable to pin                                             |
| 3                   | Capture | CAN RX Input from pin                                                   |
|                     | Update  | CAN RX Output to pin                                                    |
| 4                   | Capture | CAN TX Output Enable to pin                                             |
|                     | Update  | CAN TX Output Enable to pin                                             |
| 5                   | Capture | CAN TX Input from pin                                                   |
|                     | Update  | CAN TX Output to pin                                                    |
| 6                   | Capture | External Clock from XTAL1 pin                                           |
|                     | Update  | Not used                                                                |
| 7                   | Capture | Weak Pullup Enable from MCU                                             |
|                     | Update  | Weak Pullup Enable to Port Pins                                         |
| 8, 10, 12, 14, 16,  | Capture | P0.n output enable from MCU (e.g. Bit 8 = P0.0, Bit 10 = P0.1, etc.)    |
| 18, 20, 22          | Update  | P0.n output enable to pin (e.g. Bit 8 = P0.00e, Bit 10 = P0.10e, etc.)  |
| 9, 11, 13, 15, 17,  | Capture | P0.n input from pin (e.g. Bit 9 = P0.0, Bit 11 = P0.1, etc.)            |
| 19, 21, 23          | Update  | P0.n output to pin (e.g. Bit 9 = P0.0, Bit 11 = P0.1, etc.)             |
| 24, 26, 28, 30, 32, | Capture | P1.n output enable from MCU (follows P0.n numbering scheme)             |
| 34, 36, 38          | Update  | P1.n output enable to pin (follows P0.n numbering scheme)               |
| 25, 27, 29, 31, 33, | Capture | P1.n input from pin (follows P0.n numbering scheme)                     |
| 35, 37, 39          | Update  | P1.n output to pin (follows P0.n numbering scheme)                      |
| 40, 42, 44, 46, 48, | Capture | P2.n output enable from MCU (follows P0.n numbering scheme)             |
| 50, 52, 54          | Update  | P2.n output enable to pin (follows P0.n numbering scheme)               |
| 41, 43, 45, 47, 49, | Capture | P2.n input from pin (follows P0.n numbering scheme)                     |
| 51, 53, 55          | Update  | P2.n output to pin (follows P0.n numbering scheme)                      |
| 56, 58, 60, 62, 64, | Capture | P3.n output enable from MCU (follows P0.n numbering scheme)             |
| 66, 68, 70          | Update  | P3.n output enable to pin (follows P0.n numbering scheme)               |
| 57, 59, 61, 63, 65, | Capture | P3.n input from pin (follows P0.n numbering scheme)                     |
| 67, 69, 71          | Update  | P3.n output to pin (follows P0.n numbering scheme)                      |
| 72                  | Capture | Reset Enable from MCU                                                   |
|                     | Update  | Reset Enable to /RST pin                                                |
| 73                  | Capture | Reset Input from /RST pin                                               |
|                     | Update  | Not used                                                                |
| 74, 76, 78, 80, 82, | Capture | P5.0, P5.1, P5.2, P5.3, P5.5, P5.7 (respectively) output enable from    |
| 84                  |         | MCU†                                                                    |
|                     | Update  | P5.0, P5.1, P5.2, P5.3, P5.5, P5.7 (respectively) output enable to pin† |
| 75, 77, 79, 81, 83, | Capture | P5.0, P5.1, P5.2, P5.3, P5.5, P5.7 (respectively) input from pin†       |
| 85                  | Update  | P5.0, P5.1, P5.2, P5.3, P5.5, P5.7 (respectively) output to pin†        |
| 86, 88, 90, 92, 94, | Capture | P6.n output enable from MCU (follows P0.n numbering scheme)†            |
| 96, 98, 100         | Update  | P6.n output enable to pin (follows P0.n numbering scheme)†              |

