# HD6321/HD6821 PIA (Peripheral Interface Adapter) The HD6321/HD6821 Peripheral Interface Adapter provides the universal means of interfacing peripheral equipment to the HD6800 Microprocessing Unit (MPU). This device is capable of interfacing the MPU to peripherals through two 8-bit bi-directional peripheral data buses and four control lines. No external logic is required for interfacing to most peripheral devices. The functional configuration of the PIA is programmed by the MPU during system initialization. Each of the peripheral data lines can be programmed to act as an input or output, and each of the four control/interrupt lines may be programmed for one of several control modes. This allows a high degree of flexibility in the over-all operation of the interface. ### **FEATURES** - Two Bi-directional 8-bit Peripheral Data Bus for interface to Peripheral devices - Two programmable control, Data Direction Registers - Four Individually Controlled Interrupt Input Lines: Two Usable as Peripheral Control Outputs - Handshake Control Logic for Input and Output Peripheral Operation $$CA_1$$ , $CA_2$ ..... Port A ( $PA_0 \sim PA_7$ ) $CA_2$ , $CB_2$ ..... Port B ( $PB_0 \sim PB_7$ ) - High-Impedance 3-State and Direct Transistor Drive Peripheral Lines - Two TTL Drive Capability on All A and B Side Buffers #### -HD6321- - Low-Power, High-Speed, High-Density CMOS - Wide Range Operating Voltage (Vcc = 5V ± 10%) - Compatible with NMOS PIA (HD6821) (Refer to Electrical Specification as to Minor difference) ### -HD6821- Compatible with MC6821, MC68A21 and MC68B21 The specifications of the HD6321 are for preliminary and may change hereafter. Please make an inquire at sales office upon adoption of the HD6321. ### **■ TYPE OF PRODUCTS** | | Type No. | Process | Clock Frequency | Package | |---|---------------------|---------|--------------------|---------| | | HD6321P<br>HD63A21P | | 1.0 MHz | DD 40 | | | HD63B21P | CMOS | 1.5 MHz<br>2.0 MHz | DP-40 | | | HD6321FP | CIVIOS | 1.0 MHz | | | | HD63A21FP | | 1.5 MHz | FP-54 | | _ | HD63B21FP | | 2.0 MHz | | | | HD6821P | | 1.0 MHz | | | | HD68A21P | | 1.5 MHz | DP-40 | | _ | HD68B21P | NMOS | 2.0 MHz | | | | HD6821 | 1410100 | 1.0 MHz | | | | HD68A21 | | 1.5 MHz | DC-40 | | _ | HD68B21 | | 2.0 MHz | | **@**HITACHI ### **BASOLUTE MAXIMUM RATINGS** | | | Va | Unit | | | |------------------------------|------------------|--------------------|--------------------|--------|--| | Item | Symbol | HD6321 | HD6821 | l oint | | | Supply Voltage | Vcc * | <b>−0.3</b> ~ +7.0 | <b>−0.3</b> ~ +7.0 | V | | | Input Voltage | Vin * | <b>−0.3 ~ +7.0</b> | <b>-0.3</b> ∼ +7.0 | V | | | Maximum Output Current | 1101** | 10 | - | mA | | | Maximum Total Output Current | ΙΣΙο Ι*** | 100 | - | mA | | | Operating Temperature | Topr | <b>−20</b> ~ +75 | <b>−20 ~ +75</b> | °c | | | Storage Temperature | T <sub>stg</sub> | -55 ~ +150 | <b>−55</b> ~ +150 | °c | | <sup>\*</sup> With respect to VSS (SYSTEM GND) - \*\* Maximum output current is the maximum current which can flow in or flow out from one output terminal and I/O common terminal, (PA<sub>0</sub>~PA<sub>7</sub>, CA<sub>2</sub>, PB<sub>0</sub>~PB<sub>7</sub>, CB<sub>2</sub>, D<sub>0</sub>~D<sub>7</sub>) - \*\*\* Maximum total output current is the total sum of output current which can flow in or flow out simultaneously from output terminals and I/O common terminals. $(PA_0 \sim PA_7, CA_2, PB_0 \sim PB_7, CB_2, D_0 \sim D_7)$ - (NOTE) Permanent LSI damage may occur if maximum ratings are exceeded. Normal operation should be under recommended operating conditions. If these conditions are exceeded, it could affect reliability of LSI. ### - RECOMMENDED OPERATING CONDITIONS | | | Combal | | HD6321 | | | | Unit | | |-------------------------|-------------------------------------------------------------------------------------------------------------|-------------------|--------|--------|-----------------|------|-----|------|------| | 11 | tem | Symbol | min. | typ | max. | min. | typ | max. | Onit | | Supply Voltage | 9 | V <sub>cc</sub> * | 4.5 | 5.0 | 5.5 | 4.75 | 5.0 | 5.25 | V | | Input "Low" \ | /oltage | VIL* | 0 | - | 0.8 | -0.3 | _ | 0.8 | V | | Input "High"<br>voltage | CB <sub>1</sub> , CB <sub>2</sub> | - VIH* | 2.2 | _ | V <sub>cc</sub> | 2.0 | | Vcc | | | | E, R/W, CS <sub>0</sub> ,<br>CS <sub>2</sub> , CS <sub>1</sub> , RS <sub>0</sub> ,<br>RS <sub>1</sub> , RES | | 3.0 ** | _ | V <sub>cc</sub> | 2.0 | _ | ▼CC | | | Operating Temperature | | Topr | -20 | 25 | 75 | -20 | 25 | 75 | °c | <sup>\*</sup> With respect to VSS (SYSTEM GND) <sup>\*\*</sup> Characteristics will be improved. #### ■ PIN ARRANGEMENT HD6321P, HD6821P HD6321FP 40 CA1 Vss 1 39 CA2 38 IRQA 37 IRQB < NC > [8] 49 < NC > 48 < NC > 47 < NC > 46 < NC > 45 RES 43 D. 44 D. 40 D. 40 D. 50 D. 50 D. 50 C. 36 RS₀ <NC> 7 <NC> 8 35 RS PA, 9 PA, 10 PA, 11 34 RES 33 D<sub>o</sub> 32 D<sub>1</sub> PA, 31 D2 PB₀ 10 PB<sub>1</sub> 13 PB<sub>1</sub> 14 PB<sub>2</sub> 15 PB<sub>1</sub>11 30 D₃ 29 D4 PB<sub>2</sub> 12 PB, 16 PB, 17 PB<sub>3</sub> 13 28 D₅ 27 De PB<sub>4</sub>14 PB, 18 PB<sub>5</sub>15 26 D7 <NC > 19 <NC > 20 <NC > 21 <NC > 22 PB<sub>6</sub> 16 25 E PB<sub>7</sub>17 24 CS1 CB<sub>1</sub> 18 CB<sub>2</sub> 19 23 CS2 33 <NC> 22 CS<sub>0</sub> 21 R/W Vcc 20 (Top View) (DP-40, DC-40) (Top View) ### **■ BLOCK DIAGRAM** ( HITACHI - ELECTRICAL CHARACTERISTICS - DC CHARACTERISTICS (HD6321; $V_{CC}$ = 5V ±10%, HD6821; $V_{CC}$ = 5V ±5%, $V_{SS}$ = 0V, $T_{B}$ = -20 $\sim$ +75 $^{\circ}$ C, unless otherwise noted.) | 11 | tem | Symbol | <u> </u> | HD6821 | | | | | | | | | |---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-----------------------------------------------------|-----------------------------|--------|----------------|--------------------------------------|----------------------|--------------|------|----------|--| | | | 3711001 | Test Condition | min. | typ* | max | Test Condition | min | typ* | max | Uni | | | Input "High" Voltage | D <sub>0</sub> ~D <sub>7</sub> , PA <sub>0</sub> ~PA <sub>7</sub> ,<br>CA <sub>1</sub> CA <sub>2</sub> , PB <sub>0</sub> ~PB <sub>7</sub> ,<br>CB <sub>1</sub> , CB <sub>2</sub><br>E, R/W, CS <sub>0</sub> , CS <sub>2</sub><br>CS <sub>1</sub> , RS <sub>0</sub> , RS <sub>1</sub> , RES | v <sub>iH</sub> | | 2.2 | -<br>- | Vcc | | 2.0 | _ | Vcc | v | | | Input "Low" Voltage | All Inputs | VIL | ł <del></del> | -0.3 | _ | 0.8 | | -0.3 | <del> </del> | 0.8 | V | | | Input Leakage Current | R.W. RES, RS <sub>0</sub> , RS <sub>1</sub> ,<br>CS <sub>0</sub> , CS <sub>1</sub> , CS <sub>2</sub> , CA <sub>1</sub> ,<br>CB <sub>1</sub> , E | lin | V <sub>in</sub> =0 ~V <sub>cc</sub> | -2.5 | _ | 2.5 | Vin = 0 ~ Vcc | -2.5 | _ | 2.5 | μ.Α | | | Three State (Off State) Input Current | PA <sub>0</sub> ~PA <sub>7</sub> , CA <sub>2</sub><br>D <sub>0</sub> ~D <sub>7</sub> , PB <sub>0</sub> ~PB <sub>7</sub> , CB <sub>2</sub> | ITSI | Vin = 0.4~ Vcc | -10 | - | 10 | Vin = 0.4~ 2,4V | 10 | | 100 | μΑ | | | Input "High" Current | PA <sub>0</sub> ~PA <sub>7</sub> , CA <sub>2</sub> | Iн | - | | | | V = 2 4V | -200 | <del> </del> | 10 | <u> </u> | | | Input "Low" Current | PA <sub>0</sub> ~PA <sub>7</sub> , CA <sub>2</sub> | HL. | | | | | V <sub>IH</sub> = 2.4V | | | - | μΑ | | | mpat Low Content | 120 127, 572 | -11 | 1 | • • • | Γ | · | VIL = 0.4V | ļ. <del>-</del> . | | -2.4 | m | | | · | D <sub>0</sub> ~D <sub>7</sub> | | <sup>1</sup> OH = -400μA<br><sup>1</sup> OH ≤ -10μA | 4.1<br>V <sub>cc</sub> =0.1 | - | <del>-</del> - | IOH = -205µA | 2.4 | _ | - | | | | Output "High" Voltage | PA <sub>0</sub> ~ PA <sub>7</sub> , CA <sub>2</sub><br>PB <sub>0</sub> ~ PB <sub>7</sub> , CB <sub>2</sub> | ∨он | IOH = -400μA<br>IOH < -10μA | 4.1<br>V <sub>CC</sub> =0.1 | - | | | | | | | | | | PA <sub>0</sub> ~PA <sub>7</sub> , CA <sub>2</sub> | 1 | | | | | IOH = -200µA | 2.4*** | T _ | | \<br> \ | | | | PB <sub>0</sub> ~ PB <sub>7</sub> , CB <sub>2</sub> | | | | | | IOH = - 10#A | V <sub>cc</sub> ~0.1 | - | | ] | | | | D <sub>0</sub> ~D <sub>7</sub> , IRQA, IRQB | <del></del> | IOL = 1.6mA | | _ | 0.4 | IOH = ~200µA | - | ΙΞ- | 0.4 | | | | Output "Low" Voltage | PA <sub>0</sub> ~PA <sub>7</sub> , CA <sub>2</sub> | VOL | | | | | IOL = 1.6mA | | _ | 0.4 | V | | | | PB <sub>0</sub> ~ PB <sub>7</sub> , CB <sub>2</sub> | | IOL = 3.2mA | - | - | 0.6 | IOL = 3.2mA | _ | l | 0.6 | • | | | | D <sub>0</sub> ~ D <sub>7</sub> | | | | | | VOH = 2.4V | -205 | _ | - | μ/ | | | Output "High" Current | PA <sub>0</sub> ~PA <sub>7</sub> , CA <sub>2</sub> | ЮН | | | | | VOH = 2.4V*** | -200 | | _ | μ/ | | | | PB <sub>0</sub> ~ PB <sub>7</sub> , CB <sub>2</sub> | | | | | | VOH = 1.5V | -1.0 | _ | -10 | m | | | Output Leakage Current<br>(Off State) | IROA, IROB | <sup>1</sup> LOH | VOH = Vcc | - | - | 10 | V <sub>OH</sub> = 2.4V | _ | - | 10 | μΑ | | | | PA <sub>0</sub> ~PA <sub>7</sub> , PB <sub>0</sub> ~PB <sub>7</sub><br>CA <sub>2</sub> , CB <sub>2</sub> , D <sub>0</sub> ~D <sub>7</sub> | | Vin = OV | - | - | 12.5 | V <sub>in</sub> = 0V | _ | _ | 12.5 | | | | Input Capacitance | R/W, RES, RS <sub>0</sub> , RS <sub>1</sub><br>CS <sub>0</sub> , CS <sub>1</sub> , CS <sub>2</sub> , CA <sub>1</sub><br>CB <sub>1</sub> , E | Cin | Ta = 25°C<br>f = 1,0MHz | _ | - | 10 | Ta = 25° C<br>f = 1,0MHz | _ | _ | 10 | рF | | | Output Capacitance | IRQA, ÎRQB | Cout | V <sub>in</sub> = 0V<br>Ta = 25° C<br>f = 1.0MHz | _ | | 10 | Vin = 0V<br>Te = 25° C<br>f = 1.0MHz | - | _ | 10 | ρF | | | | PB <sub>7</sub> , CB <sub>2</sub> are specified | | E = 1.0MHz | _ | _ | 300 | | | | | - | | | | as input, •Chip is not selected, | | E = 1.5MHz | - | _ | 400 | | | - | | μΑ | | | Supply Current | ●Input level V <sub>IH</sub> min = V <sub>cc</sub> - 0.8V V <sub>IL</sub> max = 0.8V | 1 | E = 2,0MHz | ~ | - | 500 | | | | | | | | | ◆PA <sub>0</sub> ~ PA <sub>7</sub> , CA <sub>2</sub> and PB <sub>0</sub> ~ PB <sub>7</sub> , CB <sub>2</sub> are | l <sub>cc</sub> | E = 1.0MHz | _ | _ | 4 | | | | | _ | | | | specified as input. •Under Data Bus R/W operation. | | E = 1.5MHz<br>E = 2.0MHz | - | _ | 5<br>6 | | | | | m | | | Power Di- | Power Dissipation | | | | | | | | <del>-</del> | | | | | FOWER DIS | sipation | PD | | | | | | - 1 | 260 | 550 | m | | Ta = 25°C, V<sub>cc</sub> = 5.0V # **@HITACHI** <sup>\*\*\*</sup> HD68B21; V<sub>OH</sub> = 2.2V min (PA<sub>0</sub>~PA<sub>7</sub>, CA<sub>2</sub>) <sup>\*\*\*\*</sup> Supply current is defined on the condition that there is no current flow from output terminals. Supply current will be increased when the current from output terminal exists. Also the current will be increased for charging and discharging the capacitive load. Please take this case into consideration in estimating system power. ### • AC CHARACTERISTICS (HD6321; $V_{CC}$ = 5V $\pm$ 10%, HD6821; $V_{CC}$ = 5V $\pm$ 5%, $V_{SS}$ = 0V, Ta = -20 $\sim$ +75 $^{\circ}$ C unless otherwise noted) ### 1. PERIPHERAL TIMING | Item | | Symbol | Test Condition | HD6 | 321<br>max | HD63 | A21 | HD63 | B21<br>max | HD6 | 821<br>max | HD68 | A21 | HD68 | B21<br>max | Unit | |------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|---------------------|------------------------------------------------|-------------|------------|--------------|-----|--------------|--------------|----------|------------|--------------|------|----------|------------|----------------------------------------------| | Peripheral Data Setup Time | | tposu | Fig. 1 | 100 | | 100 | - | 100 | _ | 200 | _ | 135 | _ | 100 | - | ne | | Peripheral Data Hold Time | | | Fig. 1 | 0 | _ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns | | Delay Time, Enable negative<br>Transition to CA <sub>2</sub> negative<br>transition | Enable → CA <sub>2</sub> Negative | <sup>t</sup> CA2 | Fig. 2, Fig. 3 | - | 200 | | 200 | - | 200 | - | 1000 | 1 | 670 | - | 500 | ns | | Delay Time, Enable negative transition to CA <sub>2</sub> positive transition | Enable→CA <sub>2</sub> Positive | tRS1 | Fig. 2 | - | 200 | - | 200 | _ | 200 | - | 1000 | - | 670 | - | 500 | ns | | Rise and Fall Times for CA <sub>1</sub> and CA <sub>2</sub> input signals | CA <sub>1</sub> , CA <sub>2</sub> | t <sub>r</sub> , tq | Fig. 3 | - | 100 | _ | 100 | - | 100 | - | 1000 | - | 1000 | - | 1000 | ns | | Delay Time from CA <sub>1</sub> active transition to CA <sub>2</sub> positive transition | CA <sub>1</sub> → CA <sub>2</sub> | <sup>t</sup> RS2 | Fig. 3 | - | 300 | _ | 300 | - | 3 <b>0</b> 0 | - | 2000 | - | 1350 | - | 1000 | ns | | Delay Time, Enable negative<br>transition to Peripheral Data<br>Valid | EnablePeripheral Data | <sup>†</sup> PDW | Fig. 4, Fig. 5 | _ | 300 | - | 300 | - | 300 | - | 1000 | | 670 | - | 500 | ns | | Delay Time, Enable negative<br>transition to Peripheral<br>CMOS Data Valid | Enable → Peripheral<br>Data<br>PA <sub>0</sub> ~ PA <sub>7</sub> , CA <sub>2</sub> | <sup>t</sup> cmos | V <sub>cc</sub> -30% V <sub>cc</sub><br>Fig. 4 | | | | | | | - | 2000 | - | 1350 | | 1000 | nı | | Delay Time, Enable positive transition to CB <sub>2</sub> negative position | Enable → CB <sub>2</sub> | tCB2 | Fig. 6, Fig. 7 | - | 200 | _ | 200 | - | 200 | - | 1000 | - | 670 | _ | 500 | M | | Delay Time, Peripheral Data<br>Valid to CB <sub>2</sub> negative<br>transition | Peripheral Data → CB <sub>2</sub> | †DC | Fig. 5 | 20 | _ | 20 | _ | 20 | - | 20 | - | 20 | - | 20 | - | 2 | | Delay Time, Enable positive transition to CS <sub>2</sub> positive transition | Enable → CB <sub>2</sub> | <sup>t</sup> RS1 | Fig. 6 | _ | 200 | _ | 200 | - | 200 | - | 1000 | <del>-</del> | 670 | _ | 500 | n | | Peripheral Control Output<br>Pulse Width, CA <sub>2</sub> /CB <sub>2</sub> | CA <sub>2</sub> CB <sub>2</sub> | PWCT | Fig. 2, Fig. 6 | 550 | - | 375 | _ | 250 | - | 550 | _ | 550 | _ | 500 | _ | n | | Rise and Fall Time for CB <sub>1</sub> and CB <sub>2</sub> input signals | CB <sub>1</sub> , CB <sub>2</sub> | t <sub>r</sub> , tį | Fig. 7 | - | 100 | - | 100 | | 100 | _ | 1000 | - | 1000 | - | 1000 | n | | Delay Time, CB <sub>1</sub> active transition to CB <sub>2</sub> positive transition | CB <sub>1</sub> → CB <sub>2</sub> | <sup>t</sup> RS2 | Fig. 7 | - | 300 | _ | 300 | - | 300 | - | 2000 | _ | 1350 | - | 1000 | n | | Interrupt Release Time,<br>IRQA and IRQB | IRQA, IRQB | t <sub>IR</sub> | Fig. 9 | _ | 800 | _ | 800 | _ | 800 | - | 1600 | _ | 1100 | - | 850 | n | | Interrupt Response Time | IROA, IROB | t <sub>AS3</sub> | Fig. 8 | _ | 400 | - | 400 | | 400 | <u> </u> | 1000 | | 1000 | <u> </u> | 1000 | <u>' </u> | | Interrupt Input Pulse Width | CA <sub>1</sub> , CA <sub>2</sub> , CB <sub>1</sub> , CB <sub>2</sub> | PWI | Fig. 8 | 1E<br>cycle | | 1 E<br>cycle | _ | 1 E<br>cycle | <u> </u> - | 500** | | 500** | | 500** | - | n | | Reset "Low" Time | RES* | ¹BL | Fig. 10 | 200 | <b>-</b> | 200 | _ | 200 | Ī - | 1000 | T - | 660 | _ | 500 | - | n | <sup>\*</sup> The Reset line must be "High" a minimum of 1,0µs before addressing the PIA. <sup>\*\*</sup> At least one Enable "High" pulse should be included in this period. ### 2. BUS TIMING ### 1) READ | | | | | HD6321 | | HD63A21 | | HD63B21 | | HD6821 | | HD68A21 | | HD68B21 | | Unit | |------------------|---------------------|------------------|----------------|--------|-----|----------|-----|---------|-----|--------|---------------|----------|----------|---------|-----|------| | | Item | Symbol | Test Condition | min | max | min | max | min | max | min | max | min | max | min | max | Unit | | Enable Cycle Ti | me | tcycE | Fig. 11 | 1000 | - | 666 | _ | 500 | - | 1000 | <del> </del> | 666 | 1 - | 500 | - | ns | | Enable Pulse Wie | dth, "High" | PWEH | Fig. 11 | 450 | - | 280 | - | 220 | - | 450 | _ | 280 | <u> </u> | 220 | - | ns | | Enable Pulse Wie | dth, "Low" | PWEL | Fig. 11 | 430 | _ | 280 | - | 210 | - | 430 | - | 280 | - | 210 | - | ns | | Enable Pulse Ris | e and Fall Times | ter, tef | Fig. 11 | _ | 25 | <u> </u> | 25 | - | 20 | - | 25 | <u> </u> | 25 | _ | 25 | ns | | Setup Time | Address, R/W-Enable | tAS | Fig. 12 | 80 | - | 60 | _ | 40 | _ | 140 | - | 140 | - | 70 | - | ns | | Address Hold Ti | me | t <sub>A</sub> H | Fig. 12 | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | ns | | Data Delay Time | е | <sup>t</sup> DDR | Fig. 12 | _ | 290 | - | 180 | _ | 150 | | 320 | - | 220 | _ | 180 | ns | | Data Hold Time | | <sup>t</sup> DHR | Fig. 12 | 20 | 100 | 20 | 100 | 20 | 100 | 10 | - | 10 | _ | 10 | | ns | ### 2) WRITE | | | | HD | 6321 | HD6 | 3A21 | HD6 | 3821 | НD | 6821 | HD6 | 8A21 | HD€ | S8821 | Unit | |---------------------------------------|-----------------------------------|----------------|------|------|-----|------|-----|------|------|------|-----|----------------|-----|-------|------| | itėm<br> | Symbol | Test Condition | min | max | min | max | min | max | min | max | min | max | min | max | Onit | | Enable Cycle Time | t <sub>cyc</sub> E | Fig. 11 | 1000 | - | 666 | _ | 500 | _ | 1000 | - | 666 | - | 500 | - | ns | | Enable Pulse Width, "High" | PWEH | Fig. 11 | 450 | - | 280 | _ | 220 | _ | 450 | _ | 280 | - | 220 | - | ns | | Enable Pulse Width, "Low" | PWEL | Fig. 11 | 430 | _ | 280 | _ | 210 | | 430 | _ | 280 | [ <del>-</del> | 210 | - | ns | | Enable Pulse Rise and Fall Times | t <sub>Er</sub> , t <sub>Ef</sub> | Fig. 11 | | 25 | _ | 25 | _ | 20 | 1 | 25 | _ | 25 | _ | 25 | ns | | Setup Time | tAS | Fig. 13 | 80 | - | 60 | _ | 40 | | 140 | - | 140 | - | 70 | - | ns | | Address Hold Time Address, R/W-Enable | t <sub>AH</sub> | Fig. 13 | 10 | _ | 10 | _ | 10 | _ | 10 | _ | 10 | _ | 10 | _ | ns | | Data Setup Time | tosw | Fig. 13 | 165 | _ | 80 | - | 60 | - | 195 | - | 80 | _ | 60 | - | ns. | | Data Hold Time | t <sub>DHW</sub> | Fig. 13 | 10 | - | 10 | - | 10 | _ | 10 | _ | 10 | _ | 10 | - | ns | Figure 1 Peripheral Data Setup and Hold Times (Read Mode) Figure 2 CA<sub>2</sub> Delay Time (Read Mode; CRA5=CRA3=1, CRA4=0) Figure 3 CA<sub>2</sub> Delay Time (Read Mode; CRA5=1, CRA3=CRA4=0) Figure 4 Peripheral Data Delay Times (Write Mode; CRA5=CRA3=1, CRA4=0) Figure 5 Peripheral Data and CB<sub>2</sub> Delay Times (Write Mode; CRB5=CRB3=1, CRB4=0) Figure 6 CB<sub>2</sub> Delay Time (Write Mode; CRB5=CRB3=1, CRB4=0) Figure 7 CB<sub>2</sub> Delay Time (Write Mode; CRB5=1, CRB3=CRB4=0) CA<sub>1</sub>, CA<sub>2</sub> CB<sub>1</sub>, CB<sub>2</sub> V<sub>1H</sub> min V<sub>1L</sub> max V<sub>1H</sub> min V<sub>1L</sub> max \* Assumes Interrupt Enable Bits are set. Figure 8 Interrupt Pulse Width and IRQ Response \*\* 0.6V for HD6321, 0.4V for HD6821 ••• 2.4V for HD6821 # **OHITACHI** Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300 Figure 14 Bus Timing Test Loads **OHITACHI** Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300 ### ■ PIA INTERFACE SIGNALS FOR MPU The PIA interfaces to the HD6800 MPU with an eight-bit bi-directional data bus, three chip select lines, two register select lines, two interrupt request lines, read/write line, enable line and reset line. These signals, in conjunction with the HD6800 VMA output, permit the MPU to have complete control over the PIA. VMA should be utilized in conjunction with an MPU address line into a chip select of the PIA. #### Bi-Directional Data (D<sub>0</sub> ~D<sub>7</sub>) | Input | Pin No. 33 ~ 26 (DP-40)<br>Pin No. 43 ~ 36 (FP-54) | |-------|----------------------------------------------------| | | | The bi-directional data lines $(D_0 \sim D_7)$ allow the transfer of data between the MPU and the PIA. The data bus output drivers are three-state devices that remain in the high-impedance (off) state except when the MPU performs a PIA read operation. The R/W line is in the Read ("High") state when the PIA is selected for a Read operation. ### ● Enable (E) The enable pulse, E, is the only timing signal that is supplied to the PIA. Timing of all other signals is referenced to the leading and trailing edges of the E pulse. This signal will normally be a derivative of the HMCS6800 System $\phi_2$ Clock. This signal must be continuous clock pulse. ### Read/Write (R/W) | Input | Pin No. 21 (DP-40) | |-------|--------------------| | - | Pin No. 28 (FP-54) | This signal is generated by the MPU to control the direction of data transfers on the Data Bus. A "Low" state on the PIA line enables the input buffers and data is transferred from the MPU to the PIA on the E signal if the device has been selected. A "High" on the $R/\overline{W}$ line sets up the PIA for a transfer of data to the bus. The PIA output buffers are enabled when the proper address and the enable pulse E are present. ### • Reset (RES) | Input | Pin No. 34 (DP-40) | |-------|--------------------| | | Pin No. 44 (FP-54) | The active "Low" RES line is used to reset all register bits in the PIA to a logical zero "Low". This line can be used as a power-on reset and as a master reset during system operation. ### Chip Select (CS<sub>0</sub>, CS<sub>1</sub> and CS<sub>2</sub>) | Input | Pin No. 22, 24, 23 (DP-40)<br>Pin No. 29, 31, 30 (FP-54) | | |-------|----------------------------------------------------------|--| | | | | These three input signals are used to select the PIA. $CS_0$ and $CS_1$ must be "High" and $\overline{CS}_2$ must be "Low" for selection of the device. Data transfers are then performed under the control of the E and R/W signals. The chip select lines must be stable for the duration of the E pulse. The device is deselected when any of the chip selects are in the inactive state. ### • Register Select (RS<sub>0</sub> and RS<sub>1</sub>) | Input Pin No. 36, 35 (DP-40)<br>Pin No. 50, 45 (FP-54) | |--------------------------------------------------------| |--------------------------------------------------------| The two register select lines are used to select the various registers inside the PIA. These two lines are used in conjunction with internal Control Registers to select a particular register that is to be written or read. The register and chip select lines should be stable for the duration of the E pulse while in the read or write cycle. ### Interrupt Request (IRQA and IRQB) | Input | Pin No. 38, 37 (DP-40)<br>Pin No. 52, 51 (FP-54) | |-------|--------------------------------------------------| | | | The active "Low" Interrupt Request lines (IRQA and IRQB) act to interrupt the MPU either directly or through interrupt priority circuitry. These lines are "open drain" (no load device on the chip). This permits all interrupt request lines to be tied together in a wire-OR configuration. Each IRQ line has two internal interrupt flag bits that can cause the IRQ line to go "Low". Each flag bit is associated with a particular peripheral interrupt line. Also four interrupt enable bits are provided in the PIA which may be used to inhibit a particular interrupt from a peripheral device. Servicing an interrupt by the MPU may be accomplished by a software routine that, on a prioritized basis, sequentially reads and tests the two control registers in each PIA for interrupt flag bits that are set. The interrupt flags are cleared (zeroed) as a result of an MPU Read Peripheral Data Operation of the corresponding data register. After being cleared, the interrupt flag bit cannot be enabled to be set until the PIA is deselected during an E pulse. The E pulse is used to condition the interrupt control lines (CA<sub>1</sub>, CA<sub>2</sub>, CB<sub>1</sub>, CB<sub>2</sub>). When these lines are used as interrupt inputs at least one E pulse must occur from the inactive edge to the active edge of the interrupt input signal to condition the edge sense network. If the interrupt flag has been enabled and the edge sense circuit has been properly conditioned, the interrupt flag will be set on the next active transition of the interrupt input pin. ### ■ PIA PERIPHERAL INTERFACE LINES The PIA provides two 8-bit bi-directional data buses and four interrupt/control lines for interfacing to peripheral devices. There is difference between HD6821 and HD6321 in Port structure. Fig. 15 shows the block diagram of Port A and Port B in HD6321. The output drivers of Port A and Port B consist of three-state drivers, allowing them to enter a High-impedance state when the peripheral data line is used as an input. Port A and Port B have the same output buffer. But the circuit configuration is slightly different and this makes the difference on data flow when MPU reads Port A and Port B in the case each Port is specified as output. As shown in Fig. 15, the output of the peripheral data A is transferred to internal data bus when used as output. On the other hand, in the case of Port B the contents of output register (ORB) is directly transferred to internal data bus through the multiplexor. Secondly the equivalent circuit of the port in HD6821 is shown in Fig. 16. The output circuits of A port is different from that of B port. When the port is used as input, the input is pullup to $V_{CC}$ side through load MOS in A port and B port becomes "Off" (high impedance). From DRA To Data Bus To Data Bus To Data Bus To Data Bus To Data Bus From ORB (a) Port A (b) Port B Figure 16 Circuit of Port A and Port B (HD6821) ### Port A Peripheral Data (PA₀~PA₁) Input/Output Pin No. 2~ 9 (DP-40) Pin No. 2~ 5, 9~ 12 (FP-54) Each of the peripheral data lines can be programmed to act as an input or output. This is accomplished by setting a "1" in the corresponding Data Direction Register bit for those lines which are to be outputs. A "0" in a bit of the Data Direction Register causes the corresponding peripheral data line to act as an input. During an MPU Read Peripheral Data Operation, the data on peripheral lines programmed to act as inputs appears directly on the corresponding MPU Data Bus lines. The data in Output Register A will appear on the peripheral data lines that are programmed to be outputs. A logical "1" written into the register will cause a "High" on the corresponding peripheral data line while a "0" results in a "Low". Data in Output Register A may be read by an MPU "Read Peripheral Data A" operation when the corresponding lines are programmed as outputs. But concerning HD6821, this data will be read properly if the voltage on the peripheral data lines is greater than 2.0 volts for a logic "1" output and less than 0.8 volt for a logic "0" output. Loading the output lines such that the voltage on these lines does not reach full voltage causes the data transferred into the MPU on a Read operation to differ from that contained in the respective bit of Output Register A. ### Port B Peripheral Data (PB₀ ~ PB₁) Input/Output Pin No. 10 ~ 17 (DP-40) Pin No. 13 ~ 18, 23 ~ 24 (FP-54) Each of the Port B peripheral data bus can be programmed to act as an input or output like $PA_0 \sim PA_7$ . $PB_0 \sim PB_7$ are in High-impedance condition because they are three-state outputs just like $PA_0 \sim PB_0$ when the peripheral buses are used as inputs, when programmed as outputs, MPU read of Port B make it possible to read the output register regardless of $PB_0 \sim PB_7$ loads and concerning HD6821, these line may be used as a source of up to 2.5 milliampare (typ.) at 1.5 volt to directly drive the base of transistor switch. ### Interrupt input (CA<sub>1</sub> and CB<sub>1</sub>) | 40, 18 (DP-40)<br>54, 25 (FP-54) | |----------------------------------| | | The peripheral Input lines CA<sub>1</sub>, and CB<sub>1</sub> are input only lines that set the interrupt flags of the control registers. The active transition for these signals is also programmed by the two control registers. ### Peripheral Control (CA<sub>2</sub>) | Input/Output | Pin No. 39 (DP-40)<br>Pin No. 53 (FP-54) | |--------------|------------------------------------------| | | гш 140. 55 (ГТ-54) | The peripheral control line CA<sub>2</sub> can be programmed to act as an interrupt input or as a peripheral control output. The function of this signal is programmed by the Control Register A. When used as an input, this signal is in High-impedance state. ### Peripheral Control (CB<sub>2</sub>) | Input/Output | Pin No. 19 (DP-40)<br>Pin No. 26 (FP-54) | |--------------|------------------------------------------| | | | The peripheral Control line CB<sub>2</sub> may also be programmed to act as an interrupt input or peripheral control output. This line is programmed by Control Register B. When used as an input, this signal is in High-impedance. (NOTE) 1. Pulse width of interrupt inputs CA<sub>1</sub>, CA<sub>2</sub>, CB<sub>1</sub> and CB<sub>2</sub> shall be greater than a E cycle time. In the case that "High" time of E signal is not contained in Interrupt pulse, an interrupt flag may not be set. ### **Electrical Characteristics** ### (1) DC Characteristics | | | Sym- | old r | nask | Rm | nask | Unit | |-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|-----------------|------|------|------| | Item | | bol | min. | max. | min. | max. | - | | Input<br>"High" | D <sub>0</sub> -D <sub>7</sub> , PA <sub>0</sub> -PA <sub>7</sub> ,<br>PB <sub>0</sub> -PB <sub>7</sub> , CA <sub>1</sub> , CA <sub>2</sub> ,<br>CB <sub>1</sub> , CB <sub>2</sub> | VIH | 2.2 | Vcc | 2.2 | Vcc | v | | Voltage | E, R/W, CS <sub>0</sub> , CS <sub>1</sub> ,<br>CS <sub>2</sub> , RS <sub>0</sub> , RS <sub>1</sub> , RES | | 3.0 | V <sub>CC</sub> | | | | (2) AC Characteristics (Only for HD63B21) | | Cb.a1 | oid | mask | Rm | Unit | | |----------------------------------------------------------|--------|------|------|------|------|----| | Item | Symbol | min. | max. | min. | max. | | | Bus Timing (READ)<br>Setup Time (Address,<br>R/W-Enable) | tas | 60 | | 40 | | ns | | Bus Timing (WRITE) Setup time (Address, R/W-Enable) | tAS | 60 | | 40 | | ns | JAPAN (DILP) ### ■ INTERNAL CONTROLS There are six locations within the PIA accessible to the MPU data bus: two Peripheral Registers, two Data Direction Registers, and two Control Registers. Selection of these locations is controlled by the RS<sub>0</sub> and RS<sub>1</sub> inputs together with bit 2 in the Control Register, as shown in Table 1. JAPAN Table 1 Internal Addressing | _ | | Con<br>Regis | trol<br>ter Bit | | |---|---|--------------|-----------------|---------------------------| | | | CRA2 | CR82 | Location Selected | | 0 | 0 | 1 | × | Peripheral Register A* | | 0 | 0 | 0 | × | Data Direction Register A | | 0 | 1 | × | × | Control Register A | | 1 | 0 | × | 1 | Peripheral Register 8* | | 1 | 0 | × | 0 | Data Direction Register B | | 1 | 1 | × | × | Control Register B | - x = Don't Care - Peripheral interface register is a generic term containing peripheral data bus and output register. ### Initialization A "Low" reset line has the effect of zeroing all PIA registers. This will set PA<sub>0</sub>~PA<sub>7</sub>, PB<sub>0</sub>~PB<sub>7</sub>, CA<sub>2</sub> and CB<sub>2</sub> as inputs, and all interrupts disabled. The PIA must be configured during the restart program which follows the reset. Details of possible configurations of the Data Direction and Control Register are as follows. ### Data Direction Registers (DDRA and DDR8) The two Data Direction Registers allow the MPU to control the direction of data through each corresponding peripheral data line. A Data Direction Register bit set at "0" configures the corresponding peripheral data line as an input; a "1" results in an output. ### Control Registers (CRA and CRB) The two Control Registers (CRA and CRB) allow the MPU to control the operation of the four peripheral control lines $CA_1$ , $CA_2$ , $CB_1$ and $CB_2$ . In addition they allow the MPU to enable the interrupt lines and monitor the status of the interrupt flags. Bits 0 through 5 of the two registers may be written or read by the MPU when the proper chip select and register select signals are applied. Bits 6 and 7 of the two registers are read only and are modified by external interrupts occurring on control lines $CA_1$ , $CA_2$ , $CB_1$ or $CB_2$ . The format of the control words is shown in Table 2. Table 2 Control Word Format | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|-------|-------|-------------------------|-----|----------------|----------------|-------|--------| | CRA | IRQA1 | IRQA2 | CA | Con | trol | DDRA<br>Access | CA, C | ontrol | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CRB | IAQB1 | IRQB2 | CB <sub>2</sub> Control | | DORB<br>Access | C8, Control | | | ### Data Direction Access Control Bit (CRA2 and CRB2) Bit 2 in each Control register (CRA and CRB) allows selection of either a Peripheral Interface Register or the Data Direction Register when the proper register select signals are applied to RS<sub>0</sub> and RS<sub>1</sub>. ### Interrupt Flags (CRA6, CRA7, CRB6, and CRB7) The four interrupt flag bits are set by active transitions of signals on the four Interrupt and Peripheral Control lines when those lines are programmed to be inputs. These bits cannot be set directly from the MPU Data Bus and are reset indirectly by a Read Peripheral Data Operation on the appropriate section. Control of CA<sub>1</sub> and CB<sub>1</sub> Interrupt Lines (CRA0, CRB0, CRA1, and CRB1) The two lowest order bits of the control registers are used to control the interrupt input lines CA<sub>1</sub> and CB<sub>1</sub>. Bits CRAO and CRBO are used to enable the MPU interrupt signals IRQA and IRQB, respectively. Bits CRA1 and CRB1 determine the active transition of the interrupt input signals CA<sub>1</sub> and CB<sub>1</sub> (Table 3) Control of CA<sub>2</sub> and CB<sub>2</sub> Peripheral Control Lines (CRA3, CRA4, CRA5, CRB3, CRB4, and CRB5) Bits 3, 4 and 5 of the two control registers are used to control the CA<sub>2</sub> and CB<sub>2</sub> Peripheral Control lines. These bits determine if the control lines will be an interrupt input or an output control signal. If bit CRA5 (CRB5) is "0" CA<sub>2</sub> (CB<sub>2</sub>) is an interrupt input line similar to CA1 (CB1) (Table 4). When CRA5 (CRB5) is "1", CA<sub>2</sub> (CB<sub>2</sub>) becomes an output signal that may be used to control peripheral data transfers. When in the output mode, CA<sub>2</sub> and CB<sub>2</sub> have slightly different characteristics (Table 5 and 6). Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300 # Control Register A (CRA) | 7 | 6 | 5 4 3 | 2 | 1 | ) | | | | |-------------------|-------------------|-----------------------------------------|---------------------|-----------|----------------------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IRQA <sub>1</sub> | IRQA <sub>2</sub> | Control CA <sub>2</sub> | DDRA | Control C | <u> </u> | | | | | | | | | | <u></u> | _ | 0 | 1 | | | | | | | Bit CRA0 (CA <sub>1</sub> Periphera Control Lines) | al | CA <sub>1</sub> , interrupt output mask bit CRA7 (IRG A <sub>1</sub> ) is set according to the Interrupt signal CA <sub>1</sub> , but IRQA is masked and not output (in short, IRQA = 'high'). | CA <sub>1</sub> interrupt output mask bit CRA7 (IRQA <sub>1</sub> ) is set according to the interrupt signal CA <sub>1</sub> , and IRQA changes 'low'. | | | | | | | CRA1<br>(CA <sub>1</sub> active<br>edge bit) | - 1 | CRA7 (IRQA1) is set when CA <sub>1</sub> is fallen. | CRA7 (IRQA1) is set when CA <sub>1</sub> is risen. | | | | | | | CRA2 | | Data direction register A (DDRA) | Peripheral interface register A | | | | | 1 | | CRA3 CA2 (Peripheral Control Line) | | CA2 interrupt output mask bit CAR6 (IRQA2) is set according to the interrupt signal CA2, but IRQA is masked and not output (in short, IRQA = 'high'). | CA <sub>2</sub> interrupt output mask bit<br>CBR6 (IRQA <sub>2</sub> ) is set according<br>to the interrupt signal CA <sub>2</sub> .<br>And IRQA changes 'low'. | | | | | l<br>! | | CRA4<br>CA <sub>2</sub> (active<br>edge bit) | | CRA6 is set when CA2 is fallen | CRA6 is set when CA2 is risen. | | | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | <br> <br> <br> <br> | | CRA3 | | CRA4 = 0 Handshake mode bit The output CA2 is 'low' when 'E' pulse is fallen on MPU is read the data from Peripheral Interface Register A and CA2 is 'high' when CB1 is active (edge). | CRA4 = 0 Handshake mode bit After reading, CA2 is 'high' when next 'E' pulse is fallen on MPU is read the data from Interface Register A and, after reading, CA2 is 'high' when next 'E' pulse is fallen. | | | | L_ | | | CRA4 | | CRA3 is the handshake mode bit. | The content of CRA3 is out to CA2. | | | | | | | CRA5<br>CA2 input/<br>output select | bit | CA2 is input mode | CA2 is output mode | | | | | | | CRA6 (IRQA2 | 2) | No interrupt request from CA <sub>2</sub> or CA <sub>2</sub> is output (Reset Mode) | Interrupt request from CA <sub>2</sub> is occurred. | | L | | | | | CRA7 (IRQA <sub>1</sub> | ) | No interrupt request from CA <sub>1</sub> . | Interrupt request from CA <sub>1</sub> is occurred. | **OHITACHI** # Control Register B (CRB) | 7 | 6 | 5 4 3 | 2 | 1 | 0 | | | | |-------------------|-------------------|-------------------------|---------|-----------|--------------------------------------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IRQB <sub>1</sub> | IRQB <sub>2</sub> | Control CB <sub>2</sub> | DDRB | Control C | B <sub>1</sub> | | | | | | | | | | | | | | | | | | | | Bit | | 0 | 1 | | | | | | | CRB0<br>(CB <sub>1</sub> Peripho<br>Control Line | eral<br>s) | CB <sub>1</sub> , interrupt output mask bit CRB7 (IRG B <sub>1</sub> ) is set according to the Interrupt signal CB <sub>1</sub> , but IRQB is masked and not output (in short, IRQB = 'high'). | CB <sub>1</sub> interrupt output mask bit CRB7 (IRQB <sub>1</sub> ) is set according to the interrupt signal CB <sub>1</sub> , and IRQB changes 'low'. | | | | | | | CRB1<br>(CB <sub>1</sub> active<br>edge bit) | | CRB7 (IRQB1) is set when CA1 is fallen. | CRB7 (IRQB1) is set when CA <sub>1</sub> is risen. | | | | | L | | CRB2 | | Data direction register B (DDRB) | Peripheral interface register B | | | | | | | CRB3<br>CB2<br>(Peripheral<br>Control<br>Line) | CB <sub>2</sub> | CB <sub>2</sub> interrupt output mask bit CBR6 (IRQB <sub>2</sub> ) is set according to the interrupt signal CB <sub>2</sub> , but IRQB is masked and not output (in short, IRQB = 'high'). | CB <sub>2</sub> interrupt output mask bit<br>CBR6 (IRQB <sub>2</sub> ) is set according<br>to the interrupt signal CB <sub>2</sub> . And<br>IRQB changes 'low'. | | : | | | | | CRB4<br>CB <sub>2</sub> (active<br>edge bit) | | CRB6 is set when CB <sub>2</sub> is fallen | CRB6 is set when CB2 is risen. | | | | | <b></b> | | CRB3 | | CRB4 = 0 Handshake mode bit The output CB <sub>2</sub> is 'low' when 'E' pulse is fallen on MPU is read the data from Peripheral Interface Register B and CB <sub>2</sub> is 'high' when CB <sub>1</sub> is active (edge). | CRB4 = 0 Handshake mode bit After reading, CB <sub>2</sub> is 'high' when next 'E' pulse is fallen on MPU is read the data from Interface Register B and, after reading, CB <sub>2</sub> is 'high' when next 'E' pulse is fallen. | | | | L | | | CRB4 | | CRB3 is the handshake mode bit. | The content of CRB3 is out to CB2. | | | | | | | CRB5<br>CB <sub>2</sub> input/<br>output select | t bit | CB2 is input mode | CB2 is output mode | | | <u></u> | <del></del> | <u></u> | | CRB6 (IRQB2 | 2) | No interrupt request from CB <sub>2</sub> or CB <sub>2</sub> is output (Reset Mode) | Interrupt request from CB <sub>2</sub> is occurred. | | L | | | | ., | CRB7 (IRQB <sub>1</sub> | ) | No interrupt request from CB <sub>1</sub> . | Interrupt request from CB <sub>1</sub> is occurred. | Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300 Table 3 Control of Interrupt Inputs CA<sub>1</sub> and CB<sub>1</sub> | CRA1<br>(CRB1) | CRAO<br>(CRBO) | Interrupt Input<br>CA <sub>1</sub> (CB <sub>1</sub> ) | Interrupt Flag<br>CRA7 (CRB7) | MPU Interrupt Request IRQA (IRQB) | |----------------|----------------|-------------------------------------------------------|-------------------------------------------------------|---------------------------------------------------------------------| | 0 | 0 | ↓ Active | Set "1" on ↓ of CA <sub>1</sub><br>(CB <sub>1</sub> ) | Disabled — IRQ remains "High" | | 0 | 1 | ↓ Active | Set "1" on ↓ of CA <sub>1</sub><br>(CB <sub>1</sub> ) | Goes "Low" when the inter-<br>rupt flag bit CRA7 (CRB7)<br>goes "1" | | 1 | 0 | † Active | Set "1" on ↑ of CA <sub>1</sub><br>(CB <sub>1</sub> ) | Disabled — IRQ remains<br>"High" | | 1 | 1 | † Active | Set "1" on 1 of CA <sub>1</sub><br>(CB <sub>1</sub> ) | Goes "Low" when the inter-<br>rupt flag bit CRA7 (CRB7)<br>goes "1" | (Notes) - f indicates positive transition ("Low" to "High") I indicates negative transition ("High" to "Low") The Interrupt flag bit CRA7 is cleared by an MPU Read of the A Peripheral Register and CRB7 is cleared by an MPU Read of the B Peripheral Register. If CRA9 (CRB0) is "0" when an interrupt occurs (Interrupt disabled) and is later brought "1", IROA (IROB) occurs after CRA0 (CRB0) is written to a "1". Table 4 Control of CA2 and CB2 as Interrupt Inputs - CRA5 (CRB5) is "0" | CRA5<br>(CRB5) | CRA4<br>(CRB4) | CRA3<br>(CRB3) | Interrupt Input<br>CA <sub>2</sub> (CB <sub>2</sub> ) | Interrupt Flag<br>CRA6 (CRB6) | MPU Interrupt<br><u>Request</u><br>IRQA (IRQB) | |----------------|----------------|----------------|-------------------------------------------------------|-------------------------------------------------------|---------------------------------------------------------------------| | 0 | 0 | 0 | ↓ Active | Set "1" on ↓ of CA <sub>2</sub><br>(CB <sub>2</sub> ) | Disabled — IRQ remains "High" | | 0 | 0 | 1 | ↓ Active | Set "1" on ↓ of CA₂<br>(CB₂) | Goes "Low" when the inter-<br>rupt flag bit CRA6 (CRB6)<br>goes "1" | | 0 | 1 | 0 | 1 Active | Set "1" on † of CA <sub>2</sub><br>(CB <sub>2</sub> ) | Disabled — IRQ remains<br>"High" | | 0 | 1 | 1 | ↑ Active | Set "1" on ↑ of CA₂<br>(CB₂) | Goes "Low" when the inter-<br>rupt flag bit CRA6 (CRB6)<br>goes "1" | ### (Notes) - f indicates positive transition ("Low" to "High") I indicates negative transition ("High" to "Low") The interrupt flag bit CRA6 is cleared by an MPU Read of the A Peripheral Register and CRB6 is cleared by an MPU Read of the B Peripheral Register. If CRA3 (CRB3) is "0" when an interrupt occurs (Interrupt disabled) and is later brought "1", IRQA (IRQB) occurs after CRA3 (CRB3) is written to a "1". Table 5 Control of CB<sub>2</sub> as an Output — CRB5 is "1" | | | | CB <sub>2</sub> | | | | | |------|------|------|-------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | CRB5 | CRB4 | CRB3 | Cleared | Set | | | | | 1 | 0 | 0 | "Low" on the positive transition of<br>the first E pulse after MPU<br>Write "B" Data Register operation. | "High" when the interrupt flag bit CRB7 is set by an active transition of the CB <sub>1</sub> signal. (See Figure 16) | | | | | 1 | 0 | 1 | "Low" on the positive transition of<br>the first E pulse after an MPU Write<br>"B" Data Register operation. | "High" on the positive edge of the<br>first "E" pulse following an "E"<br>pulse which occurred while the<br>part was deselected. (See Figure 16) | | | | | 1 | 1 | 0 | "Low" (The content of CRB3 is output on CB2) | | | | | | 1 | 1 | 1 | "High" (The content of CRB3 is output on CB <sub>2</sub> ) | | | | | **@HITACHI** Table 6 Control of CA<sub>2</sub> as an Output — CRA5 is "1" | | | CRA3 | CA <sub>2</sub> | | | | |-------|------|------|---------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|--|--| | CRA5 | CRA4 | | Cleared | Set | | | | 1<br> | 0 | 0 | "Low" on negative transition of E<br>after an MPU Read "A" Data Opera-<br>tion. | "High" when the interrupt flag bit<br>CRA7 is set by an active transition<br>of the CA <sub>1</sub> signal. (See Figure 16) | | | | 1 | 0 | 1 | "Low" on negative transition of E<br>after an MPU Read "A" Data opera-<br>tion. | "High" on the negative edge of the first "E" pulse which occurs during a deselect. (See Figure 16) | | | | 1 | 1 | 0 | "Low" (The content of CRA3 is output on CA <sub>2</sub> ) | | | | | 1 | 1 | 1 | "High" (The content of CRA3 is output on CA <sub>2</sub> ) | | | | ### PIA OPERATION ### Initialization When the external reset input $\overline{RES}$ goes "Low", all internal registers are cleared to "0". Periperal data port $(PA_0 \sim PA7, PB_0 \sim PB_7)$ is defined to be input and control lines $(CA_1, CA_2, CB_1)$ and $(CB_2)$ are defined to be the interrupt input lines. PIA is also initialized by software sequence as follows. - Program the data direction register access bit of the control register to "0" to allow to access the dada direction register. - The data of the control line function is set into the accumulator, of which Data Direction Register Access Bit shall be programmed to "1". - Transfer the control data from the accumulator into the control register. # Reed/Write Operation Not Using Control Lines Read Operation> # **OHITACHI** Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300 ### Write Operation> ### Read/Write Operating Using Control Lines Read/write request from peripherals shall be put into the control lines as an interrupt signal, and then MPU reads or writes after detecting interrupt request. ### < Reed > The following case is that Port A is used and that the rising edge of CA<sub>1</sub> indicates the request for read from peripherals. To read the peripheral data, the data is directly transferred to the data buses $D_0 \sim D_7$ through $PA_0 \sim PA_7$ or $PB_0 \sim PB_1$ and they are not latched in the PIA. If necessary, the data should be held in the external latch until MPU completes reading it. When initializing the control register, interrupt flag bit (CRA7, CRA6, CRB7, CRB6) cannot be written from MPU. If necessary the interrupt flag must be reset by dummy read of Peripheral Register A and B. ### <Write> Write operation using the interrupt signal is as follows. In this case, B port is used and interrupt request is input to $CB_1$ . And the $\overline{IRQ}$ flag is set at the rising edge of $CB_1$ . **(1)** HITACHI Interrupt request flag bits (CRA7, CRA6, CRB7 and CRB6) cannot be written and they cannot be also reset by write operation to the peripheral interface register. So dummy read of peripheral interface register is needed to reset the flags. To accept the next interrupt, it is essential to reset indirectly the interrupt flag by dummy read of peripheral interface register. Software poling method mentioned above requires MPU to continuously monitor the control register to detect the read/write request from peripherals. So other programs cannot run at the same time. To avoid this problem, hardware interrupt may be used. The MPU is interrupted by IRQA or IRQB when the read/write request is occurred from peripherals and then MPU analyzes cause of the interrupt request during interrupt processing. ### Hendshake Mode The functions of CRA and CRB are similar but not identical in the hand-shake modes. Port A is used for read hand-shake operation and Port B is used for write hand-shake mode. CA<sub>1</sub> and CB<sub>1</sub> are used for interrupt input requests and CA<sub>2</sub> and CB<sub>2</sub> are control outputs (answer) in hand-shake mode. Fig. 17, Fig. 18 and Fig. 19 show the timing of hand-shake mode. ### < Read Hand-shake Mode> CRA5="1", CRA4="0" and CRA3="0" - A peripheral device puts the 8-bit data on the peripheral data lines after the control output CA<sub>2</sub> goes "Low". - The peripheral requests MPU to read the data by using CA<sub>1</sub> input. - 3 CRA7 flag is set and CA<sub>2</sub> becomes "High" (CA<sub>2</sub> automatically becomes "High" by the interrupt CA<sub>1</sub>). This indicates the peripheral to maintain the current data and not to transfer the next data. - MPU accepts the read request by IRQA hardware interrupt or CRA read. Then MPU reads the peripheral register A. - S CA<sub>2</sub> goes "Low" on the following edge of read Enable pulse. This informs that the peripheral can set the next data to port A. ### <Write Hand-shake> CRB5 = "1", CRB4 = "0" and CRB3 = "0" - ① A peripheral device requests MPU to write the data by using CB<sub>1</sub> input. CB<sub>2</sub> output remains "High" until MPU write data to the peripheral interface register. - ② CRB7 flag is set and MPU accepts the write request. - MPU reads the peripheral interface register to reset CRB7 (dummy read). - Then MPU write data to the peripheral interface register. The data is output to port B through the output register. - (5) CB<sub>2</sub> automatically becomes "Low" to tell the peripheral that new data is on port B. - (6) The peripheral read the data on Port B peripheral data lines and set CB<sub>1</sub> to "Low" to tell MPU that the data on the peripheral data lines has been taken and that next data can be written to the peripheral interface register. ### <Pulse mode> CRA5 = "1", CRA4 = "0" and CRA3 = "1" CRB5 = "1", CRB4 = "0" and CRB3 = "1" This mode is shown in Figure 17, Figure 20 and Figure 21. # **OHITACHI** Figure 17 Timing of Hand-shake Mode and Pulse Mode **OHITACHI** Figure 18 Bits 5, 4, 3 of CRA = 100 (Hand-shake Mode) Figure 19 Bits 5, 4, 3 of CRB = 100 (Hand-shake Mode) **OHITACHI** Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300 Figure 20 Bits 5, 4, 3 of CRA = 101 (Pulse Mode) Figure 21 Bits 5, 4, 3 of CRB = 101 (Pulse Mode) **@HITACHI** Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300 # ■ SUMMARY OF CONTROL REGISTERS CRA AND CRB Control registers CRA and CRB have total control of $CA_1$ , $CA_2$ , $CB_1$ , and $CB_2$ lines. The status of eight bits of the control registers may be read into the MPU. However, the MPU can only write into Bit 0 through Bit 5 (6 bits), since Bit 6 and Bit 7 are set only by $CA_1$ , $CA_2$ , $CB_1$ , or $CB_2$ . ### Addressing PIAs Before addressing PIAs, the data direction (DDR) must first be loaded with the bit pattern that defines how each line is to function, i.e., as an input or an output. A logic "1" in the data direction register defines the corresponding line as an output while a logic "0" defines the corresponding line as an input. Since the DDR and the peripheral interface resister have the same address, the control register bit 2 determines which register is being addressed. If Bit 2 in the control register is a logic "0", then the DDR is addressed. If Bit 2 in the control register is a logic "1", the peripheral interface register is addressed. Therefore, it is essential that the DDR be loaded first before setting Bit 2 of the control register. ### <Example> Given a PIA with an address of 4004, 4005, 4006, and 4007. 4004 is the address of the A side peripheral interface register. 4005 is the address of the A side control register. 4006 is the address of the B side peripheral interface register. 4007 is the address of the B side control register. On the A side, Bits 0, 1, 2, and 3 will be defined as inputs, while Bits 4, 5, 6, and 7 will be used as outputs. On the B side, all lines will be used as outputs. | | PIA1AD = 4004<br>PIA1AC = 4005<br>PIA1BD = 4006<br>PIA1BC = 4007 | (DDRA, PIRA)<br>(CRA)<br>(DDRB, PIRB)<br>(CRB) | |----------------------------------------|-------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------| | 1.<br>2.<br>3.<br>4.<br>5.<br>6.<br>7. | LDA A #%11110000 STA A PIA1AD LDA A #%1111111 STA A PIA1BD LDA A #%00000100 STA A PIA1AC STA A PIA1BC | (4 outputs, 4 inputs) (Loads A DDR) (All outputs) (Loads B DDR) (Sets Bit 2) (Bit 2 set in A control register) (Bit 2 set in B control register) | Statement 2 addresses the DDR, since the control register (Bit 2) has not been loaded. Statements 6 and 7 load the control registers with Bit 2 set, so addressing PIA1AD or PIA1BD accesses the peripheral interface register. ### • PIA Programming Via The Index Register The program shown in the previous section can be accomplished using the Index Register. | 1. | LDX | #\$F004 | | |----|-----|---------|-------------------------| | 2. | STX | PIA1AD | \$F0→PIA1AD;\$04→PIA1AC | | 3. | LDX | #\$FF04 | | | 4. | STX | PIAIBD | \$FF→PIA1BD;\$04→PIA1BC | Using the index register in this example has saved six bytes of program memory as compared to the program shown in the previous section. ### Active Low Outputs When all the outputs of given PIA port are to be active "Low" (True ≤ 0.4 volts), the following procedure should be used. - Set Bit 2 in the control register. - b) Store all 1s (\$FF) in the peripheral interface register. - c) Clear Bit 2 in the control register. - d) Store all 1s (\$FF) in the data direction register. - e) Store control word (Bit 2 = 1) in control register. ### <Example> The B side of PIA1 is set up to have all active low outputs. CB<sub>1</sub> and CB<sub>2</sub> are set up to allow interrupts in the HAND-SHAKE MODE and CB<sub>1</sub> will respond to positive edges ("Low"-to-"High" transitions). Assume reset conditions. Addresses are set up and equated to the same labels as previous example. - 1. LDA A #4 - 2. STA A PIA1BC Set Bit 2 in PIA1BC (control register) - 3. LDA B #\$FF - 4. STA B PIA1BD All 1s in peripheral interface register - 5. CLR PIA1BC Clear Bit 2 - 6. STA B PIA1BD All 1s in data direction register - 7. LDA A #\$27 - STA A PIA1BC 00100111 → control register The above procedure is required in order to avoid outputs going "Low", to the active "Low" TRUE STATE, when all Is are stored to the data direction register as would be the case if the normal configuration procedure were followed. ### Interchanging RS<sub>0</sub> And RS<sub>1</sub> Some system applications may require movement of 16 bits of data to or from the "outside world" via two PIA ports (A side + B side). When this is the case it is an advantage to interconnect RS<sub>1</sub> and RS<sub>0</sub> as follows. RS<sub>0</sub> to A1 (Address Line A1) RS<sub>1</sub> to A0 (Address Line A0) This will place the peripheral interface registers and control registers side by side in the memory map as follows. | Table | Example Address | | | |--------|-----------------|-------------------|--| | PIATAD | \$4004 | —<br>(DDRA, PIRA) | | | PIA1BD | \$4005 | (DDRB, PIRB) | | | PIATAC | \$4006 | (CRA) | | | PIA1BC | \$4007 | (CRB) | | The index register or stackpointer may be used to move the 16-bit data in two 8-bit bytes with one instruction. As an example: LDX PIA1AD $\rightarrow$ IXH: PIA1BD $\rightarrow$ IXI ### PiA – After Reset When the RES (Reset Line) has been held "Low" for a minimum of one microsecond, all registers in the PIA will be cleared. Because of the reset conditions, the PIA has been defined as # **OHITACHI** #### follows - All I/O lines to the "outside world" have been defined as inputs. - CA<sub>1</sub>, CA<sub>2</sub>, CB<sub>1</sub>, and CB<sub>2</sub> have been defined as interrupt input lines that are negative edge sensitive. - All the interrupts on the control lines are masked. Setting of interrupt flag bits will not cause IRQA or IRQB to go "Low". ### ■ SUMMARY OF CA1-CB1 PROGRAMMING Bits 1 and 0 of the respective control registers are used to program the interrupt input control lines CA<sub>1</sub> and CB<sub>1</sub>. | <b>b1</b> | ь0 | | |-----------|----|---------------------------------| | 0 | 0 | b1 = Edge (0 = -, 1 = +) | | 0 | 1 | b0 = Mask (0 = Mask, 1 = Allow) | | 1 | 0 | | | 1 | 1 | | Note that this is the same logic as Bits 4 and 3 for CA<sub>2</sub>-CB<sub>2</sub> when CA<sub>2</sub>-CB<sub>2</sub> are programmed as inputs. ## ■ SUMMARY OF CA2-CB2 PROGRAMMING Bits 5, 4, and 3 of the control registers are used to program the operation of $CA_2 \cdot CB_2$ . | _ | <b>b</b> 5 | b4 | <b>b</b> 3 | | |---------------------------------------------|------------|------------------|------------|-------------------------------------------------------| | CA CB | 0 | 0(-) | 0 | (Mask) CA <sub>2</sub> -CB <sub>2</sub> Input Mode | | CA <sub>2</sub> –CB <sub>2</sub><br>Input → | 0 | 0(-) | 1 | (Allow) $b4 = Edge (0 = -, 1 = +)$ | | Mode → | 0 | 1(+) | 0 | (Mask) b3 = Mask (0 = Mask, | | Mode | 0 | 1(+) | 1 | (Allow) 1 = Allow) | | CA₂ –CB₂<br>Output →<br>Mode | 1 1 1 1 | 0<br>0<br>1<br>1 | 1 - | - Handshake Mode<br>- Pulse Mode<br>b3 Following Mode | ### I/O As Follow: Control Lines: CA<sub>1</sub> - Positive Edge, Allow Interrupt CA, - Pulse Mode $\mathsf{CB}_1$ — Negative Edge, Mask Interrupt CB, - Hand Shake Mode ### **Assume Reset Condition** PIA1AD PIA1AC PIA18D PIA18C PIA Configuration Solution 10111100 LDA A #\$BC STA A PIA1AD I/O to DDRA LDA A #\$FF 1111 1111 STA A PIA1BD I/O to DDRB LDA A #\$2F 0010 1111 STA A PIA1AC To "A" Control LDA A #\$24 0010 0100 STA A PIA1BC To "B" Control Figure 22 PIA Configuration Problem # **OHITACHI** ### ■ NOTE FOR USE ## Compatibility with NMOS PIA (HD6821) Table 7 Comparison CMOS PIA (HD6321) with NMOS PIA (HD6821) | Item | CMOS PIA (HD6321) | NMOS PIA (HD6821) | |----------------------------|--------------------------------------------------------------------------------|-----------------------------------------| | | Thrée-state output | Pull-up output | | Port A<br>Output<br>Buffer | DDRA ORA Internal Data Bus Read signal Measure for Input floating | DDRA DMOS PA, CA, CA, Internal Data Bus | | | Three-state output | Three-state output | | Port B<br>Output<br>Buffer | DDRB PB0 ~ PB, CB2 Internal Data Bus Read signal Measure for Input floating | DDRB NMOS PB, CB, CB, Internal Data Bus | There is no difference between CMOS PIA and NMOS PIA in pin arrangement.