# 8255A/8255A-5 PROGRAMMABLE PERIPHERAL INTERFACE - MCS-85™ Compatible 8255A-5 - 24 Programmable I/O Pins - **Completely TTL Compatible** - Fully Compatible with Intel Microprocessor Families - Improved Timing Characteristics - Direct Bit Set/Reset Capability Easing Control Application Interface - Reduces System Package Count - Improved DC Driving Capability - Available in EXPRESS - Standard Temperature Range - Extended Temperature Range - 40 Pin DIP Package (See Intel Packaging: Order Number: 240800-001, Package Type P) The Intel 8255A is a general purpose programmable I/O device designed for use with Intel microprocessors. It has 24 I/O pins which may be individually programmed in 2 groups of 12 and used in 3 major modes of operation. In the first mode (MODE 0), each group of 12 I/O pins may be programmed in sets of 4 to be input or output. In MODE 1, the second mode, each group may be programmed to have 8 lines of input or output. Of the remaining 4 pins, 3 are used for handshaking and interrupt control signals. The third mode of operation (MODE 2) is a bidirectional bus mode which uses 8 lines for a bidirectional bus, and 5 lines, borrowing one from the other group, for handshaking. Figure 1. 8255A Block Diagram # 8255A FUNCTIONAL DESCRIPTION ### General The 8255A is a programmable peripheral interface (PPI) device designed for use in Intel microcomputer systems. Its function is that of a general purpose I/O component to interface peripheral equipment to the microcomputer system bus. The functional configuration of the 8255A is programmed by the system software so that normally no external logic is necessary to interface peripheral devices or structures. # **Data Bus Buffer** This 3-state bidirectional 8-bit buffer is used to interface the 8255A to the system data bus. Data is transmitted or received by the buffer upon execution of input or output instructions by the CPU. Control words and status information are also transferred through the data bus buffer. # Read/Write and Control Logic The function of this block is to manage all of the internal and external transfers of both Data and Control or Status words. It accepts inputs from the CPU Address and Control busses and in turn, issues commands to both of the Control Groups. # (CS) Chip Select. A "low" on this input pin enables the communication between the 8255A and the CPU. # (RD) Read. A "low" on this input pin enables the 8255A to send the data or status information to the CPU on the data bus. In essence, it allows the CPU to "read from" the 8255A. # (WR) Write. A "low" on this input pin enables the CPU to write data or control words into the 8255A. # (A<sub>0</sub> and A<sub>1</sub>) Port Select 0 and Port Select 1. These input signals, in conjunction with the RD and WR inputs, control the selection of one of the three ports or the control word registers. They are normally connected to the least significant bits of the address bus (A<sub>0</sub> and A<sub>1</sub>). Figure 3. 8255A Block Diagram Showing Data Bus Buffer and Read/Write Control Logic Functions #### 8255A BASIC OPERATION | A <sub>1</sub> | A <sub>0</sub> | RD | WR | <u>cs</u> | Input Operation (READ) | |----------------|----------------|----|----|-----------|--------------------------| | 0 | 0 | 0 | 1 | 0 | Port A → Data Bus | | 0 | 1 | 0 | 1 | 0 | Port B → Data Bus | | 1 | 0 | 0 | 1 | 0 | Port C → Data Bus | | | | | | | Output Operation (WRITE) | | 0 | 0 | 1 | 0 | 0 | Data Bus → Port A | | 0 | 1 | 1 | 0 | 0 | Data Bus → Port B | | 1 | 0 | - | 0 | 0 | Data Bus → Port C | | 1 | 1 | 1 | .0 | 0 | Data Bus → Control | | | | | | | Disable Function | | Х | Х | Х | Х | 1 | Data Bus → 3-State | | 1 | 1 | 0 | 1 | 0 | Illegal Condition | | Х | Х | 1 | 1 | 0 | Data Bus → 3-State | ### (RESET) Reset. A "high" on this input clears the control register and all ports (A, B, C) are set to the input mode. ### **Group A and Group B Controls** The functional configuration of each port is programmed by the systems software. In essence, the CPU "outputs" a control word to the 8255A. The control word contains information such as "mode", "bit set", "bit reset", etc., that initializes the functional configuration of the 8255A. Each of the Control blocks (Group A and Group B) accepts "commands" from the Read/Write Control Logic, receives "control words" from the internal data bus and issues the proper commands to its associated ports. Control Group A—Port A and Port C upper (C7-C4) Control Group B—Port B and Port C lower (C3-C0) The Control Word Register can **Only** be written into. No Read operation of the Control Word Register is allowed. #### Ports A, B, and C The 8255A contains three 8-bit ports (A, B, and C). All can be configured in a wide variety of functional characteristics by the system software but each has its own special features or "personality" to further enhance the power and flexibility of the 8255A. Port A. One 8-bit data output latch/buffer and one 8-bit data input latch. Port B. One 8-bit data input/output latch/buffer and one 8-bit data input buffer. Port C. One 8-bit data output latch/buffer and one 8-bit data input buffer (no latch for input). This port can be divided into two 4-bit ports under the mode control. Each 4-bit port contains a 4-bit latch and it can be used for the control signal outputs and status signal inputs in conjunction with ports A and B. Figure 4. 8225A Block Diagram Showing Group A and Group B Control Functions | D <sub>7</sub> -D <sub>0</sub> | Data Bus (Bi-Directional) | |--------------------------------|---------------------------| | RESET | Reset Input | | <u>cs</u> | Chip Select | | RD | Read Input | | WR | Write Input | | A0, A1 | Port Address | | PA7-PA0 | Port A (BIT) | | PB7-PB0 | Port B (BIT) | | PC7-PC0 | Port C (BIT) | | V <sub>CC</sub> | + 5 Volts | | GND | 0 Volts | #### 8255A OPERATIONAL DESCRIPTION #### **Mode Selection** There are three basic modes of operation that can be selected by the system software: Mode 0-Basic Input/Output Mode 1-Strobed Input/Output Mode 2-Bi-Directional Bus When the reset input goes "high" all ports will be set to the input mode (i.e., all 24 lines will be in the high impedance state). After the reset is removed the 8255A can remain in the input mode with no additional initialization required. During the execution of the system program any of the other modes may be selected using a single output instruction. This allows a single 8255A to service a variety of peripheral devices with a simple software maintenance routine. The modes for Port A and Port B can be separately defined, while Port C is divided into two portions as required by the Port A and Port B definitions. All of the output registers, including the status flip-flops, will be reset whenever the mode is changed. Modes may be combined so that their functional definition can be "tailored" to almost any I/O structure. For instance; Group B can be programmed in Mode 0 to monitor simple switch closings or display computational results, Group A could be programmed in Mode 1 to monitor a keyboard or tape reader on an interrupt-driven basis. Figure 5. Basic Mode Definitions and Bus Interface Figure 6. Mode Definition Format The mode definitions and possible mode combinations may seem confusing at first but after a cursory review of the complete device operation a simple, logical I/O approach will surface. The design of the 8255A has taken into account things such as efficient PC board layout, control signal definition vs PC layout and complete functional flexibility to support almost any peripheral device with no external logic. Such design represents the maximum use of the available pins. # Single Bit Set/Reset Feature Any of the eight bits of Port C can be Set or Reset using a single OUTput instruction. This feature reduces software requirements in Control-based applications. Figure 7. Bit Set/Reset Format When Port C is being used as status/control for Port A or B, these bits can be set or reset by using the Bit Set/Reset operation just as if they were data output ports. #### **Interrupt Control Functions** When the 8255A is programmed to operate in mode 1 or mode 2, control signals are provided that can be used as interrupt request inputs to the CPU. The interrupt request signals, generated from port C, can be inhibited or enabled by setting or resetting the associated INTE flip-flop, using the bit set/reset function of port C. This function allows the Programmer to disallow or allow a specific I/O device to interrupt the CPU without affecting any other device in the interrupt structure. INTE flip-flop definition: (BIT-SET)—INTE is set—Interrupt enable (BIT-RESET)-INTE is RESET-Interrupt disable #### NOTE: All Mask flip-flops are automatically reset during mode selection and device Reset. #### **Operating Modes** MODE 0 (Basic Input/Output). This functional configuration provides simple input and output operations for each of the three ports. No "handshaking" is required, data is simply written to or read from a specified port. Mode 0 Basic Functional Definitions: - · Two 8-bit ports and two 4-bit ports. - · Any port can be input or output. - · Outputs are latched. - · Inputs are not latched. - 16 different Input/Output configurations are possible in this Mode. #### **MODE 0 (BASIC INPUT)** ### MODE 0 (BASIC OUTPUT) #### **MODE 0 PORT DEFINITION** | - | A B | | 3 | Gro | up A | | Gro | ир В | |----------------|----------------|----------------|----------------|--------|-------------------|----|--------|-------------------| | D <sub>4</sub> | D <sub>3</sub> | D <sub>1</sub> | D <sub>0</sub> | Port A | Port C<br>(Upper) | # | Port B | Port C<br>(Lower) | | 0 | 0 | 0 | 0 | OUTPUT | OUTPUT | 0 | OUTPUT | OUTPUT | | 0 | 0 | 0 | 1 | OUTPUT | OUTPUT | 1 | OUTPUT | INPUT | | 0 | 0 | 1 | 0 | OUTPUT | OUTPUT | 2 | INPUT | OUTPUT | | 0 | 0 | 1 | 1 | OUTPUT | OUTPUT | 3 | INPUT | INPUT | | 0 | 1 | 0 | 0 | OUTPUT | INPUT | 4 | OUTPUT | OUTPUT | | 0 | 1 | 0 | 1 | OUTPUT | INPUT | 5 | OUTPUT | INPUT | | 0 | 1 | 1 | 0 | OUTPUT | INPUT | 6 | INPUT | OUTPUT | | 0 | 1 | 1 | 1 | OUTPUT | INPUT | 7 | INPUT | INPUT | | 1 | 0 | 0 | 0 | INPUT | OUTPUT | 8 | OUTPUT | OUTPUT | | 1 | 0 | 0 | 1 | INPUT | OUTPUT | 9 | OUTPUT | INPUT | | 1 | 0 | 1 | 0 | INPUT | OUTPUT | 10 | INPUT | OUTPUT | | 1 | 0 | 1 | 1 | INPUT | OUTPUT | 11 | INPUT | INPUT | | 1 | 1 | 0 | 0 | INPUT | INPUT | 12 | OUTPUT | OUTPUT | | 1 | 1 | 0 | 1 | INPUT | INPUT | 13 | OUTPUT | INPUT | | 1 | 1 | 1 | 0 | INPUT | INPUT | 14 | INPUT | OUTPUT | | 1 | 1 | 1 | 1 | INPUT | INPUT | 15 | INPUT | INPUT | #### **MODE CONFIGURATIONS** # Operating Modes MODE 1 (Strobed Input/Output). This functional configuration provides a means for transferring I/O data to or from a specified port in conjunction with strobes or "handshaking" signals. In mode 1, port A and port B use the lines on port C to generate or accept these "handshaking" signals. Mode 1 Basic Functional Definitions: - Two Groups (Group A and Group B) - · Each group contains one 8-bit data port and one 4-bit control/data port. - The 8-bit data port can be either input or output. Both inputs and outputs are latched. - . The 4-bit port is used for control and status of the 8-bit data port. # Input Control Signal Definition STB (Strobe Input). A "low" on this input loads data into the input latch. #### IBF (Input Buffer Full F/F) A "high" on this output indicates that the data has been loaded into the input latch; in essence, an acknowledgement. IBF is set by STB input being low and is reset by the rising edge of the RD input. # **INTR** (Interrupt Request) A "high" on this output can be used to interrupt the CPU when an input device is requesting service. INTR is set by the STB is a "one", IBF is a "one" and INTE is a "one". It is reset by the falling edge of RD. This procedure allows an input device to request service from the CPU by simply strobing its data into the port. INTE A Controlled by bit set/reset of PC4. #### INTE B Controlled by bit set/reset of PC2. Figure 8. MODE 1 Input Figure 9. MODE 1 (Strobed Input) # 3 ### **Output Control Signal Definition** OBF (Output Buffer Full F/F). The OBF output will go "low" to indicate that the CPU has written data out to the specified port. The OBF F/F will be set by the rising edge of the WR input and reset by ACK input being low. ACK (Acknowledge Input). A "low" on this input informs the 8255A that the data from port A or port B has been accepted. In essence, a response from the peripheral device indicating that it has received the data output by the CPU. INTR (Interrupt Request). A "high" on this output can be used to interrupt the CPU when an output device has accepted data transmitted by the CPU. INTR is set when $\overline{ACK}$ is a "one", $\overline{OBF}$ is a "one", and INTE is a "one". It is reset by the falling edge of $\overline{WR}$ . #### INTE A Controlled by bit set/reset of PC6. #### INTE B Controlled by bit set/reset of PC2. Figure 10. MODE 1 Output Figure 11. MODE 1 (Strobed Output) Figure 12. Combinations of MODE 1 #### **Combinations of MODE 1** Port A and Port B can be individually defined as input or output in MODE 1 to support a wide variety of strobed I/O applications. #### **Operating Modes** MODE 2 (Strobed Bidirectional Bus I/O). This functional configuration provides a means for communicating with a peripheral device or structure on a single 8-bit bus for both transmitting and receiving data (bidirectional bus I/O). "Handshaking" signals are provided to maintain proper bus flow discipline in a similar manner to MODE 1. Interrupt generation and enable/disable functions are also available. MODE 2 Basic Functional Definitions: - Used in Group A only. - One 8-bit, bi-directional bus Port (Port A) and a 5bit control Port (Port C). - Both inputs and outputs are latched. - The 5-bit control port (Port C) is used for control and status for the 8-bit, bi-directional bus port (Port A). # Bidirectional Bus I/O Control Signal Definition **INTR (Interrupt Request).** A high on this output can be used to interrupt the CPU for both input or output operations. #### **Output Operations** **OBF** (Output Buffer Full). The OBF output will go "low" to indicate that the CPU has written data out to port A. ACK (Acknowledge). A "low" on this input enables the tri-state output buffer of port A to send out the data. Otherwise, the output buffer will be in the high impedance state. INTE 1 (The INTE Flip-Flop Associated with OBF). Controlled by bit set/reset of PC<sub>6</sub>. #### Input Operations **STB** (Strobe Input). A "low" on this input loads data into the input latch. 3 **IBF (Input Buffer Full F/F).** A "high" on this output indicates that data has been loaded into the input latch. INTE 2 (The INTE Flip-Flop Associated with IBF). Controlled by bit set/reset of PC<sub>4</sub>. Figure 13. MODE Control Word Figure 14. MODE 2 Figure 15. MODE 2 (Bidirectional) Figure 16. MODE 1/4 Combinations ### **Mode Definition Summary** | Mode Deminion Sum | | | | | | | | |-------------------|----|------|--|--|--|--|--| | | MC | DE 0 | | | | | | | | IN | OUT | | | | | | | PAo | IN | OUT | | | | | | | PA <sub>1</sub> | IN | OUT | | | | | | | PA <sub>2</sub> | IN | OUT | | | | | | | PA <sub>3</sub> | IN | OUT | | | | | | | PA <sub>4</sub> | IN | OUT | | | | | | | PA <sub>5</sub> | IN | OUT | | | | | | | PA <sub>6</sub> | IN | OUT | | | | | | | PA <sub>7</sub> | IN | OUT | | | | | | | PB <sub>0</sub> | IN | OUT | | | | | | | PB <sub>1</sub> | IN | OUT | | | | | | | PB <sub>2</sub> | IN | OUT | | | | | | | PB <sub>3</sub> | IN | OUT | | | | | | | PB <sub>4</sub> | IN | OUT | | | | | | | PB <sub>5</sub> | IN | OUT | | | | | | | PB <sub>6</sub> | IN | OUT | | | | | | | PB <sub>7</sub> | IN | OUT | | | | | | | PC <sub>0</sub> | IN | OUT | | | | | | | PC <sub>1</sub> | IN | OUT | | | | | | | PC <sub>2</sub> | IN | OUT | | | | | | | PC <sub>3</sub> | IN | OUT | | | | | | | PC <sub>4</sub> | IN | OUT | | | | | | | PC <sub>5</sub> | IN | OUT | | | | | | | PC <sub>6</sub> | IN | OUT | | | | | | | PC <sub>7</sub> | ΙN | OUT | | | | | | | MOI | DE 1 | |---------------------------------------|------------------| | IN | OUT | · OUT | | iN | OUT | | IN | OUT | | IN | OUT | | IN | OUT | | IN | OUT | | | | | INTR <sub>B</sub><br>IBF <sub>B</sub> | OBF <sub>B</sub> | | STBB | ACKB | | INTRA | INTRA | | STBA | 1/0 | | IBFA | 1/0 | | 1/0 | ACKA | | 1/0 | OBFA | | | 1 331 A | | ONLY | |-------------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | A<br>\ | | ١. | | | | \<br>\<br>\ | | 1 | | | MODE MODE 0 OR MODE 1 ONLY #### **Special Mode Combination** Considerations There are several combinations of modes when not all of the bits in Port C are used for control or status. The remaining bits can be used as follows: If Programmed as Inputs- All input lines can be accessed during a normal Port C read. If Programmed as Outputs- Bits in C upper (PC7-PC4) must be individually accessed using the bit set/reset function. Bits in C lower (PC<sub>3</sub>-PC<sub>0</sub>) can be accessed using the bit set/reset function or accessed as a threesome by writing into Port C. #### Source Current Capability on Port B and Port C Any set of eight output buffers, selected randomly from Ports B and C can source 1 mA at 1.5 volts. This feature allows the 8255 to directly drive Darlington type drivers and high-voltage displays that require such source current. #### Reading Port C Status In Mode 0, Port C transfers data to or from the peripheral device. When the 8255 is programmed to function in Modes 1 or 2, Port C generates or accepts "hand-shaking" signals with the peripheral device. Reading the contents of Port C allows the programmer to test or verify the "status" of each peripheral device and change the program flow accordingly. There is no special instruction to read the status information from Port C. A normal read operation of Port C is executed to perform this function. Figure 17. MODE 1 Status Word Format Figure 18. MODE 2 Status Word Format #### **APPLICATIONS OF THE 8255A** The 8255A is a very powerful tool for interfacing peripheral equipment to the microcomputer system. It represents the optimum use of available pins and is flexible enough to interface almost any I/O device without the need for additional external logic. Each peripheral device in a microcomputer system usually has a "service routine" associated with it. The routine manages the software interface between the device and the CPU. The functional definition of the 8255A is programmed by the I/O service routine and becomes an extension of the system software. By examining the I/O devices interface characteristics for both data transfer and timing, and matching this information to the examples and tables in the detailed operational description, a control word can easily be developed to initialize the 8255A to exactly "fit" the application. Figures 19 through 25 represent a few examples of typical applications of the 8255A. Figure 19. Printer Interface Figure 20. Keyboard and Display Interface Figure 21. Keyboard and Terminal Address Interface Figure 22. Digital to Analog, Analog to Digital Figure 23. Basic Floppy Disk Interface Figure 24. Basic CRT Controller Interface Figure 25. Machine Tool Controller Interface #### **ABSOLUTE MAXIMUM RATINGS\*** | Ambient Temperature Under Bias0°C to 70°C | |---------------------------------------------------------------------------| | Storage Temperature $\dots -65^{\circ}\text{C}$ to $+150^{\circ}\text{C}$ | | Voltage on Any Pin with Respect to Ground $-0.5V$ to $+7V$ | | Power Dissipation 1 Watt | NOTICE: This is a production data sheet. 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. # **D.C. CHARACTERISTICS** $T_A = 0^{\circ}C$ to $70^{\circ}C$ , $V_{CC} = +5V \pm 10\%$ , GND = $0V^{\bullet}$ | Symbol | Parameter | Min | Max | Unit | Test Conditions | |-----------------------|---------------------------------------|------|-------|------|---------------------------------------| | V <sub>IL</sub> | Input Low Voltage | -0.5 | 0.8 | ٧ | | | V <sub>IH</sub> | Input High Voltage | 2.0 | Vcc | ٧ | | | V <sub>OL</sub> (DB) | Output Low Voltage (Data Bus) | | 0.45* | ٧ | I <sub>OL</sub> = 2.5 mA | | V <sub>OL</sub> (PER) | Output Low Voltage (Peripheral Port) | | 0.45* | ٧ | I <sub>OL</sub> = 1.7 mA | | V <sub>OH</sub> (DB) | Output High Voltage (Data Bus) | 2.4 | | ٧ | $I_{OH} = -400 \mu\text{A}$ | | V <sub>OH</sub> (PER) | Output High Voltage (Peripheral Port) | 2.4 | | ٧ | I <sub>OH</sub> = -200 μA | | I <sub>DAR</sub> (1) | Darlington Drive Current | -1.0 | -4.0 | mA | $R_{EXT} = 750\Omega; V_{EXT} = 1.5V$ | | Icc | Power Supply Current | | 120 | mA | | | I <sub>IL</sub> | Input Load Current | | ±10 | μΑ | $V_{IN} = V_{CC}$ to 0V | | lofL | Output Float Leakage | | ±10 | μΑ | $V_{OUT} = V_{CC}$ to 0.45V | #### NOTE <sup>1.</sup> Available on any 8 pins from Port B and C. # $\textbf{CAPACITANCE} \; T_{A} = 25^{\circ}\text{C, V}_{CC} = \; \text{GND} = \; \text{0V}$ | Symbol | Parameter | Min | Тур | Max | Unit | Test Conditions | |------------------|-------------------|-----|-----|-----|------|------------------------------------| | C <sub>IN</sub> | Input Capacitance | | | 10 | pF | f <sub>C</sub> = 1 MHz(4) | | C <sub>I/O</sub> | I/O Capacitance | | | 20 | pF | Unmeasured pins returned to GND(4) | # A.C. CHARACTERISTICS $T_A=0^{o}C$ to 70°C, $V_{CC}=+5V~\pm10$ %, GND $=0V^{\bullet}$ # **Bus Parameters** #### **READ** | Symbol | Parameter | 82 | 55A | 8255A-5 | | Unit | |-----------------|----------------------------------|-----|-----|---------|-----|-------| | | T all all lots | Min | Max | Min | Max | Offic | | t <sub>AR</sub> | Address Stable before READ | 0 | | 0 | | ns | | t <sub>RA</sub> | Address Stable after READ | 0 | | 0 | | ns | | t <sub>RR</sub> | READ Pulse Width | 300 | | 300 | | ns | | t <sub>RD</sub> | Data Valid from READ(1) | | 250 | | 200 | ns | | t <sub>DF</sub> | Data Float after READ | 10 | 150 | 10 | 100 | ns | | t <sub>RV</sub> | Time between READs and/or WRITEs | 850 | | 850 | | ns | #### WRITE | Symbol | Parameter | 82 | 55A | 8255A-5 | | Unit | |-----------------|-----------------------------|-----|-----|---------|-----|--------| | | | Min | Max | Min | Max | 1 0000 | | t <sub>AW</sub> | Address Stable before WRITE | 0 | | 0 | | ns | | t <sub>WA</sub> | Address Stable after WRITE | 20 | | 20 | | ns | | t <sub>WW</sub> | WRITE Pulse Width | 400 | | 300 | | ns | | t <sub>DW</sub> | Data Valid to WRITE (T.E.) | 100 | | 100 | | ns | | t <sub>WD</sub> | Data Valid after WRITE | 30 | * | 30 | | ns | #### **OTHER TIMINGS** | Symbol | Parameter | 8255A | | 8255A-5 | | Unit | |-----------------|------------------------------|-------|-------|---------|-----|------| | | | Min | Max | Min | Max | Unit | | t <sub>WB</sub> | WR = 1 to Output(1) | | 350 | | 350 | ns | | t <sub>IR</sub> | Peripheral Data before RD | 0 | | 0 | - | ns | | t <sub>HR</sub> | Peripheral Data after RD | 0 | 1,000 | 0 | | ns | | t <sub>AK</sub> | ACK Pulse Width | 300 | | 300 | | ns | | tst | STB Pulse Width | 500 | | 500 | | ns | | t <sub>PS</sub> | Per. Data before T.E. of STB | 0 | | 0 | | ns | | t <sub>PH</sub> | Per. Data after T.E. of STB | 180 | * *** | 180 | | ns | | t <sub>AD</sub> | ACK = 0 to Output(1) | | 300 | | 300 | ns | | t <sub>KD</sub> | ACK = 1 to Output Float | 20 | 250 | 20 | 250 | ns | #### A.C. CHARACTERISTICS (Continued) #### **OTHER TIMINGS (Continued)** | Symbol | Parameter | 8255A | | 8255A-5 | | Unit | |------------------|---------------------------|-------|-----|---------|-----|------| | | | Min | Max | Min | Max | | | twoB | WR = 1 to OBF = 0(1) | | 650 | | 650 | ns | | t <sub>AOB</sub> | ACK = 0 to OBF = 1(1) | | 350 | | 350 | ns | | tsiB | STB = 0 to IBF = 1(1) | | 300 | | 300 | ns | | t <sub>RIB</sub> | RD = 1 to IBF = 0(1) | | 300 | | 300 | ns | | t <sub>RIT</sub> | RD = 0 to INTR = 0(1) | | 400 | | 400 | ns | | t <sub>SIT</sub> | STB = 1 to INTR = 1(1) | | 300 | | 300 | ns | | t <sub>AIT</sub> | ACK = 1 to INTR = 1(1) | | 350 | | 350 | ns | | twiT | WR = 0 to INTR = 0(1, 3) | | 850 | | 850 | ns | #### NOTES: - 1. Test Conditions: $C_L = 150 \text{ pF}.$ - 2. Period of Reset pulse must be at least 50 µs during or after power on. Subsequent Reset pulse can be 500 ns min. - 3. INTR↑ may occur as early as WR↓. - 4. Sampled, not 100% tested. - \*For Extended Temperature EXPRESS, use M8255A electrical parameters. #### A.C. TESTING INPUT, OUTPUT WAVEFORM #### A.C. TESTING LOAD CIRCUIT \*V<sub>EXT</sub> is set at various voltages during testing to guarantee the specification. C<sub>L</sub> includes jig capacitance. # **WAVEFORMS** # MODE 0 (BASIC INPUT) # MODE 0 (BASIC OUTPUT) # **WAVEFORMS** (Continued) # MODE 1 (STROBED INPUT) ### **MODE 1 (STROBED OUTPUT)** # intel. # WAVEFORMS (Continued) ### **MODE 2 (BIDIRECTIONAL)** #### WRITE TIMING ### **READ TIMING**