87C552 Single-chip 8-bit microcontroller with 10-bit A/D, capture/compare timer, high-speed outputs, PWM #### DESCRIPTION The 87C552 Single-Chip 8-Bit Microcontroller is manufactured in an advanced CMOS process and is a derivative of the 80C51 microcontroller family. The 87C552 has the same instruction set as the 80C51. Three versions of the derivative exist: - 83C552—8k bytes mask programmable ROM - 80C552—ROMless version of the 83C552 - 87C552—8k bytes EPROM The 87C552 contains a $8k \times 8$ a volatile $256 \times 8$ read/write data memory, five 8-bit I/O ports, one 8-bit input port, two 16-bit timer/event counters (identical to the timers of the 80C51), an additional 16-bit timer coupled to capture and compare latches, a 15-source, two-priority-level, nested interrupt structure, an 8-input ADC, a dual DAC pulse width modulated interface, two serial interfaces (UART and I<sup>2</sup>C-bus), a "watchdog" timer and on-chip oscillator and timing circuits. For systems that require extra capability, the 87C552 can be expanded using standard TTL compatible memories and logic. In addition, the 87C552 has two software selectable modes of power reduction—idle mode and power-down mode. The idle mode freezes the CPU while allowing the RAM, timers, serial ports, and interrupt system to continue functioning. The power-down mode saves the RAM contents but freezes the oscillator, causing all other chip functions to be inoperative. The device also functions as an arithmetic processor having facilities for both binary and BCD arithmetic plus bit-handling capabilities. The instruction set consists of over 100 instructions: 49 one-byte, 45 two-byte, and 17 three-byte. With a 16MHz (24MHz) crystal, 58% of the instructions are executed in 0.75μs (0.5μs) and 40% in 1.5μs (1μs). Multiply and divide instructions require 3μs (2μs). #### **FEATURES** - 80C51 central processing unit - 8k x 8 EPROM expandable externally to 64k bytes - An additional 16-bit timer/counter coupled to four capture registers and three compare registers - Two standard 16-bit timer/counters - 256 x 8 RAM, expandable externally to 64k bytes - Capable of producing eight synchronized, timed outputs - A 10-bit ADC with eight multiplexed analog inputs - Two 8-bit resolution, pulse width modulation outputs - Five 8-bit I/O ports plus one 8-bit input port shared with analog inputs - I<sup>2</sup>C-bus serial I/O port with byte oriented master and slave functions - Full-duplex UART compatible with the standard 80C51 - On-chip watchdog timer - Three speed ranges: - 16MHz - Extended temperature ranges - OTP package available ### PIN CONFIGURATIONS ## PLASTIC QUAD FLAT PACK PIN FUNCTIONS ### **LOGIC SYMBOL** 87C552 ### **ORDERING INFORMATION** | PART ORD | ILIPS<br>IER NUMBER<br>MARKING | | RICA PHILIPS<br>ER NUMBER | DRAWING | TEMPERATURE °C | FREC | |--------------------------|--------------------------------|--------------|---------------------------|---------|---------------------------------------------------------------------------|----------| | ROMiess | ROM | ROMiess | ROM | NUMBER | AND PACKAGE | MHz | | PCB80C552-5-16WP | PCB83C552-5WP/xxx | S80C552-4A68 | S83C552-4A68 | SOT188 | 0 to +70, Plastic Leaded Chip<br>Carrier | 16 | | PCB80C552-5-16H | PCB83C552-5H/xxx | S80C552-4B | S83C552-4B | SOT318 | Oto :70 Blooks Oved Slat Dark | | | PCF80C552-5-16WP | PCF83C552-5WP/xxx | S80C552-5A68 | S83C552-5A68 | SOT188 | 0 to +70, Plastic Quad Flat Pack -40 to +85, Plastic Leaded Chip Carrier | 16<br>16 | | | | | | | | | | PCF80C552-5-16H | PCF83C552-5H/xxx | S80C552-5B | S83C552-5B | SOT318 | -40 to +85, Plastic Quad Flat<br>Pack | 16 | | PCA80C552-5-16WP | PCA83C552-5WP/xxx | S80C552-6A68 | S83C552-6A68 | SOT188 | -40 to +125, Plastic Leaded Chip<br>Carrier | 16 | | PCA80C552-5-16H | PCA83C552-5H/xxx | S80C552-6B | S83C552-6B | SOT318 | –40 to +125, Plastic Quad Flat<br>Pack | 16 | | PCB80C552-5-24WP | PCB83C552-5WP/xxx | S80C552-AA68 | S83C552-AA68 | SOT188 | 0 to +70, Plastic Leaded Chip<br>Carrier | 24 | | PCB80C552-5-24H | PCB83C552-5H/xxx | S80C552-AB | \$83C552-AB | SOT318 | 0 to +70, Plastic Quad Flat Pack | 24 | | PCF80C552-5-24WP | PCF83C552-5WP/xxx | S80C552-BA68 | S83C552-BA68 | SOT188 | -40 to +85, Plastic Leaded Chip<br>Carrier | 24 | | PCF80C552-5-24H | PCF83C552-5H/xxx | S80C552-BB | S83C552-BB | SOT318 | –40 to +85, Plastic Quad Flat<br>Pack | 24 | | PCB80C552-5-30WP | PCB83C552-5WP/xxx | S80C552-CA68 | S83C552-CA68 | SOT188 | 0 to +70, Plastic Leaded Chip<br>Carrier | 30 | | PCB80C552-5-30H<br>IOTE: | PCB83C552-5H/xxx | S80C552-CB | S83C552-CB | SOT318 | 0 to +70, Plastic Quad Flat Pack | 30 | <sup>1.</sup> xxx denotes the ROM code number. | | | | r | |--------------|---------|-----------------------------------------------------|------| | | DRAWING | TEMPERATURE °C | FREQ | | EPROM | NUMBER | AND PACKAGE | MHz | | S87C552-4A68 | 0398E | 0 to +70, Plastic Leaded Chip<br>Carrier | 16 | | S87C552-4K68 | 1473A | 0 to +70, Ceramic Leaded Chip<br>Carrier w/Window | 16 | | S87C552-4B | SOT318 | 0 to +70, Plastic Quad Flat Pack | 16 | | S87C552-5A68 | 0398E | -40 to +85, Plastic Leaded Chip<br>Carrier | 16 | | S87C552-5K68 | 1473A | -40 to +85, Ceramic Leaded<br>Chip Carrier w/Window | 16 | | S87C552-5B | SOT318 | –40 to +85, Plastic Quad Flat<br>Pack | 16 | | : | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 87C552 ### **BLOCK DIAGRAM** 87C552 ### PIN DESCRIPTION | | PIN | NO. | | | |-----------------|-------------|-----------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MNEMONIC | PLCC | QFP | TYPE | NAME AND FUNCTION | | V <sub>DD</sub> | 2 | 72 | I | Digital Power Supply: +5V power supply pin during normal operation, idle and power-down mode. | | STADC | 3 | 74 | 1 | Start ADC Operation: Input starting analog to digital conversion (ADC operation can also be started by software). | | PWM0 | 4 | 75 | 0 | Pulse Width Modulation: Output 0. | | PWM1 | 5 | 76 | 0 | Pulse Width Modulation: Output 1. | | EW | 6 | 77 | ļ | Enable Watchdog Timer: Enable for T3 watchdog timer and disable power-down mode. | | P0.0-P0.7 | 57-50 | 58-51 | 1/0 | Port 0: Port 0 is an 8-bit open-drain bidirectional I/O port. Port 0 pins that have 1s written to them float and 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 pull-ups when emitting 1s. Port 0 is also used to input the code byte during programming and to output the code byte during verification. | | P1.0-P1.7 | 16-23 | 10-17 | 1/0 | Port 1: 8-bit I/O port. Alternate functions include: | | | 16-21 | 10-15 | 1/0 | (P1.0-P1.5): Quasi-bidirectional port pins. | | | 22-23 | 16-17 | 1/0 | (P1.6, P1.7): Open drain port pins. | | | 16-19 | 10-13 | 1 | CT0I-CT3I (P1.0-P1.3): Capture timer input signals for timer T2. | | | 20 | 14 | ! | T2 (P1.4): T2 event input. | | | 21 | 15 | | RT2 (P1.5): T2 timer reset signal. Rising edge triggered. | | | 22 | 16 | 1/0 | SCL (P1.6): Serial port clock line I <sup>2</sup> C-bus. | | | 23 | 17 | 1/0 | SDA (P1.7): Serial port data line I <sup>2</sup> C-bus. | | | | | | Port 1 is also used to input the lower order address byte during EPROM programming and verification. A0 is on P1.0, etc. | | P2.0-P2.7 | 39-46 | 38-42,<br>45-47 | 1/0 | Port 2: 8-bit quasi-bidirectional I/O port. Alternate function: High-order address byte for external memory (A08-A15). Port 2 is also used to input the upper order address during EPROM programming and verification. A8 is on P2.0, A9 on P2.1, through A12 on P2.4. | | P3.0-P3.7 | 24-31 | 18-20,<br>23-27 | 1/0 | Port 3: 8-bit quasi-bidirectional I/O port. Alternate functions include: | | | 24 | 18 | | RxD(P3.0): Serial input port. | | | 25 | 19 | | TxD (P3.1): Serial output port. | | | 26 | 20 | | INTO (P3.2): External interrupt. | | | 27 | 23 | | INT1 (P3.3): External interrupt. | | | 28 | 24 | i | T0 (P3.4): Timer 0 external input. | | | 29 | 25 | | T1 (P3.5): Timer 1 external input. | | | 30 | 26 | | WR (P3.6): External data memory write strobe. | | | 31 | 27 | | RD (P3.7): External data memory read strobe. | | P4.0-P4.7 | 7-14 | 80, 1-2<br>4-8 | 1/0 | Port 4: 8-bit quasi-bidirectional I/O port. Alternate functions include: | | | 7-12 | 80, 1-2<br>4-6 | 0 | CMSR0-CMSR5 (P4.0-P4.5): Timer T2 compare and set/reset outputs on a match with timer T2. | | | 13, 14 | 7, 8 | 0 | CMT0, CMT1 (P4.6, P4.7): Timer T2 compare and toggle outputs on a match with timer T2. | | P5.0-P5.7 | 68-62,<br>1 | 71-64, | | Port 5: 8-bit input port. ADC0-ADC7 (P5.0-P5.7): Alternate function: Eight input channels to ADC. | | RST | 15 | 9 | 1/0 | Reset: input to reset the 87C552. It also provides a reset pulse as output when timer T3 overflows. | | XTAL1 | 35 | 32 | ı | Crystal Input 1: Input to the inverting amplifier that forms the oscillator, and input to the internal clock generator. Receives the external clock signal when an external oscillator is used. | | XTAL2 | 34 | 31 | 0 | Crystal Input 2: Output of the inverting amplifier that forms the oscillator. Left open-circuit when an external clock is used. | | V <sub>SS</sub> | 36, 37 | 34-36 | ı | Digital ground. | | PSEN | 47 | 48 | 0 | Program Store Enable: Active-low read strobe to external program memory. | **Philips Semiconductors Microcontroller Products** ## Single-chip 8-bit microcontroller 87C552 ### PIN DESCRIPTION (Continued) | | PIN | NO. | Ĭ . | | |---------------------|------|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MNEMONIC | PLCC | QFP | TYPE | NAME AND FUNCTION | | ALE/PROG | 48 | 49 | 0 | Address Latch Enable: Latches the low byte of the address during accesses to external memory. It is activated every six oscillator periods. During an external data memory access, one ALE pulse is skipped. ALE can drive up to eight LS TTL inputs and handles CMOS inputs without an external pull-up. This pin is also the program pulse input (PROG) during EPROM programming. | | EAV <sub>PP</sub> | 49 | 50 | 1 | External Access: When EA is held at TTL level high, the CPU executes out of the internal program ROM provided the program counter is less than 8192. When EA is held at TTL low level, the CPU executes out of external program memory. EA is not allowed to float. This pin also receives the 12.75V programming supply voltage (V <sub>PP</sub> ) during EPROM programming. | | AV <sub>REF</sub> _ | 58 | 59 | l | Analog to Digital Conversion Reference Resistor: Low-end. | | AV <sub>REF+</sub> | 59 | 60 | 1 | Analog to Digital Conversion Reference Resistor: High-end. | | AVSS | 60 | 61 | 1 | Analog Ground | | AV <sub>DD</sub> | 61 | 63 | 1 | Analog Power Supply | #### NOTE: ### **OSCILLATOR CHARACTERISTICS** XTAL1 and XTAL2 are the input and output, respectively, of an inverting amplifier. The pins can be configured for use as an on-chip oscillator, as shown in the logic symbol. To drive the device from an external clock source, XTAL1 should be driven while XTAL2 is left unconnected. There are no requirements on the duty cycle of the external clock signal, because the input to the internal clock circuitry is through a divide-by-two flip-flop. However, minimum and maximum high and low times specified in the data sheet must be observed. #### RESET A reset is accomplished by holding the RST pin high for at least two machine cycles (24 oscillator periods), while the oscillator is running. To insure a good power-on reset, the RST pin must be high long enough to allow the oscillator time to start up (normally a few milliseconds) plus two machine cycles. At power-on, the voltage on V<sub>DD</sub> and RST must come up at the same time for a proper start-up. #### **IDLE MODE** In the idle mode, the CPU puts itself to sleep while all of the on-chip peripherals stay active. The instruction to invoke the idle mode is the last instruction executed in the normal operating mode before the idle mode is activated. The CPU contents, the on-chip RAM, and all of the special function registers remain intact during this mode. The idle mode can be terminated either by any enabled interrupt (at which time the process is picked up at the interrupt service routine and continued), or by a hardware reset which starts the processor in the same manner as a power-on reset. #### **POWER-DOWN MODE** In the power-down mode, the oscillator is stopped and the instruction to invoke power-down is the last instruction executed. Only the contents of the on-chip RAM are preserved. A hardware reset is the only way to terminate the power-down mode. The control bits for the reduced power modes are in the special function register PCON. Table 1 shows the state of the I/O ports during low current operating modes. Table 1. External Pin Status During Idle and Power-Down Modes | MODE | PROGRAM<br>MEMORY | ALE | PSEN | PORT 0 | PORT 1 | PORT 2 | PORT 3 | PORT 4 | PWM0/<br>PWM1 | |------------|-------------------|-----|------|--------|--------|---------|--------|--------|---------------| | ldie | Internal | 1 | 1 | Data | Data | Data | Data | Data | High | | ldie | External | 1 | 1 | Float | Data | Address | Data | Data | High | | Power-down | Internal | - 0 | 0 | Data | Data | Data | Data | Data | High | | Power-down | External | 0 | 0 | Float | Data | Data | Data | Data | High | <sup>1.</sup> To avoid "latch-up" effect at power-on, the voltage on any pin at any time must not be higher or lower than $V_{DD}$ + 0.5V or $V_{SS}$ = 0.5V, respectively. 87C552 Serial Control Register (S1CON) - See Table 2 S1CON (D8H) CR2 ENS1 STA STO SI AA CR1 CR0 Bits CR0, CR1 and CR2 determine the serial clock frequency that is generated in the master mode of operation. Table 2. Serial Clock Rates | | | | BIT FRE | QUENCY (kHz) | AT fosc | | |-----|-----|-----|-------------|--------------|------------------|-------------------------------------| | CR2 | CR1 | CR0 | 6MHz | 12MHz | 16MHz | fosc DIVIDED BY | | 0 | 0 | 0 | 23 | 47 | 62.5 | 256 | | 0 | 0 | 1 | 27 | 54 | 71 | 224 | | 0 | 1 1 | 0 | 31.25 | 62.5 | 83.3 | 192 | | 0 | 1 | 1 | 37 | 75 | 100 | 160 | | . 1 | 0 | 0 | 6.25 | 12.5 | 17 | 960 | | 1 | 0 | 1 1 | 50 | 100 | 133 1 | 120 | | 1 | 1 | 0 | 100 | 200 | 267 <sup>1</sup> | 60 | | 1 | 1 1 | 1 | 0.25 < 62.5 | 0.5 < 62.5 | 0.67 < 56 | 96 × (256 - (reload value Timer 1)) | | | | | 0 to 225 | 0 to 224 | 0 to 223 | Timer 1 in Mode 2. | NOTE: #### ABSOLUTE MAXIMUM RATINGS<sup>1, 2, 3</sup> | PARAMETER | RATING | UNIT | |----------------------------------------------------------------------------------------------|--------------|------| | Storage temperature range | -65 to +150 | °C | | Voltage on EAV <sub>PP</sub> to V <sub>SS</sub> | -0.5 to +13 | V | | Voltage on any other pin to V <sub>SS</sub> | -0.5 to +6.5 | V | | Input, output DC current on any single I/O pin | 5.0 | mA | | Power dissipation (based on package heat transfer limitations, not device power consumption) | 1.0 | w | #### NOTES: 2. This product includes circuitry specifically designed for the protection of its internal devices from the damaging effects of excessive static charge. Nonetheless, it is suggested that conventional precautions be taken to avoid applying greater than the rated maxima. Parameters are valid over operating temperature range unless otherwise specified. All voltages are with respect to V<sub>SS</sub> unless otherwise noted. #### **DEVICE SPECIFICATIONS** | · | SUPPLY V | OLTAGE (V) | FREQUE | NCY (MHz) | | |-----------|----------|------------|--------|-----------|------------------------| | TYPE | MIN | MAX | MIN | MAX | TEMPERATURE RANGE (°C) | | P87C552-4 | 4.5 | 5.5 | 3.5 | 16 | 0 to +70 | | P87C552-5 | 4.5 | 5.5 | 3.5 | 16 | -40 to +85 | <sup>1.</sup> These frequencies exceed the upper limit of 100kHz of the I<sup>2</sup>C-bus specification and cannot be used in an I<sup>2</sup>C-bus application. 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 conditions other than those described in the AC and DC Electrical Characteristics section of this specification is not implied. 87C552 ## DC ELECTRICAL CHARACTERISTICS VSS, AVSS = OV | | | TEST | | IITS | | |--------------------|---------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--------------------------------------------------|-------------------------|------| | SYMBOL | PARAMETER | CONDITIONS | MIN | MAX | UNIT | | מס <sup>ו</sup> | Supply current operating: PCA8XC552-5-16 | See notes 1 and 2<br>f <sub>OSC</sub> = 16MHz | | 40 | mA | | l <sub>'D</sub> | Idle mode:<br>87C552 | See notes 1 and 3<br>f <sub>OSC</sub> = 16MHz | | 7 | mA | | I <sub>PD</sub> | Power-down current: | See notes 1 and 4;<br>2V < V <sub>PD</sub> < V <sub>DD</sub> max | | 50 | | | Inputs | 87C552 | | | 50 | μΑ | | V <sub>IL</sub> | Input low voltage, except EA, P1.6, P1.7 | | -0.5 | 0.2V <sub>DD</sub> -0.1 | V | | V <sub>IL1</sub> | Input low voltage to EA | | -0.5 | 0.2V <sub>DD</sub> -0.3 | l v | | V <sub>IL2</sub> | Input low voltage to P1.6/SCL, P1.7/SDA <sup>5</sup> | | -0.5 | 0.3V <sub>DD</sub> | V | | VIH | Input high voltage, except XTAL1, RST | | 0.2V <sub>DD</sub> +0. | V <sub>DD</sub> +0.5 | ٧ | | V <sub>IH1</sub> | Input high voltage, XTAL1, RST | | 0.7V <sub>DD</sub> | V <sub>DD</sub> +0.5 | V | | V <sub>IH2</sub> | Input high voltage, P1.6/SCL, P1.7/SDA <sup>5</sup> | | 0.7V <sub>DD</sub> | 6.0 | V | | | Logical 0 input current, ports 1, 2, 3, 4, except P1.6, P1.7 | V <sub>IN</sub> = 0.45V | | -50 | μА | | Iτι | Logical 1-to-0 transition current, ports 1, 2, 3, 4, except P1.6, P1.7 | See note 6 | | -650 | μА | | ±l <sub>1</sub> L1 | Input leakage current, port 0, EA, STADC, EW | 0.45V < V <sub>I</sub> < V <sub>DD</sub> | | 10 | μΑ | | ±I <sub>IL2</sub> | Input leakage current, P1.6/SCL, P1.7/SDA | 0V < V <sub>I</sub> < 6V<br>0V < V <sub>DD</sub> < 5.5V | | 10 | μА | | ±I <sub>IL3</sub> | Input leakage current, port 5 | 0.45V < V <sub>1</sub> < V <sub>DD</sub> | | 1 | μА | | Outputs | | | | | | | V <sub>OL</sub> | Output low voltage, ports 1, 2, 3, 4, except P1.6, P1.7 | I <sub>OL</sub> = 1.6mA <sup>7</sup> | | 0.45 | ٧ | | V <sub>OL1</sub> | Output low voltage, port 0, ALE, PSEN, PWM0, PWM1 | I <sub>OL</sub> = 3.2mA <sup>7</sup> | | 0.45 | ٧ | | V <sub>OL2</sub> | Output low voltage, P1.6/SCL, P1.7/SDA | $I_{OL} = 3.0 \text{mA}^7$ | | 0.4 | ٧ | | V <sub>OH</sub> | Output high voltage, ports 1, 2, 3, 4, except P1.6/SCL, P1.7/SDA | -l <sub>OH</sub> = 60µA<br>-l <sub>OH</sub> = 25µA<br>-l <sub>OH</sub> = 10µA | 2.4<br>0.75V <sub>DD</sub><br>0.9V <sub>DD</sub> | | >>> | | V <sub>OH1</sub> | Output high voltage (port 0 in external bus mode, ALE, PSEN, PWM0, PWM1)8 | l <sub>OH</sub> = 400μA<br>l <sub>OH</sub> = 150μ <b>A</b><br>l <sub>OH</sub> = 40μA | 2.4<br>0.75V <sub>DD</sub><br>0.9V <sub>DD</sub> | | V V | | V <sub>OH2</sub> | Output high voltage (RST) | -l <sub>OH</sub> = 400μA<br>-l <sub>OH</sub> = 120μA | 2.4<br>0.8V <sub>DD</sub> | | V | | R <sub>RST</sub> | Internal reset pull-down resistor | | 50 | 150 | kΩ | | Сю | Pin capacitance | Test freq = 1MHz,<br>T <sub>amb</sub> = 25°C | | 10 | ρF | | Analog In | puts | | | | | | AV <sub>DD</sub> | Analog supply voltage:<br>87C552 <sup>9</sup> | AV <sub>DD</sub> = V <sub>DD</sub> ±0.2V | 4.5 | 5.5 | V | | Al <sub>DD</sub> | Analog supply current: operating: | Port 5 = 0 to AV <sub>DD</sub> | | 1.2 | m/ | | Al <sub>ID</sub> | Idle mode:<br>87C552 | | | 50 | μ./ | | AlpD | Power-down mode:<br>87C552 | 2V < AV <sub>PD</sub> < AV <sub>DD</sub> max | | 50 | μ. | 87C552 ### DC ELECTRICAL CHARACTERISTICS (Continued) | | | TEST | LIM | IITS | | |-------------------|--------------------------------------------------------------|------------|-----------------------|-----------------------|--------| | SYMBOL | PARAMETER | CONDITIONS | MIN | MAX | UNIT | | Analog In | puts (Continued) | | | | | | AVIN | Analog input voltage | | AV <sub>SS</sub> -0.2 | AV <sub>DD</sub> +0.2 | ٧ | | AV <sub>REF</sub> | Reference voltage: AV <sub>REF</sub> - AV <sub>REF+</sub> | | AV <sub>SS</sub> 0.2 | AV <sub>DD</sub> +0.2 | V<br>V | | RREF | Resistance between AV <sub>REF+</sub> and AV <sub>REF-</sub> | | 10 | 50 | kΩ | | CIA | Analog input capacitance | | | 15 | pF | | t <sub>ADS</sub> | Sampling time | | | 8t <sub>CY</sub> | μs | | t <sub>ADC</sub> | Conversion time (including sampling time) | | | 50t <sub>CY</sub> | μs | | DLe | Differential non-linearity <sup>10, 11, 12</sup> | | | ±1 | LSB | | الـ | Integral non-linearity <sup>10, 13</sup> | | | ±2 | LSB | | OS, | Offset error <sup>10, 14</sup> | | | ±2 | LSB | | G, | Gain error <sup>10, 15</sup> | | | ±0.4 | % | | A | Absolute voltage error <sup>10, 16</sup> | | | ±3 | LSB | | MCTC | Channel to channel matching | | | ±1 | LSB | | Ct | Crosstalk between inputs of port 517 | 0-100kHz | | -60 | dB | #### **NOTES FOR DC ELECTRICAL CHARACTERISTICS:** - See Figures 10 through 15 for IDD test conditions. - The operating supply current is measured with all output pins disconnected; XTAL1 driven with $t_r = t_f = 10$ ns; $V_{IL} = V_{SS} + 0.5V$ ; $V_{IH} = V_{DD} 0.5V$ ; XTAL2 not connected; EA = RST = Port $0 = EW = V_{DD}$ ; STADC = $V_{SS}$ . - The idle mode supply current is measured with all output pins disconnected; XTAL1 driven with $t_r = t_f = 10$ ns; $V_{IL} = V_{SS} + 0.5V$ ; $V_{IH} = V_{DD} 0.5V$ ; XTAL2 not connected; Port $0 = EW = V_{DD}$ ; EA = RST = STADC = $V_{SS}$ . - The power-down current is measured with all output pins disconnected; XTAL2 not connected; Port 0 = EW = VDD; EA = RST = STADC = XTAL1 = VSS. - 5. The input threshold voltage of P1.6 and P1.7 (SIO1) meets the I<sup>2</sup>C specification, so an input voltage below 1.5V will be recognized as a logic 0 while an input voltage above 3.0V will be recognized as a logic 1. - Pins of ports 1 (except P1.6, P1.7), 2, 3, and 4 source a transition current when they are being externally driven from 1 to 0. The transition current reaches its maximum value when $V_{\text{IN}}$ is approximately 2V. - 7. Capacitive loading on ports 0 and 2 may cause spurious noise to be superimposed on the V<sub>OL</sub>s 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 > 100pF), the noise pulse on the ALE 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. IOL can exceed these conditions provided that no single output sinks more than 5mA and no more than two outputs exceed the test conditions. 8. Capacitive loading on ports 0 and 2 may cause the V<sub>OH</sub> on ALE and PSEN to momentarily fall below the 0.9V<sub>DD</sub> specification when the - address bits are stabilizing. - 9. The following condition must not be exceeded: $V_{DD} 0.2V < AV_{DD} < V_{DD} + 0.2V$ . - 10. Conditions: AV<sub>REF</sub> = 0V; AV<sub>DD</sub> = 5.0V. Measurement by continuous conversion of AV<sub>IN</sub> = -20mV to 5.12V in steps of 0.5mV, derivating parameters from collected conversion results of ADC. AV<sub>REF</sub> (87C552) = 4.977V. ADC is monotonic with no missing codes. 11. The differential non-linearity (DL<sub>e</sub>) is the difference between the actual step width and the ideal step width. (See Figure 1.) - 12. The ADC is monotonic; there are no missing codes. - 13. The integral non-linearity (IL.) is the peak difference between the center of the steps of the actual and the ideal transfer curve after appropriate adjustment of gain and offset error. (See Figure 1.) - 14. The offset error (OSe) is the absolute difference between the straight line which fits the actual transfer curve (after removing gain error), and a straight line which fits the ideal transfer curve. (See Figure 1.) - 15. The gain error (Ge) is the relative difference in percent between the straight line fitting the actual transfer curve (after removing offset error), and the straight line which fits the ideal transfer curve. Gain error is constant at every point on the transfer curve. (See Figure 1.) - The absolute voltage error (A<sub>a</sub>) is the maximum difference between the center of the steps of the actual transfer curve of the non-calibrated ADC and the ideal transfer curve. - 17. This should be considered when both analog and digital signals are simultaneously input to port 5. 87C552 ### AC ELECTRICAL CHARACTERISTICS<sup>1, 2</sup> | | | [ | 12MHz | CLOCK | 16MHz | CLOCK | VARIABLI | ECLOCK | | |---------------------|--------------|-------------------------------------------------------------------|-----------|----------------------|-----------|-----------|-------------------------|-------------------------|------| | SYMBOL | FIGURE | PARAMETER | MIN | MAX | MIN | MAX | MIN | MAX | UNIT | | 1/t <sub>CLCL</sub> | 2 | Oscillator frequency | | | | | 3.5 | 16 | MHz | | LHLL | 2 | ALE pulse width | 127 | | 85 | | 2t <sub>CLCL</sub> -40 | | ns | | AVLL | 2 | Address valid to ALE low | 28 | | 8 | | t <sub>CLCL</sub> -55 | | ns | | LLAX | 2 | Address hold after ALE low | 48 | | 28 | | t <sub>CLCL</sub> -35 | | ns | | LLIV | 2 | ALE low to valid instruction in | | 234 | | 150 | | 4t <sub>CLCL</sub> -100 | ns | | LLPL | 2 | ALE low to PSEN low | 43 | | 23 | | t <sub>CLCL</sub> -40 | | ns | | РГБН | 2 | PSEN pulse width | 205 | | 143 | | 3t <sub>CLCL</sub> -45 | | กร | | t <sub>PLIV</sub> | 2 | PSEN low to valid instruction in | | 145 | | 83 | | 3t <sub>CLCL</sub> -105 | ns | | t <sub>PXIX</sub> | 2 | Input instruction hold after PSEN | 0 | | 0 | | 0 | | ns | | t <sub>PXIZ</sub> | 2 | Input instruction float after PSEN | | 59 | | 38 | | t <sub>CLCL</sub> -25 | ns | | t <sub>aviv</sub> | 2 | Address to valid instruction in | | 312 | | 208 | | 5t <sub>CLCL</sub> -105 | ns | | t <sub>PLAZ</sub> | 2 | PSEN low to address float | | 10 | | 10 | | 10 | ns | | Data Memo | ry | | • | | | • | | · | - | | t <sub>AVLL</sub> | 3, 4 | Address valid to ALE low | 43 | | 23 | | t <sub>CLCL</sub> -40 | | ns | | RLRH | 3 | RD pulse width | 400 | | 275 | | 6t <sub>CLCL</sub> -100 | | ns | | twwH | 3 | WR pulse width | 400 | 1 | 275 | | 6t <sub>CLCL</sub> -100 | | ns | | RLDV | 3 | RD low to valid data in | | 252 | | 148 | | 5t <sub>CLCL</sub> -165 | ns | | чнох | 3 | Data hold after RD | 0 | | 0 | | 0 | | ns | | t <sub>янох</sub> | 3 | Data float after RD | | 97 | | 55 | | 2t <sub>CLCL</sub> -70 | ns | | tudv | 3 | ALE low to valid data in | | 517 | | 350 | | 8t <sub>CLCL</sub> -150 | ns | | t <sub>AVDV</sub> | 3 | Address to valid data in | | 585 | | 398 | | 9t <sub>CLCL</sub> -165 | ns | | LLWL | 3, 4 | ALE low to RD or WR low | 200 | 300 | 138 | 238 | 3t <sub>CLCL</sub> -50 | 3t <sub>CLCL</sub> +50 | ns | | t <sub>avwl</sub> | 3, 4 | Address valid to WR low or RD low | 203 | T | 120 | | 4t <sub>CLCL</sub> -130 | | ns | | <sup>‡</sup> QVWX | 4 | Data valid to WR transition | 23 | T | 3 | | t <sub>CLCL</sub> -60 | | ns | | t <sub>DW</sub> | 4 | Data before WR | 433 | <u> </u> | 288 | <u> </u> | 7t <sub>CLCL</sub> 150 | | ns | | twhox | 4 | Data hold after WR | 33 | | 13 | | t <sub>CLCL</sub> -50 | | ns | | <sup>†</sup> RLAZ | 4 | RD low to address float | | 0 | | 0 | | 0 | ns | | twhLH | 3, 4 | RD or WR high to ALE high | 43 | 123 | 23 | 103 | t <sub>CLCL</sub> -40 | t <sub>CLCL</sub> +40 | ns | | External Ci | ock | <u> </u> | | • | 1 . | • | | | | | <sup>‡</sup> снсх | 5 | High time <sup>3</sup> | 20 | | 20 | | 20 | | ns | | t <sub>CLCX</sub> | 5 | Low time <sup>3</sup> | 20 | | 20 | | 20 | | ns | | ‡CLCH | 5 | Rise time <sup>3</sup> | <b> </b> | 20 | | 20 | | 20 | ns | | tchcl. | 5 | Fall time <sup>3</sup> | | 20 | 1 | 20 | | 20 | ns | | | ng - Shift R | legister Mode <sup>4</sup> (Test Conditions: T <sub>amb</sub> = 0 | 0°C to +7 | 0°C; V <sub>SS</sub> | = 0V; Loa | ad Capaci | atnce = 80pF) | <u> </u> | · | | txLXL | 6 | Serial port clock cycle time | 1.0 | T | 0.75 | T | 12t <sub>CLCL</sub> | | μs | | фухн | 6 | Output data setup to clock rising edge | 700 | | 492 | | 10t <sub>CLCL</sub> -13 | | ns | | t <sub>XHQX</sub> | 6 | Output data hold after clock rising edge | 50 | | 8 | | 2t <sub>CLCL</sub> -117 | | ns | | t <sub>XHDX</sub> | 6 | Input data hold after clock rising edge | 0 | | 0 | 1 | 0 | <b> </b> | ns | | txHDV | 6 | Clock rising edge to input data valid | | 700 | | 492 | | 10t <sub>CLCL</sub> -13 | ns | #### NOTES: - Parameters are valid over operating temperature range unless otherwise specified. Load capacitance for port 0, ALE, and PSEN = 100pF, load capacitance for all other outputs = 80pF. t<sub>CLCL</sub> = 1f<sub>OSC</sub> = one oscillator clock period. t<sub>CLCL</sub> = 83.3ns at f<sub>OSC</sub> = 12MHz. t<sub>CLCL</sub> = 62.5ns at f<sub>OSC</sub> = 16MHz. These values are characterized but not 100% production tested. 87C552 ### AC ELECTRICAL CHARACTERISTICS (Continued) | SYMBOL | PARAMETER | INPUT | OUTPUT | | | |---------------------------|-------------------------------------------|------------------------|------------------------------------------|--|--| | I <sup>2</sup> C Interfac | e (Refer to Figure 9) <sup>5</sup> | | | | | | t <sub>HD</sub> ; STA | START condition hold time | ≥ 14 t <sub>CLCL</sub> | > 4.0µs <sup>1</sup> | | | | t <sub>L</sub> ow | SCL low time | ≥ 16 t <sub>CLCL</sub> | > 4.7μs <sup>1</sup> | | | | <sup>‡</sup> ніGН | SCL high time | ≥ 14 t <sub>CLCL</sub> | > 4.0µs <sup>1</sup> | | | | t <sub>RC</sub> | SCL rise time | ≤ 1μs | _ 2 | | | | t <sub>FC</sub> | SCL fall time | ≤ 0.3μ <b>s</b> | < 0.3μs <sup>3</sup> | | | | t <sub>SU</sub> ; DAT1 | Data set-up time | ≥ 250ns | > 20 t <sub>CLCL</sub> - t <sub>RD</sub> | | | | t <sub>SU</sub> ; DAT2 | SDA set-up time (before rep. START cond.) | ≥ 250ns | > 1µs <sup>1</sup> | | | | t <sub>SU</sub> ; DAT3 | SDA set-up time (before STOP cond.) | ≥ 250ns | > 8 t <sub>CLCL</sub> | | | | t <sub>HD</sub> ; DAT | Data hold time | ≥ 0ns | > 8 t <sub>CLCL</sub> - t <sub>FC</sub> | | | | t <sub>SU</sub> ; STA | Repeated START set-up time | ≥ 14 t <sub>CLCL</sub> | > 4.7µs <sup>1</sup> | | | | t <sub>SU</sub> ; STO | STOP condition set-up time | ≥ 14 t <sub>CLCL</sub> | > 4.0μs <sup>1</sup> | | | | <sup>t</sup> BUF | Bus free time | ≥ 14 t <sub>CLCL</sub> | > 4.7μs <sup>1</sup> | | | | t <sub>RD</sub> | SDA rise time | ≤ tµs | _2 | | | | t <sub>FD</sub> | SDA fall time | ≤ 0.3µs | < 0.3μs <sup>3</sup> | | | At 100 kbit/s. At other bit rates this value is inversely proportional to the bit-rate of 100 kbit/s. Determined by the external bus-line capacitance and the external bus-line pull-resistor, this must be < 1μs.</li> Spikes on the SDA and SCL lines with a duration of less than 3 t<sub>CLCL</sub> will be filtered out. Maximum capacitance on bus-lines SDA and SCL = 400pF. <sup>4.</sup> t<sub>CLCL</sub> = 1/f<sub>OSC</sub> = one oscillator clock period at pin XTAL1. For 62ns (42s) < t<sub>CLCL</sub> < 285ns (16MHz (24Hz) > f<sub>OSC</sub> > 3.5MHz) the Si01 interface meets the l<sup>2</sup>C-bus specification for bit-rates up to 100 kbit/s. 5. These values are guaranteed but not 100% production tested. 87C552 #### **EXPLANATION OF THE AC SYMBOLS** Each timing symbol has five characters. The first character is always 't' (= time). The other characters, depending on their positions, indicate the name of a signal or the logical status of that signal. The designations are: 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 Examples: t<sub>AVLL</sub> = Time for address valid to ALE low. t<sub>LLPL</sub> = Time for ALE low to PSEN low. 87C552 #### NOTES: - 1. Active Mode: - a. The following pins must be forced to VDD: EA, RST, Port 0, and EW. - b. The following pins must be forced to VSS: STADC, AVss, and AVref- - c. Ports 1.6 and 1.7 should be connected to V<sub>DD</sub> through resistors of sufficiently high value such that the sink current into these pins cannot exceed the I<sub>OL1</sub> spec of these pins. - d. The following pins must be disconnected: XTAL2 and all pins not specified above. - 2. Idle Mode: - a. The following pins must be forced to VDD: Port 0 and EW. - b. The following pins must be forced to $V_{SS}$ : RST, STADC, $AV_{ss}$ , $AV_{ref-}$ , and $\overline{EA}$ . - c. Ports 1.6 and 1.7 should be connected to V<sub>DD</sub> through resistors of sufficiently high value such that the sink current into these pins cannot exceed the I<sub>OL1</sub> spec of these pins. These pins must not have logic 0 written to them prior to this measurement. - d. The following pins must be disconnected: XTAL2 and all pins not specified above. - 3. Power Down Mode: - a. The following pins must be forced to VDD: Port 0 and EW. - b. The following pins must be forced to Vss: RST, STADC, XTAL1, AVss., AVref., and EA. - c. Ports 1.6 and 1.7 should be connected to V<sub>DD</sub> through resistors of sufficiently high value such that the sink current into these pins cannot exceed the I<sub>OL1</sub> spec of these pins. These pins must not have logic 0 written to them prior to this measurement. - d. The following pins must be disconnected: XTAL2 and all pins not specified above. ### **EPROM CHARACTERISTICS** The 87C552 is programmed by using a modified Quick-Pulse Programming™ algorithm. It differs from older methods in the value used for V<sub>PP</sub> (programming supply voltage) and in the width and number of the ALE/PROG pulses. The 87C552 contains two signature bytes that can be read and used by an EPROM programming system to identify the device. The signature bytes identify the device as an 87C552 manufactured by Philips. Table 3 shows the logic levels for reading the signature byte, and for programming the program memory, the encryption table, and the lock bits. The circuit configuration and waveforms for quick-pulse programming are shown in Figures 15 and 16. Figure 17 shows the circuit configuration for normal program memory verification. ### **Quick-Pulse Programming** The setup for microcontroller quick-pulse programming is shown in Figure 15. Note that the 87C552 is running with a 4 to 6MHz oscillator. The reason the oscillator needs to be running is that the device is executing internal address and program data transfers. The address of the EPROM location to be programmed is applied to ports 1 and 2, as shown in Figure 15. The code byte to be programmed into that location is applied to port 0. RST, PSEN, and pins of ports 2 and 3 specified in Table 3 are held at the "Program Code Data" levels indicated in Table 3. The ALE/PROG is pulsed low 25 times as shown in Figure 16. To program the encryption table, repeat the 25-pulse programming sequence for addresses 0 through 1FH, using the "Pgm Encryption Table" levels. Do not forget that after the encryption table is programmed, verification cycles will produce only encrypted data. To program the lock bits, repeat the 25-pulse programming sequence using the "Pgm Lock Bit" levels. After one lock bit is programmed, further programming of the code memory and encryption table is disabled. However, the other lock bit can still be programmed. Note that the EA/V<sub>PP</sub> pin must not be allowed to go above the maximum specified V<sub>PP</sub> level for any amount of time. Even a narrow glitch above that voltage can cause permanent damage to the device. The V<sub>PP</sub> source should be well regulated and free of glitches and overshoot. ### **Program Verification** If lock bit 2 has not been programmed, the on-chip program memory can be read out for program verification. The address of the program memory locations to be red is applied to ports 1 and 2 as shown in Figure 17. The other pins are held at the "Verify Code Data" levels indicated in Table 3. The contents of the address location will be emitted on port 0. External pull-ups are required on port 0 for this operation. If the encryption table has been programmed, the data presented at port 0 will be the exclusive NOR of the program byte with one of the encryption bytes. The user will have to know the encryption table contents in order to correctly decode the verification data. The encryption table itself cannot be read out. #### 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 are: (030H) = 15H indicates manufactured by Philips Components (031H) = 94H indicates 87C552 ### **Program/Verify Algorithms** Any algorithm in agreement with the conditions listed in Table 3, and which satisfies the timing specifications, is suitable. ### **Erasure Characteristics** Erasure of the EPROM begins to occur when the chip is exposed to light with wavelengths shorter than approximately 4,000 angstroms. Since sunlight and fluorescent lighting have wavelengths in this range, exposure to the light sources over an extended time (about 1 week in sunlight, or 3 years in room level fluorescent lighting) could cause inadvertent erasure. For this and secondary effects, it is recommended that an opaque label be placed over the window. For elevated temperature or environments where solvents are being used, apply Kapton tape Fluorglas part number 2345-5, or equivalent. The recommended erasure procedure is exposure to ultraviolet light (at 2537 angstroms) to an integrated dose of at least 15W-sec/cm². Exposing the EPROM to an ultraviolet lamp of 12,000µW/cm² rating for 20 to 39 minutes, at a distance of about 1 inch, should be sufficient. Erasure leaves the array in an all 1s state. **Table 3. EPROM Programming Modes** | MODE | RST | PSEN | ALE/PROG | EA/V <sub>PP</sub> | P2.7 | P2.6 | P3.7 | P3.6 | |----------------------|-----|------|----------|--------------------|------|------|------|------| | Read signature | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | | Program code data | 1 | 0 | 0* | Vpp | 1 | 0 | 1 | 1 | | Verify code data | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | | Pgm encryption table | 1 | 0 | 0* | V <sub>PP</sub> | 1 | 0 | 1 | 0 | | Pgm lock bit 1 | 1 | 0 | 0* | V <sub>PP</sub> | 1 | 1 | 1 | 1 | | Pgm lock bit 2 | 1 | 0 | 0* | V <sub>РР</sub> | 1 | 1 | 0 | 0 | #### NOTES: 1. 0 = Valid low for that pin; 1 = valid high for that pin. 2. $V_{PP} = 12.75V \pm 0.25V$ . 3. $V_{DD} = 5V \pm 10\%$ during programming and verification. ALE/PROG receives 25 programming pulses while V<sub>PP</sub> is held at 12.75V. Each programming pulse is low for 100μs (±10μs) and high for a minimum of 10μs. <sup>™</sup>Trademark phrase of Intel Corporation. 87C552 ### **EPROM PROGRAMMING AND VERIFICATION CHARACTERISTICS** $T_{amb} = 21^{\circ}C$ to $+27^{\circ}C$ , $V_{DD} = 5V \pm 10\%$ , $V_{SS} = 0V$ | SYMBOL | PARAMETER | MIN | MAX | UNIT | |---------------------|---------------------------------------|---------------------|---------------------|------| | V <sub>PP</sub> | Programming supply voltage | 12.5 | 13.0 | V | | Ірр | Programming supply current | | 50 | mA | | 1/t <sub>CLCL</sub> | Oscillator frequency | 4 | 6 | MHz | | †AVGL | Address setup to PROG low | 48t <sub>CLCL</sub> | | | | t <sub>GHAX</sub> | Address hold after PROG | 48t <sub>CLCL</sub> | | | | t <sub>DVGL</sub> | Data setup to PROG low | 48t <sub>CLCL</sub> | | | | t <sub>GHDX</sub> | Data hold after PROG | 48t <sub>CLCL</sub> | | | | t <sub>EHSH</sub> | P2.7 (ENABLE) high to V <sub>PP</sub> | 48t <sub>CLCL</sub> | | | | t <sub>SHGL</sub> | V <sub>PP</sub> setup to PROG low | 10 | | μs | | <sup>t</sup> GHSL | V <sub>PP</sub> hold after PROG | 10 | | μs | | <sup>t</sup> GLGH | PROG width | 90 | 110 | μs | | t <sub>AVQV</sub> | Address to data valid | | 48t <sub>CLCL</sub> | | | t <sub>ELQZ</sub> | ENABLE low to data valid | | 48t <sub>CLCL</sub> | | | <sup>†</sup> EHQZ | Data float after ENABLE | 0 | 48t <sub>CLCL</sub> | | | t <sub>GHGL</sub> | PROG high to PROG low | 10 | | μs | Purchase of Philips' I<sup>2</sup>C components conveys a license under the Philips' I<sup>2</sup>C patent to use the components in the I<sup>2</sup>C-system provided the system conforms to the I<sup>2</sup>C specifications defined by Philips.