#### **DATA SHEET** ### 80C32/80C52 # CMOS SINGLE-CHIP 8 BIT MICROCONTROLLER 80C32 : ROMLESS VERSION OF THE 80C52 80C32/80C52: 0 TO 12 MHz 80C32/80C52-1: 0 TO 16 MHz 80C32-S/80C52-S : 0 TO 20 MHz 80C32/80C52-L: 0 TO 6 MHz WITH 2.7 V < $V_{\rm CC}$ < 5.5 V 80C52F: 80C52 WITH PROTECTED ROM #### **FEATURES** - POWER CONTROL MODES - 256 x 8 BIT RAM - 8 K BYTES OF ROM (80C52) - 32 PROGRAMMABLE VO LÍNES - THREE 16 BIT TIMER/COUNTER - 64 K PROGRAM MEMORY SPACE - FULLY STATIC DESIGN - HIGH PERFORMANCE SAJI VI CMOS PROCESS - BOOLEAN PROCESSOR - 6 INTERRUPT SOURCES - PROGRAMMABLE SERIAL PORT - 64 K DATA MEMORY SPACE - TEMPERATURE RANGE: COMMERCIAL, INDUSTRIAL AUTOMOTIVE AND MILITARY #### INTRODUCTION MHS's 80C52 and 80C32 are high performance CMOS versions of the 8052/8032 NMOS single chip 8 bit $\mu$ C and is manufactured using a self-aligned silicon gate CMOS process (SAJI VI). The fully static design of the MHS 80C52/80C32 allows to reduce system power consumption by bringing the clock frequency down to any value, even DC, without loss of data The 80C52 retains all the features of the 8052: 8 K bytes of ROM; 256 bytes of RAM; 32 I/O lines; three 16 bit timers; a 6-source, 2-level interrupt structure; a full duplex serial port; and on-chip oscillator and clock circuits. In addition, the 80C52 has two software-selectable modes of reduced activity for further reduction in power consumption. In the Idle Mode the CPU is frozen while the RAM, the timers, the serial port, and the interrupt system continue to function. In the Power Down Mode the RAM is saved and all other functions are inoperative. The 80C32 is identical to the 80C52 except that it has no on-chip ROM. 5 The information contained herein is subject to change without notice. No responsibility is assumed by MATRA MHS SA for using this publication and/or circuits described herein: nor for any possible infringements of patents or other rights of third parties which may result from its use. #### INTERFACE #### **PIN CONFIGURATION** Figure 1. #### PIN DESCRIPTION #### Vee Circuit Ground Potential. #### Vcc Supply voltage during normal, Idle, and Power Down operation. #### PORT 0 Port 0 is an 8 bit open drain bi-directional I/O port. Port 0 pins that have 1's written to them float, and in that state can be used as high-impedance inputs. Port 0 is also the multiplexed low-order address and data bus during accesses to external Program and Data Memory. In this application it uses strong internal pullups when emitting 1's. Port 0 also outputs the code bytes during program verification in the 80C52. External pullups are required during program verification. Port 0 can sink eight LS TTL inputs. #### PORT 1 Port is an 8 bit bi-directional I/O port with internal pullups. Port 1 pins that have 1's written to them are pulled high by the internal pullups, and in that state can be used as inputs. As inputs, Port 1 pins that are externally being pulled low will source current (IIL, on the data sheet) because of the internal pullups. Port 1 also receives the low-order address byte during program verification. In the 80C52, Port 1 can sink/source three LS TTL inputs. It can drive CMOS inputs without external pullups. 2 inputs of PORT 1 are also used for timer/counter 2: P1.0 [T2]: External clock input for timer/counter 2. P1.1 [T2EX]: A trigger input for timer/counter 2, to be reloaded or captured causing the timer/counter 2 interrupt. #### PORT 2 Port 2 is an 8 bit bi-directional I/O port with internal pullups. Port 2 pins that have 1's written to them are pulled high by the internal pullups, and in that state can be used as inputs. As inputs, Port 2 pins that are externally being pulled low will source current (IIL, on the data sheet) because of the internal pullups. Port 2 emits the high-order address byte during fetches from external Program Memory and during accesses to external Data Memory that use 16 bit addresses (MOVX @DPTR). In this application, it uses strong internal pullups when emitting 1's. During accesses to external Data Memory that use 8 bit addresses (MOVX @Ri), Port 2 emits the contents of the P2 Special Function Register. It also receives the high-order address bits and control signals during program verification in the 80C52. Port 2 can sink/source three LS TTL inputs. It can drive CMOS inputs without external pullups. #### PORT 3 Port 3 is an 8 bit bi-directional I/O port with internal pullups. Port 3 pins that have 1's written to them are pulled high by the internal pullups, and in that state can be used as inputs. As inputs, Port 3 pins that are externally being pulled low will source current (IIL, on the data sheet) because of the pullups. It also serves the function of various special features of the MHS 51 Family, as listed below. | Port Pin | Alternate Function | |----------|----------------------------------------| | P3.0 | RXD (serial input port) | | P3.1 | TXD (serial output port) | | P3.2 | INTO (external interrupt 0) | | P3.3 | INT1 (external interrupt 1) | | P3.4 | T0 (Timer 0 external input) | | P3.5 | T1 (Timer 1 external input) | | P3.6 | WR (external Data Memory write strobe) | | P3.7 | RD (external Data Memory read strobe) | Port 3 can sink/source three LS TTL inputs. It can drive CMOS inputs without external pullups. #### RST A high level on this for two machine cycles while the oscillator is running resets the device. An internal pull-down resistor permits Power-On reset using only a capacitor connected to $V_{\rm CC}$ . #### ALE Address Latch Enable output for latching the low byte of the address during accesses to external memory. ALE is activated as though for this purpose at a constant rate of 1/6 the oscillator frequency except during an external data memory access at which time on ALE pulse is skipped. ALE can sink/source 8 LS TTL inputs. It can drive CMOS inputs without an external pullup. #### DOEN Program Store Enable output is the read strobe to external Program Memory. PSEN is activated twice each machine cycle during fetches from external Program Memory. (However, when executing out of external Program Memory, two activations of PSEN are skipped during each access to external Data Memory). PSEN is not activated during fetches from internal Program Memory. PSEN can sink/source 8 LS TTL inputs. It can drive CMOS inputs without an external pullup. #### FΔ When EA is held high, the CPU executed out of internal Program Memory (unless the Program Counter exceeds 1FFFH). When EA is held low, the CPU executes only out of external Program Memory. EA must not be floated. #### YTAI 1 Input to the inverting amplifier that forms the oscillator. Receives the external oscillator signal when an external oscillator is used. #### XTAL2 Output of the inverting amplifier that forms the oscillator, and input to the internal clock generator. This pin should be floated when an external oscillator is used. #### **BLOCK DIAGRAM** Figure 2. #### **IDLE AND POWER DOWN OPERATION** Figure 3 shows the internal Idle and Power Down clock configuration. As illustrated, Power Down operation stops the oscillator. Idle mode operation allows the interrupt, serial port, and timer blocks to continue to function while the clock to the CPU is gated off. These special modes are activated by software via the Special Function Register, PCON. Its hardware address is 87H. PCON is not bit addressable. Figure 3: Idle and Power Down Hardware. PCON: Power Control Register | (MSB) | | | | | | | (LSB) | |-------|---|---|---|-----|-----|----|-------| | SMOD | 1 | _ | - | GF1 | GF0 | PD | IDL | #### Symbol Position Name and Function | SMOD | PCON.7 | Double Baud rate bit. When set<br>to a 1, the baud rate is doubled<br>when the serial port is being<br>used in either modes 1, 2 or 3. | |------|--------|----------------------------------------------------------------------------------------------------------------------------------------| | _ | PCON.6 | (Reserved) | | - | PCON.5 | (Reserved) | | - | PCON.4 | (Reserved) | | GF1 | PCON.3 | General-purpose flag bit. | | GF0 | PCON.2 | General-purpose flag bit. | | PD | PCON.1 | Power Down bit. Setting this bit activates power down operation. | | IDL | PCON.0 | Idle mode bit. Setting this bit activates idle mode operation. | If 1's are written to PD and IDL at the same time. PD takes precedence. The reset value of PCON is (0XXX0000). #### **IDLE MODE** The instruction that sets PCON.0 is the last instruction executed before the Idle mode is activated. Once in the Idle mode the CPU status is preserved in its entirety: the Stack Pointer, Program Counter, Program Status Word, Accumulator, RAM, and all other register maintain their data during Idle. *Table 1* describes the status of the external pins during Idle mode. There are two ways to terminate the Idle mode. Activation of any enabled interrupt will cause PCON.0 to be cleared by hardware, terminating Idle mode. The interrupt is serviced, and following RETI, the next instruction to be executed will be the one following the instruction that wrote 1 to PCON.0. The flag bits GF0 and GF1 may be used to determine whether the interrupt was received during normal execution or during the Idle mode. For example, the instruction that writes to PCON.0 can also set or clear one or both flag bits. When Idle mode is terminated by an enabled interrupt, the service routine can examine the status of the flag bits. The second way of terminating the Idle is with a hardware reset. Since the oscillator is still running, the hardware reset needs to be active for only 2 machine cycles (24 oscillator periods) to complete the reset operation. #### POWER DOWN MODE The instruction that sets PCON.1 is the last executed prior to entering power down. Once in power down, the oscillator is stopped. The contents of the onchip RAM and the Special Function Register is saved during power down mode. A hardware reset is the only way of exiting the power down mode. The hardware reset initiates the Special Function Register. In the Power Down mode, Vcc may be lowered to minimize circuit power consumption. Care must be taken to ensure the voltage is not reduced until the power down mode is entered, and that the voltage is restored before the hardware reset is applied which frees the oscillator. Reset should not be released until the oscillator has restarted and stabilized. Table 1 describes the status of the external pins while in the power down mode. It should be noted that if the power down mode is activated while in external program memory, the port data that is held in the Special Function Register P2 is restored to Port 2. If the data is a 1, the port pin is held high during the power down mode by the strong pullup, T1, shown in Figure 4. #### STOP CLOCK MODE Due to static design, the MHS 80C32/C52 clock speed can be reduced until 0 MHz without any data loss in memory or registers. This mode allows step by step utilization, and permits to reduce system power consumption by bringing the clock frequency down to any value. At 0 MHz, the power consumption is the same as in the Power Down Mode. #### I/O PORTS The I/O port drive of the 80C52 is similar to the 8052. The I/O buffers for Ports 1, 2 and 3 are implemented as shown in *figure 4*. Figure 4: I/O Buffers in the 80C52 (Ports 1, 2, 3). When the port latch contains a 0, all pFETS in figure 4 are off while the nFET is turned on. When the port latch makes a 0-to-1 transition, the nFET turns off. The strong pFET, T1, turns on for two oscillator periods, pulling the output high very rapidly. As the output line is drawn high, pFET T3 turns on through the inverter to supply the lon source current. This inverter and T form a latch which holds the 1 and is supported by T2. When Port 2 is used as an address port, for access to external program of data memory, any address bit that contains a 1 will have his strong pullup turned on for the entire duration of the external memory access. | MODE | PROGRAM MEMORY | ALE | PSEN | PORT0 | PORT1 | PORT2 | PORT3 | |---------------|----------------|-----|------|-----------|-----------|-----------|-----------| | ldle | Internal | 1 | 1 | Port Data | Port Data | Port Data | Port Data | | idle | External | 1 | 1 | Floating | Port Data | Address | Port Data | | Power<br>Down | internal | 0 | 0 | Port Data | Port Data | Port Data | Port Data | | Power<br>Down | External | 0 | 0 | Floating | Port Data | Port Data | Port Data | Table 1: Status of the external pins during Idle and Power Down modes. When an I/O pin on Ports 1, 2 or 3 is used as an input, the user should be aware that the external circuit must sink current during the logical 1-to-0 transition. The maximum sink current is specified as ITL under the D.C. Specifications. When the input goes below approximately 2 V, T3 turns off to save ICC current. Note, when returning to a logical 1, T2 is the only internal pullup that is on. This will result in a slow rise time if the user's circuit does not force the input line high. #### **OSCILLATOR CHARACTERISTICS** XTAL1 and XTAL2 are the input and output respectively, of an inverting amplifier which is configured for use as an on-chip oscillator, as shown in figure 5. Either a quartz crystal or ceramic resonator may be used. To drive the device from an external clock source, XTAL1 should be driven while XTAL2 is left unconnected as shown in *figure 6*. There are no requirements on the duty cycle of the external clock signal, since the input to the internal clocking circuitry is through a divide-by-two flip-flop, but minimum and maximum high and low times specified on the Data Sheet must be observed. Figure 5: Crystal Oscillator. Figure 6: External Drive Configuration. #### HARDWARE DESCRIPTION Same as for the 80C51, plus a third timer/counter: #### **TIMER/EVENT COUNTER 2** Timer 2 is a 16 bit timer/counter like Timers 0 and 1, it can operate either as a timer or as an event counter. This is selected by bit C/T2 in the Special Function Register T2CON (Figure 1). It has three operating modes: "capture", "autoload" and "baud rate generator", which are selected by bits in T2CON as shown in Table 2. | 1 | RCLK+<br>TCLK | CP/RL2 | TR2 | MODE | |---|---------------|--------|-----|---------------------| | | 0 | 0 | 1 | 16-bit auto-reload | | ı | 0 | 1 | 1 | 16-bit capture | | ı | 1 | X | 1 | baud rate generator | | ı | Х | X | 0 | (off) | Table 2: Timer 2 Operating Modes. In the capture mode there are two options which are selected by bit EXEN2 in T2CON; If EXEN2 = 0, then Timer 2 is a 16 bit timer or counter which upon overflowing sets bit TF2, the Timer 2 overflow bit, which can be used to generate an interrupt. If EXEN2 = 1, then Timer 2 still does the above, but with the added feature that a 1-to-0 transition at external input T2EX causes the current value in the Timer 2 registers, TL2 and TH2, to be captured into registers RCAP2L and RCAP2H, respectively, (RCAP2L and RCAP2H are new Special Function Register in the 80C52). In addition, the transition at T2EX causes bit EXF2 in T2CON to be set, and EXF2, like TF2, can generate an interrupt. The capture mode is illustrated in Figure 7. Figure 7: Timer 2 in Capture Mode. In the auto-reload mode there are again two options, which are selected by bit EXEN2 in T2CON.If EXEN2 = 0, then when Timer 2 rolls over it does not only set TF2 but also causes the Timer 2 register to be reloaded with the 16 bit value in registers RCAP2L and RCAP2H, which are preset by software. If EXEN2 = 1, then Timer 2 still does the above, but with the added feature that a 1-to-0 transition at external input T2EX will also trigger the 16 bit reload and set EXF2. The auto-reload mode is illustrated in Figure 8. Figure 8: Timer in Auto-Reload Mode. | (MSB) | | | | | | | (LSB) | | |-------|------|------|------|-------|-----|------|--------|--| | TF2 | EXF2 | RCLK | TCLK | EXEN2 | TR2 | C/T2 | CP/RL2 | | The baud rate generator mode is selected by : RCLK = 1 and/or TCLK = 1. | Symbol | Position | Name and Significance | |--------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TF2 | T2CON.7 | Timer 2 overflow flag set by a Timer 2 overflow and must be cleared by software. TF2 will not be set when either RCLK = 1 OR TCLK = 1. | | EXF2 | T2CON.6 | Timer 2 external flag set when either a capture or reload is caused by a negative transition on T2EX and EXEN2 = 1. When Timer 2 interrupt is enabled, EXF2 = 1 will cause the CPU to vector to the Timer 2 interrupt routine. EXF2 must be cleared by software. | | RCLK | T2CON.5 | Receive clock flag. When set, causes the serial port to use Timer 2 overflow pulses for its receive clock in modes 1 and 3. RCLK = 0 causes Timer 1 overflow to be used for the receive clock. | | TCLK | T2CON.4 | Transmit clock flag. When set, causes the serial port to use Timer 2 overflow pulses for its transmit clock in modes 1 and 3. TCLK = 0 causes Timer 1 overflows to be used for the transmit clock. | | EXEN2 | T2CON.3 | Timer 2 external enable flag. When set, allows capture or reload to occur as a result of a negative transition on T2EX if Timer 2 is not being used to clock the serial port. EXEN2 = 0 causes Timer 2 to ignore events at T2EX. | | TR2 | T2CON.2 | Start/stop control for Timer 2. A logic 1 starts the timer. | | C/T2 | T2CON.1 | Timer or counter select. (Timer 2) 0 = Internal timer (OSC/12) 1 = External event counter (falling edge triggered). | | CP/RL2 | T2CON.0 | Capture/Reload flag. When set, captures will occur on negative transitions at T2EX if EXEN 2 = 1. When cleared, auto reloads will occur either with Timer 2 overflows or negative transition at T2EX when EXEN2 = 1. When either RCLK = 1 or TCLK = 1, this bit is ignored and the timer is forced to auto-reload on Timer 2 overflow. | #### 80C52 WITH PROTECTED ROM MHS provides a new member in the 80C52 Family named "80C52F" which permits full protection of the internal ROM contents. With a non protected 80C52, it is very easy to read out the contents of the internal 8 K bytes of ROM. Three methods exist, two of them are special test modes and the last one is by means of MOVC instructions. - Test mode "VER": Using this special test mode, the internal ROM contents are output on port P0; the address being applied on ports P2 (AD15...AD8) and P1 (AD7...AD0). - Test mode "TMB": With this second test mode, the contents of the 80C52 internal bus is presented on port P1 during the PH2 clock phases. - Using MOVC instructions: If EA = 0, and following a reset, the 80C52 fetches its instructions from external program memory. It is then possible to write a small program whose purpose is to dump the internal ROM contents by means of MOVC A, @A + DPTR and MOVC A, @A + PC instructions. ## 80C52F WITH PROGRAM PROTECTION FEATURES This new version adds ROM protection features in some strategic points of the 80C52F in order to eliminate the possibility of reading the ROM contents (once the protection has been programmed) by one if the three forementioned methods (VER and TMB test modes, or MOVC instructions). Nevertheless the customer must note the following: - Once the protection has been programmed, the 80C52F program always starts at address 0 in the internal ROM. - The application program must be self contained in the internal 8 K of ROM, otherwise it would be possible to trap the program counter address in the ex- ternal PROM/EPROM (beyond 8 K) and then to dump the internal ROM contents by means of a patch using MOVC instructions. Thus, if an extra EPROM is necessary, it is advised to ensure that it will contain only constants or tables. ### TEST OF THE ON-CHIP PROGRAM MEMORY - Before protection is activated: The 80C52F can be tested as any normal 80C52 (using test equipment or any other methods). - After protection is activated: It is then no longer possible to dump the internal ROM contents. ## HOW TO PROGRAM THE PROTECTION MECHANISM - To burn correctly the fuse a specific configuration of inputs must be settled as below: - RST = ALE = 1 - -P2.7 = 1 Furthermore PSEN signal must be tied at $+9 \text{ V} \pm 5 \%$ level voltage and a pulse must be applied on P2.6 input Port. The timing on P2.6 is shown below: Time Rise and Fall Rise ≤ 100 µs. The electrical schematic shows a typical application to deliver P2.6 signal. #### **ELECTRICAL CHARACTERISTICS** #### **ABSOLUTE MAXIMUM RATINGS\*** #### \* Notice | Ambiant Temperature Under Bias: | | |------------------------------------------|---------------------| | C = commercial | 0°C to 70°C | | I = industrial | 40°C to +85°C | | Storage Temperature | -65°C to + 150°C | | Voltage on Vcc to Vss | 0.5 V to + 7 V | | Voltage on Any Pin to Vss 0. | .5 V to Vcc + 0.5 V | | Power Dissipation | | | ** This value is based on the max | | | temperature and the thermal resistance o | f the package | Stresses at or above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions may affect device reliability. #### **DC CHARACTERISTICS** $T_A = 0^{\circ}C$ to + 70°C; $V_{CC} = 5$ V ± 10 %; $V_{SS} = 0$ V; F = 0 to 20 MHz. $T_A = -40^{\circ}C$ to 85°C; $V_{CC} = 5$ V ± 10 %; $V_{SS} = 0$ V; F = 0 to 16 MHz. | SYMBOL | PARAMETER | MIN | MAX | UNIT | TEST CONDITIONS | |--------|-------------------------------------------------------------------------------|------------------|--------------------------|----------------------|-------------------------------------------------------| | VIL | Input Low Voltage | - 0.5 V | 0.2 VCC<br>- 0.1 | ٧ | | | VIH | Input High Voltage<br>(Except XTAL and RST) | 0.2 VCC<br>+ 0.9 | VCC + 0.5 | ٧ | | | VIH1 | Input High Voltage<br>(RST and XTAL1) | 0.7 VCC | VCC + 0.5 | V | | | VOL | Output Low Voltage<br>(Ports 1, 2, and 3) | | 0.3<br>0.45<br>1.0 | V<br>V<br>V | IOL = 100 μA<br>IOL = 1.6 mA (note 3)<br>IOL = 3.5 mA | | VOL1 | Output Low Voltage<br>(Port 0, ALE, PSEN) | | 0.3<br>0.45<br>1.0 | V<br>V<br>V | IOL = 200 μA<br>IOL = 3.2 mA (note 3)<br>IOL = 7.0 mA | | VOH 1 | Output High Voltage Ports 1, 2, 3 | Vcc - 0.3 | | ٧ | IOH = - 10 μA | | | | V∞ - 0.7 | | V | IOH = - 30 μA | | | | Vcc - 1.5 | | ٧ | IOH = - 60 μA | | VOH1 | Output High Voltage | Vcc - 0.3 | | ٧ | IOH = - 200 μA | | | (Port 0, ALE, PSEN) | Vcc - 0.7 | | ٧ | IOH = - 3.2 mA | | | | Vcc - 1,5 | | ٧ | IOH = - 7.0 mA | | IIL | Logical 0 Input Current (Ports 1, 2, 3) | | C -50<br>I -60 | μА | Vin = 0.45 V | | ILI | input Leakage Current (Port 0, EA) | | ± 10 | μА | 0.45 < Vin < VCC | | ITL. | Logical 1 to 0 Transition Current<br>(Ports 1, 2, 3) | | - 650 | μА | Vin = 2.0 V | | IPD | Power Down Current | | 50 | μA | VCC = 2.0 V to 6 V (note 2) | | RRST | RST Pulldown Resistor | 50 | 150 | kΩ | | | CIO | Capacitance of I/O Buffer | | 10 | рF | f <sub>c</sub> = 1 MHz, T <sub>A</sub> = 25°C | | ICC | Power Supply Current Active Mode 12 MHz 16 MHz 20 MHz Idie Mode 12 MHz 16 MHz | | 22<br>28<br>34<br>7<br>9 | mA<br>mA<br>mA<br>mA | (notes 1, 2) | | | 20 MHz | | 11 | mA | | #### **ABSOLUTE MAXIMUM RATINGS\*** | Ambiant Temperature Under I | Bias : | |-----------------------------|-----------------| | A = Automotive | 40°C to + 125°C | | Storage Temperature | 65°C to + 150°C | | Voltage on Any Pin to Vss | | | Voltage on Vcc to Vss | | | Power Dissipation | 1 W | #### \* Notice Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. #### DC CHARACTERISTICS $T_A = -40^{\circ}$ to 125°C; $V_{CC} = 5 \text{ V} \pm 10 \text{ %}$ ; $V_{SS} = 0 \text{ V}$ ; F = 0 to 12 MHz | SYMBOL | PARAMETER | MIN | MAX | UNIT | TEST CONDITIONS | |--------|----------------------------------------------------------------|------------------|--------------------|-------------|-------------------------------------------------------| | VIL | Input Low Voltage | -0.5 V | 0.2 VCC<br>- 0.1 | ٧ | | | VIH | Input High Voltage (Except XTAL and RST) | 0.2 VCC<br>+ 0.9 | VCC + 0.5 | V | | | VIH1 | Input High Voltage (XTAL1, RST) | 0.7 VCC | VCC+0.5 | ٧ | | | VOL | Output Low Voltage<br>(Ports 1, 2, and3) | | 0.3<br>0.45<br>1.0 | V<br>V<br>V | IOL = 100 μA<br>IOL = 1.6 mA (note 3)<br>IOL = 3.5 mA | | VOL1 | Output Low Voltage<br>(Port 0, ALE, PSEN) | | 0.3<br>0.45<br>1.0 | V<br>V<br>V | IOL = 200 μA<br>IOL = 3.2 mA (note 3)<br>IOL = 7.0 mA | | VOH | Output High Voltage (Ports 1, 2, 3) | Vcc - 0.3 | | V | IOH = - 10 μA | | | | Vcc - 0.7 | | V | $1OH = -30 \mu A$ | | | | Vcc - 1.5 | | V | IOH = - 60 μA | | VOH1 | Output High Voltage | V∞-0.3 | | ٧ | 1OH = - 200 μA | | | (Port 0 in External Bus Mode, ALE, PSEN) | Vcc - 0.7 | | V | IOH = - 3.2 mA | | | | V∞-1,5 | | | 1OH = - 7.0 mA | | IIL | Logical 0 Input Current Ports 1, 2, 3 | | - 75 | μA | Vin = 0.45 V | | ΠL | Logical 1 to 0 Transition Current<br>(Ports 1, 2, 3) | | - 750 | μΑ | Vin = 2.0 V | | ILI | Input Leakage Current (Port 0, EA) | | ± 10 | μА | 0.45 < Vin < VCC | | RRST | RST Pulldown Resistor | 50 | 150 | kΩ | | | CIO | Pin Capacitance | | 10 | pF | Test Freq = 1 MHz,<br>T <sub>A</sub> = 25°C | | IPD | Power Down Current | | 75 | μA | VCC = 2 V to 5.5 V | | ICC | Power supply current<br>Active mode 12 MHz<br>idle mode 12 MHz | | 25<br>10 | mA<br>mA | VCC = 5.5 V<br>VCC = 5.5 V | #### **ABSOLUTE MAXIMUM RATINGS\*** | Ambiant Temperature Under Bias : | |------------------------------------------------| | M =Military 55°C to + 125°C | | Storage Temperature 65°C to + 150°C | | Voltage on Any Pin to Vss 0.5 V to VCC + 0.5 V | | Voltage on Vcc to Vss 0.5 V to 6.5 V | | Power Dissipation | #### \* Notice Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended period may affect device reliability. #### DC CHARACTERISTICS $T_A = -55^{\circ}$ to 125°C; VSS = 0 V; VCC = 5 V ± 10 %; F = 0 to 12 MHz | SYMBOL | PARAMETER | MIN | MAX | UNIT | TEST CONDITIONS | |--------|----------------------------------------------------------------|------------------|-----------------|----------|---------------------------------------------| | VIL | Input Low Voltage | – 0.5 V | 0.2 VCC<br>-0.1 | ٧ | | | VIH | Input High Voltage (Except XTAL1, RST) | 0.2 VCC<br>+ 0.9 | VCC + 0.5 | ٧ | | | VIH1 | Input High Voltage (XTAL1, RST) | 0.7 VCC | VCC + 0.5 | ٧ | | | VOL | Output Low Voltage (Ports 1, 2, 3) | | 0.45 | ٧ | IOL = 1.6 mA (note 3) | | VOL1 | Output Low Voltage (Port 0, ALE, PSEN) | | 0.45 | ٧ | iOL = 3.2 mA (note 3) | | VOH | Output High Voltage (Ports 1, 2, 3) | 2.4 | | ٧ | IOH = - 60 μA | | | | 0.75 VCC | | V | IOH = - 25 μA | | | | 0.9 VCC | | ٧ | IOH = - 10 μA | | VOH1 | Output High Voltage | 2.4 | | ٧ | IOH = - 800 μA | | | (Port 0 in External Bus Mode, ALE, PEN) | 0.75 VCC | | ٧ | IOH = - 300 μA | | | | 0.9 VCC | | ٧ | IOH = - 80 μA | | IIL | Logical 0 Input Current Ports 1, 2, 3 | | - 75 | μА | Vin = 0.45 V | | ITL | Logical 1 to 0 Transition Current<br>(Ports 1, 2, 3) | | - 750 | μА | Vin = 2 V | | ILI | Input Leakage Current (Port 0, EA) | | ± 10 | μA | 0.45 < Vin < VCC | | RRST | RST Pulldown Resistor | 50 | 150 | kΩ | | | CIO | Pin Capacitance | | 10 | pF | Test Freq = 1 MHz,<br>T <sub>A</sub> = 25°C | | IPD | Power Down Current | | 75 | μА | VCC = 2 V to 5.5 V | | ICC | Power supply current<br>Active mode 12 MHz<br>Idle mode 12 MHz | | 25<br>10 | mA<br>mA | VCC = 5.5 V<br>VCC = 5.5 V | #### **ABSOLUTE MAXIMUM RATINGS\*** | Ambiant Temperature Under Bias | : | |----------------------------------------|----------------------| | C = commercial | 0°C to 70°C | | I = industrial | 40°C to +85°C | | Storage Temperature | 65°C to + 150°C | | Voltage on Vcc to Vss | 0.5 V to + 7 V | | Voltage on Any Pin to Vss | 0.5 V to Vcc + 0.5 V | | Power Dissipation | | | ** This value is based on the ma | | | temperature and the thermal resistance | of the package | #### \* Notice Stresses at or above those listed under " Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions may affect device reliability. #### DC CHARACTERISTICS $T_A = -40^{\circ}$ to 85°C; $V_{CC} = 2.7 \text{ V}$ to 5,5 V; VSS = 0 V; F = 0 to 6 MHz | SYMBOL | PARAMETER | MIN | M/ | XX | UNIT | TEST CONDITIONS | |--------|-------------------------------------------------------------|------------------------------|------|------------|------|-----------------------------------------------| | VIL | Input Low Voltage | -0.5 V 0.2 Vcc -0.1 | | 1 | ٧ | | | VIH | Input High Voltage<br>(Except XTALs and RST) | 0.2 V <sub>CC</sub><br>+ 0.9 | Voc- | + 0.5 | ٧ | | | VIH1 | Input High Voltage to RST for Reset | 0.7 Vcc | Vcc- | + 0.5 | ٧ | | | VIH2 | Input High Voltage to XTAL1 | 0.7 V <sub>CC</sub> | Vcc· | + 0.5 | ٧ | | | VPD | Power Down Voltage to Vcc in PD Mode | 2.0 | 6. | 0 | ٧ | | | VOL | Output Low Voltage<br>(Ports 1, 2, and3) | | 0.4 | 45 | V | IOL = 800 μA (note 3) | | VOL1 | Output Low Voltage<br>(Port 0, ALE, PSEN) | | 0.45 | | ٧ | IOL = 1.6 mA (note 3) | | VOH | Output High Voltage Ports 1, 2, 3 | 0.9 V∞ | | | ٧ | IOH = - 10 μA | | VOH1 | Output High Voltage (Port 0 in External Bus Mode), ALE, PEN | 0.9 Vcc | | | V | IOH = - 80 μA | | IIL | Logical 0 Input Current Ports 1, 2, 3 | | C - | -50<br>-60 | μА | Vin = 0.45 V | | ILI | Input Leakage Current | | ±. | 10 | μА | 0.45 < Vin < VCC | | ITL. | Logical 1 to 0 Transition Current<br>(Ports 1, 2, 3) | | -6 | 50 | μA | Vin = 2.0 V | | IPD | Power Down Current | | 50 | | μА | V <sub>CC</sub> = 2.0 V to 5.5 V (note 2) | | RRST | RST Pulldown Resistor | 50 | 15 | 50 | kΩ | | | CIO | Capacitance of I/O Buffer | | 1 | 0 | pF | f <sub>c</sub> = 1 MHz, T <sub>A</sub> = 25°C | #### MAXIMUM ICC (mA) | | OPERATING (NOTE 2) | | | | IDLE (NOTE 2) | | |----------------|--------------------|----------------|-----------------|------------------|------------------|----------------| | FREQ. VCC | 2.7 V | 4.5 V | 5.5 V | 2.7 V | 4.5 V | 5.5 V | | 1 MHz<br>6 MHz | 1.2 mA<br>5 mA | 2 mA<br>8.5 mA | 2.5 mA<br>11 mA | 600 μA<br>1.6 mA | 1.2 mA<br>3,8 mA | 1.6 mA<br>4 mA | Figure 9 : ICC vs. Frequency. Valid only within frequency specifications of the device under test. Figure 10 : ICC Test Condition, Idle Mode. All other pins are disconnected. Figure 11 : ICC Test Condition, Active Mode. All other pins are disconnected. Figure 13 : ICC Test Condition, Power Down Mode. All other pins are disconnected. Figure 12 : Clock Signal Waveform for ICC Tests in Active and Idle Modes. TCLCH = TCHCL = 5 ns. Note 1: ICC max is given by: Active Mode: ICCMAX = 1,5 x FREQ + 4 Idle Mode: ICCMAX = 0.15 x FREQ + 1 where FREQ is the external oscillator frequency in MHz. ICCMAX is given in mA. See figures 9 through 13 for ICC test conditions. Note 2: ICC is measured with all output pins disconnected; XTAL1 driven with TCLCH, TCHCL = 5 ns, VIL = VSS + .5 V, VIH = VCC - .5 V; XTAL2 N.C.; EA = RST = Port 0 = VCC. ICC would be slightly higher if a crystal oscillator used. Idle ICC is measured with all output pins disconnected; XTAL1 driven with TCLCH, TCHCL = 5 ns, VIL = VSS + #### **EXPLANATION OF THE AC SYMBOL** Each timing symbol has 5 characters. The first character is always a "T" (stands for time). The other characters, depending on their positions, stand for the name of a signal or the logical status of that signal. The following is a list of all the characters and what they stand for. .5 V, VIH = VCC ~ .5 V; XTAL2 N.C; Port 0 = VCC; EA = RST = VSS. Power Down ICC is measured with all output pins disconnected; EA = PORT 0 = VCC; XTAL2 N.C.; RST = VSS. Note 3: Capacitance loading on Ports 0 and 2 may cause spurious noise pulses to be superimposed on the Vols of ALE and Ports 1 and 3. The noise is due to external bus capacitance discharging into the Port 0 and Port 2 pins when these pins make 1 to 0 transitions during bus operations. In the worst cases (capacitive loading 100 pF), the noise pulse on the ALE line may exceed 0.45 V may exceed 0,45 V with maxi VOL peak 0.6 V. A Schmitt Trigger use is not necessary. #### Example: TAVLL = Time for Address Valid to ALE low. TLLPL = Time for ALE low to PSEN low. A: Address. C: Clock. D: Input data. H: Logic level HIGH. I: Instruction (program memory contents). L : Logic level LOW, or ALE. P: PSEN. Q: Output data. R: READ signal. T: Time. V: Valid. W: WRITE signal. X : No longer a valid logic level. Z: Float. #### AC PARAMETERS : $T_A = 0 \text{ to} + 70 \text{ °C}$ ; VSS = 0 V; $VCC = 5 \text{ V} \pm 10 \text{ %}$ ; 0 to 20 MHz $T_A = -40$ to +85 °C; VSS = 0 V; VCC = 5 V $\pm$ 10 %; 0 to 16 MHz $T_A = -55$ to +125 °C; VSS = 0 V; VCC = 5 V $\pm$ 10 %; 0 to 12 MHz (Load Capacitance for PORT0, ALE and PSEN = 100 pf; Load Capacitance for all other outputs = 80 pf. #### EXTERNAL PROGRAM MEMORY CHARACTERISTICS | SYMBOL | PARAMETER | 0 TO 1 | 2 MHz | 16 | MHz | 20 MHz | | |--------|------------------------------|-----------|------------|-----|-----|--------|----------| | SIMBUL | PARAMEIER | MIN | MAX | MIN | MAX | MIN | MAX | | TLHLL | ALE pulse width | 2TCLCL-40 | _ | 110 | | 70 | | | TAVLL | Address Valid to ALE | TCLCL-40 | | 30 | | 25 | | | TLLAX | Address Hold After ALE | TCLCL-30 | | 35 | | 25 | | | TLLIV | ALE to Valid Instr In | | 4TCLCL-100 | | 185 | | 140 | | TLLPL | ALE to PSEN | TCLCL-30 | | 45 | | 30 | <u> </u> | | TPLPH | PSEN Pulse Width | 3TCLCL-45 | | 165 | | 130 | | | TPLIV | PSEN to Valid Instr IN | | 3TCLCL-105 | _ | 125 | | 80 | | TPXIX | input Instr Hold After PSEN | 0 | | 0 | | 0 | | | TPXIZ | Input Instr Float After PSEN | | TCLCL-25 | | 22 | | 10 | | TPXAV | PSEN to Address Valid | TCLCL-8 | | 55 | | 45 | | | TAVIV | Address to Valid Instr In | | 5TCLCL-105 | | 230 | | 180 | | TPLAZ | PSEN Low to Address Float | | 10 | | 10 | | 10 | #### **EXTERNAL PROGRAM MEMORY READ CYCLE** #### **EXTERNAL DATA MEMORY CHARACTERISTICS** | SYMBOL | PARAMETER | 0 TO 1 | 2 MHz | 16 [ | MHz | 20 | ИНz | |--------|-----------------------------|------------|------------|------|-----|-----|-----| | SIMBUL | PARAMETER | MIN | MAX | MIN | MAX | MIN | MAX | | TRLRH | RD Pulse Width | 6TCLCL-100 | | 340 | | 260 | | | TWLWH | WR Pulse Width | 6TCLCL-100 | | 340 | | 260 | | | TRLDV | RD to Valid Data In | | 5TCLCL-165 | | 240 | | 180 | | TRHDX | Data Hold After RD | 0 | | 0 | | 0 | | | TRHDZ | Data Float After RD | | 2TCLCL-60 | | 90 | | 70 | | TLLDV | ALE to Valid Data In | | 8TCLCL-150 | · | 435 | | 360 | | TAVDV | Address to Valid Data In | | 9TCLCL-165 | | 480 | | 400 | | TLLWL | ALE to WR or RD | 3TCLCL-50 | 3TCLCL+50 | 150 | 250 | 125 | 185 | | TAVWL | Address to WR or RD | 4TCLCL-130 | | 180 | | 170 | | | TQVWX | Data Valid to WR Transition | TCLCL-50 | | 15 | | 10 | | | TQVWH | Data Set-Up to WR High | 7TCLCL-150 | | 380 | | 310 | | | TWHQX | Data Hold After WR | TCLCL-50 | | 40 | | 30 | | | TRLAZ | RD Low to Address Float | | 0 | , | 0 | | 0 | | TWHLH | RD or WR High to ALE High | TCLCL-40 | TCLCL+40 | 35 | 90 | 30 | 65 | #### **EXTERNAL DATA MEMORY WRITE CYCLE** #### **EXTERNAL DATA MEMORY READ CYCLE** #### **SERIAL PORT TIMING - SHIFT REGISTER MODE** $T_A = 0 \text{ to} + 70 \text{ °C} ; VSS = 0 \text{ V}; VCC = 5 \text{ V} \pm 10 \text{ %}; 0 \text{ to} 20 \text{ MHz} \\ T_A = -40 \text{ to} + 85 \text{ °C}; VSS = 0 \text{ V}; VCC = 5 \text{ V} \pm 10 \text{ %}; 0 \text{ to} 16 \text{ MHz} \\ T_A = -55 \text{ to} + 125 \text{ °C}; VSS = 0 \text{ V}; VCC = 5 \text{ V} \pm 10 \text{ %}; 0 \text{ to} 12 \text{ MHz} \\ \end{array}$ | SYMBOL | PARAMETER | 0 TO 1 | 16 MHz | | 20 MHz | | | |--------|------------------------------------------|-------------|-------------|------|--------|-----|-----| | SIMBOL | PANAMEIEN | MIN | MAX | MIN | MAX | MIN | MAX | | TXLXL | Serial port clock cycle time | 12TCLCL | | 750_ | | 600 | | | TQVHX | Output data setup to clock rising edge | 10TCLCL-133 | | 563 | | 450 | | | TXHQX | Output data hold after clock rising edge | 2TCLCL-117 | | 63 | | 50 | | | TXHDX | Input data hold after clock rising edge | 0 | | 0 | | 0 | | | TXHDV | Clock rising edge to input data valid | | 10TCLCL-133 | | 563 | | 450 | #### SHIFT REGISTER TIMING WAVEFORMS #### **EXTERNAL CLOCK DRIVE CHARACTERISTICS (XTAL1)** | SYMBOL | PARAMETER | M | IIN | M | 4X | UNIT | |--------|-------------------|----|-----|----|-----|------| | TCLCL | Oscillator Period | 50 | (5) | | | ns | | TCHCX | High Time | 20 | (5) | | | ns | | TCLCX | Low Time | 20 | (5) | | | ns | | TCLCH | Rise Time | | | 20 | (5) | ns | | TCHCL | Fall Time | | | 20 | (5) | ns | (5) AT 20 MHz #### **EXTERNAL CLOCK DRIVE WAVEFORMS** #### **AC TESTING INPUT/OUTPUT WAVEFORMS** AC inputs during testing are driven at $V_{CC} - 0.5$ for a logic "1" and 0.45 V for a logic "0". Timing measurements are made at VIH min for a logic "1" and VIL max for a logic "0". #### **FLOAT WAVEFORMS** For timing purposes as port pin is no longer floating when a 100 mV change from load voltage occurs and begins to float when a 100 mV change from the loaded VOH/VOL level occurs. $IoV/IoH \ge \pm 20$ mA. #### **CLOCK WAVEFORMS** This diagram indicates when signals are clocked internally. The time it takes the signals to propagate to the pins, however, ranges from 25 to 125 ns. This propagation delay is dependent on variables such as temperature and pin loading. Propagation also varies from output to output and component. Typically though ( $T_A = 25^{\circ}C$ fully loaded) RD and WR propagation delays are approximately 50 ns. The other signals are typically 85 ns. Propagation delays are incorporated in the AC specifications. ### **INSTRUCTION OPCODES** #### MHS C51 INSTRUCTION SET DESCRIPTION | ARITHMETIC O | PERATIONS | | | | |-----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MNEMONIC | PENATIONS | DESCRIPTION | BYTE | CYC | | ADD | A, Rn | Add registrer to Accumulator | 1 | 1 | | ADD | A, direct | Add direct bytes to Accumulator | 2 | 1 | | ADD | A, @Ri | Add indirect RAM to Accumulator | 1 | 1 | | ADD | A, #data | Add immediate data ot Accumulator | 2 | 1 | | ADDC | A, Rn | Add register to Accumulator with Carry | 1 | 1 | | ADDC | A, direct | Add direct byte to A with Carry flag | 2 | 1 | | ADDC | A, @Ri | Add indirect RAM to A with Carry flag | 1 | 1 | | ADDC | A, #data | Add immediate data to A with Carry flag | 2 | 1 | | SUBB | A, Rn | Subtract register from A with borrow | 1 | 1 | | SUBB | A, direct | Subtract direct byte from A with Borrow | 2 | 1 | | SUBB | A, @Ri | Subtract indirect RAM from A with Borrow | 1 | 1 | | SUBB | A, data | Subtract immed. data from A with Borrow | 2 | 1 | | INC | Α | Increment Accumulator | 1 | 1 | | INC | Rn | Increment register | 1 | 1 | | INC | direct | Increment direct byte | 2 | 1 | | INC | @Ri | Increment indirect RAM | 1 | 1 | | INC | DPTR | Increment Data Pointer | 1 | 2 | | DEC | Α | Decrement Accumulator | 1 | 1 | | DEC | Rn | Decrement register | 1 | 1 | | DEC | direct | Decrement direct byte | 2 | 1 | | DEC | @Ri | Decrement indirect RAM | 1 | 1 | | MUL | AR | Multiply A & B | 1 | 4 | | DIV | AB | Divide A by B | 1 | 4 | | DA | Α | Decimal Adjust Accumulator | 1 | 1 | | LOGICAL OPE | RATIONS | • | | | | | | | | | | MNEMONIC | | DESTINATION | BYTE | CYC | | MNEMONIC<br>ANL | A, Rn | DESTINATION AND register to Accumulator | BYTE<br>1 | CYC<br>1 | | | A, Rn<br>A, direct | AND register to Accumulator | | | | ANL | | | 1 | 1 | | ANL<br>ANL | A, direct | AND register to Accumulator AND direct byte to Accumulator | 1 2 | 1 | | ANL<br>ANL<br>ANL | A, direct<br>A, @Ri | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator AND immediate data to Accumulator | 1<br>2<br>1 | 1<br>1<br>1 | | ANL<br>ANL<br>ANL<br>ANL | A, direct<br>A, @Ri<br>A, #data | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator | 1<br>2<br>1<br>2 | 1<br>1<br>1<br>1 | | ANL<br>ANL<br>ANL<br>ANL<br>ANL | A, direct<br>A, @Ri<br>A, #data<br>direct, A | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator AND immediate data to Accumulator AND Accumulator to direct byte AND immediate data to direct byte | 1<br>2<br>1<br>2<br>2 | 1<br>1<br>1 | | ANL<br>ANL<br>ANL<br>ANL<br>ANL<br>ANL | A, direct<br>A, @Ri<br>A, #data<br>direct, A<br>direct, #data | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator AND immediate data to Accumulator AND Accumulator to direct byte AND immediate data to direct byte OR register to Accumulator | 1<br>2<br>1<br>2<br>2<br>3<br>1 | 1<br>1<br>1<br>1<br>1<br>2 | | ANL<br>ANL<br>ANL<br>ANL<br>ANL<br>ANL<br>ORL | A, direct<br>A, @Ri<br>A, #data<br>direct, A<br>direct, #data<br>A, Rn | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator AND immediate data to Accumulator AND Accumulator to direct byte AND immediate data to direct byte | 1<br>2<br>1<br>2<br>2<br>2 | 1<br>1<br>1<br>1<br>1<br>2 | | ANL<br>ANL<br>ANL<br>ANL<br>ANL<br>ORL<br>ORL | A, direct<br>A, @Ri<br>A, #data<br>direct, A<br>direct, #data<br>A, Rn<br>A, direct | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator AND immediate data to Accumulator AND Accumulator to direct byte AND immediate data to direct byte OR register to Accumulator OR direct byte to Accumulator OR indirect RAM to Accumulator | 1<br>2<br>1<br>2<br>2<br>2<br>3<br>1<br>2 | 1<br>1<br>1<br>1<br>1<br>2<br>1<br>1 | | ANL ANL ANL ANL ANL ANL ORL ORL ORL | A, direct A, @Ri A, #data direct, A direct, #data A, Rn A, direct A, @Ri | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator AND immediate data to Accumulator AND Accumulator to direct byte AND immediate data to direct byte OR register to Accumulator OR direct byte to Accumulator OR indirect RAM to Accumulator OR immediate data to Accumulator | 1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>1<br>2 | 1<br>1<br>1<br>1<br>1<br>2<br>1 | | ANL ANL ANL ANL ANL ANL ORL ORL ORL ORL | A, direct A, @Ri A, #data direct, A direct, #data A, Rn A, direct A, @Ri A, #data direct A | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator AND immediate data to Accumulator AND Accumulator to direct byte AND immediate data to direct byte OR register to Accumulator OR direct byte to Accumulator OR indirect RAM to Accumulator OR immediate data to Accumulator OR immediate data to Accumulator OR Accumulator to direct byte | 1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>1<br>2<br>1<br>2 | 1<br>1<br>1<br>1<br>2<br>1<br>1<br>1 | | ANL ANL ANL ANL ANL ANL ORL ORL ORL ORL ORL | A, direct A, @Ri A, #data direct, A direct, #data A, Rn A, direct A, @Ri A, #data | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator AND immediate data to Accumulator AND Accumulator to direct byte AND immediate data to direct byte OR register to Accumulator OR direct byte to Accumulator OR indirect RAM to Accumulator OR immediate data to Accumulator OR Accumulator to direct byte OR immediate data to direct byte | 1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>1<br>2<br>1<br>2<br>3 | 1<br>1<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>1<br>1<br>1 | | ANL ANL ANL ANL ANL ORL ORL ORL ORL ORL ORL | A, direct A, @Ri A, #data direct, A direct, #data A, Rn A, direct A, @Ri A, #data direct A direct, #data | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator AND immediate data to Accumulator AND Accumulator to direct byte AND immediate data to direct byte OR register to Accumulator OR direct byte to Accumulator OR indirect RAM to Accumulator OR immediate data to Accumulator OR Accumulator to direct byte OR immediate data to direct byte Exclusive-OR register to Accumulator | 1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>1<br>2<br>2<br>3<br>1 | 1<br>1<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | | ANL ANL ANL ANL ANL ORL ORL ORL ORL ORL ORL ORL XRL | A, direct A, @Ri A, #data direct, A direct, #data A, Rn A, direct A, @Ri A, #data direct A direct, #data A, Rn A, direct A, @Ri A, #data A, Rn A, direct A, Rn A, direct | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator AND immediate data to Accumulator AND Accumulator to direct byte AND immediate data to direct byte OR register to Accumulator OR direct byte to Accumulator OR indirect RAM to Accumulator OR immediate data to Accumulator OR Accumulator to direct byte OR immediate data to direct byte | 1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>2<br>3<br>1<br>2<br>2<br>2<br>3 | 1<br>1<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>1<br>1<br>1 | | ANL ANL ANL ANL ANL ORL ORL ORL ORL ORL ORL XRL XRL | A, direct A, @Ri A, #data direct, A direct, #data A, Rn A, direct A, @Ri A, #data direct A direct, #data | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator AND immediate data to Accumulator AND Accumulator to direct byte AND immediate data to direct byte OR register to Accumulator OR direct byte to Accumulator OR indirect RAM to Accumulator OR immediate data to Accumulator OR Accumulator to direct byte OR immediate data to Accumulator OR Accumulator to direct byte Exclusive-OR register to Accumulator Exclusive-OR direct byte to Accumulator | 1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>1<br>2<br>2<br>3<br>1 | 1<br>1<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>1<br>1<br>2<br>1<br>1 | | ANL ANL ANL ANL ANL ORL ORL ORL ORL ORL ORL XRL XRL XRL | A, direct A, @Ri A, #data direct, A direct, #data A, Rn A, direct A, @Ri A, #data direct A direct A direct, #data A, Rn A, Rn A, Grect A, Rn A, Grect A, @Ri | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator AND immediate data to Accumulator AND Accumulator to direct byte AND immediate data to direct byte OR register to Accumulator OR direct byte to Accumulator OR indirect RAM to Accumulator OR immediate data to Accumulator OR Accumulator to direct byte OR immediate data to direct byte Exclusive-OR register to Accumulator Exclusive-OR direct byte to Accumulator Exclusive-OR immediate data to A Exclusive-OR immediate data to A | 1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>2<br>3<br>1<br>2<br>2<br>1 | 1<br>1<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | | ANL ANL ANL ANL ANL ORL ORL ORL ORL ORL ORL XRL XRL XRL XRL | A, direct A, @Ri A, #data direct, A direct, #data A, Rn A, direct A, @Ri A, #data direct A direct A direct, #data A, Rn A, Rn A, Rn A, Rn A, Grect A, @Ri A, #data direct, #data A, Rn A, direct A, @Ri A, #data direct, A | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator AND immediate data to Accumulator AND Accumulator to direct byte AND immediate data to direct byte OR register to Accumulator OR direct byte to Accumulator OR indirect RAM to Accumulator OR immediate data to Accumulator OR Accumulator to direct byte OR immediate data to direct byte Exclusive-OR register to Accumulator Exclusive-OR direct byte to Accumulator Exclusive-OR immediate data to A Exclusive-OR immediate data to A Exclusive-OR Accumulator to direct byte | 1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>2<br>2<br>3<br>1<br>2<br>2<br>2<br>2 | 1<br>1<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | | ANL ANL ANL ANL ANL ORL ORL ORL ORL ORL XRL XRL XRL XRL XRL | A, direct A, @Ri A, #data direct, A direct, #data A, Rn A, direct A, @Ri A, #data direct A direct A direct, #data A, Rn A, Rn A, Grect A, @Ri A, #data | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator AND immediate data to Accumulator AND Accumulator to direct byte AND immediate data to direct byte OR register to Accumulator OR direct byte to Accumulator OR indirect RAM to Accumulator OR immediate data to Accumulator OR Accumulator to direct byte OR immediate data to direct byte Exclusive-OR register to Accumulator Exclusive-OR direct byte to Accumulator Exclusive-OR immediate data to A Exclusive-OR immediate data to A | 1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>2<br>3<br>1<br>2<br>2<br>3<br>1<br>2<br>2<br>3 | 1<br>1<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | | ANL ANL ANL ANL ANL ORL ORL ORL ORL ORL XRL XRL XRL XRL XRL XRL | A, direct A, @Ri A, #data direct, #data A, Rn A, direct A, @Ri A, #data direct A direct, #data A, Rn A, direct A, @Ri A, #data A, Rn A, direct A, @Ri A, #data direct, #data direct, #data direct, #data | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator AND immediate data to Accumulator AND Accumulator to direct byte AND immediate data to direct byte OR register to Accumulator OR direct byte to Accumulator OR indirect RAM to Accumulator OR immediate data to Accumulator OR Accumulator to direct byte OR immediate data to Accumulator OR Accumulator to Accumulator OR Accumulator to direct byte Exclusive-OR register to Accumulator Exclusive-OR direct byte to Accumulator Exclusive-OR indirect RAM to A Exclusive-OR Accumulator to direct byte Exclusive-OR immediate data to A Exclusive-OR immediate data to direct Clear Accumulator | 1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>2<br>3<br>1<br>2<br>2<br>3<br>3<br>1<br>2<br>2<br>3 | 1<br>1<br>1<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | | ANL ANL ANL ANL ANL ORL ORL ORL ORL XRL XRL XRL XRL XRL XRL XRL XRL XRL CLR | A, direct A, @Ri A, #data direct, A direct, #data A, Rn A, direct A, @Ri A, #data direct A direct, #data A, Rn A, direct A, @Ri A, #data direct, #data A, Rn A, direct A, @Ri A, #data A, Rn A, direct A, @Ri A, #data A, #data A, #data A | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator AND immediate data to Accumulator AND Accumulator to direct byte AND immediate data to direct byte OR register to Accumulator OR direct byte to Accumulator OR indirect RAM to Accumulator OR immediate data to Accumulator OR Accumulator to direct byte OR immediate data to Accumulator OR Accumulator to direct byte Exclusive-OR register to Accumulator Exclusive-OR indirect RAM to A Exclusive-OR indirect RAM to A Exclusive-OR immediate data to A Exclusive-OR immediate data to A Exclusive-OR immediate data to direct byte Exclusive-OR immediate data to direct Clear Accumulator Complement Accumulator | 1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>2<br>3<br>1<br>2<br>2<br>3<br>1<br>2<br>1<br>2 | 1<br>1<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | | ANL ANL ANL ANL ANL ORL ORL ORL ORL XRL XRL XRL XRL XRL XRL XRL CLR CPL | A, direct A, @Ri A, #data direct, A direct, #data A, Rn A, direct A, @Ri A, #data direct A direct, #data A, Rn A, direct A, @Ri A, #data direct, #data A, Rn A, direct A, @Ri A, #data A, & @Ri A, #data A, #data A, #data A | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator AND immediate data to Accumulator AND Accumulator to direct byte AND immediate data to direct byte AND immediate data to direct byte OR register to Accumulator OR direct byte to Accumulator OR indirect RAM to Accumulator OR immediate data to Accumulator OR Accumulator to direct byte OR immediate data to direct byte Exclusive-OR register to Accumulator Exclusive-OR direct byte to Accumulator Exclusive-OR indirect RAM to A Exclusive-OR indirect RAM to A Exclusive-OR Accumulator to direct byte Exclusive-OR immediate data to A Complement Accumulator Complement Accumulator Rotate Accumulator Rotate Accumulator Rotate Accumulator Complement Accumulator | 1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>2<br>3<br>1<br>2<br>2<br>3<br>1<br>2<br>1<br>2 | 1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | | ANL ANL ANL ANL ANL ANL ORL ORL ORL ORL XRL XRL XRL XRL XRL XRL XRL XRL XRL X | A, direct A, @Ri A, #data direct, A direct, #data A, Rn A, direct A, @Ri A, #data direct A direct, #data A, Rn A, direct A, @Ri A, #data direct, #data A, Rn A, direct A, @Ri A, #data direct, A direct, A | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator AND immediate data to Accumulator AND accumulator to direct byte AND immediate data to direct byte AND immediate data to direct byte OR register to Accumulator OR direct byte to Accumulator OR indirect RAM to Accumulator OR immediate data to Accumulator OR Accumulator to direct byte OR immediate data to direct byte Exclusive-OR register to Accumulator Exclusive-OR direct byte to Accumulator Exclusive-OR indirect RAM to A Exclusive-OR immediate data to A Exclusive-OR immediate data to A Exclusive-OR immediate data to direct byte Exclusive-OR immediate data to direct Clear Accumulator Complement Accumulator Rotate Accumulator Rotate Accumulator Left Rotate A Left through the Carry flag | 1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>2<br>3<br>1<br>2<br>1<br>2 | 1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | | ANL ANL ANL ANL ANL ANL ORL ORL ORL ORL ORL XRL XRL XRL XRL XRL XRL XRL XRL XRL X | A, direct A, @Ri A, #data direct, A direct, #data A, Rn A, direct A, @Ri A, #data direct A direct, #data A, Rn A, direct A, @Ri A, #data direct, #data A, en A, direct A, @Ri A, #data direct, A direct, A | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator AND immediate data to Accumulator AND accumulator to direct byte AND immediate data to direct byte AND immediate data to direct byte OR register to Accumulator OR direct byte to Accumulator OR indirect RAM to Accumulator OR immediate data to Accumulator OR Accumulator to direct byte OR immediate data to direct byte Exclusive-OR register to Accumulator Exclusive-OR direct byte to Accumulator Exclusive-OR direct byte to Accumulator Exclusive-OR immediate data to A Exclusive-OR Accumulator to direct byte Exclusive-OR Accumulator to direct byte Exclusive-OR immediate data to direct Clear Accumulator Complement Accumulator Rotate Accumulator Left Rotate A Left through the Carry flag Rotate Accumulator Right | 1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>1<br>2<br>2<br>3<br>1<br>1<br>1<br>1 | 1<br>1<br>1<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | | ANL ANL ANL ANL ANL ORL ORL ORL ORL ORL VRL XRL XRL XRL XRL XRL XRL XRL XRL XRL X | A, direct A, @Ri A, #data direct, A direct, #data A, Rn A, direct A, @Ri A, #data direct A direct, #data A, Rn A, direct A, @Ri A, #data direct, #data A, #data direct, A direct, A direct, A | AND register to Accumulator AND direct byte to Accumulator AND indirect RAM to Accumulator AND immediate data to Accumulator AND accumulator to direct byte AND immediate data to direct byte AND immediate data to direct byte OR register to Accumulator OR direct byte to Accumulator OR indirect RAM to Accumulator OR immediate data to Accumulator OR Accumulator to direct byte OR immediate data to direct byte Exclusive-OR register to Accumulator Exclusive-OR direct byte to Accumulator Exclusive-OR indirect RAM to A Exclusive-OR immediate data to A Exclusive-OR immediate data to A Exclusive-OR immediate data to direct byte Exclusive-OR immediate data to direct Clear Accumulator Complement Accumulator Rotate Accumulator Rotate Accumulator Left Rotate A Left through the Carry flag | 1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>1<br>2<br>2<br>3<br>1<br>2<br>2<br>3<br>1<br>1<br>1<br>1 | 1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | #### 80C32/80C52 | ARITHMETIC TE<br>MNEMONIC | RANSFER | DESCRIPTION | BYTE | CYC | |---------------------------|---------------------|-----------------------------------------------------------------------------|--------|---------------------| | MOV | A, Rn | Move register to Accumulator | 1 | 1 | | MOV | A, direct | Move direct byte to Accumulator | 2 | 1 | | MOV | A, @Ri | Move indirect RAM to Accumulator | 1 | 1 | | MOV | A, #data | Move immediate data to Accumulator | 2 | 1 | | MOV | Rn, A | Move Accumulator to register | 1 | 1 | | MOV | Rn, direct | Move direct byte to register | 2 | 2 | | MOV | Rn, #data | Move immediate data to register | 2 | 1 | | MOV | direct, A | Move Accumulator to direct byte | 2 | 1 | | MOV | direct, Rn | Move register to direct byte | 2 | 2 | | MOV | direct, direct | Move direct byte to direct | 3 | 2 | | MOV | direct, @Ri | Move indirect RAM to direct byte | 2 | 2<br>2<br>2<br>1 | | MOV | direct, #data | Move immediate data to direct byte | 3 | 2 | | MOV | @Ri, A | Move Accumulator to indirect RAM | 1 | 1 | | MOV | @Ri, direct | Move direct byte to indirect RAM | 2 | 2<br>1 | | MOV | @Ri, #data | Move immediate data to indirect RAM | 2<br>3 | 2 | | MOV | DPTR, #data 16 | Load Data Pointer with a 16-bit constant | _ | 2 | | MOVC | A, @A + DPTR | Move Code byte relative to DPTR to A | 1 | 2 | | MOVC | A, @A + PC | Move Code byte relative to PC to A | 1 | 2 | | MOVX<br>MOVX | A, @Ri | Move External RAM (8-bit addr) to A | 1 | 2 | | | A, @DPTR | Move external RAM (16-bit addr) to A | 1 | 2 | | MOVX<br>MOVX | @Ri, A | Move A to External RAM (8-bit addr) | 1 | 2 | | PUSH | @DPTR, A | Move A to External RAM (16-bit addr) | 2 | 2 | | POP | direct<br>direct | Push direct byte onto stack | 2 | 2 | | XCH | | Pop direct byte from stack | 1 | 1 | | XCH | A, Rn<br>A, direct | Exchange register with Accumulator<br>Exchange direct byte with Accumulator | 2 | 1 | | XCH | A, direct<br>A. @Ri | Exchange indirect BAM with A | 1 | 1 | | XCHD | A, @Ri<br>A. @Ri | Exchange low-order nibble ind RAM with A | 1 | 1 | | | | • | ı | • | | MNEMONIC | IABLE MANIPULAT | DESCRIPTION | BYTE | CYC | | CLR | С | Clear Carry flag | 1 | 1 | | CLR | bit | Clear direct bit | 2 | 1 | | SETB | C | Set Carry flag | 1 | 1 | | SETB | bit | Set direct Bit | 2 | 1 | | CPL | С | Complement Carry flag | 1 | 1 | | CPL | bit | Complement direct bit | 2 | 1 | | ANL | C, bit | AND direct bit to Carry flag | 2 | 2 | | ANL | C,/bit | AND complement of direct bit to Carry | 2 | 2 | | ORL | C,bit | OR direct bit to Carry flag | 2 | 2 | | ORL | C,/bit | OR complement of direct bit to Carry | 2 | 2 | | MOV | C,bit | Move direct bit to Carry flag | 2 | 1 | | MOV | bit, C | Move Carry flag to direct bit | 2 | 2 | | PROGRAM AND | MACHINE CONTR | OL | | | | MNEMONIC | | DESCRIPTION | BYTE | CYC | | ACALL | addr 11 | Absolute subroutine Call | 2 | 2 | | LCALL | addr 16 | Long Subroutine Call | 3 | _ | | RET | | Return from subroutine | ĭ | 2 | | RETI | | Return from interrupt | i | 2 | | AJMP | addr 11 | Absolute Jump | 2 | 2 | | LJMP | addr 16 | Long Jump | 3 | 2 | | SJMP | rel | Short Jump (relative addr) | 2 | 2 | | JMP | @A + DPTR | Jump indirect relative to the DPTR | 1 | 2 | | JZ | rel | Jump if Accumulator is Zero | 2 | 2 | | JNZ | rel | Jump if Accumulator is Not Zero | 2 | 2 | | JC | rel | Jump if Carry flag is set | 2 | 2 2 2 2 2 2 2 2 2 2 | | JNC | rel | Jump if No Carry flag | 2 | 2 | | | | | | | | PROGRAM AN | D MACHINE CONTR | IOL (cont.) DESCRIPTION | BYTE | CYC | |------------|-----------------|------------------------------------------|------|-----| | JB | bit, rel | Jump if direct Bit set | 3 | 2 | | JNB | bit, rel | Jump if direct Bit Not sef | 3 | 2 | | JBC | bit, rel | Jump if direct Bit is set & Clear bit | 3 | 2 | | CJNE | A, direct, rel | Compare direct to A & Jump if Not Equal | 3 | 2 | | CJNE | A. #data, ref | Comp. immed. to A & Jump if Not Equal | 3 | 2 | | CJNE | Rn. #data, rel | Comp. immed. to reg & Jump if Not Equal | 3 | 2 | | CJNE | @Ri, #data, rel | Comp. immed. to ind. & jump if Not Equal | 3 | 2 | | DJNZ | Rn. rel | Decrement register & Jump if Not Zero | 2 | 2 | | DJNZ | direct, rel | Decrement direct & Jump if Not Zero | 3 | 2 | | NOP | unou, 101 | No operation | 1 | 1 | #### Notes on data addressing modes: Rn - Working register R0-R7 direct – 128 internal RAM locations, any I/O port, control or status register RBi – Indirect internal RAM location addressed by register R0 or R1 #data - 8-bit constant included in instruction #data 16 - 16-bit constant included as bytes 2 & 3 of instruction bit - 128 software flags, any I/O pin, control or status bit #### Notes on program addressing modes: addr 16 - Destination address for LCALL & LJMP may be anywhere within the 64-k program memory address space Addr 11 — Destination address for ACALL & AJMP will be within the same 2-k page of program memory as the first byte of the following instruction rel - SJMP and all conditional jumps include an 8-bit offset byte. Range is + 127 - 128 bytes relative to the first byte of the following instruction. All mnemonics copyrighted® Intel Corporation 1979 #### INSTRUCTION OPCODES IN HEXADECIMAL ORDER | 00 1 NO | | |---------------------|---------------------| | ו עט ו ושני | ь | | 01 2 AJI | 1 | | 02 3 LJN | | | | | | 03 1 RR<br>04 1 INC | . A | | 05 2 INC | | | 06 1 INC | | | 07 1 INC | | | 08 1 INC | | | 09 1 INC | | | 0A 1 INC | | | 0B 1 INC | | | 0C 1 INC | | | 0D 1 INC | | | 0E 1 INC | - | | 0F 1 INC | | | 10 3 JB | | | | ALL code addr | | | ALLRR code addr | | 13 1 C | A | | 14 1 DE | • • | | 15 2 DE | | | 16 1 DE | | | 17 1 DE | | | 18 1 DE | | | 19 1 DE | | | 1A 1 DE | | | 1B 1 DE | | | 1C 1 DE | - · · · - | | 1D 1 DE | | | 1E 1 DE | | | 1F 1 DE | | | 20 3 JB | bit addr, code addr | | 21 2 AJI | | | 22 1 RE | | | 23 1 RL | ' A | | 24 2 AD | | | 25 2 AD | . , | | 26 1 AD | . , | | 27 1 AD | | | 28 1 AD | | | 29 1 AD | | | 2A 1 AD | - ',' | | 2B 1 AD | | | 2C 1 AD | , | | 2D 1 AD | | | 2E 1 AD | • | | 2F 1 AD | | | 30 3 JN | | | | ALL code addr | | 32 1 RE | | | HEX | NUMB.<br>OF<br>BYTES | MNEM. | OPERANDS | |----------|----------------------|------------|------------------| | 33 | 1 | RLC | Α | | 34 | 2 | ADDC | A, #data | | 35 | 2 | ADDC | A, data addr | | 36 | 1 | ADDC | A, @RD | | 37 | 1 | ADDC | A, @R1 | | 38 | 1 | ADDC | A, R0 | | 39 | 1 | ADDC | A, R1 | | 3A | 1 | ADDC | A, R2 | | 3B | 1 | ADDC | A, R3 | | 3C | 1 | ADDC | A, R4 | | 3D | 1 | ADDC | A, R5 | | 3E | 1 | ADDC | A, R6 | | 3F | 1 | ADDC | A, R7 | | 40 | 2 | JC | code addr | | 41 | 2 | AJMP | code addr | | 42 | 2 | ORL | data addr A | | 43 | 3 | ORL | data addr, #data | | 44 | 2 | ORL | A, #data | | 45 | 2 | ORL | A, data addr | | 46 | 1 | ORL | A, @R0 | | 47 | 1 | ORL | A, @R1 | | 48 | 1 | ORL | A, R0 | | 49 | 1 | ORL | A, R1 | | 4A | 1 | ORL | A, R2 | | 4B | 1 | ORL | A, R3 | | 4C | 1 | ORL | A, R4 | | 4D<br>4E | 1 | ORL<br>ORL | A, R5 | | 4E<br>4F | 1 | ORL | A, R6<br>A, R7 | | 50 | 2 | JNC | code addr | | 50<br>51 | 2 | ACALL | code addr | | 52 | 2 | ANL | data addr, A | | 53 | 3 | ANL | data addr. #data | | 54 | 2 | ANL | A. #data | | 55 | 2 | ANL | A, data addr | | 56 | 1 | ANL | A, @R0 | | 57 | i | ANL | A, @R1 | | 58 | i | ANL | A, R0 | | 59 | i | ANL | A, R1 | | 5A | i | ANL | A, R2 | | 5B | 1 | ANL | A. R3 | | 5C | i | ANL | A, R4 | | 5D | i | ANL | A, R5 | | 5E | 1 | ANL | A, R6 | | 5F | 1 | ANL | A, R7 | | 60 | 2 | JZ | code addr | | 61 | 2 | AJMP | code addr | | 62 | 2 | XRL | data addr A | | 63 | 3 | XRL | data addr, #data | | 64 | 2 | XRL | A, #data | | 65 | 2 | XRL | A, data addr | | CODE | NUMB.<br>OF<br>BYTES | MNEM. | OPERANDS | |------|----------------------|-------|----------------------| | 66 | 1 | XRL | A, @R0 | | 67 | 1 | XRL | A, @R1 | | 68 | 1 | XRL | A, RO | | 69 | 1 | XRL | A, R1 | | 6A | 1 | XRL | A, R2 | | 6B | 1 | XRL | A, R3 | | 6C | 1 | XRL | A, R4 | | 6D | 1 | XRL | A, R5 | | 6E | 1 | XRL | A, R6 | | 6F | 1 | XRL | A, R7 | | 70 | 2 | JNZ | code addr | | 71 | 2 | ACALL | code addr | | 72 | 2 | ORL | C, bit addr | | 73 | 1 | JMP | @A + DPTR | | 74 | 2 | MOV | A, #data | | 75 | 3 | MOV | data addr, #data | | 76 | 2 | MOV | @R0, #data | | 77 | 2 | MOV | @R1, #data | | 78 | 2 | MOV | R0, #data | | 79 | 2 | MOV | R1, #data | | 7A | 2 | MOV | R2, #data | | 7B | 2 | MOV | R3, #data | | 7C | 2 | MOV | R4, #data | | 7D | 2 | MOV | R5, #data | | 7E | 2 | MOV | R6, #data | | 7F | 2 | MOV | R7, #data | | 80 | 2 | SJMP | code addr | | 81 | 2 | AJMP | code addr | | 82 | 2 | anl | C, bit addr | | 83 | 1 | MOVC | A, @A + PC | | 84 | 1 | DIV | AB | | 85 | 3 | MOV | data addr, data addr | | 86 | 2 | MOV | data addr, @R0 | | 87 | 2 | MOV | data addr, @R1 | | 88 | 2 | MOV | data addr, R0 | | 89 | 2 | MOV | data addr, R1 | | 8A | 2 | MOV | data addr, R2 | | 8B | 2 | MOV | data addr, R3 | | 8C | 2 | MOV | data addr, R4 | | BD | 2 | MOV | data addr, R5 | | 8E | 2 | MOV | data addr, R6 | | 8F | 2 | MOV | data addr, R7 | | 90 | 3 | MOV | DPTR, #data | | 91 | 2 | ACALL | code adddr | | 92 | 2 | MOV | bit addr, C | | 93 | 1 | MOVC | A, @A + DPTR | | 94 | 2 | SUBB | A, #data | | 95 | 2 | SUBB | A, data addr | | 96 | 1 | SUBB | A, @R0 | | 97 | 1 | SUBB | A, @R1 | | 98 | 1 | SUBB | A, R0 | | HEX | NUMB.<br>OF<br>BYTES | MNEM. | OPERANDS | |----------|----------------------|--------------|------------------------------------------------| | 99 | 1 | SUBB | A, R1 | | 9A | 1 | SUBB | A, R2 | | 9B | 1 | SUBB | A, R3 | | 9C | 1 | SUBB | A, R4 | | 9D | 1 | SUBB | A, R5 | | 9E | 1 | SUBB | A, R6 | | 9F | 1<br>2 | SUBB<br>ORL | A, R7<br>C, bit addr | | A0<br>A1 | 2 | AJMP | code addr | | A2 | 2 | MOV | C, bit addr | | A3 | 1 | INC | DPTR | | A4 | i | MUL | AB | | A5 | | reserved | , u | | A6 | 2 | MOV | @R0, data addr | | A7 | 2 | MOV | @R1, data addr | | A8 | 2 | MOV | R0, data addr | | A9 | 2 | MOV | R1, data addr | | AA | 2 | MOV | R2, data addr | | AB | 2 | MOV | R3, data addr | | AC | 2 | MOV | R4, data addr | | AD | 2 | MOV | R5, data addr | | AE | 2 | MOV | R6, data addr | | AF | 2 | MOV | R7, data addr | | B0 | 2 | ANL | C, bit addr | | B1 | 2 | ACALL | code addr | | B2 | 2 | CPL | Bit addr | | B3 | 1 | CPL | C | | B4 | 3 | CJNE | A, #data, code addr | | B5 | 3 | CJNE | A, data addr, code addr | | B6 | 3<br>3 | CJNE<br>CJNE | @R0, #data, code addr<br>@R1, #data, code addr | | B7<br>B8 | 3 | CJNE | R0, #data, code addr | | B9 | 3 | CJNE | R1, #data, code addr | | BA | 3 | CJNE | R2, #data, code addr | | BB | 3 | CJNE | R3, #data, code addr | | BC | 3 | CJNE | R5, #data, code addr | | BD | 3 | CJNE | R4, #data, code addr | | BE | 3 | CJNE | R6, #data, code addr | | BF | 3 | CJNE | R7, #data, code addr | | CO | 2 | PUSH | data addr | | C1 | 2 | AJMP | code addr | | C2 | 2 | CLR | bit addr | | C3 | 1 | CLR | С | | C4 | 1 | SWAP | A | | C5 | 2 | XCH | A, data addr | | C6 | 1 | XCH | A, @R0 | | C7 | 1 | XCH | A, @R1 | | C8 | 1 | XCH | A, RO | | C9 | 1 | XCH | A, R1 | | CA | 1 | XCH | A, R2 | | CB | 1 | XCH | A, R3 | | HEX | NUMB.<br>OF<br>BYTES | MNEM. | OPERANDS | |-----|----------------------|-------|----------------------| | CC | 1 | XCH | A, R4 | | CD | 1 | XCH | A, <del>R</del> 5 | | CE | 1 | XCH | A, R6 | | CF | 1 | XCH | A, R7 | | D0 | 2 | POP | data addr | | D1 | 2 | ACALL | code addr | | D2 | 2 | SETB | bit addr | | D3 | 1 | SETB | С | | D4 | 1 | DA | Α | | D5 | 3 | DJNZ | data addr, code addr | | D6 | 1 | XCHD | A, @R0 | | D7 | 1 | XCHD | A, @R1 | | D8 | 2 | DJNZ | R0, code addr | | D9 | 2 | DJNZ | R1, code addr | | DA | 2<br>2<br>2<br>2 | DJNZ | R2, code addr | | DB | 2 | DJNZ | R3, code addr | | DC | 2 | DJNZ | R4, code addr | | DD | 2 | DJNZ | R5, code addr | | DE | 2<br>2 | DJNZ | R6, code addr | | DF | | DJNZ | R7, code addr | | E0 | 1 | MOVX | A, @DPTR | | E1 | 2 | AJMP | code addr | | E2 | 1 | MOVX | A, @R0 | | E3 | 1 | MOVX | A, @R1 | | E4 | 1 | CLR | Α | | E5 | 2 | MOV | A, data addr | F F: Quad Flat Pack V: S Quad Flat Pack (1.4 mm) T: T Quad Flat Pack (1.0 mm)\*\* | HEX<br>CODE | NUMB.<br>OF<br>BYTES | MNEM. | OPERANDS | |-------------|----------------------|--------|--------------| | E6 | 1 | MOV | A, @R0 | | <b>E</b> 7 | 1 | MOV | A, @R1 | | E8 | 1 | MOV | A, R0 | | E9 | 1 | MOV | A, R1 | | EA | 1 | MOV | A, R2 | | EB | 1 | MOV | A, R3 | | EC | 1 | MOV | A, R4 | | ED | 1 | MOV | A, R5 | | EE | 1 | MOV | A, R6 | | EF | 1 | MOV | A, R7 | | F0 | 1 | MOVX | @DPTR, A | | F1 | 2 | ACALL. | code addr | | F2 | 1 | MOVX | @R0, A | | F3 | 1 | MOVX | @R1, A | | F4 | 1 | CPL | Α | | F5 | 2 | MOV | data addr, A | | F6 | 1 | MOV | @R0, A | | F7 | 1 | MOV | @R1, A | | F8 | 1 | MOV | R0, A | | F9 | 1 | MOV | R1, A | | FA | 1 | MOV | R2, A | | FB | 1 | MOV | R3, A | | FC | 1 | MOV | R4, A | | FD | 1 | MOV | R5, A | | FE | 1 | MOV | R6, A | | FF | 1 | MOV | R7, A | ### **ORDERING INFORMATION** 5-66