# MCS® 51 8-BIT CONTROL-ORIENTED MICROCONTROLLERS Commercial/Express 8031AH/8051AH/8051AHP 8032AH/8052AH 8751H/8751H-8 8751BH/8752BH - High Performance HMOS Process - **Internal Timers/Event Counters** - 2-Level Interrupt Priority Structure - 32 I/O Lines (Four 8-Bit Ports) - 64K External Program Memory Space - Security Feature Protects EPROM Parts **Against Software Piracy** - Boolean Processor - Bit-Addressable RAM - Programmable Full Duplex Serial Channel - 111 Instructions (64 Single-Cycle) - 64K External Data Memory Space - Extended Temperature Range (-40°C to +85°C) The MCS® 51 controllers are optimized for control applications. Byte-processing and numerical operations on small data structures are facilitated by a variety of fast addressing modes for accessing the internal RAM. The instruction set provides a convenient menu of 8-bit arithmetic instructions, including multiply and divide instructions. Extensive on-chip support is provided for one-bit variables as a separate data type, allowing direct bit manipulation and testing in control and logic systems that require Boolean processing. The 8751H is an EPROM version of the 8051AH. It has 4 Kbytes of electrically programmable ROM which can be erased with ultraviolet light. It is fully compatible with the 8051AH but incorporates one additional feature: a Program Memory Security bit that can be used to protect the EPROM against unauthorized readout. The 8751H-8 is identical to the 8751H but only operates up to 8 MHz. The 8051AHP is identical to the 8051AH with the exception of the Protection Feature. To incorporate this Protection Feature, program verification has been disabled and external memory accesses have been limited to 4K. The 8052AH is an enhanced version of the 8051AH. It is backwards compatible with the 8051AH and is fabricated with HMOS II technology. The 8052AH enhancements are listed in the table below. Also refer to this table for the ROM, ROMless and EPROM versions of each product. | Device | Internal f | Memory | Timers/ | Interrupts | | |---------|--------------|--------------|----------------|------------|--| | Device | Program | Data | Event Counters | interrupts | | | 8031AH | none | 128 x 8 FIAM | 2 x 16-Bit | 5 | | | 8051AH | 4K x 8 ROM | 128 x 8 RAM | 2 x 16-Bit | 5 | | | 8051AHP | 4K x 8 ROM | 128 x 8 RAM | 2 x 16-Bit | 5 | | | 8751H | 4K x 8 EPROM | 128 x 8 RAM | 2 x 16-Bit | 5 | | | 8751H-8 | 4K x 8 EPROM | 128 x 8 RAM | 2 x 16-Bit | 5 | | | 8751BH | 4K x 8 EPROM | 128 x 8 RAM | 2 x 16-Bit | 5 | | | 8032AH | none | 256 x 8 RAM | 3 x 16-Bit | 6 | | | 8052AH | 8K x 8 ROM | 256 x 8 RAM | 3 x 16-Bit | 6 | | | 8752BH | 8K x 8 EPROM | 256 x 8 RAM | 3 x 16-Bit | 6 | | October 1994 2-21 Figure 1. MCS® 51 Controller Block Diagram # PROCESS INFORMATION The 8031AH/8051AH and 8032AH/8052AH devices are manufactured on P414.1, an HMOS II process. The 8751H/8751H-8 devices are manufactured on P421.X, an HMOS-E process The 8751BH and 8752BH devices are manufactured on P422. Additional process and reliability information is available in Intel's Components Quality and Reliability Handbook, Order No. 210997. #### **PACKAGES** | Part | Prefix | Package Type | $\theta_{ja}$ | $\theta_{ extsf{jc}}$ | |---------|--------|--------------------|---------------|-----------------------| | 8051AH | Р | 40-Pin Plastic DIP | 45°C/W | 16°C/W | | 8031AH | D | 40-Pin CERDIP | 45°C/W | 15°C/W | | 8052AH | N | 44-Pin PLCC | 46°C/W | 16°C/W | | 8032AH | | | | | | 8752BH* | | | | | | 8751H | D | 40-Pin CERDIP | 45°C/W | 15°C/W | | 8751H-8 | | | | | | 8051AHP | P P | 40-Pin Plastic DIP | 45°C/W | 16°C/W | | | D | 40-Pin CERDIP | 45°C/W | 15°C/W | | 8751BH | Р | 40-Pin Plastic DIP | 36°C/W | 12°C/W | | | N | 44-Pin PLCC | 47°C/W | 16°C/W | #### NOTE: All thermal impedance data is approximate for static air conditions at 1W of power dissipation. Values will change depending on operating conditions and application. See the Intel *Packaging Handbook* (Order Number 240800) for a description of Intel's thermal impedance test methodology. Figure 2. MCS® 51 Controller Connections <sup>\*8752</sup>BH is 36°/10° for D, and 38°/22° for N. #### PIN DESCRIPTIONS Vcc: Supply voltage. Ves: Circuit ground. Port 0: Port 0 is an 8-bit open drain bidirectional I/O port. As an output port each pin can sink 8 LS TTL inputs. Port 0 pins that have 1's written to the n 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 and can source and sink 8 LS TTL inputs. Port 0 also receives the code bytes during programming of the EPROM parts, and outputs the code bytes during program verification of the ROM and EPROM parts. External pullups are required during program verification. Port 1: Port 1 is an 8-bit bidirectional I/O port with internal pullups. The Port 1 output buffers can sink/ source 4 LS TTL inputs. 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 pulled low will source current (I<sub>IL</sub> on the data sheet) because of the internal pullups. Port 1 also receives the low-order address bytes during programming of the EPROM parts and during program verification of the ROM and EPROM parts. In the 8032AH, 8052AH and 8752BH Port 1 pins P1.0 and P1.1 also serve the T2 and T2EX functions, respectively. | Port<br>Pin | Alternative Function | |-------------|-------------------------------------| | P1.0 | T2 (Timer/Counter 2 External input) | | P1.1 | T2EX (Timer/Counter 2 | | _ | Capture/Reload Trigge ) | **Port 2:** Port 2 is an 8-bit bidirectional 'O port with internal pullups. The Port 2 output buffers can sink/ source 4 LS TTL inputs. 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 pulled low will source current (I<sub>IL</sub> 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. Port 2 also receives the high-order address bits during programming of the EPROM parts and during program verification of the ROM and EPROM parts. The protection feature of the 8051AHP causes bits P2.4 through P2.7 to be forced to 0, effectively limiting external Data and Code space to 4K each during external accesses. **Port 3:** Port 3 is an 8-bit bidirectional I/O port with internal pullups. The Port 3 output buffers can sink/source 4 LS TTL inputs. 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 pulled low will source current (I<sub>IL</sub> on the data sheet) because of the pullups. Port 3 also serves the functions of various special features of the MCS 51 Family, as listed below: | Port<br>Pin | Alternative 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) | | **RST:** Reset input. A high on this pin for two machine cycles while the oscillator is running resets the device. **ALE/PROG:** Address Latch Enable output pulse for latching the low byte of the address during accesses to external memory. This pin is also the program pulse input (PROG) during programming of the EPROM parts In normal operation ALE is emitted at a constant rate of ½ the oscillator frequency, and may be used for external timing or clocking purposes. Note, however, that one ALE pulse is skipped during each access to external Data Memory. **PSEN**: Program Store Enable is the read strobe to external Program Memory. When the device is executing code from external Program Memory, PSEN is activated twice each machine cycle, except that two PSEN activations are skipped during each access to external Data Memory. **EA/Vpp:** External Access enable EA must be strapped to V<sub>SS</sub> in order to enable any MCS 51 device to fetch code from external Program memory locations starting at 0000H up to FFFFH. EA must be strapped to V<sub>CC</sub> for internal program execution. Note, however, that if the Security Bit in the EPROM devices is programmed, the device will not fetch code from any location in external Program Memory. This pin also receives the programming supply voltage (VPP) during programming of the EPROM parts. Figure 3. Oscillator Connections XTAL1: Input to the inverting oscillator amplifier. XTAL2: Output from the inverting oscillator amplifier. #### OSCILLATOR CHARACTERISTICS XTAL1 and XTAL2 are the input and output, respectively, of an inverting amplifier which can be configured for use as an on-chip oscillator, as shown in Figure 3. Either a quartz crystal or ceramic resonator may be used. More detailed information concerning the use of the on-chip oscillator is available in Application Note AP-155, "Oscillators for Microcontrollers," Order No. 230659. To drive the device from an external clock source, XTAL1 should be grounded, while XTAL2 is driven, as shown in Figure 4. 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 4. External Drive Configuration #### **EXPRESS Version** The Intel EXPRESS system offers enhancements to the operational specifications of the MCS 51 family of microcontrollers. These EXPRESS products are designed to meet the needs of those applications whose operating requirements exceed commercial standards. The EXPRESS program includes the commercial standard temperature range with burn-in, and an extended temperature range with or without burn-in. With the commercial standard temperature range, operational characteristics are guaranteed over the temperature range of 0°C to +70°C. With the extended temperature range option, operational characteristics are guaranteed over a range of -40°C to +85°C. The optional burn-in is dynamic, for a minimum time of 160 hours at 125°C with $V_{CC} = 5.5V \pm 0.25V$ , following guidelines in MIL-STD-883, Method 1015. Package types and EXPRESS versions are identified by a one- or two-letter prefix to the part number. The prefixes are listed in Table 1. For the extended temperature range option, this data sheet specifies the parameters which deviate from their commercial temperature range limits. Table 1. EXPRESS Prefix Identification | Prefix | Package Type | Temperature Range | Burn-In | |--------|--------------|-------------------|---------| | Р | Plastic | Commercial | No | | D | Cerdip | Commercial | No | | N | PLCC | Commercial | No | | TD | Cerdip | Extended | No | | TP | Plastic | Extended | No | | TN | PLCC | Extended | No | | LD | Cerdip | Extended | Yes | | LP | Plastic | Extended | Yes | #### NOTE: Contact distributor or local sales office to match EXPRESS prefix with proper device. # **DESIGN CONSIDERATIONS** - If an 8751BH or 8752BH is replacing an 8751H in a future design, the user should carefully compare both data sheets for DC or AC Characteristic differences. Note that the V<sub>IH</sub> and I<sub>IH</sub> specifications for the EA pin differ significantly between the devices. - Exposure to light when the EPROM device is in operation may cause logic errors. For this reason, it is suggested that an opaque label be placed over the window when the die is exposed to ambient light. The 8051AHP cannot access external Program or Data memory above 4K. This means that the following instructions that use the Data Pointer only read/write data at address locations below 0FFFH: MOVX A,@DPTR MOVX @DPTR, A When the Data Pointer contains an address above the 4K limit, those locations will not be accessed. To access Data Memory above 4K, the MOVX @Ri,A or MOVX A,@Ri instructions must be used. # **ABSOLUTE MAXIMUM RATINGS\*** | Ambient Temperature Under Bias40°C to +85°C | |---------------------------------------------------------| | Storage Temperature65°C to +150°C | | Voltage on EA/V <sub>PP</sub> Pin to V <sub>SS</sub> | | 8751H0.5V to +21.5V | | 8751BH/8752BH +0.5V to +13.0V | | Voltage on Any Other Pin to $V_{SS}$ ~ 0.5V to $\pm 7V$ | | Power Dissipation1.5W | NOTICE: This is a production data sheet. It is valid for the devices indicated in the revision history. The specifications are subject to change without notice. \*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability. # **OPERATING CONDITIONS** | Symbol | Description | Min | Max | Units | |-----------------|---------------------------------------------------------|-----------|--------------|-------| | ТА | Ambient Temperature Under Bias<br>Commercial<br>Express | 0<br>- 40 | + 70<br>+ 85 | ů | | V <sub>CC</sub> | Supply Voltage | 4.5 | 5.5 | V | | Fosc | Oscillator Frequency | 3.5 | 12 | MHz | **DC CHARACTERISTICS** (Over Operating Conditions) All parameter values apply to all devices unless otherwise indicated | Symbol | Parameter | Min | Max | Units | Test Conditions | |------------------|-----------------------------------------------------------------------|------|-----------------------|----------------------------------------------------------|---------------------------------------------------------------------------------------------------| | V <sub>IL</sub> | Input Low Voltage (Except EA Pin of 8751H and 8751H-8) | -0.5 | 0.8 | V | | | V <sub>IL1</sub> | Input Low Voltage to EA Pin of<br>8751H and 8751H-8 | 0 | 0.7 | ٧ | | | V <sub>IH</sub> | Input High Voltage (Except XTAL2, RST) | 2.0 | $V_{CC} + 0.5$ | ٧ | | | V <sub>IH1</sub> | Input High Voltage to XTAL2, RST | 2.5 | V <sub>CC</sub> + 0.5 | V | XTAL1 = V <sub>SS</sub> | | V <sub>IH2</sub> | Input High Voltage to EA pin<br>of 8751BH and 8752BH | 4.5 | 5. <b>5</b> V | | | | V <sub>OL</sub> | Output Low Voltage (Ports 1, 2, 3)* | | 0.45 | V | I <sub>OL</sub> = 1.6 mA | | V <sub>OL1</sub> | Output Low Voltage (Port C. ALE, PSEN)* 8751H, 8751H-8 All Others | | 0.60<br>0.45<br>0.45 | <b>&gt; &gt; &gt; &gt; &gt; &gt; &gt; &gt; &gt; &gt;</b> | $I_{OL} = 3.2 \text{ mA}$<br>$I_{OL} = 2.4 \text{ mA}$<br>$I_{OL} = 3.2 \text{ mA}$ | | V <sub>OH</sub> | Output High Voltage (Ports 1, 2, 3, ALE, PSEN) | 2.4 | | ٧ | $I_{OH} = -80 \mu A$ | | V <sub>OH1</sub> | Output High Voltage (Port () in External Bus Mode) | 2.4 | | V | I <sub>OH</sub> = -400 μA | | l <sub>IL</sub> | Logical 0 Input Current (Ports 1, 2, 3, and RST) | | - 500 | μΑ | $V_{IN} = 0.45V$ | | IIL1 | Logical 0 Input Current (EA)<br>8751H and 8751H-8<br>8751BH<br>8752BH | 10 | - 15<br>- 10<br>0.5 | mA<br>mA<br>mA | V <sub>IN</sub> = 0.45V<br>V <sub>IN</sub> = V <sub>SS</sub><br>V <sub>IN</sub> = V <sub>SS</sub> | # DC CHARACTERISTICS (Over Operating Conditions) All parameter values apply to all devices unless otherwise indicated (Continued) | Symbol | Parameter | Min | Max | Units | Test Conditions | |------------------|------------------------------------------------------------------------------------------------|-----|-------------------|--------------------------|--------------------------------------------------------------------------------------| | IL2 | Logical 0 Input Current (XTAL2) | | -3.2 | mA | V <sub>IN</sub> = 0.45V | | ال | Input Leakage Current (Port 0)<br>8751H and 8751H-8<br>All Others | | ± 100<br>± 10 | μ <b>Α</b><br>μ <b>Α</b> | 0.45 ≤ V <sub>IN</sub> ≤ V <sub>CC</sub><br>0.45 ≤ V <sub>IN</sub> ≤ V <sub>CC</sub> | | t <sub>IH</sub> | Logical 1 Input Current (F.Ā)<br>8751H and 8751H-8<br>8751BH/8752BH | | 500<br>1 | μA<br>mA | V <sub>IN</sub> = 2.4V<br>4.5V < V <sub>IN</sub> < 5.5V | | l <sub>IH1</sub> | Input Current to RST to Activate Reset | | 500 | μА | $V_{IN} < (V_{CC} - 1.5V)$ | | lcc | Power Supply Current:<br>8031AH/8051AH/8051AHP<br>8032AH/8052AH/8751BH/8752BH<br>8751H/8751H-8 | | 125<br>175<br>250 | mA<br>mA<br>mA | All Outputs Disconnected; EA = V <sub>CC</sub> | | C <sub>IO</sub> | Pin Capacitance | | 10 | pF | Test freq = 1 MHz | #### NOTES 2. ALE/PROG refers to a pin on the 87518H. ALE refers to a timing signal that is output on the ALE/PROG pin. 3. Under steady state (non-transient) conditions, IOL must be externally limited as follows: Maximum I<sub>OL</sub> per port pin: 10 m/ Maximum IOL per 8-bit port - Port 0: 26 mA Ports 1, 2, and 3: 15 mA Maximum total I<sub>OL</sub> for all output pins: 71 mA If I<sub>OL</sub> exceeds the test condition, V<sub>OL</sub> may exceed the related specification. Pins are not guaranteed to sink current greater than the listed test conditions. <sup>1.</sup> Capacitive loading on Ports 0 and 2 may cause spurious noise pulses to be superimposed on the V<sub>OL</sub>s of ALE/PROG 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/PROG pin may exceed 0.8V. In such cases it may be desirable to qualify ALE with a Schmitt Trigger, or use an address latch with a Schmitt Trigger STROBE input. # **EXPLANATION OF THE AC SYMBOLS** 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. 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: RD signal T: Time V: Valid W: WR signal X: No longer a valid logic level Z: Float For example, TAVLL = Time from Address Valid to ALE Low. TLLPL = Time from ALE Low to PSEN Low. AC CHARACTERISTICS (Under Operating Conditions; Load Capacitance for Port 0, ALE/PROG, and PSEN = 100 pF; Load Capacitance for All Other Outputs = 80 pF) # **EXTERNAL PROGRAM MEMORY CHARACTERISTICS** | Symbol | Parameter | 12 MHz C | scillator | Variable | Oscillator | Units | |---------|---------------------------------------------------|------------|------------|------------------------|------------------------------|----------| | Symbol | Parameter | Min | Max | Min | Max | Units | | 1/TCLCL | Oscillator Frequency | | | 3.5 | 12.0 | MHz | | TLHLL | ALE Pulse Width | 127 | | 2TCLCL-40 | | ns | | TAVLL | Address Valid to ALE Low | 43 | | TCLCL - 40 | | ns | | TLLAX | Address Hold after ALE Low | 48 | | TCLCL - 35 | | ns | | TLLIV | ALE Low to Valid Instr In<br>8751H<br>All Others | | 183<br>233 | | 4TCLCL150<br>4TCLCL100 | ns<br>ns | | TLLPL | ALE Low to PSEN Low | 58 | | TCLCL - 25 | | ns | | TPLPH | PSEN Pulse Width<br>8751H<br>All Others | 190<br>215 | | 3TCLCL-60<br>3TCLCL-35 | | ns<br>ns | | TPLIV | PSEN Low to Valid Instr Ir<br>8751H<br>All Others | | 100<br>125 | | 3TCLCL - 150<br>3TCLCL - 125 | ns<br>ns | | TPXIX | Input Instr Hold after PSEN | 0 | | 0 | | ns | | TPXIZ | Input Instr Float after PSEN | | 63 | | TCLCL - 20 | ns | | TPXAV | PSEN to Address Valid | 75 | | TCLCL-8 | | ns | | TAVIV | Address to Valid Instr In<br>8751H<br>All Others | | 267<br>302 | | 5TCLCL - 150<br>5TCLCL - 115 | ns<br>ns | | TPLAZ | PSEN Low to Address Float | | 20 | | 20 | ns | | TRLRH | RD Pulse Width | 400 | | 6TCLCL - 100 | | ns | | TWLWH | WR Pulse Width | 400 | , | 6TCLCL - 100 | | ns | | TRLDV | RD Low to Valid Data In | | 252 | | 5TCLCL - 165 | ns | | TRHDX | Data Hold after RD | 0 | | 0 | | ns | | TRHDZ | Data Float after RD | | 97 | | 2TCLCL - 70 | ns | | TLLDV | ALE Low to Valid Data In | | 517 | | 8TCLCL - 150 | ns | | TAVDV | Address to Valid Data In | | 585 | | 9TCLCL - 165 | ns | # **EXTERNAL PROGRAM MEMORY CHARACTERISTICS (Continued)** | Symbol | Parameter | 12 MHz Oscillator | | Variable ( | Units | | |--------|----------------------------------------------------|-------------------|------------|--------------------------|--------------------------|----------| | Symbol | raiametei | Min | Max | Min | Max | Onita | | TLLWL | ALE Low to RD or WR Low | 200 | 300 | 3TCLCL - 50 | 3TCLCL+50 | ns | | TAVWL | Address to RD or WR Low | 203 | | 4TCLCL-130 | | ns | | TQVWX | Data Valid to WR Transition<br>8751H<br>All Others | 13<br>23 | | TCLCL - 70<br>TCLCL - 60 | | ns<br>ns | | TQVWH | Data Valid to WR High | 433 | | 7TCLCL - 150 | · | ns | | TWHQX | Data Hold after WR | 33 | | TCLCL-50 | | ns | | TRLAZ | RD Low to Address Float | | 20 | | 20 | ns | | TWHLH | RD or WR High to ALE ⊣igh<br>8751H<br>All Others | 33<br>43 | 133<br>123 | TCLCL 50<br>TCLCL 40 | TCLCL + 50<br>TCLCL + 40 | ns<br>ns | #### NOTE: <sup>\*</sup>The 8751H-8 is identical to the 8751H but only operates up to 8 MHz. When calculating the AC Characteristics for the 8751H-8, use the 8751H formula for variable oscillators. # EXTERNAL PROGRAM MEMORY READ CYCLE # **EXTERNAL DATA MEMORY READ CYCLE** # **EXTERNAL DATA MEMORY WRITE CYCLE** # SERIAL PORT TIMING-SHIFT REGISTER MODE Test Conditions: Over Operating Conditions; Load Capacitance = 80 pF | Symbol | Parameter | 12 MHz C | scillator | Variable Oscillator | | Units | |--------|---------------------------------------------|----------|-----------|---------------------|---------------|-------| | Symbol | raidilietei | Min | Max | Min | Max | | | TXLXL | Serial Port Clock Cycle Time | 1.0 | | 12TCLCL | | μs | | TQVXH | Output Data Setup to Clock Fising Edge | 700 | | 10TCLCL-133 | | ns | | TXHQX | Output Data Hold after Clock<br>Rising Edge | 50 | | 2TCLCL - 117 | | ns | | TXHDX | Input Data Hold after Clock Rising Edge | 0 | | 0 | | ns | | TXHDV | Clock Rising Edge to Input Data<br>Valid | | 700 | | 10TCLCL - 133 | ns | # SHIFT REGISTER MODE TIMING WAVEFORMS # **EXTERNAL CLOCK DRIVE** | Symbol | Parameter | Min | Max | Units<br>MHz<br>MHz | | |---------|--------------------------------------------------|------------|---------|---------------------|--| | 1/TCLCL | Oscillator Frequency (except 8751H-8)<br>8751H-8 | 3.5<br>3.5 | 12<br>8 | | | | TCHCX | High Time | 20 | | ns | | | TCLCX | Low Time | 20 | | ns | | | TCLCH | Rise Time | | 20 | ns | | | TCHCL | Fall Time | | 20 | ns | | # **EXTERNAL CLOCK DRIVE WAVEFORM** # AC TESTING INPUT, OUTPUT WAVEFORM #### **EPROM CHARACTERISTICS** | Table 3. El | PROM | <b>Programming</b> | Modes | |-------------|------|--------------------|-------| |-------------|------|--------------------|-------| | Mode | RST | PSEN | ALE | EA | P2.7 | P2.6 | P2.5 | P2.4 | |--------------|-----|------|-----|-----|------|------|------|------| | Program | 1 | 0 | 0* | VPP | 1 | 0 | X | X | | Verify | 1 | 0 | 1 | 1 | 0 | 0 | Х | Х | | Security Set | 1 | 0 | 0* | VPP | 1 | 1 | Х | Х | NOTE: "VPP" = $+21V \pm 0.5V$ #### **PROGRAMMING THE 8751H** To be programmed, the part must be running with a 4 to 6 MHz oscillator. (The reason the oscillator needs to be running is that the internal bus is being used to transfer address and program data to appropriate internal registers.) The address of an EPROM location to be programmed is applied to Port 1 and pins P2.0–P2.3 of Port 2, while the code byte to be programmed into that location is applied to Port 0. The other Port 2 pins, and RST, PSEN, and EA/Vpp should be held at the "Program" levels indicated in Table 3. ALE/PROG is **pulsed** low for 50 ms to program the code byte into the addressed EPROM location. The setup is shown in Figure 5 Normally EA/V<sub>PP</sub> is held at a logic high until just before ALE/PROG is to be pulsed. Then EA/V<sub>PP</sub> is raised to +21V, ALE/PROG is pulsed, and then EA/V<sub>PP</sub> is returned to a logic high. Waveforms and detailed timing specifications are shown in later sections of this data sheet. Figure 5. Programming Configuration Note that the EA/VPP pin must not be allowed to go above the maximum specified VPP level of 21.5V for any amount of time. Even a narrow glitch above that voltage level can cause permanent damage to the device. The VPP source should be well regulated and free of glitches. # **Program Verification** If the Security Bit has not been programmed, the onchip Program Memory can be read out for verification purposes, if desired, either during or after the programming operation. The address of the Program Memory location to be read is applied to Port 1 and pins P2.0–P2.3. The other pins should be held at the "Verify" levels indicated in Table 3. The contents of the addressed location will come out on Port 0. External pullups are required on Port 0 for this operation. The setup, which is shown in Figure 6, is the same as for programming the EPROM except that pin P2.7 is held at a logic low, or may be used as an active-low read strobe. Figure 6. Program Verification <sup>&</sup>quot;1" = logic high for that pin <sup>&</sup>quot;0" = logic low for that pin <sup>&</sup>quot;X" = "don't care" <sup>\*</sup>ALE is pulsed low for 50 ms. # **EPROM Security** The security feature consists of a "locking" bit which when programmed denies electrical access by any external means to the on-chip Program Memory. The bit is programmed as shown in Figure 7. The setup and procedure are the same as for normal EPROM programming, except that P2.6 is held at a logic high. Port 0, Port 1 and pins P2.0-P2.3 may be in any state. The other pins should be held at the "Security" levels indicated in Table 3. Once the Security Bit has been programmed, it can be cleared only by full erasure of the Program Memory. While it is programmed, the internal Program Memory can not be read out, the device can not be further programmed, and it can not execute out of external program memory. Erasing the EPROM, thus clearing the Security Bit, restores the device's full functionality. It can then be reprogrammed. #### **Erasure Characteristics** Erasure of the EPROM begins to occur when the device is exposed to light with wavelengths shorter than approximately 4,000 Angstroms. Since sunlight and fluorescent lighting have wavelengths in this range, exposure to these light sources over an extended time (about 1 week in sunlight, or 3 years in room-level fluorescent lighting) could cause inadvertent erasure. If an application subjects the device to this type of exposure, it is suggested that an opaque label be placed over the window. Figure 7. Programming the Security Bit The recommended erasure procedure is exposure to ultraviolet light (at 2537 Angstroms) to an integrated dose of at least 15 W-sec/cm². Exposing the EPROM to an ultraviolet lamp of 12,000 $\mu$ W/cm² rating for 20 to 30 minutes, at a distance of about 1 inch. should be sufficient. Erasure leaves the array in an all 1's state. #### **EPROM PROGRAMMING AND VERIFICATION CHARACTERISTICS** $T_{\Delta} = 21^{\circ}\text{C to } 27^{\circ}\text{C}; \text{ VCC} = 5\text{V } \pm 10\%; \text{ VSS} = 0\text{V}$ | Symbol | Parameter | Min | Max | Units | | |---------------------------|-----------------------------|---------|---------|-------|--| | VPP | Programming Supply Voltage | 20.5 | 21.5 | | | | IPP | Programming Supply Current | | 30 | mA | | | 1/TCLCL | Oscillator Frequency | 4 | 6 | MHz | | | TAVGL | Address Setup to PROG Low | 48TCLCL | | | | | TGHAX | Address Hold after PROG | 48TCLCL | | | | | TDVGL | Data Setup to PROG Low | 48TCLC | | | | | TGHDX | Data Hold after PROG | 48TCLCL | | | | | TEHSH | P2.7 (ENABLE) High to VPP | 48TCLCL | | | | | TSHGL | VPP Setup to PROG Low | 10 | | μs | | | TGHSL VPP Hold after PROG | | 10 | | μs | | | TGLGH PROG Width | | 45 | 55 | ms | | | TAVQV | TAVQV Address to Data Valid | | 48TCLCL | | | | TELQV | ENABLE Low to Data Valid | | 48TCLCL | | | | TEHQZ | Data Float after ENABLE | 0 | 48TCLCL | | | # **EPROM PROGRAMMING AND VERIFICATION WAVEFORMS** # Programming the 8751BH/8752BH To be programmed, the 875XBH must be running with a 4 to 6 MHz oscillator. (The reason the oscillator needs to be running is that the internal bus is being used to transfer address and program data to appropriate internal registers.) The address of an EPROM location to be programmed is applied to Port 1 and pins P2.0 - P2.4 of Port 2, while the code byte to be programmed into that location is applied to Port 0. The other Port 2 and 3 pins, and RST, PSEN, and EA/V<sub>PP</sub> should be held at the "Program" levels indicated in Table 1. ALE/PROG is pulsed low to program the code byte into the addressed EPROM location. The setup is shown in Figure 8. Normally EA/Vpp is held at a logic high until just before ALE/PROG is to be pulsed. Then EA/Vpp is raised to Vpp, ALE/PROG is pulsed low, and then EA/Vpp is returned to a valid high voltage. The voltage on the EA/Vpp pin must be at the valid EA/Vpp high level before a verify is attempted. Waveforms and detailed timing specifications are shown in later sections of this data sheet. Note that the $\overline{EA}/V_{PP}$ pin must not be allowed to go above the maximum specified $V_{PP}$ level for any amount of time. Even a narrow glitch above that voltage level can cause permanent damage to the device. The $V_{PP}$ source should be well regulated and free of glitches. Figure 8. Programming the EPROM Table 4. EPROM Programming Modes for 875XBH | · · · · · · · · · · · · · · · · · · · | | | | | | | | | |-------------------------------------------------|-----|------|--------------|------------------------|------|------|--------|--------| | MODE | RST | PSEN | ALE/<br>PROG | EA/<br>V <sub>PP</sub> | P2.7 | P2.6 | P3.6 | P3.7 | | Program Code Data | 1 | 0 | 0* | V <sub>PP</sub> | 1 | 0 | 1 | 1 | | Verify Code Data | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | | Program Encryption Table<br>Use Addresses 0-1FH | 1 | 0 | 0* | V <sub>PP</sub> | 1 | 0 | 0 | 1 | | Program Lock $x = 1$<br>Bits (LBx) $x = 2$ | 1 | 0 | 0*<br>0* | V <sub>PP</sub> | 1 | 1 1 | 1<br>0 | 1<br>0 | | Read Signature | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | #### NOTES: "1" = Valid high for that pin "0" = Valid low for that pin " $V_{PP}$ " = +12.75V ±0.25V \*ALE/PROG is pulsed low for 100 uS for programming. (Quick-Pulse Programming) # QUICK-PULSE PROGRAMMING ALGORITHM The 875XBH can be programmed using the Quick-Pulse Programming Algorithm for microcontrollers. The features of the new programming method are a lower Vpp (12.75 volts as compared to 21 volts) and a shorter programming pulse. For example, it is possible to program the entire 8 Kbytes of 875XBH EPROM memory in less than 25 seconds with this algorithm! To program the part using the new algorithm, Vpp must be 12.75 ±0.25 Volts. ALE/PROG is pulsed low for 100 µseconds, 25 times as shown in Figure 9. Then, the byte just programmed may be verified. After programming, the entire array should be verified. The Program Lock features are programmed using the same method, but with the setup as shown in Table 4. The only difference in programming Lock features is that the Lock features cannot be directly verified. Instead, verification of programming is by observing that their features are enabled. #### PROGRAM VERIFICATION If the Lock Bits have not been programmed, the onchip Program Memory can be read out for verification purposes, if desired, either during or after the programming operation. The address of the Program Memory location to be read is applied to Port 1 and pins P2.0 - P2.4. The other pins should be held at the "Verify" levels indicated in Table 1. The contents of the addressed location will come out on Port 0. External pullups are required on Port 0 for this operation. (If the Encryption Array in the EPROM has been programmed, the data present at Port 0 will be Code Data XNOR Encryption Data. The user must know the Encryption Array contents to manually "unencrypt" the data during verify.) The setup, which is shown in Figure 10, is the same as for programming the EPROM except that pin P2.7 is held at a logic low, or may be used as an active low read strobe. Figure 9. PROG Waveforms Figure 10. Verifying the EPROM # PROGRAM MEMORY LOCK The two-level Program Lock system consists of 2 Lock bits and a 32-byte Encryption Array which are used to protect the program memory against software piracy. #### **ENCRYPTION ARRAY** Within the EPROM array are 32 bytes of Encryption Array that are initially unprogrammed (all 1s). Every time that a byte is addressed during a verify, 5 address lines are used to select a byte of the Encryption Array. This byte is then exclusive-NORed (XNOR) with the code byte, creating an Encrypted Verify byte. The algorithm, with the array in the unprogrammed state (all 1s), will return the code in its original, unmodified form. It is recommended that whenever the Encryption Array is used, at least one of the Lock Bits be programmed as well. #### LOCK BITS Also included in the EPROM Program Lock scheme are two Lock Bits which function as shown in Table 5. Erasing the EPROM also erases the Encryption Array and the Lock Bits, returning the part to full unlocked functionality. To ensure proper functionality of the cl ip, the internally latched value of the EA pin must agree with its external state. Table 5. Lock Bits and their Features | Lock | Bits | - Logic Enabled | |------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LB1 | LB2 | - Logic Lilabled | | C | υ | Minimum Program Lock features<br>enabled. (Code Verify will still be<br>encrypted by the Encryption<br>Array) | | Р | V | MOVC instructions executed from external program memory are disabled from fetching code bytes from internal memory, EA is sampled and latched on reset, and further programming of the EPROM is disabled | | Р | Р | Same as above, but Verify is also disabled | | J | Р | Reserved for Future Definition | P = Programmed # **READING THE SIGNATURE BYTES** The signature bytes are read by the same procedure as a normal verification of locations 030H and 031H, except that P3.6 and P3.7 need to be pulled to a logic low. The values returned are: (030H) = 89H indicates manufactured by Intel (031H) = 51H indicates 8751BH 52H indicates 8752BH U = Unprogrammed # **ERASURE CHARACTERISTICS** Erasure of the EPROM begins to occur when the 8752BH is exposed to light with wavelengths shorter than approximately 4,000 Angstroms. Since sunlight and fluorescent lighting have wavelengths in this range, exposure to these light sources over an extended time (about 1 week in sunlight, or 3 years in room-level fluorescent lighting) could cause inadvertent erasure. If an application subjects the device to this type of exposure, it is suggested that an opaque label be placed over the window. The recommended erasure procedure is exposure to ultraviolet light (at 2537 Angstroms) to an integrated dose of at lease 15 W-sec/cm. Exposing the EPROM to an ultraviolet lamp of 12,000 $\mu$ W/cm rating for 30 minutes, at a distance of about 1 inch, should be sufficient. Erasure leaves the array in an all 1s state. # **EPROM PROGRAMMING AND VERIFICATION CHARACTERISTICS** $(T_A = 21^{\circ}C \text{ to } 27^{\circ}C, V_{CC} = 5.0V \pm 10\%, V_{SS} = 0V)$ | Symbol | Parameter | Min | Max | Units | | |---------------------------------|-----------------------------------|------------|---------|-------|--| | V <sub>PP</sub> | Programming Supply Voltage | 12.5 | 13.0 | V | | | lpp | Programming Supply Current | | 50 | mA | | | 1/TCLCL | Oscillator Frequency | 4 | 6 | MHz | | | TAVGL | Address Setup to PROG Low | 48TCLCL | | | | | TGHAX | Address Hold After PROG | 48TCLCL | | | | | TDVGL | Data Setup to PROG Low | 48TCLCL | | | | | TGHDX | Data Hold After PROG | 48TCLCL | | | | | TEHSH P2.7 (ENABLE) High to VPP | | 48TCLCL | | | | | TSHGL | V <sub>PP</sub> Setup to PROG Low | 10 | | μS | | | TGHSL | V <sub>PP</sub> Hold After PROG | 10 | | μs | | | TGLGH | PROG Width | 90 | 110 | μs | | | TAVQV | Address to Data Valid | 2, 1,,,,,, | 48TCLCL | · | | | TELQV | ENABLE Low to Data Valid | | 48TCLCL | - | | | TEHQZ | Data Float After ENABLE | 0 | 48TCLCL | | | | TGHGL | PROG High to PROG Low | 10 | | μs | | # **EPROM PROGRAMMING AND VERIFICATION WAVEFORMS** # **DATA SHEET REVISION HISTORY** Datasheets are changed as new device information becomes available. Verify with your local Intel sales office that you have the latest version before finalizing a design or ordering devices. The following differences exist between this datasheet (272318-002) and the previous version (272318-001): 1. Removed QP and QD (commercial with extended burn-in) from Table 1. EXPRESS Prefix Identification. This datasheet (272318-001) replaces the following datasheets: MCS® 51 Controllers (270048-007) 8051AHP (270279-004) 8751BH (270248-005) 8751BH EXPRESS (270708-001) 8752BH (270429-004) 8752BH EXPRESS (270650-002) 2