



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                      | 16MHz                                                                      |
| Connectivity               | EBI/EMI, I <sup>2</sup> C, UART/USART                                      |
| Peripherals                | POR, PWM, WDT                                                              |
| Number of I/O              | 40                                                                         |
| Program Memory Size        | -                                                                          |
| Program Memory Type        | ROMIess                                                                    |
| EEPROM Size                | -                                                                          |
| RAM Size                   | 1K x 8                                                                     |
| Voltage - Supply (Vcc/Vdd) | 4.5V ~ 5.5V                                                                |
| Data Converters            | A/D 8x10b                                                                  |
| Oscillator Type            | External                                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 80-BQFP                                                                    |
| Supplier Device Package    | 80-PQFP (14x20)                                                            |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/p80c557e4efb-01-51 |

Email: info@E-XFL.COM

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





P83C557E4/P80C557E4/P89C557E4

# Single-chip 8-bit microcontroller

# 4.1 PIN DESCRIPTION

| SYMBOL                                                                       | PIN                | DESCRIPTION                                                                                                                                                                |  |  |  |  |  |
|------------------------------------------------------------------------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| AV <sub>ref-</sub><br>AV <sub>ref+</sub>                                     | 1<br>2             | Low end of analog to digital conversion reference resistor<br>High end of analog to digital conversion reference resistor.                                                 |  |  |  |  |  |
| AV <sub>SS1</sub><br>AV <sub>DD1</sub>                                       | 3<br>4             | Analog ground for ADC<br>Analog power supply (+5 V) for ADC                                                                                                                |  |  |  |  |  |
| AV <sub>SS2</sub><br>AV <sub>DD2</sub>                                       | 77<br>76           | Analog ground; for PLL oscillator<br>Analog power supply; (+5 V) for PLL oscillator                                                                                        |  |  |  |  |  |
| P5.7 – P5.0                                                                  | 5 – 12             | Port 5<br>8-bit input port                                                                                                                                                 |  |  |  |  |  |
|                                                                              |                    | Port pin Alternative function                                                                                                                                              |  |  |  |  |  |
|                                                                              |                    | P5.0–P5.7 Eight input channels to ADC (ADC0–ADC7)                                                                                                                          |  |  |  |  |  |
| V <sub>DD1</sub> , V <sub>DD2</sub> ,<br>V <sub>DD3</sub> , V <sub>DD4</sub> | 14, 28,<br>53, 66  | <b>Digital power supply:</b> +5 V power supply pins during normal operation and power reduction modes. All pins must be connected.                                         |  |  |  |  |  |
| V <sub>SS1</sub> , V <sub>SS2</sub><br>V <sub>SS3</sub> , V <sub>SS4</sub>   | 13, 29,<br>54, 67  | Digital ground: circuit ground potential. All pins must be connected.                                                                                                      |  |  |  |  |  |
| ADEXS                                                                        | 15                 | Start ADC operation: Input starting analog to digital conversion triggered by a programmable edge (ADC operation can also be started by software). This pin must not float |  |  |  |  |  |
| PWM0                                                                         | 16                 | Pulse width modulation output 0                                                                                                                                            |  |  |  |  |  |
| PWM1                                                                         | 17                 | Pulse width modulation output 1                                                                                                                                            |  |  |  |  |  |
| EW                                                                           | 18                 | Enable watchdog timer: Enable for T3 watchdog timer and disable Power-down Mode. This pin must not float.                                                                  |  |  |  |  |  |
| P4.0 – P4.7                                                                  | 19 – 22<br>24 – 27 | Port 4<br>8-bit quasi-bidirectional I/O port                                                                                                                               |  |  |  |  |  |
|                                                                              |                    | Port pin Alternative function                                                                                                                                              |  |  |  |  |  |
|                                                                              |                    | P4.0     CMSR0 }       P4.1     CMSR1 }       P4.2     CMSR2 } compare and set/reset       P4.3     CMSR3 } outputs on a match with timer T2       P4.4     CMSR4 }        |  |  |  |  |  |
|                                                                              |                    | P4.5 CMSR5 }<br>P4.6 CMT0 } compare and togole outputs                                                                                                                     |  |  |  |  |  |
|                                                                              |                    | P4.7 CMT1 } on a match with timer T2                                                                                                                                       |  |  |  |  |  |
| RSTIN                                                                        | 30                 | Reset: Input to reset the P8xC557E4.                                                                                                                                       |  |  |  |  |  |
| RSTOUT                                                                       | 23                 | <b>Reset:</b> Output of the P8xC557E4 for resetting peripheral devices during initialization and Watchdog Timer overflow.                                                  |  |  |  |  |  |
| P1.0 – P1.7                                                                  | 31 – 38            | Port 1<br>8-bit quasi-bidirectional I/O port                                                                                                                               |  |  |  |  |  |
|                                                                              |                    |                                                                                                                                                                            |  |  |  |  |  |
|                                                                              |                    | P1.0 CT0//NT2}<br>P1.1 CT1//NT3} : Capture timer inputs for                                                                                                                |  |  |  |  |  |
|                                                                              |                    | P1.2 CT2I/INT4} timer 12 or external interrupt inputs<br>P1.3 CT3I/INT5}                                                                                                   |  |  |  |  |  |
|                                                                              |                    | P1.4 I2 : I2 event input, rising edge triggered<br>P1.5 RT2 : T2 timer reset input, rising edge triggered                                                                  |  |  |  |  |  |
|                                                                              |                    | P1.6<br>P1.7                                                                                                                                                               |  |  |  |  |  |
| SCL                                                                          | 39                 | I <sup>2</sup> C-bus serial clock I/O port                                                                                                                                 |  |  |  |  |  |
| SDA                                                                          | 40                 | I <sup>2</sup> C-bus serial data I/O port<br>If SCL and SDA are not used, they must be connected to V <sub>SS</sub> .                                                      |  |  |  |  |  |

### 6.6.2 Configuration and Operation

Every A/D conversion is an autoscan conversion. The two user selectable general operation modes are continuous scan and one-time scan mode.

The desired analog input port channel/s for conversion is/are selected by programming A/D input port scan-select bits in SFR ADPSS. An analog input channel is included in the autoscan loop if the corresponding bit in ADPSS is 1, a channel is skipped if the corresponding bit in ADPSS is 0.

An autoscan is always started according to the lowest bit position of ADPSS that contains a 1.

An autoscan conversion is started by setting the flag ADSST in register ADCON either by software or by an external start signal at input pin ADEXS, if enabled. Either no edge (external start totally disabled), a rising edge or/and a falling edge of ADEXS is selectable for external conversion start by the bits ADSRE and ADSFE in register ADCON.

After completion of an A/D conversion the 10-bit result is stored in the corresponding 10-bit buffer register. Then the next analog input is selected according to the next higher set bit position in ADPSS, converted and stored, and so on. When the result of the last conversion of this autoscan loop is stored, flag ADCON.4/ADINT, the ADC interrupt flag, is set. It is not cleared by interrupt hardware – it must be cleared by software.

In continuous scan mode (ADCON.2/ADCSA=1) the ADC start and status flag ADCON.3/ADSST retains the set state and the autoscan loop restarts from the beginning. In one-time scan mode (ADCSA=0) conversions stop after the last selected analog input was converted, ADINT is set and ADSST is cleared automatically.

ADSST cannot be set (neither externally nor by software) as long as ADINT=1, i.e. as long as ADINT is set, a new conversion start – by setting flag ADSST – is inhibited; actually it is only delayed until ADINT is cleared.

(If a '1' is written to ADSST while ADINT=1, this new value is internally latched and preserved, not setting ADSST until ADCON.4/ADINT=0. In this state, a read of SFR ADCON will display ADCON.3/ADSST=0, because always the effective ADC status is read.)

Note that under software control the analog inputs can also be converted in arbitrary order, when one-time scan mode is selected and in SFR ADPSS only one bit is set at a time. In this case ADINT is set and ADSST is cleared after every conversion.

#### 6.6.3 Resolution and Characteristics

The ADC system has its own analog supply pins AV<sub>DD</sub> and AV<sub>SS</sub>. It is referenced by two special reference voltage input pins sourcing the resistance ladder of the DAC: AV<sub>ref+</sub> and AV<sub>ref-</sub>. The voltage between AV<sub>REF+</sub> and AV<sub>REF-</sub> defines the full-scale range. Due to the 10-bit resolution the full scale range is divided into 1024 unit steps. The unit step voltage is 1 LSB, which is typically 5 mV (AV<sub>ref+</sub> = 5.12 V, AV<sub>ref-</sub> = 0 V = AV<sub>SS</sub>).

The DAC's resistance ladder has 1023 equally spaced taps, separated by a unit resistance 'R'. The first tap is located 0.5 x R above AV<sub>ref-</sub>, the last tap is located 1.5 x R below AV<sub>ref+</sub>. This results in a total ladder resistance of 1024 x R. This structure ensures that the DAC is monotonic and results in a symmetrical quantization error. For input voltages between AV<sub>ref-</sub> and (AV<sub>ref-</sub> + 1/2 LSB) the 10-bit conversion result code will be 00 0000 0000 B = 000H = 0D. For input voltages between

(AVref+ - 3/2 LSB) and AVref+ the 10-bit conversion result code will be 11 1111 1111 B = 3FFH = 1023D.

P83C557E4/P80C557E4/P89C557E4

The result code corresponding to an analog input voltage  $(\mathrm{AV}_{\text{in}})$  can be calculated from the formula:

$$\label{eq:ResultCode} \text{ResultCode} = 1024 \times \frac{\text{AV}_{\text{IN}} - \text{AV}_{\text{ref}-}}{\text{AV}_{\text{ref}+} - \text{AV}_{\text{ref}-}}$$

The analog input voltage should be stable when it is sampled for conversion. At any times the input voltage slew rate must be less than 10 V/ms (5 V conversion range) in order to prevent an undefined result.

This maximum input voltage slew rate can be ensured by an RC low pass filter with R =  $2k^2$  and C = 100 nF. The capacitor between analog input pin and analog ground pin shall be placed close to the pins in order to have maximum effect in minimizing input noise coupling.

### 6.7 Timer/Counters

The P8xC557E4 contains three 16-bit timer/event counters: Timer 0, Timer 1 and Timer T2 and one 8-bit timer, T3. Timer 0 and Timer 1 may be programmed to carry out the following functions:

- Measure time intervals and pulse durations
- Count events
- Generate interrupt requests

### 6.7.1 Timer 0 and Timer 1

Timers 0 and 1 each have a control bit in SFR TMOD that selects the timer or counter function of the corresponding timer.

In the timer function, the register is incremented every machine cycle. Thus, one can think of it as counting machine cycles. Since a machine cycle consists of 12 oscillator periods, the count rate is 1/12 of the oscillator frequency.

In the counter function, the register is incremented in response to a 1-to-0 transition at the corresponding external input pin, T0 or T1. In this function, the external input is sampled during S5P2 of every machine cycle. When the samples show a HIGH in one cycle and a LOW in the next cycle, the counter is incremented. Thus, it takes two machine cycles (24 oscillator periods) to recognize a 1-to-0 transition. There are no restrictions on the duty cycle of the external input signal, but to insure that a given level is sampled at least once before it changes, it should be held for at least one full machine cycle.

Timer 0 and Timer 1 can be programmed independently to operate in one of four modes:

#### • Mode 0:

8-bit timer or 8-bit counter each with divide-by-32 prescaler

Mode 1:

16-bit time-interval or event counter

• Mode 2:

8-bit time-interval or event counter with automatic reload upon overflow

#### • Mode 3:

- -Timer 0: one 8-bit time-interval or event counter and one 8-bit time-interval counter
- -Timer 1: stopped

# P83C557E4/P80C557E4/P89C557E4

|            | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------------|-----|-----|-----|-----|-----|-----|-----|-----|
| TCON (88H) | TF1 | TR1 | TF0 | TR0 | IE1 | IT1 | IE0 | IT0 |

### Table 14. Description of TCON bits

| SYMBOL | BIT    | FUNCTION                                                                                                                           |
|--------|--------|------------------------------------------------------------------------------------------------------------------------------------|
| TF1    | TCON.7 | Timer 1 overflow flag. Set by hardware on Timer/Counter overflow. Cleared by hardware when processor vectors to interrupt routine. |
| TR1    | TCON.6 | Timer 1 run control bit. Set/cleared by software to turn Timer/Counter on/off.                                                     |
| TF0    | TCON.5 | Timer 0 overflow flag. Set by hardware on Timer/Counter overflow. Cleared by hardware when processor vectors to interrupt routine. |
| TR0    | TCON.4 | Timer 0 run control bit. Set/cleared by software to turn Timer/Counter on/off.                                                     |
| IE1    | TCON.3 | Interrupt 1 edge flag. Set by hardware when external interrupt edge detected. Cleared when interrupt processed.                    |
| IT1    | TCON.2 | Interrupt 1 type control bit. Set/cleared by software to specify falling edge/low level triggered external interrupts.             |
| IEO    | TCON.1 | Interrupt 0 edge flag. Set by hardware when external interrupt edge detected. Cleared when interrupt processed.                    |
| IT0    | TCON.0 | Interrupt 0 type control bit. Set/cleared by software to specify falling edge/low level triggered external interrupts.             |

## P83C557E4/P80C557E4/P89C557E4

|                                          | 7     | 6     | 5    | 4    | 3    | 2    | 1     | 0     |
|------------------------------------------|-------|-------|------|------|------|------|-------|-------|
| TM2CON (EAH)                             | T2IS1 | T2IS0 | T2ER | T2BO | T2P1 | T2P0 | T2MS1 | T2MS0 |
| Figure 22. T2 control register (TM2CON). |       |       |      |      |      |      |       |       |

## Table 15. Description of TM2CON bits

| SYMBOL | BIT      | FUNCTION                                                                                                    |
|--------|----------|-------------------------------------------------------------------------------------------------------------|
| T2IS1  | TM2CON.7 | Timer T2 16-bit overflow interrupt select                                                                   |
| T2IS0  | TM2CON.6 | Timer T2 byte overflow interrupt select                                                                     |
| T2ER   | TM2CON.5 | Timer T2 external reset enable. When this bit is set, Timer T2 may be reset by a rising edge on RT2 (P1.5). |
| T2BO   | TM2CON.4 | Timer T2 byte overflow interrupt flag                                                                       |
| T2P1   | TM2CON.3 | Timer T2 prescaler select                                                                                   |
| T2P0   | TM2CON.2 |                                                                                                             |
| T2MS1  | TM2CON.1 | Timer T2 mode select                                                                                        |
| T2MS0  | TM2CON.0 |                                                                                                             |

## Table 16. Timer 2 prescaler select

| T2P1 | T2P0 | TIMER T2 CLOCK |
|------|------|----------------|
| 0    | 0    | Clock source   |
| 0    | 1    | Clock source/2 |
| 1    | 0    | Clock source/4 |
| 1    | 1    | Clock source/8 |

## Table 17. Timer 2 mode select

| T2MS1 | T2MS0 | MODE SELECTED                  |
|-------|-------|--------------------------------|
| 0     | 0     | Timer T2 halted (off)          |
| 0     | 1     | T2 clock source = $f_{CLK}/12$ |
| 1     | 0     | Test mode; do not use          |
| 1     | 1     | T2 clock source = pin T2       |



## P83C557E4/P80C557E4/P89C557E4

The polling cycle is repeated with every machine cycle, and the values polled are the values present at S5P2 of the previous machine cycle. Note that if an interrupt flag is active but is not being responded to because of one of the above conditions, and if the flag is inactive when the blocking condition is removed, then the blocked interrupt will not be serviced. Thus, the fact that the interrupt flag was once active but not serviced is not remembered. Every polling cycle is new.

The processor acknowledges an interrupt request by executing a hardware-generated LCALL to the appropriate service routine. In some cases it also clears the flag which generated the interrupt, and in others it does not. It clears the Timer 0, Timer 1, and external

interrupt flags. An external interrupt flag (IE0 or IE1) is cleared only if it was transition-activated. All other interrupt flags are not cleared by hardware and must be cleared by the software. The LCALL pushes the contents of the program counter on to the stack (but it does not save the PSW) and reloads the PC with an address that depends on the source of the interrupt being vectored to as shown in Table 38.

Execution proceeds from the vector address until the RETI instruction is encountered. The RETI instruction clears the "priority level active" flip-flop that was set when this interrupt was acknowledged. It then pops the top two bytes from the stack and reloads the program counter. Execution of the interrupted program continues from where it was interrupted.

|            | 7  | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------------|----|-----|-----|-----|-----|-----|-----|-----|
| IEN0 (A8H) | EA | EAD | ES1 | ES0 | ET1 | EX1 | ET0 | EX0 |

### Table 33. Description of IEN0 bits

| SYMBOL | BIT    | FUNCTION                                                                                                      |
|--------|--------|---------------------------------------------------------------------------------------------------------------|
| EA     | IEN0.7 | Global enable/disable control0 =No interrupt is enabled1 =Any individually enabled interrupt will be accepted |
| EAD    | IEN0.6 | Enable ADC interrupt                                                                                          |
| ES1    | IEN0.5 | Enable SIO1 (I <sup>2</sup> C) interrupt                                                                      |
| ES0    | IEN0.4 | Enable SIO0 (UART) interrupt                                                                                  |
| ET1    | IEN0.3 | Enable Timer 1 interrupt                                                                                      |
| EX1    | IEN0.2 | Enable External interrupt 1 / Seconds interrupt                                                               |
| ETO    | IEN0.1 | Enable Timer 0 interrupt                                                                                      |
| EX0    | IEN0.0 | Enable External interrupt 0                                                                                   |

## P83C557E4/P80C557E4/P89C557E4

|            | 7   | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|------------|-----|------|------|------|------|------|------|------|
| IEN1 (E8H) | ET2 | ECM2 | ECM1 | ECM0 | ECT3 | ECT2 | ECT1 | ECT0 |
|            | E12 | ECM2 | ECM1 | ECM0 | ECI3 | EC12 | ECI1 | EC   |

## Table 34. Description of IEN1 bits

| SYMBOL | BIT    | FUNCTION                               |
|--------|--------|----------------------------------------|
| ET2    | IEN1.7 | Enable T2 overflow interrupt(s)        |
| ECM2   | IEN1.6 | Enable T2 comparator 2 interrupt       |
| ECM1   | IEN1.5 | Enable T2 comparator 1 interrupt       |
| ECM0   | IEN1.4 | Enable T2 comparator 0 interrupt       |
| ECT3   | IEN1.3 | Enable T2 capture register 3 interrupt |
| ECT2   | IEN1.2 | Enable T2 capture register 2 interrupt |
| ECT1   | IEN1.1 | Enable T2 capture register 1 interrupt |
| ECT0   | IEN1.0 | Enable T2 capture register 0 interrupt |

If the enable bit is 0, then the interrupt is disabled, if the enable bit is 1, then the interrupt is enabled.

|           | 7 | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----------|---|-----|-----|-----|-----|-----|-----|-----|
| IP0 (B8H) | - | PAD | PS1 | PS0 | PT1 | PX1 | PT0 | PX0 |

### Table 35. Description of IP0 bits

| SYMBOL | BIT   | FUNCTION                                              |
|--------|-------|-------------------------------------------------------|
| -      | IP0.7 | Reserved for future use                               |
| PAD    | IP0.6 | ADC interrupt priority level                          |
| PS1    | IP0.5 | SIO1 (I <sup>2</sup> C) interrupt priority level      |
| PS0    | IP0.4 | SIO0 (UART) interrupt priority level                  |
| PT1    | IP0.3 | Timer 1 interrupt priority level                      |
| PX1    | IP0.2 | External interrupt 1/Seconds interrupt priority level |
| PT0    | IP0.1 | Timer 0 interrupt priority level                      |
| PX0    | IP0.0 | External interrupt 0 priority level                   |

### 7. INSTRUCTION SET

The P8xC557E4 uses the powerful instruction set of the PCB80C51. It consists of 49 single-byte, 45 two-byte and 17 three-byte instructions. Using a 16 MHz quartz, 64 of the instructions are executed in 0.75  $\mu$ s, 45 in 1,5  $\mu$ s and the multiply, divide instructions in 3  $\mu$ s.

A summary of the instruction set is given in Table 43.

The P8xC557E4 has additional Special Function Registers to control the on-chip peripherals.

### 7.1 Addressing Modes

Most instructions have a "destination, source" field that specifies the data type, addressing modes and operands involved. For all these instructions, except for MOVs, the destination operand is also the source operand (e.g., ADD A,R7).

There are five kinds of addressing modes:

- Register Addressing
  - R0 R7 (4 banks)
  - A,B,C (bit), AB (2 bytes), DPTR (double byte)
- Direct Addressing
  - lower 128 bytes of internal Main RAM (including the 4 R0–R7 register banks)
  - Special Function Registers
  - 128 bits in a subset of the internal Main RAM
  - 128 bits in a subset of the Special Function Registers
- Register-Indirect Addressing
- internal Main RAM (@R0, @R1, @SP [PUSH/POP])
- internal Auxiliary RAM (@R0, @R1, @DPTR)
- external Data Memory (@R0, @R1, @DPTR)
- Immediate Addressing
- Program Memory (in-code 8 bit or 16 bit constant)
- Base-Register-plus Index-Register-Indirect Addressing
  - Program Memory look-up table (@DPTR+A, @PC+A)

The first three addressing modes are usable for destination operands.

### 7.1.1 80C51 Family Instruction Set

### Table 42. Instruction that affect Flag settings<sup>1</sup>

P83C557E4/P80C557E4/P89C557E4

| INSTRUCTION                                                                                  |                                           | FLAG          |             |
|----------------------------------------------------------------------------------------------|-------------------------------------------|---------------|-------------|
|                                                                                              | С                                         | ov            | AC          |
| ADD<br>ADDC<br>SUBB<br>MUL<br>DIV<br>DA<br>RRC<br>RLC<br>SETB C                              | X<br>X<br>X<br>0<br>0<br>X<br>X<br>X<br>1 | × × × × × × × | x<br>x<br>x |
| CLR C<br>CPL C<br>ANL C, bit<br>ANL C,/bit<br>ANL C, bit<br>ORL C, bit<br>MOV C, bit<br>CJNE | 0<br>X X X X<br>X X X X<br>X X            |               |             |

### NOTES:

### Notes on instruction set and addressing modes:

| Rn             | Register R7-R0 of the currently selected Register Bank.                                                                                                                            |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| direct         | 8-bit internal data location's address. This could be<br>an Internal Data RAM location (0-127) or a SFR<br>[i.e., I/O port, control register, status register, etc.<br>(128-255)]. |
| @Ri            | 8-bit RAM location addressed indirectly through register R1 or R0 of the actual register bank.                                                                                     |
| #data          | 8-bit constant included in the instruction.                                                                                                                                        |
| #data 16       | 16-bit constant included in the instruction                                                                                                                                        |
| addr 16        | 16-bit destination address. Used by LCALL and LJMP. A branch can be anywhere within the 64 Kbytes Program Memory address space.                                                    |
| addr 11        | 11-bit destination address. Used by ACALL and AJMP. The branch will be within the same 2 Kbytes page of program memory as the first byte of the following instruction.             |
| rel            | Signed (two's complement) 8-bit offset byte. Used<br>by SJMP and all conditional jumps. Range is $-128$<br>to $+127$ bytes relative to first byte of the following<br>instruction. |
| bit            | Direct Addressed bit in Internal Data RAM or<br>Special Function Register.                                                                                                         |
| Hexadecimal or | code cross-reference to Table 43:                                                                                                                                                  |

| *   | : | 8, 9, A, B, C, D, E. F.         |
|-----|---|---------------------------------|
| **  | : | 11, 31, 51, 71, 91, B1, D1, F1. |
| *** | : | 01, 21, 41, 61, 81, A1, C1, E1. |

Note that operations on SFR byte address 208 or bit addresses 209-215 (i.e., the PSW or bits in the PSW) will also affect flag settings.

# P83C557E4/P80C557E4/P89C557E4

| MNEMONIC  |                       | DESCRIPTION                                    | BYTE / | OPCODE<br>(HEX.) |        |
|-----------|-----------------------|------------------------------------------------|--------|------------------|--------|
| LOGICAL O | PERATIONS (Continued) | •                                              |        |                  |        |
| XRL       | A,#data               | Exclusive-OR immediate data to Accumulator     | 2      | 1                | 64     |
| XRL       | direct,A              | Exclusive-OR Accumulator to direct byte        | 2      | 1                | 62     |
| XRL       | direct,#data          | Exclusive-OR immediate data to direct byte     | 3      | 2                | 63     |
| CLR       | А                     | Clear Accumulator                              | 1      | 1                | E4     |
| CPL       | А                     | Complement Accumulator                         | 1      | 1                | F4     |
| RL        | А                     | Rotate Accumulator left                        | 1      | 1                | 23     |
| RLC       | А                     | Rotate Accumulator left through the carry      | 1      | 1                | 33     |
| RR        | А                     | Rotate Accumulator right                       | 1      | 1                | 03     |
| RRC       | А                     | Rotate Accumulator right through the carry     | 1      | 1                | 13     |
| SWAP      | А                     | Swap nibbles within the Accumulator            | 1      | 1                | C4     |
| DATA TRAN | ISFER                 |                                                |        |                  |        |
| MOV       | A,Rn                  | Move register to Accumulator                   | 1      | 1                | E*     |
| MOV       | A,direct              | Move direct byte to Accumulator                | 2      | 1                | E5     |
| MOV       | A,@Ri                 | Move indirect RAM to Accumulator               | 1      | 1                | E6, E7 |
| MOV       | A,#data               | Move immediate data to Accumulator             | 2      | 1                | 74     |
| MOV       | Rn,A                  | Move Accumulator to register                   | 1      | 1                | F*     |
| MOV       | Rn,direct             | Move direct byte to register                   | 2      | 2                | A*     |
| MOV       | RN,#data              | Move immediate data to register                | 2      | 1                | 7*     |
| MOV       | direct,A              | Move Accumulator to direct byte                | 2      | 1                | F5     |
| MOV       | direct,Rn             | Move register to direct byte                   | 2      | 2                | 8*     |
| MOV       | direct,direct         | Move direct byte to direct                     | 3      | 2                | 85     |
| MOV       | direct,@Ri            | Move indirect RAM to direct byte               | 2      | 2                | 86, 87 |
| MOV       | direct,#data          | Move immediate data to direct byte             | 3      | 2                | 75     |
| MOV       | @Ri,A                 | Move Accumulator to indirect RAM               | 1      | 1                | F6, F7 |
| MOV       | @Ri,direct            | Move direct byte to indirect RAM               | 2      | 2                | A6, A7 |
| MOV       | @Ri,#data             | Move immediate data to indirect RAM            | 2      | 1                | 76, 77 |
| MOV       | DPTR,#data16          | Load Data Pointer with a 16-bit constant       | 3      | 2                | 90     |
| MOVC      | A,@A+DPTR             | Move Code byte relative to DPTR to ACC         | 1      | 2                | 93     |
| MOVC      | A,@A+PC               | Move Code byte relative to PC to ACC           | 1      | 2                | 83     |
| MOVX      | A,@Ri                 | Move AUX-RAM (8-bit addr) to ACC               | 1      | 2                | E2, E3 |
| MOVX      | A,@DPTR               | Move AUX-RAM (16-bit addr) to $A_{CC}$         | 1      | 2                | E0     |
| MOVX      | @Ri,A                 | Move ACC to AUX-RAM (8-bit addr)               | 1      | 2                | F2, F3 |
| MOVX      | @DPTR,A               | Move ACC to AUX-RAM (16-bit addr)              | 1      | 2                | F0     |
| PUSH      | direct                | Push direct byte onto stack                    | 2      | 2                | C0     |
| POP       | direct                | Pop direct byte from stack                     | 2      | 2                | D0     |
| ХСН       | A,Rn                  | Exchange register with Accumulator             | 1      | 1                | C*     |
| ХСН       | A,direct              | Exchange direct byte with Accumulator          | 2      | 1                | C5     |
| XCH       | A,@Ri                 | Exchange indirect RAM with Accumulator         | 1      | 1                | C6, C7 |
| XCHD      | A,@Ri                 | Exchange low-order digit indirect RAM with ACC | 1      | 1                | D6, D7 |

## Table 43. 80C51 Instruction Set Summary (Continued)

P83C557E4/P80C557E4/P89C557E4

# Single-chip 8-bit microcontroller

## Table 44. Instruction map P8xC557E4

| Ī        |   | 0            | 1      | 2      | 3          | 4           | 5          | 6               | 7   | 8             | 9  | А   | В    | С      | D     | Е  | F |
|----------|---|--------------|--------|--------|------------|-------------|------------|-----------------|-----|---------------|----|-----|------|--------|-------|----|---|
| t        | 0 | NOP          | AJMP   | LJMP   | RR         | INC         | INC        | INC @ Ri        |     | <u> </u>      |    |     | INC  | Rr     |       |    |   |
|          |   |              | addr11 | addr16 | А          | А           | dir        | 0               | 1   | 0             | 1  | 2   | 3    | 4      | 5     | 6  | 7 |
|          | 1 | JBC          | ACALL  | LCALL  | RRC        | DEC         | DEC        | DEC @ Ri        |     |               |    |     | DEC  | Rr     |       |    |   |
|          |   | bit, rel     | addr11 | addr16 | А          | А           | dir        | 0               | 1   | 0             | 1  | 2   | 3    | 4      | 5     | 6  | 7 |
| Ī        | 2 | JB           | AJMP   | RET    | RL         | ADD         | ADD        | ADD A, @ Ri     |     | <u> </u>      |    | A   | DD / | A, F   | ۲r    |    |   |
|          |   | bit, rel     | addr11 |        | А          | A, #data    | A, dir     | 0               | 1   | 0             | 1  | 2   | 3    | 4      | 5     | 6  | 7 |
|          | 3 | JNB          | ACALL  | RETI   | RLC        | ADDC        | ADDC       | ADDC A, @ Ri    |     |               |    | AD  | DC   | Α,     | Rr    |    |   |
|          |   | bit, rel     | addr11 |        | А          | A, #data    | A, dir     | 0               | 1   | 0             | 1  | 2   | 3    | 4      | 5     | 6  | 7 |
| - [      | 4 | JC           | AJMP   | ORL    | ORL        | ORL         | ORL        | ORL A, @ Ri     |     |               |    | 0   | RL   | A, R   | r     |    |   |
|          |   | rel          | addr11 | dir, A | dir, #data | A, #data    | A, dir     | 0               | 1   | 0             | 1  | 2   | 3    | 4      | 5     | 6  | 7 |
| <u>ه</u> | 5 | JNC          | ACALL  | ANL    | ANL        | ANL         | ANL        | ANL A, @ Ri     | _   |               |    | A   | NL / | A, F   | Rr    |    |   |
| ŏ        |   | rel          | addr11 | dir, A | dir, #data | A, #data    | A, dir     | 0               | 1   | 0             | 1  | 2   | 3    | 4      | 5     | 6  | 7 |
| ğ        | 6 | JZ           | AJMP   | XRL    | XRL        | XRL         | XRL        | XRL A, @ Ri     |     |               |    | Х   | RL   | A, R   | r     |    |   |
| er o     |   | rel          | addr11 | dir, A | dir, #data | A, #data    | A, dir     | 0               | 1   | 0             | 1  | 2   | 3    | 4      | 5     | 6  | 7 |
| g        | 7 | JNZ          | ACALL  | ORL    | JMP        | MOV         | MOV        | MOV @ Ri, #data |     | MOV Rr, #data |    |     |      |        |       |    |   |
| har      |   | rel          | addr11 | C, bit | @A+DPTR    | A, #data    | dir,#data  | 0               | 1   | 0             | 1  | 2   | 3    | 4      | 5     | 6  | 7 |
|          | 8 | SJMP         | AJMP   | ANL    | MOVC       | DIV         | MOV        | MOV dir, @ Ri   |     |               |    | M   | OV   | dir, F | ٦r    |    |   |
| .ä       |   | rel          | addr11 | C, bit | A, @A+PC   | AB          | dir, dir   | 0               | 1   | 0             | 1  | 2   | 3    | 4      | 5     | 6  | 7 |
| dec      | 9 | MOV          | ACALL  | MOV    | MOVC       | SUBB        | SUBB       | SUBB A, @ Ri    |     |               |    | SL  | JBB  | А,     | Rr    |    |   |
| exe      |   | DPTR,#data16 | addr11 | bit, C | A,@A+DPTR  | A, #data    | A, dir     | 0               | 1   | 0             | 1  | 2   | 3    | 4      | 5     | 6  | 7 |
| sth      | А | ORL          | AJMP   | MOV    | INC        | MUL         |            | MOV @ Ri, dir   | _   |               |    | M   | OVI  | Rr, c  | lir   |    |   |
| ÷        |   | C,/bit       | addr11 | C, bit | DPTR       | AB          |            | 0               | 1   | 0             | 1  | 2   | 3    | 4      | 5     | 6  | 7 |
| _ [      | В | ANL          | ACALL  | CPL    | CPL        | CJNE        | CJNE       | CJNE @Ri,#data, | rel |               | C. | JNE | Rr,  | #da    | ta, r | el |   |
|          |   | C,/bit       | addr11 | bit    | С          | A,#data,rel | A,dir, rel | 0               | 1   | 0             | 1  | 2   | 3    | 4      | 5     | 6  | 7 |
|          | С | PUSH         | AJMP   | CLR    | CLR        | SWAP        | ХСН        | XCH A, @ Ri     |     |               |    | Х   | СН   | A, R   | lr    |    |   |
|          |   | dir          | addr11 | bit    | С          | А           | A, dir     | 0               | 1   | 0             | 1  | 2   | 3    | 4      | 5     | 6  | 7 |
| [        | D | POP          | ACALL  | SETB   | SETB       | DA          | DNJZ       | XCHD A, @ Ri    |     |               |    | DJ  | NZ   | Rr, ı  | el    |    |   |
|          |   | dir          | addr11 | bit    | С          | А           | dir, rel   | 0               | 1   | 0             | 1  | 2   | 3    | 4      | 5     | 6  | 7 |
| Ī        | Е | MOVX         | AJMP   | MOVX A | ., @Ri     | CLR         | MOV        | MOV A, @ Ri     |     |               |    | Μ   | ٥V   | A, F   | Rr    |    |   |
|          |   | A, @DPTR     | addr11 | 0      | 1          | А           | A, dir *)  | 0               | 1   | 0             | 1  | 2   | 3    | 4      | 5     | 6  | 7 |
|          | F | MOVX         | ACALL  | MOVX A | ., @Ri, A  | CPL         | MOV        | MOV @ Ri, A     |     |               |    | Μ   | OV   | Rr,    | A     |    |   |
|          |   | @DPTR, A     | addr11 | 0      | 1          | А           | dir, A     | 0               | 1   | 0             | 1  | 2   | 3    | 4      | 5     | 6  | 7 |

### second hexadecimal character of opcode

\*) MOV A, ACC is not a valid instruction

## P83C557E4/P80C557E4/P89C557E4

### 8. FLASH EEPROM

### 8.1 General

- 32 Kbytes electrically erasable internal program memory with Block-and Page-Erase option ("Flash Memory").
- Internal fixed boot ROM.
- Up to 32 Kbytes external program memory in combination with the internal FEEPROM (EA=1).
- Up to 64 Kbytes external program memory if the internal program memory is switched off (EA=0).

The FEEPROM can be read and written byte-wise. Full Erase, Block Erase, and Page erase will erase 32 Kbytes, 256 bytes and 32 bytes respectively. In-circuit programming and out-of-circuit programming is possible. On-chip erase and write timing generation and on chip high voltage generation contribute to a user friendly interface.

### 8.2 Features

• Read:

byte-wise

Write:

byte-wise within 2.5 ms. (previously erased by a page, block or full erase).

• Erase:

Page Erase (32 bytes) within 5 ms. Block Erase (256 bytes) within 5 ms. Full Erase (32 Kbytes) within 5 ms. Erased bytes contain FFH.

Endurance:

100 erase and write cycles each byte at  $T_{amb} = 22^{\circ}C$ 

• Retention:

10 years

- Out-of-circuit programming: Parallel programming with 87C51 compatible hardware Interface to programmer.
- In-circuit programming: Serial programming via RS232 interface under boot ROM program control. Auto baud rate selection. Intel Hex Object file Format. The user program can call routines in the boot ROM for erase, write and verify of the FEEPROM.
- High programming voltage generation: on chip
- Zero point on-chip oscillator and timer to generate the write and erase time durations.
- Programmable security for the code in the FEEPROM to prevent software piracy. The Security Byte is located in the highest address (7FFFH) of the FEEPROM.
- Supply voltage monitoring circuit on-chip to prevent loss of information in the FEEPROM during power-on and power-off.

### 8.3 Memory Map

Figure 48 shows the memory map of the user program memory and the boot ROM. They are located in the same program address space. Two bits UBS1 and UBS0 of the FEEPROM control special function register FMCON select between the two memory blocks.

#### User program memory selection

If UBS1 and UBS0 are both 0, then the user program memory is mapped into the 64 K program memory space and the boot ROM cannot be selected. This is the situation after a reset when  $\overrightarrow{PSEN}$  and ALE have not been pulled down during reset. Program execution starts at 0000H in the internal FEEPROM or in the external program memory dependent on the level of  $\overrightarrow{EA}$  during reset.

#### **Boot ROM selection**

After a reset program execution starts in the boot ROM when during reset  $\overrightarrow{\text{PSEN}}$  and  $\overrightarrow{\text{EA}}$  are pulled down while ALE stay high. The boot ROM size is 1 Kbyte. Besides the serial in-circuit programming routine the boot ROM contains the routines for erase, write and verify of the FEEPROM, which can be called by the user program (LCALL to the address space between 63 K and 64 K).

#### Switching between user program memory and boot ROM

Switching between user program memory (internal or external) and boot ROM is possible if UBS1 and UBS0 are 0,1. Then in the program memory address space between 0 and 63k the user program memory is selected and in the memory space between 63 K and 64 K the boot ROM is selected.

To switch from user program memory to boot ROM first UBS0 must be set (UBS1 stay 0) and a jump or call instruction to a location >63 K must be executed.

At the moment of crossing the 63 K address border by a return instruction the switching from boot ROM to user memory (internal or external) is performed. After crossing the 63 K address border UBS1 and UBS0 are cleared and the total 64 K memory space is mapped as user program memory. By clearing UBS1 and UBS0, no special requirements to the user program are necessary to do that after a read or erase or write routine.

A small restriction for memory switching is that no memory switching is allowed from or to the address space between 63 K and 64 K of the user program memory because the UBS bits must stay 0 in this range. This restriction can be avoided if the memory switching is always done by a subroutine in the address range between 0 and 63 K.

#### Description

The user program code in the FEEPROM is executed as in the standard 80C51 microcontroller. Erase and write cycles in the FEEPROM are always performed under control of the boot program in the boot ROM in the address space between 63 K and 64 K. Address and data parameters are passed via DPTR and accumulator A respectively. During an erase or write cycle in the FEEPROM no other access or program execution in the FEEPROM is possible. All interrupts must be disabled when the user program calls a user routine in the boot ROM.

The boot routine for serial programming takes care of addressing, data transfer, verify, high voltage control, error message and return to the user program memory. It also contains the serial communication routine.

The FEEPROM control register FMCON is a special function register. It contains the control bits for verify, write, erase and boot ROM switching.

## P83C557E4/P80C557E4/P89C557E4

|            | 7    | 6    | 5  | 4    | 3    | 2    | 1    | 0    |
|------------|------|------|----|------|------|------|------|------|
| FMCON (FB) | UBS1 | UBS0 | ΗV | _ 1) | FCB3 | FCB2 | FCB1 | FCB0 |

### Figure 49. FEEPROM control register.

NOTE:

1. Reserved for future use; a write operation must write "0" to the location.

| Table 45. | Description | of FMCON bits |
|-----------|-------------|---------------|
|-----------|-------------|---------------|

| UBS1 |      | UBS0 |                                                                                                                                                                         | User - Boot selection bits          |  |  |  |  |
|------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|--|--|--|--|
| 0    |      | 0    |                                                                                                                                                                         | User memory mapped from 0 to 64 K.  |  |  |  |  |
| 0 1  |      |      | User memory mapped from 0 to 63 K.<br>Boot ROM mapped from 63 K to 64 K.                                                                                                |                                     |  |  |  |  |
| 1 0  |      |      | er memory mapped from 0 to 63 K, but UBS1 bit cleared by hardware in this user address ran<br>ot ROM mapped from 63 K to 64 K. User software should not write "1" UBS1. |                                     |  |  |  |  |
| 1 1  |      |      | Boot ROM mapped from 0 to 64 K. User software should not write "1" UBS1.                                                                                                |                                     |  |  |  |  |
|      |      |      |                                                                                                                                                                         |                                     |  |  |  |  |
| HV   |      |      | <b>High voltage indication bit.</b> Read only. Is "1" as long as the high voltage for an erase or write operation is present.                                           |                                     |  |  |  |  |
|      |      |      |                                                                                                                                                                         |                                     |  |  |  |  |
| FCB3 | FCB2 | FCB1 | FCB0                                                                                                                                                                    | Function Code Bits                  |  |  |  |  |
| 0    | 0    | 0    | 0                                                                                                                                                                       | Value after Reset.                  |  |  |  |  |
| 0    | 1    | 0    | 1                                                                                                                                                                       | Byte Write or byte read (verify)    |  |  |  |  |
| 1    | 1    | 0    | 0                                                                                                                                                                       | Page Erase (32 bytes boundaries).   |  |  |  |  |
| 0    | 0    | 1    | 1                                                                                                                                                                       | Block Erase (256 bytes boundaries). |  |  |  |  |
| 1    | 0    | 1    | 0                                                                                                                                                                       | Full Erase (32 Kbytes).             |  |  |  |  |

The four FCB bits are write protected if the security feature is activated. Then only instructions in the internal program memory (FEEPROM) are able to write FCB (3–0), boot ROM and external program memory instructions cannot change FCB (3–0) except the full erase code can be loaded.

The duration of a write or erase operation is determined by the FEEPROM timer. This timer includes a zero point RC oscillator and cannot be controlled by software.

For calling a user routine in the boot ROM first all interrupts must be disabled and the DPTR and A have to be loaded with the desired values. After setting UBS0 = 1 and UBS1 = 0 and selecting the function via FCB-bits the respective user routine has to be called.

The table below lists the boot ROM user routines, which can be called by the user program. The content of FMCON, A and DPTR before the call is described by "(IN)" and the contents after the return is described by "(OUT)". The boot ROM user routines do not change other registers or Data memory.

| BOOT-ROM<br>ROUTINE | CALL<br>ADDRESS | FMCON<br>(IN) | FMCON<br>(OUT) | ACC<br>(IN) | ACC<br>(OUT) | DPTR<br>(IN)               | DPTR<br>(OUT)              |
|---------------------|-----------------|---------------|----------------|-------------|--------------|----------------------------|----------------------------|
| BYTE_READ           | FFBAH           | 45H           | 15H            | ХХН         | BYTE         | BYTE ADDRESS               | BYTE ADDRESS               |
| BYTE_WRITE          | FFADH           | 45H           | 15H            | BYTE        | BYTE (V)     | BYTE ADDRESS               | BYTE ADDRESS               |
| PAGE_ERASE          | FFAAH           | 4CH           | 1CH            | ХХН         | 08H          | PAGE ADDRESS <sup>1)</sup> | PAGE ADDRESS <sup>2)</sup> |
| BLOCK_ERASE         | FFA5H           | 43H           | 13H            | ХХН         | 02H          | BLOCK ADDRESS 3)           | BLOCK ADDRESS 4)           |
| FULL_ERASE          | FFA0H           | 4AH           | 1AH            | XXH         | 0AH          | ХХХХН                      | 0018H                      |

X = don't care or not defined

V = verified byte (read back)

1) = 5 LSB's of DPTR are don't care

2) = 5 LSB's of DPTR are "0"

3) = 8 LSB's of DPTR are don't care

4) = 8 LSB's of DPTR contain 08H.

## P83C557E4/P80C557E4/P89C557E4

## FEEPROM PROGRAMMING AND VERIFICATION CHARACTERISTICS

 $T_{amb} = -40$  °C to +85 °C,  $V_{DD} = 5 V \pm 10\%$ ,  $V_{SS} = 0 V$  (see Figure 53)

| SYMBOL             | PARAMETER                                    | MIN                | MAX                | UNIT |
|--------------------|----------------------------------------------|--------------------|--------------------|------|
| 1/t <sub>CLK</sub> | System clock frequency (standard oscillator) | 4                  | 6                  | MHz  |
| t <sub>AVWL</sub>  | Address setup to WE LOW                      | 48t <sub>CLK</sub> | -                  |      |
| t <sub>WHAX</sub>  | Address hold after WE HIGH                   | 48t <sub>CLK</sub> | -                  |      |
| t <sub>DVWL</sub>  | Data setup to WE LOW                         | 48t <sub>CLK</sub> | -                  |      |
| t <sub>WHDX</sub>  | Data hold after WE HIGH                      | 48t <sub>CLK</sub> | -                  |      |
| t <sub>EHWL</sub>  | P2.7 (ENABLE) HIGH to WE LOW                 | 48t <sub>CLK</sub> | -                  |      |
| t <sub>WHEL</sub>  | WE HIGH to P2.7 (ENABLE) LOW                 | 48t <sub>CLK</sub> | -                  |      |
| t <sub>WLWHp</sub> | WE width (programming)                       | 2.25               | 2.75               | ms   |
| t <sub>WLWHe</sub> | WE width (erase)                             | 4.5                | 5.5                | ms   |
| t <sub>AVQV</sub>  | Address to data valid                        | -                  | 48t <sub>CLK</sub> |      |
| t <sub>ELQV</sub>  | P2.7 (ENABLE) Low to data valid              | -                  | 48t <sub>CLK</sub> |      |
| t <sub>EHQZ</sub>  | Data float after P2.7 (ENABLE) HIGH          | 0                  | 48t <sub>CLK</sub> |      |



## P83C557E4/P80C557E4/P89C557E4

## DC ELECTRICAL CHARACTERISTICS (Continued)

 $V_{DD} = 5 V (\pm 10\%), V_{SS} = 0 V, T_{amb} = -40^{\circ}C \text{ to } +85^{\circ}C (P8xC557E4EFx).$ 

DC parameters not included here are the same as in the P8xC557E4EBx, DC electrical characteristics

All voltages with respect to V<sub>SS</sub> unless otherwise specified.

|                  |                                                          | TEST                                          | LIMITS                  |                          |      |
|------------------|----------------------------------------------------------|-----------------------------------------------|-------------------------|--------------------------|------|
| SYMBOL           | PARAMETER                                                | CONDITIONS                                    | MIN                     | MAX                      | UNIT |
| R <sub>RST</sub> | Internal reset pull-down resistor                        |                                               | 50                      | 150                      | kΩ   |
| C <sub>IO</sub>  | Pin capacitance                                          | Test freq = 1MHz,<br>T <sub>amb</sub> = 25 °C |                         | 10                       | pF   |
| Inputs           |                                                          |                                               |                         |                          |      |
| V <sub>IL</sub>  | Input LOW voltage, except EA, SCL, SDA                   |                                               | -0.5                    | 0.2V <sub>DD</sub> -0.15 | V    |
| V <sub>IL1</sub> | Input LOW voltage to EA                                  |                                               | -0.5                    | 0.2V <sub>DD</sub> -0.35 | V    |
| V <sub>IH</sub>  | Input HIGH voltage, except XTAL1, RSTIN, SCL, SDA, ADEXS |                                               | 0.2V <sub>DD</sub> +1.0 | V <sub>DD</sub> +0.5     | V    |
| V <sub>IH1</sub> | Input HIGH voltage, XTAL1, RSTIN, ADEXS                  |                                               | 0.7V <sub>DD</sub> +0.1 | V <sub>DD</sub> +0.5     | V    |
| IL               | Input current LOW level, Ports 1, 2, 3, 4                | V <sub>IN</sub> = 0.45 V                      |                         | -75                      | μA   |
| ITL              | Transition current HIGH to LOW, Ports 1, 2, 3, 4         | See note 6                                    |                         | -750                     | μA   |

NOTES: See Page 62.

## DC ELECTRICAL CHARACTERISTICS ANALOG

 $\begin{array}{l} {\sf AV}_{DD}=5~V~(\pm~10\%),~{\sf AV}_{SS}=0~V,~{\sf Tamb}=~0~^\circ{\sf C}~to~+70~^\circ{\sf C}~({\sf P8xC557E4EBx}).\\ {\sf AV}_{DD}=5~V~(\pm~10\%),~{\sf AV}_{SS}=0~V,~{\sf Tamb}=-40~^\circ{\sf C}~to~+85~^\circ{\sf C}~({\sf P8xC557E4EFx}).\\ {\sf All~voltages~with~respect~to~V}_{SS}~unless~otherwise~specified. \end{array}$ 

|                   |                                                                | TEST                                                     | LIMITS                |                       |        |
|-------------------|----------------------------------------------------------------|----------------------------------------------------------|-----------------------|-----------------------|--------|
| SYMBOL            | PARAMETER                                                      | CONDITIONS                                               | MIN MAX               |                       | UNIT   |
| AV <sub>DD</sub>  | Analog supply voltage                                          | $AV_{DD} = V_{DD} \pm 0.2 V$                             | 4.5                   | 5.5                   | V      |
| AI <sub>DD</sub>  | Analog supply current operating                                | Port 5 = 0 to AV <sub>DD</sub><br>see notes 1 and 2      |                       | 1.2                   | mA     |
|                   | Analog supply current operating:<br>32 kHz/PLL operation       | Port 5 = 0 to AV <sub>DD</sub><br>see note 17, 18        |                       | 7.2                   | mA     |
| AI <sub>ID</sub>  | Analog supply current Idle Mode                                | see notes 1 and 3                                        |                       | 70                    | μΑ     |
|                   | Analog supply current Idle Mode:<br>32 kHz/PLL operation       | see note 17                                              |                       | 6.0                   | mA     |
| Al <sub>PD</sub>  | Supply current Power-down mode                                 | 2 V < V <sub>PD</sub> < V <sub>DDmax</sub><br>see note 4 |                       | 50                    | μA     |
|                   | Supply current Power-down mode:<br>32 kHz / PLL operation      | V <sub>DD</sub> = 5.5V<br>see note 17                    |                       | 200                   | μA     |
| Analog Inp        | uts                                                            |                                                          |                       |                       |        |
| AV <sub>IN</sub>  | Analog input voltage                                           |                                                          | AV <sub>SS</sub> -0.2 | AV <sub>DD</sub> +0.2 | V      |
| AV <sub>REF</sub> | Reference voltage:<br>AV <sub>REF-</sub><br>AV <sub>REF+</sub> |                                                          | AV <sub>SS</sub> -0.2 | AV <sub>DD</sub> +0.2 | V<br>V |
| R <sub>REF</sub>  | Resistance between AV <sub>REF+</sub> and AV <sub>REF-</sub>   |                                                          | 10                    | 50                    | kΩ     |
| C <sub>IA</sub>   | Analog input capacitance                                       |                                                          |                       | 15                    | pF     |
| DLe               | Differential non-linearity <sup>9, 10, 11,</sup>               |                                                          |                       | ±1                    | LSB    |
| ILe               | Integral non-linearity 9, 12                                   |                                                          |                       | ±2                    | LSB    |
| OS <sub>e</sub>   | Offset error <sup>9, 13</sup>                                  |                                                          |                       | ±2                    | LSB    |
| G <sub>e</sub>    | Gain error <sup>9, 14</sup>                                    |                                                          |                       | ±0.4                  | %      |
| A <sub>e</sub>    | Absolute voltage error <sup>9, 15</sup>                        |                                                          |                       | ±3                    | LSB    |
| M <sub>CTC</sub>  | Channel to channel matching                                    |                                                          |                       | ±1                    | LSB    |
| Ct                | Crosstalk between inputs of port 5 <sup>16</sup>               | 0–100kHz                                                 |                       | -60                   | dB     |

NOTES: See Page 62.



P83C557E4/P80C557E4/P89C557E4

# Single-chip 8-bit microcontroller

### **11. AC CHARACTERISTICS**

### **AC ELECTRICAL CHARACTERISTICS**

 $\begin{array}{l} \mathsf{V}_{DD} = 5 \; \mathsf{V} \pm 10\% \; (\mathsf{EBx}), \; \mathsf{V}_{SS} = 0 \; \mathsf{V}, \; t_{\mathsf{CLK}} \; \mathsf{min} = 1/\mathsf{fmax} \; (\mathsf{maximum} \; \mathsf{operating} \; \mathsf{frequency}) \\ \mathsf{V}_{DD} = 5 \; \mathsf{V} \pm 10\% \; (\mathsf{EFx}), \; \mathsf{V}_{SS} = 0 \; \mathsf{V}, \; t_{\mathsf{CLK}} \; \mathsf{min} = 1/\mathsf{fmax} \; (\mathsf{maximum} \; \mathsf{operating} \; \mathsf{frequency}) \\ \mathsf{T}_{\mathsf{amb}} = 0 \; ^\circ \mathsf{C} \; \mathsf{to} + 70 \; ^\circ \mathsf{C}, \; t_{\mathsf{CLK}} \; \mathsf{min} = 63 \; \mathsf{ns} \; \mathsf{for} \; \mathsf{P8xC557E4EBx} \\ \mathsf{T}_{\mathsf{amb}} = -40 \; ^\circ \mathsf{C} \; \mathsf{to} + 85 \; ^\circ \mathsf{C}, \; t_{\mathsf{CLK}} \; \mathsf{min} = 63 \; \mathsf{ns} \; \mathsf{for} \; \mathsf{P8xC557E4EFx} \\ \mathsf{C1} = 100 \; \mathsf{pF} \; \mathsf{for} \; \mathsf{Port} \; \mathsf{0}, \; \mathsf{ALE} \; \mathsf{and} \; \overline{\mathsf{PSEN}} \; \mathsf{;} \; \mathsf{C1} = 80 \; \mathsf{pF} \; \mathsf{for} \; \mathsf{all} \; \mathsf{otherwise} \; \mathsf{specified}. \end{array}$ 

|                    |              |                                                             | 12MHz CLOCK |                     | 16MHz CLOCK |          | VARIABLE CLOCK          |                         |      |
|--------------------|--------------|-------------------------------------------------------------|-------------|---------------------|-------------|----------|-------------------------|-------------------------|------|
| SYMBOL             | FIGURE       | PARAMETER                                                   | MIN         | MAX                 | MIN         | MAX      | MIN                     | MAX                     | UNIT |
| 1/t <sub>CLK</sub> | 60           | System clock frequency                                      |             |                     |             |          | 3.5                     | 16                      | MHz  |
| t <sub>LHLL</sub>  | 60           | ALE pulse width                                             | 127         |                     | 85          |          | 2t <sub>CLK</sub> -40   |                         | ns   |
| t <sub>AVLL</sub>  | 60           | Address valid to ALE LOW                                    | 43          |                     | 23          |          | t <sub>CLK</sub> –40    |                         | ns   |
| t <sub>LLAX</sub>  | 60           | Address hold after ALE LOW                                  | 53          |                     | 33          |          | t <sub>CLK</sub> -30    |                         | ns   |
| t <sub>LLIV</sub>  | 60           | ALE LOW to valid instruction in                             |             | 234                 |             | 150      |                         | 4t <sub>CLK</sub> –100  | ns   |
| t <sub>LLPL</sub>  | 60           | ALE LOW to PSEN LOW                                         | 53          |                     | 33          |          | t <sub>CLK</sub> –30    |                         | ns   |
| t <sub>PLPH</sub>  | 60           | PSEN pulse width                                            | 205         |                     | 143         |          | 3t <sub>CLK</sub> –45   |                         | ns   |
| t <sub>PLIV</sub>  | 60           | PSEN LOW to valid instruction in                            |             | 145                 |             | 83       |                         | 3t <sub>CLK</sub> –105  | ns   |
| t <sub>PXIX</sub>  | 60           | Input instruction hold after PSEN                           | 0           |                     | 0           |          | 0                       |                         | ns   |
| t <sub>PXIZ</sub>  | 60           | Input instruction float after PSEN                          |             | 59                  |             | 38       |                         | t <sub>CLK</sub> –25    | ns   |
| t <sub>AVIV</sub>  | 60           | Address to valid instruction in                             |             | 312                 |             | 208      |                         | 5t <sub>CLK</sub> -105  | ns   |
| t <sub>PLAZ</sub>  | 60           | PSEN LOW to address float                                   |             | 10                  |             | 10       |                         | 10                      | ns   |
| Data Memo          | ry           |                                                             |             |                     |             |          |                         |                         |      |
| t <sub>AVLL</sub>  | 61, 62       | Address valid to ALE LOW                                    | 43          |                     | 23          |          | t <sub>CLK</sub> –40    |                         | ns   |
| t <sub>LLAX</sub>  | 61, 62       | Address hold after ALE LOW                                  | 48          |                     | 28          |          | t <sub>CLK</sub> -35    |                         | ns   |
| t <sub>RLRH</sub>  | 61           | RD pulse width                                              | 400         |                     | 275         |          | 6t <sub>CLK</sub> -100  |                         | ns   |
| t <sub>WLWH</sub>  | 62           | WR pulse width                                              | 400         |                     | 275         |          | 6t <sub>CLK</sub> -100  |                         | ns   |
| t <sub>RLDV</sub>  | 61           | RD LOW to valid data in                                     |             | 252                 |             | 148      |                         | 5t <sub>CLK</sub> -165  | ns   |
| t <sub>RHDX</sub>  | 61           | Data hold after RD                                          | 0           |                     | 0           |          | 0                       |                         | ns   |
| t <sub>RHDZ</sub>  | 61           | Data float after RD                                         |             | 97                  |             | 55       |                         | 2t <sub>CLK</sub> –70   | ns   |
| t <sub>LLDV</sub>  | 61           | ALE LOW to valid data in                                    |             | 517                 |             | 350      |                         | 8t <sub>CLK</sub> –150  | ns   |
| t <sub>AVDV</sub>  | 61           | Address to valid data in                                    |             | 585                 |             | 398      |                         | 9t <sub>CLK</sub> -165  | ns   |
| t <sub>LLWL</sub>  | 61, 62       | ALE LOW to RD or WR LOW                                     | 200         | 300                 | 138         | 238      | 3t <sub>CLK</sub> –50   | 3t <sub>CLK</sub> +50   | ns   |
| t <sub>AVWL</sub>  | 61, 62       | Address valid to $\overline{WR}$ LOW or $\overline{RD}$ LOW | 203         |                     | 120         |          | 4t <sub>CLK</sub> -130  |                         | ns   |
| t <sub>QVWX</sub>  | 62           | Data valid to $\overline{WR}$ transition                    | 33          |                     | 13          |          | t <sub>CLK</sub> –50    |                         | ns   |
| t <sub>QVWH</sub>  | 62           | Data before WR                                              | 433         |                     | 288         |          | 7t <sub>CLK</sub> -150  |                         | ns   |
| t <sub>WHQX</sub>  | 62           | Data hold after WR                                          | 33          |                     | 13          |          | t <sub>CLK</sub> –50    |                         | ns   |
| t <sub>RLAZ</sub>  | 61           | RD low to address float                                     |             | 0                   |             | 0        |                         | 0                       | ns   |
| t <sub>WHLH</sub>  | 61, 62       | RD or WR HIGH to ALE HIGH                                   | 43          | 123                 | 23          | 103      | t <sub>CLK</sub> –40    | t <sub>CLK</sub> +40    | ns   |
| UART Timir         | ng – Shift R | egister Mode (Test Conditions: T <sub>amb</sub> = 0         | °C to +70   | °C; V <sub>SS</sub> | = 0 V; Loa  | ad Capac | itance = 80pF)          |                         |      |
| t <sub>XLXL</sub>  | 64           | Serial port clock cycle time                                | 1.0         |                     | 0.75        |          | 12t <sub>CLK</sub>      |                         | μs   |
| t <sub>QVXH</sub>  | 64           | Output data setup to clock rising edge                      | 700         |                     | 492         |          | 10t <sub>CLK</sub> -133 |                         | ns   |
| t <sub>XHQX</sub>  | 64           | Output data hold after clock rising edge                    | 50          |                     | 8           |          | 2t <sub>CLK</sub> -117  |                         | ns   |
| t <sub>XHDX</sub>  | 64           | Input data hold after clock rising edge                     | 0           |                     | 0           |          | 0                       |                         | ns   |
| t <sub>XHDV</sub>  | 64           | Clock rising edge to input data valid                       |             | 700                 |             | 492      |                         | 10t <sub>CLK</sub> -133 | ns   |









