



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                      | 100MHz                                                      |
| Connectivity               | EBI/EMI, SMBus (2-Wire/I <sup>2</sup> C), SPI, UART/USART   |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, Temp Sensor, WDT          |
| Number of I/O              | 32                                                          |
| Program Memory Size        | 128KB (128K x 8)                                            |
| Program Memory Type        | FLASH                                                       |
| EEPROM Size                | -                                                           |
| RAM Size                   | 8.25K x 8                                                   |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 3.6V                                                   |
| Data Converters            | A/D 8x10b                                                   |
| 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/c8051f131 |

Email: info@E-XFL.COM

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

# 1.8. 12 or 10-Bit Analog to Digital Converter

All devices include either a 12 or 10-bit SAR ADC (ADC0) with a 9-channel input multiplexer and programmable gain amplifier. With a maximum throughput of 100 ksps, the 12 and 10-bit ADCs offer true 12-bit linearity with an INL of  $\pm$ 1LSB. The ADC0 voltage reference can be selected from an external VREF pin, or (on the C8051F12x devices) the DAC0 output. On the 100-pin TQFP devices, ADC0 has its own dedicated Voltage Reference input pin; on the 64-pin TQFP devices, the ADC0 shares a Voltage Reference input pin with the 8-bit ADC2. The on-chip voltage reference may generate the voltage reference for other system components or the on-chip ADCs via the VREF output pin.

The ADC is under full control of the CIP-51 microcontroller via its associated Special Function Registers. One input channel is tied to an internal temperature sensor, while the other eight channels are available externally. Each pair of the eight external input channels can be configured as either two single-ended inputs or a single differential input. The system controller can also put the ADC into shutdown mode to save power.

A programmable gain amplifier follows the analog multiplexer. The gain can be set in software from 0.5 to 16 in powers of 2. The gain stage can be especially useful when different ADC input channels have widely varied input voltage signals, or when it is necessary to "zoom in" on a signal with a large DC offset (in differential mode, a DAC could be used to provide the DC offset).

Conversions can be started in four ways; a software command, an overflow of Timer 2, an overflow of Timer 3, or an external signal input. This flexibility allows the start of conversion to be triggered by software events, external HW signals, or a periodic timer overflow signal. Conversion completions are indicated by a status bit and an interrupt (if enabled). The resulting 10 or 12-bit data word is latched into two SFRs upon completion of a conversion. The data can be right or left justified in these registers under software control.

Window Compare registers for the ADC data can be configured to interrupt the controller when ADC data is 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 the specified window.



Figure 1.13. 12-Bit ADC Block Diagram



|                |                                                                                  | Pin Nu                                                                           | mbers          |                |               |                                                                                                                                                                                                                       |  |  |
|----------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------|----------------|----------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Name           | <sup>•</sup> F120<br><sup>•</sup> F122<br><sup>•</sup> F124<br><sup>•</sup> F126 | <sup>•</sup> F121<br><sup>•</sup> F123<br><sup>•</sup> F125<br><sup>•</sup> F127 | 'F130<br>'F132 | ʻF131<br>ʻF133 | Туре          | Description                                                                                                                                                                                                           |  |  |
| DAC1           | 99                                                                               | 63                                                                               |                |                | A Out         | Digital to Analog Converter 1 Voltage Output.<br>(See DAC Specification for complete descrip-<br>tion).                                                                                                               |  |  |
| P0.0           | 62                                                                               | 55                                                                               | 62             | 55             | D I/O         | Port 0.0. See Port Input/Output section for complete description.                                                                                                                                                     |  |  |
| P0.1           | 61                                                                               | 54                                                                               | 61             | 54             | D I/O         | Port 0.1. See Port Input/Output section for complete description.                                                                                                                                                     |  |  |
| P0.2           | 60                                                                               | 53                                                                               | 60             | 53             | D I/O         | Port 0.2. See Port Input/Output section for complete description.                                                                                                                                                     |  |  |
| P0.3           | 59                                                                               | 52                                                                               | 59             | 52             | D I/O         | Port 0.3. See Port Input/Output section for complete description.                                                                                                                                                     |  |  |
| P0.4           | 58                                                                               | 51                                                                               | 58             | 51             | D I/O         | Port 0.4. See Port Input/Output section for complete description.                                                                                                                                                     |  |  |
| ALE/P0.5       | 57                                                                               | 50                                                                               | 57             | 50             | D I/O         | ALE Strobe for External Memory Address bus<br>(multiplexed mode)<br>Port 0.5<br>See Port Input/Output section for complete<br>description.                                                                            |  |  |
| RD/P0.6        | 56                                                                               | 49                                                                               | 56             | 49             | D I/O         | /RD Strobe for External Memory Address bus<br>Port 0.6<br>See Port Input/Output section for complete<br>description.                                                                                                  |  |  |
| WR/P0.7        | 55                                                                               | 48                                                                               | 55             | 48             | D I/O         | /WR Strobe for External Memory Address bus<br>Port 0.7<br>See Port Input/Output section for complete<br>description.                                                                                                  |  |  |
| AIN2.0/A8/P1.0 | 36                                                                               | 29                                                                               | 36             | 29             | A In<br>D I/O | ADC2 Input Channel 0 (See ADC2 Specification<br>for complete description).<br>Bit 8 External Memory Address bus (Non-multi-<br>plexed mode)<br>Port 1.0<br>See Port Input/Output section for complete<br>description. |  |  |
| AIN2.1/A9/P1.1 | 35                                                                               | 28                                                                               | 35             | 28             | A In<br>D I/O | Port 1.1. See Port Input/Output section for complete description.                                                                                                                                                     |  |  |

Table 4.1. Pin Definitions (Continued)



The Temperature Sensor transfer function is shown in Figure 6.2. The output voltage ( $V_{TEMP}$ ) is the PGA input when the Temperature Sensor is selected by bits AMX0AD3-0 in register AMX0SL; this voltage will be amplified by the PGA according to the user-programmed PGA settings. Typical values for the Slope and Offset parameters can be found in Table 6.1.



Figure 6.2. Typical Temperature Sensor Transfer Function



# 6.2. ADC Modes of Operation

ADC0 has a maximum conversion speed of 100 ksps. The ADC0 conversion clock is derived from the system clock divided by the value held in the ADCSC bits of register ADC0CF.

### 6.2.1. Starting a Conversion

A conversion can be initiated in one of four ways, depending on the programmed states of the ADC0 Start of Conversion Mode bits (AD0CM1, AD0CM0) in ADC0CN. Conversions may be initiated by:

- 1. Writing a '1' to the AD0BUSY bit of ADC0CN;
- 2. A Timer 3 overflow (i.e. timed continuous conversions);
- 3. A rising edge detected on the external ADC convert start signal, CNVSTR0;
- 4. A Timer 2 overflow (i.e. timed continuous conversions).

The AD0BUSY bit is set to logic 1 during conversion and restored to logic 0 when conversion is complete. The falling edge of AD0BUSY triggers an interrupt (when enabled) and sets the AD0INT interrupt flag (ADC0CN.5). Converted data is available in the ADC0 data word MSB and LSB registers, ADC0H, ADC0L. Converted data can be either left or right justified in the ADC0H:ADC0L register pair (see example in Figure 6.5) depending on the programmed state of the AD0LJST bit in the ADC0CN register.

When initiating conversions by writing a '1' to AD0BUSY, the AD0INT bit should be polled to determine when a conversion has completed (ADC0 interrupts may also be used). The recommended polling procedure is shown below.

Step 1. Write a '0' to AD0INT; Step 2. Write a '1' to AD0BUSY; Step 3. Poll AD0INT for '1'; Step 4. Process ADC0 data.

When CNVSTR0 is used as a conversion start source, it must be enabled in the crossbar, and the corresponding pin must be set to open-drain, high-impedance mode (see **Section "18. Port Input/Output" on page 235** for more details on Port I/O configuration).



| SFR Page: 2<br>SFR Address: 0xBA |                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                             |                                               |                                             |                                                   |                                         |               |             |             |  |  |
|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|---------------------------------------------|---------------------------------------------------|-----------------------------------------|---------------|-------------|-------------|--|--|
| R/W                              | / R/W R/W R/W R/W R/W F                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                             |                                               |                                             |                                                   |                                         |               |             | Reset Value |  |  |
| -                                | -                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                             | -                                             | -                                           | PIN67IC                                           | PIN45IC                                 | PIN23IC       | PIN01IC     | 00000000    |  |  |
| Bit7                             | Bi                                                                                                                                                                                                                                                                             | 6                                                                                                                                                                                                                           | Bit5                                          | Bit4                                        | Bit3                                              | Bit2                                    | Bit1          | Bit0        | <u>_</u>    |  |  |
| Bits7–4<br>Bit3:                 | <ul> <li>UNUSED. Read = 0000b; Write = don't care.</li> <li>PIN67IC: AIN2.6, AIN2.7 Input Pair Configuration Bit.</li> <li>0: AIN2.6 and AIN2.7 are independent single-ended inputs.</li> <li>1: AIN2.6 and AIN2.7 are (respectively) +, - differential input pair.</li> </ul> |                                                                                                                                                                                                                             |                                               |                                             |                                                   |                                         |               |             |             |  |  |
| BILZ:                            | 0: AIN2<br>1: AIN2                                                                                                                                                                                                                                                             | 4 and<br>4 and<br>4 and                                                                                                                                                                                                     | d AIN2.5 and AIN2.5 and AIN2.5 and AIN2.5 and | e independe<br>e (respectiv                 | ent single-e                                      | nded inputs<br>ferential inp            | ut pair.      |             |             |  |  |
| Bit1:                            | PIN23I0<br>0: AIN2<br>1: AIN2                                                                                                                                                                                                                                                  | 2 and<br>2 and<br>2 and                                                                                                                                                                                                     | l2.2, AIN2.3<br>d AIN2.3 ar<br>d AIN2.3 ar    | 3 Input Pair<br>e independe<br>e (respectiv | Configuration<br>ent single-en<br>vely) +, – diff | on Bit.<br>nded inputs<br>ferential inp | ut pair.      |             |             |  |  |
| Bit0:                            | PIN0110<br>0: AIN2<br>1: AIN2                                                                                                                                                                                                                                                  | <ul> <li>PIN01IC: AIN2.0, AIN2.1 Input Pair Configuration Bit.</li> <li>0: AIN2.0 and AIN2.1 are independent single-ended inputs.</li> <li>1: AIN2.0 and AIN2.1 are (respectively) +, – differential input pair.</li> </ul> |                                               |                                             |                                                   |                                         |               |             |             |  |  |
| Note:                            | The ADC2                                                                                                                                                                                                                                                                       | Data \                                                                                                                                                                                                                      | Word is in 2's                                | s complemer                                 | nt format for c                                   | hannels con                             | figured as di | fferential. |             |  |  |

# SFR Definition 7.1. AMX2CF: AMUX2 Configuration



# SFR Definition 10.2. CPT0MD: Comparator0 Mode Selection

| SFR Page: 1<br>SFR Address: 0x89 |                                                                                                                                                                                                        |               |               |             |            |        |        |          |  |  |  |  |
|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|---------------|-------------|------------|--------|--------|----------|--|--|--|--|
| R/W                              | R/W                                                                                                                                                                                                    | R/W           | Reset Value   |             |            |        |        |          |  |  |  |  |
| -                                | -                                                                                                                                                                                                      | CP0RIE        | CP0FIE        | -           | -          | CP0MD1 | CP0MD0 | 00000010 |  |  |  |  |
| Bit7                             | Bit6                                                                                                                                                                                                   | Bit0          |               |             |            |        |        |          |  |  |  |  |
| Bits7–6:<br>Bit 5:               | UNUSED. Read = 00b, Write = don't care.<br>CP0RIE: Comparator 0 Rising-Edge Interrupt Enable Bit.<br>0: Comparator 0 rising-edge interrupt disabled.<br>1: Comparator 0 rising-edge interrupt enabled. |               |               |             |            |        |        |          |  |  |  |  |
| Bit 4:                           | CP0FIE: Comparator 0 Falling-Edge Interrupt Enable Bit.<br>0: Comparator 0 falling-edge interrupt disabled.<br>1: Comparator 0 falling-edge interrupt enabled                                          |               |               |             |            |        |        |          |  |  |  |  |
| Bits3–2:                         | UNUSED. Re                                                                                                                                                                                             | ad = 00b, W   | /rite = don't | t care.     |            |        |        |          |  |  |  |  |
| Bits1–0:                         | CP0MD1-CP                                                                                                                                                                                              | 0MD0: Com     | parator0 M    | lode Select |            |        |        |          |  |  |  |  |
|                                  | These bits se                                                                                                                                                                                          | lect the resp | onse time     | for Compar  | ator0.     |        |        |          |  |  |  |  |
|                                  |                                                                                                                                                                                                        | 000000        | 000400        |             |            |        |        |          |  |  |  |  |
|                                  | Mode                                                                                                                                                                                                   | CP0MD1        | CPOMDO        |             | Notes      |        |        |          |  |  |  |  |
|                                  | 0                                                                                                                                                                                                      | 0             | 0             | Fastes      | st Respons | e Time |        |          |  |  |  |  |
|                                  | 1 0 1 —                                                                                                                                                                                                |               |               |             |            |        |        |          |  |  |  |  |
|                                  | 2 1 0 —                                                                                                                                                                                                |               |               |             |            |        |        |          |  |  |  |  |
|                                  | 3 1 1 Lowest Power Consumption                                                                                                                                                                         |               |               |             |            |        |        |          |  |  |  |  |
|                                  |                                                                                                                                                                                                        | •             |               | •           |            | ,      |        |          |  |  |  |  |

# 11.3. Interrupt Handler

The CIP-51 includes an extended interrupt system supporting a total of 20 interrupt sources with two priority levels. The allocation of interrupt sources between on-chip peripherals and external input pins varies according to the specific version of the device. Each interrupt source has one or more associated interruptpending flag(s) located in an SFR. When a peripheral or external source meets a valid interrupt condition, the associated interrupt-pending flag is set to logic 1.

If interrupts are enabled for the source, an interrupt request is generated when the interrupt-pending flag is set. As soon as execution of the current instruction is complete, the CPU generates an LCALL to a predetermined address to begin execution of an interrupt service routine (ISR). Each ISR must end with an RETI instruction, which returns program execution to the next instruction that would have been executed if the interrupt request had not occurred. If interrupts are not enabled, the interrupt-pending flag is ignored by the hardware and program execution continues as normal. (The interrupt-pending flag is set to logic 1 regard-less of the interrupt's enable/disable state.)

Each interrupt source can be individually enabled or disabled through the use of an associated interrupt enable bit in an SFR (IE, EIE1, or EIE2). However, interrupts must first be globally enabled by setting the EA bit (IE.7) to logic 1 before the individual interrupt enables are recognized. Setting the EA bit to logic 0 disables all interrupt sources regardless of the individual interrupt-enable settings.

**Note:** Any instruction that clears the EA bit should be immediately followed by an instruction that has two or more opcode bytes. For example:

// in 'C': EA = 0; // clear EA bit. EA = 0; // this is a dummy instruction with two-byte opcode. ; in assembly: CLR EA ; clear EA bit. CLR EA ; this is a dummy instruction with two-byte opcode.

If an interrupt is posted during the execution phase of a "CLR EA" opcode (or any instruction which clears the EA bit), and the instruction is followed by a single-cycle instruction, the interrupt may be taken. However, a read of the EA bit will return a '0' inside the interrupt service routine. When the "CLR EA" opcode is followed by a multi-cycle instruction, the interrupt will not be taken.

Some interrupt-pending flags are automatically cleared by the hardware when the CPU vectors to the ISR. However, most are not cleared by the hardware and must be cleared by software before returning from the ISR. If an interrupt-pending flag remains set after the CPU completes the return-from-interrupt (RETI) instruction, a new interrupt request will be generated immediately and the CPU will re-enter the ISR after the completion of the next instruction.

### 11.3.1. MCU Interrupt Sources and Vectors

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



## 12.3. Operating in Multiply and Accumulate Mode

MAC0 operates in Multiply and Accumulate (MAC) mode when the MACOMS bit (MAC0CF.0) is cleared to '0'. When operating in MAC mode, MAC0 performs a 16-by-16 bit multiply on the contents of the MAC0A and MAC0B registers, and adds the result to the contents of the 40-bit MAC0 accumulator. Figure 12.4 shows the MAC0 pipeline. There are three stages in the pipeline, each of which takes exactly one SYSCLK cycle to complete. The MAC operation is initiated with a write to the MAC0BL register. After the MAC0BL register is written, MAC0A and MAC0B are multiplied on the first SYSCLK cycle. During the second stage of the MAC0 pipeline, the results of the multiplication are added to the current accumulator contents, and the result of the addition is stored in the MAC0 accumulator. The status flags in the MAC0STA register are set after the end of the second pipeline stage. During the second stage of the pipeline, the next multiplication can be initiated by writing to the MAC0BL register, if it is desired. The rounded (and optionally, saturated) result is available in the MAC0RNDH and MAC0RNDL registers at the end of the third pipeline stage. If the MAC0CA bit (MAC0CF.3) is set to '1' when the MAC operation is initiated, the accumulator and all MAC0STA flags will be cleared during the next cycle of the controller's clock (SYSCLK). The MAC0CA bit will clear itself to '0' when the clear operation is complete.



Figure 12.4. MAC0 Pipeline

# 12.4. Operating in Multiply Only Mode

MAC0 operates in Multiply Only mode when the MAC0MS bit (MAC0CF.0) is set to '1'. Multiply Only mode is identical to Multiply and Accumulate mode, except that the multiplication result is added with a value of zero before being stored in the MAC0 accumulator (i.e. it overwrites the current accumulator contents). The result of the multiplication is available in the MAC0 accumulator registers at the end of the second MAC0 pipeline stage (two SYSCLKs after writing to MAC0BL). As in MAC mode, the rounded result is available in the MAC0 Rounding Registers after the third pipeline stage. Note that in Multiply Only mode, the MAC0HO flag is not affected.

### 12.5. Accumulator Shift Operations

MAC0 contains a 1-bit arithmetic shift function which can be used to shift the contents of the 40-bit accumulator left or right by one bit. The accumulator shift is initiated by writing a '1' to the MAC0SC bit (MAC0CF.5), and takes one SYSCLK cycle (the rounded result is available in the MAC0 Rounding Registers after a second SYSCLK cycle, and MAC0SC is cleared to '0'). The direction of the arithmetic shift is controlled by the MAC0SD bit (MAC0CF.4). When this bit is cleared to '0', the MAC0 accumulator will shift left. When the MAC0SD bit is set to '1', the MAC0 accumulator will shift right. Right-shift operations are sign-extended with the current value of bit 39. Note that the status flags in the MAC0STA register are not affected by shift operations.



# SFR Definition 12.2. MAC0STA: MAC0 Status

| R                   | R                                                                                                                                                                        | R                                                              | R                                                  | R/W                                                            | R/W                                                 | R/W                                            | R/W                                   | Reset Value                           |  |  |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|----------------------------------------------------|----------------------------------------------------------------|-----------------------------------------------------|------------------------------------------------|---------------------------------------|---------------------------------------|--|--|
| -                   | -                                                                                                                                                                        | -                                                              | -                                                  | MAC0HO                                                         | MAC0Z                                               | MAC0SO                                         | MAC0N                                 | 00000100                              |  |  |
| Bit7                | Bit6                                                                                                                                                                     | Bit5                                                           | Bit4                                               | Bit3                                                           | Bit2                                                | Bit1                                           | Bit0                                  | Bit<br>Addressable                    |  |  |
|                     |                                                                                                                                                                          |                                                                |                                                    |                                                                |                                                     | S                                              | SFR Address                           | s: 0xC0                               |  |  |
|                     |                                                                                                                                                                          |                                                                |                                                    |                                                                |                                                     |                                                | SFR Page                              | e: 3                                  |  |  |
| Bits 7–4:<br>Bit 3: | UNUSED: R<br>MAC0HO: H                                                                                                                                                   | ead = 0000<br>ard Overflo                                      | b, Write = o<br>w Flag.                            | don't care.                                                    |                                                     |                                                |                                       |                                       |  |  |
|                     | This bit is se<br>MAC operati<br>The hard ove<br>the MAC log                                                                                                             | t to '1' whei<br>on (i.e. whe<br>erflow flag r<br>ic using the | never an ov<br>en MAC0OV<br>nust be clea<br>MAC0CA | verflow out o<br>VR changes<br>ared in softw<br>bit in registe | of the MAC<br>from 0x7F<br>vare by dire<br>r MAC0CF | 0OVR regist<br>to 0x80 or f<br>ectly writing i | er occurs<br>rom 0x80<br>t to '0', or | during a<br>to 0x7F).<br>by resetting |  |  |
| Bit 2:              | MAC0Z: Zer<br>This bit is se<br>is non-zero,                                                                                                                             | o Flag.<br>t to '1' if a M<br>this bit will I                  | IAC0 opera                                         | ation results                                                  | in an Accu                                          | mulator valu                                   | e of zero.                            | If the result                         |  |  |
| Bit 1:              | MAC0SO: S<br>This bit is se<br>MAC0 Accur<br>tion this bit i                                                                                                             | oft Overflow<br>t to '1' wher<br>nulator. If t                 | v Flag.<br>n a MAC op<br>he overflow<br>n '0'      | eration caus                                                   | ses an over<br>s corrected                          | rflow into the<br>after a subs                 | e sign bit (l<br>sequent M            | oit 31) of the<br>AC opera-           |  |  |
| Bit 0:              | MACON: Negative Flag.<br>If the MAC Accumulator result is negative, this bit will be set to '1'. If the result is positive or<br>zero, this flag will be cleared to '0'. |                                                                |                                                    |                                                                |                                                     |                                                |                                       |                                       |  |  |
| *Note: T            | he contents of t                                                                                                                                                         | this register s                                                | should not be                                      | e changed by                                                   | software du                                         | uring the first t                              | wo MAC0                               | oipeline stages.                      |  |  |

# SFR Definition 12.3. MAC0AH: MAC0 A High Byte





# SFR Definition 12.10. MAC0ACC0: MAC0 Accumulator Byte 0



# SFR Definition 12.11. MAC0OVR: MAC0 Accumulator Overflow



# SFR Definition 12.12. MAC0RNDH: MAC0 Rounding Register High Byte





Electrical specifications for the precision internal oscillator are given in Table 14.1. Note that the system clock may be derived from the programmed internal oscillator divided by 1, 2, 4, or 8, as defined by the IFCN bits in register OSCICN.

# SFR Definition 14.1. OSCICL: Internal Oscillator Calibration.



# SFR Definition 14.2. OSCICN: Internal Oscillator Control

| R/W       | R                                                                                                                                                 | R/W           | R            | R/W         | R/W          | R/W   | R/W         | Reset Value |  |  |  |  |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--------------|-------------|--------------|-------|-------------|-------------|--|--|--|--|
| IOSCEN    | I IFRDY                                                                                                                                           | -             | -            | -           | -            | IFCN1 | IFCN0       | 11000000    |  |  |  |  |
| Bit7      | Bit6                                                                                                                                              | Bit5          | Bit4         | Bit3        | Bit2         | Bit1  | Bit0        | -           |  |  |  |  |
|           |                                                                                                                                                   |               |              |             |              |       | SFR Address | : 0x8A      |  |  |  |  |
|           |                                                                                                                                                   |               |              |             |              |       | SFR Page    | :F          |  |  |  |  |
| Bit 7:    | <ul> <li>7: IOSCEN: Internal Oscillator Enable Bit.</li> <li>0: Internal Oscillator Disabled.</li> <li>1: Internal Oscillator Enabled.</li> </ul> |               |              |             |              |       |             |             |  |  |  |  |
| Bit 6:    | IFRDY: Inter                                                                                                                                      | nal Oscillat  | or Frequence | cy Ready Fl | ag.          |       |             |             |  |  |  |  |
|           | 0: Internal O                                                                                                                                     | scillator not | running at   | programme   | ed frequency | y.    |             |             |  |  |  |  |
|           | 1: Internal O                                                                                                                                     | scillator rur | ining at pro | grammed fr  | equency.     |       |             |             |  |  |  |  |
| Bits 5–2: | Reserved.                                                                                                                                         |               |              |             |              |       |             |             |  |  |  |  |
| Bits 1–0: | IFCN1-0: Int                                                                                                                                      | ernal Oscill  | ator Freque  | ncy Contro  | Bits.        |       |             |             |  |  |  |  |
|           | 00: Internal (                                                                                                                                    | Oscillator is | divided by   | 8.          |              |       |             |             |  |  |  |  |
|           | 01: Internal (                                                                                                                                    | Oscillator is | divided by   | 4.          |              |       |             |             |  |  |  |  |
|           | 10: Internal (                                                                                                                                    | Oscillator is | divided by   | 2.          |              |       |             |             |  |  |  |  |
|           | 11: Internal (                                                                                                                                    | Oscillator is | divided by   | 1.          |              |       |             |             |  |  |  |  |





# **15.2. Security Options**

The CIP-51 provides security options to protect the Flash memory from inadvertent modification by software as well as prevent the viewing of proprietary program code and constants. The Program Store Write Enable (PSCTL.0), Program Store Erase Enable (PSCTL.1), and Flash Write/Erase Enable (FLACL.0) bits protect the Flash memory from accidental modification by software. These bits must be explicitly set to logic 1 before software can write or erase the Flash memory. Additional security features prevent proprietary program code and data constants from being read or altered across the JTAG interface or by software running on the system controller.

A set of security lock bytes protect the Flash program memory from being read or altered across the JTAG interface. Each bit in a security lock-byte protects one 16k-byte block of memory. Clearing a bit to logic 0 in the Read Lock Byte prevents the corresponding block of Flash memory from being read across the JTAG interface. Clearing a bit in the Write/Erase Lock Byte protects the block from JTAG erasures and/or writes. The Scratchpad area is read or write/erase locked when all bits in the corresponding security byte are cleared to logic 0.

On the C8051F12x and C8051F130/1, the security lock bytes are located at 0x1FBFE (Write/Erase Lock) and 0x1FBFF (Read Lock), as shown in Figure 15.2. On the C8051F132/3, the security lock bytes are located at 0x0FFFE (Write/Erase Lock) and 0x0FFFF (Read Lock), as shown in Figure 15.3. The 1024-byte sector containing the lock bytes can be written to, but not erased, by software. An attempted read of a read-locked byte returns undefined data. Debugging code in a read-locked sector is not possible through the JTAG interface. The lock bits can always be read from and written to logic 0 regardless of the security setting applied to the block containing the security bytes. This allows additional blocks to be protected after the block containing the security bytes has been locked.

Important Note: To ensure protection from external access, the block containing the lock bytes must be Write/Erase locked. On the 128 kB devices (C8051F12x and C8051F130/1), the block containing the security bytes is 0x18000-0x1BFFF, and is locked by clearing bit 7 of the Write/Erase Lock Byte. On the 64 kB devices (C8051F132/3), the block containing the security bytes is 0x0C000-0x0FFFF, and is locked by clearing bit 3 of the Write/Erase Lock Byte. If the page containing the security bytes is not Write/Erase locked, it is still possible to erase this page of Flash memory through the JTAG port and reset the security bytes.

When the page containing the security bytes has been Write/Erase locked, a JTAG full device erase must be performed to unlock any areas of Flash protected by the security bytes. A JTAG full device erase is initiated by performing a normal JTAG erase operation on either of the security byte locations. This operation must be initiated through the JTAG port, and cannot be performed from firmware running on the device.



The Flash Access Limit security feature (see SFR Definition 15.1) protects proprietary program code and data from being read by software running on the device. This feature provides support for OEMs that wish to program the MCU with proprietary value-added firmware before distribution. The value-added firmware can be protected while allowing additional code to be programmed in remaining program memory space later.

The Flash Access Limit (FAL) is a 17-bit address that establishes two logical partitions in the program memory space. The first is an upper partition consisting of all the program memory locations at or above the FAL address, and the second is a lower partition consisting of all the program memory locations starting at 0x00000 up to (but excluding) the FAL address. Software in the upper partition can execute code in the lower partition, but is prohibited from reading locations in the lower partition using the MOVC instruction. (Executing a MOVC instruction from the upper partition with a source address in the lower partition will return indeterminate data.) Software running in the lower partition can access locations in both the upper and lower partition without restriction.

The Value-added firmware should be placed in the lower partition. On reset, control is passed to the valueadded firmware via the reset vector. Once the value-added firmware completes its initial execution, it branches to a predetermined location in the upper partition. If entry points are published, software running in the upper partition may execute program code in the lower partition, but it cannot read or change the contents of the lower partition. Parameters may be passed to the program code running in the lower partition either through the typical method of placing them on the stack or in registers before the call or by placing them in prescribed memory locations in the upper partition.

The FAL address is specified using the contents of the Flash Access Limit Register. The 8 MSBs of the 17bit FAL address are determined by the setting of the FLACL register. Thus, the FAL can be located on 512byte boundaries anywhere in program memory space. However, the 1024-byte erase sector size essentially requires that a 1024 boundary be used. The contents of a non-initialized FLACL security byte are 0x00, thereby setting the FAL address to 0x00000 and allowing read access to all locations in program memory space by default.



# SFR Definition 15.1. FLACL: Flash Access Limit



- 5. Select the memory mode (on-chip only, split mode without bank select, split mode with bank select, or off-chip only).
- 6. Set up timing to interface with off-chip memory or peripherals.

Each of these five steps is explained in detail in the following sections. The Port selection, Multiplexed mode selection, and Mode bits are located in the EMI0CF register shown in SFR Definition 17.2.

## 17.3. Port Selection and Configuration

The External Memory Interface can appear on Ports 3, 2, 1, and 0 (All Devices) or on Ports 7, 6, 5, and 4 (100-pin TQFP devices only), depending on the state of the PRTSEL bit (EMI0CF.5). If the lower Ports are selected, the EMIFLE bit (XBR2.1) must be set to a '1' so that the Crossbar will skip over P0.7 (/WR), P0.6 (/RD), and if multiplexed mode is selected P0.5 (ALE). For more information about the configuring the Crossbar, see Section "18.1. Ports 0 through 3 and the Priority Crossbar Decoder" on page 238.

The External Memory Interface claims the associated Port pins for memory operations ONLY during the execution of an off-chip MOVX instruction. Once the MOVX instruction has completed, control of the Port pins reverts to the Port latches or to the Crossbar (on Ports 3, 2, 1, and 0). See Section "18. Port Input/ Output" on page 235 for more information about the Crossbar and Port operation and configuration. The Port latches should be explicitly configured to 'park' the External Memory Interface pins in a dormant state, most commonly by setting them to a logic 1.

During the execution of the MOVX instruction, the External Memory Interface will explicitly disable the drivers on all Port pins that are acting as Inputs (Data[7:0] during a READ operation, for example). The Output mode of the Port pins (whether the pin is configured as Open-Drain or Push-Pull) is unaffected by the External Memory Interface operation, and remains controlled by the PnMDOUT registers. In most cases, the output modes of all EMIF pins should be configured for push-pull mode. See "Configuring the Output Modes of the Port Pins" on page 239.

| R/W                                                                                                 | R/W                                                                                                              | R/W                                                                                  | R/W                                                                                 | R/W                                | R/W                            | R/W                         | R/W                       | Reset Value    |
|-----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|------------------------------------|--------------------------------|-----------------------------|---------------------------|----------------|
| PGSEL7                                                                                              | PGSEL6                                                                                                           | PGSEL5                                                                               | PGSEL4                                                                              | PGSEL3                             | PGSEL2                         | PGSEL1                      | PGSEL0                    | 00000000       |
| Bit7                                                                                                | Bit6                                                                                                             | Bit5                                                                                 | Bit4                                                                                | Bit3                               | Bit2                           | Bit1                        | Bit0                      | -              |
|                                                                                                     |                                                                                                                  |                                                                                      |                                                                                     |                                    |                                |                             | SFR Address:<br>SFR Page: | 0xA2<br>0      |
| Bits7–0:  <br> | PGSEL[7:0]:<br>The XRAM F<br>address whe<br>RAM.<br>0x00: 0x000<br>0x01: 0x010<br><br>0xFE: 0xFE(<br>0xFF: 0xFF( | XRAM Page<br>Page Select<br>on using an<br>0 to 0x00FF<br>0 to 0x01FF<br>00 to 0xFEF | ge Select Bi<br>Bits provid<br>8-bit MOV><br><del>-</del><br><del>-</del><br>F<br>F | its.<br>le the high t<br>< command | oyte of the 1<br>, effectively | 6-bit exterr<br>selecting a | nal data me<br>256-byte p | mory<br>age of |

# SFR Definition 17.1. EMI0CN: External Memory Interface Control



| R/W                  | R/W                                                                                                                            | R/W         | R/W            | R/W         | R/W         | R/W  | R/W         | Reset Value |  |  |  |  |  |  |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------|-------------|----------------|-------------|-------------|------|-------------|-------------|--|--|--|--|--|--|
| EAS1                 | EAS0                                                                                                                           | ERW3        | EWR2           | EWR1        | EWR0        | EAH1 | EAH0        | 11111111    |  |  |  |  |  |  |
| Bit7                 | Bit6                                                                                                                           | Bit5        | Bit4           | Bit3        | Bit2        | Bit1 | Bit0        | -           |  |  |  |  |  |  |
|                      |                                                                                                                                |             |                |             |             |      | SFR Address | :: 0xA1     |  |  |  |  |  |  |
|                      | SER Page: 0                                                                                                                    |             |                |             |             |      |             |             |  |  |  |  |  |  |
| Bits7–6 <sup>.</sup> | EAS1–0: EMIF Address Setup Time Bits.<br>00: Address setup time = 0 SYSCLK cycles.<br>01: Address setup time = 1 SYSCLK cycle. |             |                |             |             |      |             |             |  |  |  |  |  |  |
| 2.10. 0.             |                                                                                                                                |             |                |             |             |      |             |             |  |  |  |  |  |  |
|                      |                                                                                                                                |             |                |             |             |      |             |             |  |  |  |  |  |  |
|                      | 10: Address                                                                                                                    | setup time  | = 2 SYSCL      | K cycles.   |             |      |             |             |  |  |  |  |  |  |
|                      | 11: Address                                                                                                                    | setup time  | = 3 SYSCL      | K cycles.   |             |      |             |             |  |  |  |  |  |  |
| Bits5–2:             | EWR3–0: EN                                                                                                                     | MIF /WR ar  | nd /RD Puls    | e-Width Co  | ntrol Bits. |      |             |             |  |  |  |  |  |  |
|                      | 0000: /WR a                                                                                                                    | ind /RD pul | se width = 1   | I SYSCLK of | ycle.       |      |             |             |  |  |  |  |  |  |
|                      | 0001: /WR a                                                                                                                    | ind /RD pul | se width = $2$ | 2 SYSCLK (  | ycles.      |      |             |             |  |  |  |  |  |  |
|                      | 0010: /WR a                                                                                                                    | ind /RD pul | se width = 3   |             | ycles.      |      |             |             |  |  |  |  |  |  |
|                      | 0011: /WR a                                                                                                                    | na /RD puis | se width = 4   |             | ycies.      |      |             |             |  |  |  |  |  |  |
|                      | 0100./WR a                                                                                                                     | ind /RD put | se width = t   |             | ycles.      |      |             |             |  |  |  |  |  |  |
|                      | 0101./WR a                                                                                                                     | nd /RD pul  | se width – 7   | SYSCIK (    | vcles.      |      |             |             |  |  |  |  |  |  |
|                      | 0111: /WR a                                                                                                                    | nd /RD puls | se width = $8$ | SYSCLK      | vcles.      |      |             |             |  |  |  |  |  |  |
|                      | 1000: /WR a                                                                                                                    | ind /RD pul | se width = 9   | SYSCLK (    | vcles.      |      |             |             |  |  |  |  |  |  |
|                      | 1001: /WR a                                                                                                                    | nd /RD pul  | se width =     | 10 SYSCLK   | Cycles.     |      |             |             |  |  |  |  |  |  |
|                      | 1010: /WR a                                                                                                                    | nd /RD pul  | se width = 1   | 11 SYSCLK   | cycles.     |      |             |             |  |  |  |  |  |  |
|                      | 1011: /WR a                                                                                                                    | nd /RD puls | se width = 1   | 2 SYSCLK    | cycles.     |      |             |             |  |  |  |  |  |  |
|                      | 1100: /WR a                                                                                                                    | nd /RD puls | se width = 1   | 3 SYSCLK    | cycles.     |      |             |             |  |  |  |  |  |  |
|                      | 1101: /WR a                                                                                                                    | nd /RD puls | se width = 1   | 4 SYSCLK    | cycles.     |      |             |             |  |  |  |  |  |  |
|                      | 1110: /WR a                                                                                                                    | nd /RD puls | se width = 1   | 5 SYSCLK    | cycles.     |      |             |             |  |  |  |  |  |  |
| <b>D</b> 12 4 A      | 1111: /WR ai                                                                                                                   | nd /RD puls | se width = 1   | 6 SYSCLK    | cycles.     |      |             |             |  |  |  |  |  |  |
| Bits1–0:             | EAH1-0: EN                                                                                                                     | IF Address  | s Hold Time    | Bits.       |             |      |             |             |  |  |  |  |  |  |
|                      | 00: Address                                                                                                                    | hold time = |                | Cycles.     |             |      |             |             |  |  |  |  |  |  |
|                      | 10: Address                                                                                                                    | hold time = | 2 SVSCLA       | Cycle.      |             |      |             |             |  |  |  |  |  |  |
|                      | 11. Address                                                                                                                    | hold time - | 2 3 1 3 ULM    | Cycles.     |             |      |             |             |  |  |  |  |  |  |
|                      | TI. Addie35                                                                                                                    |             |                | 0,000       |             |      |             |             |  |  |  |  |  |  |
|                      |                                                                                                                                |             |                |             |             |      |             |             |  |  |  |  |  |  |

### SFR Definition 17.3. EMI0TC: External Memory Timing Control



| R/W      |                                                                                                                                                                                                        | R/W                                                                                                    | R/W                                                                                        | R/W                                                      | R/W         | R/W       | R/W         | R/W                | Reset Value  |  |  |  |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|----------------------------------------------------------|-------------|-----------|-------------|--------------------|--------------|--|--|--|
| P4.7     |                                                                                                                                                                                                        | P4.6                                                                                                   | P4.5                                                                                       | P4.4                                                     | P4.3        | P4.2      | P4.1        | P4.0               | 11111111     |  |  |  |
| Bit7     | Bit6 Bit5                                                                                                                                                                                              |                                                                                                        | Bit4                                                                                       | Bit3                                                     | Bit2        | Bit1      | Bit0        | Bit<br>Addressable |              |  |  |  |
|          | SFR Address: 0xC8<br>SFR Page: F                                                                                                                                                                       |                                                                                                        |                                                                                            |                                                          |             |           |             |                    |              |  |  |  |
| Bits7–0: | P4.[<br>Writ<br>0: L<br>1: L<br>18.1<br>Rea<br>0: P<br>1: P                                                                                                                                            | [7:0]: Port<br>te - Outpu<br>ogic Low<br>ogic High<br>14.<br>ad - Return<br>24.n pin is<br>24.n pin is | 4 Output L<br>t appears<br>Output.<br>Output (O<br>ns states o<br>logic low.<br>logic high | atch Bits.<br>on I/O pins<br>pen-Drain i<br>of I/O pins. | f correspon | ding P4MD | OUT.n bit = | 0). See SF         | R Definition |  |  |  |
| Note:    | P4.7 (/WR), P4.6 (/RD), and P4.5 (ALE) can be driven by the External Data Memory Interface. See <b>Section "17. External Data Memory Interface and On-Chip XRAM" on page 219</b> for more information. |                                                                                                        |                                                                                            |                                                          |             |           |             |                    |              |  |  |  |

## SFR Definition 18.13. P4: Port4 Data

# SFR Definition 18.14. P4MDOUT: Port4 Output Mode







\* SCK is shown for CKPOL = 0. SCK is the opposite polarity for CKPOL = 1.





\* SCK is shown for CKPOL = 0. SCK is the opposite polarity for CKPOL = 1.





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

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

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



Figure 24.8. PCA 8-Bit PWM Mode Diagram



# DOCUMENT CHANGE LIST

# Revision 1.3 to Revision 1.4

- Added new paragraph tags: SFR Definition and JTAG Register Definition.
- Product Selection Guide Table 1.1: Added RoHS-compliant ordering information.
- Overview Chapter, Figure 1.8, "On-Chip Memory Map": Corrected on-chip XRAM size to "8192 Bytes".
- SAR8 Chapter: Table 7.1, "ADC2 Electrical Characteristics": Track/Hold minimum spec corrected to "300 ns".
- SAR8 Chapter: Table 7.1, "ADC2 Electrical Characteristics": Total Harmonic Distortion typical spec corrected to "-51 dB".
- Oscillators Chapter, Figure 14.1, "Oscillator Diagram": Corrected location of IOSCEN arrow.
- CIP51 Chapter, **Section 11.3**: Added note describing EA change behavior when followed by singlecycle instruction.
- CIP51 Chapter, Interrupt Summary Table: Added "SFRPAGE" column and SFRPAGE value for each interrupt source.
- CIP-51 Chapter, Figure 11.2, "Memory Map": Corrected on-chip XRAM size to "8192 Bytes".
- Port I/O Chapter, Crossbar Priority Figures: Character formatting problem corrected.
- Port I/O Chapter, P7MDOUT Register Description: Removed references to UART and SMBus peripherals.
- Port I/O Chapter, P3MDOUT Register Description: Corrected text to read "P3MDOUT.[7:0]".
- Timers Chapter: References to "TnCON" corrected to read "TMRnCN".
- PCA0 Chapter, Section 24.1: Added note about PCA0CN Register and effects of read-modify-write instructions on the CF bit.

