# PDP 8e HARDWARE FAMILIARIZATION AND INTERFACING ## TABLE OF CONTENTS ### TUOCNAL ### SUBJECT | | • | |---------------------------------------|----------------------------------------------------------------------------------------------| | BLOCK DIAGRAM | MAJOR REGISTERS & DATA FLOW | | | 8/e TIMING | | · · · · · · · · · · · · · · · · · · · | | | 2 | MAJOR STATES FLOWS | | | MRI CODING FLOW DIAGRAM | | 3 | POWER UP SEQUENCE | | 4 | TIMING FLOW | | 4A | TIMING FLOW CONT. | | 5 | CORE MEMORY CONSTRUCTION | | 6 | X READ LINE LAYOUT | | | MEMORY ADDRESS SELECTION | | _ | MEMORY VENEZO SEPERTION | | 9 | MEMORY ADDRESS DECODER | | 7 | UMNIBUS & CHIP LOCATIONS | | 10 | BASIC LOGIC & TRUTH TABLES | | 11 | OMNIBUS & CHIP LOCATIONS BASIC LOGIC & TRUTH TABLES ADDER & I/O TRUTH TABLES | | 12 | MANUAL KEYS FLOW DIAGRAM | | 13 | KEY FUNCTIONS FLOWS | | 14 | ROTARY SWITCH SELECTOR FLOWS | | 15 | KEY FUNCTION SIGNALS, HANDOUT "A" DESCRIPTION OF 8/e OPERATIONS BUS LOGIC & 724 POWER SUPPLY | | MECHANIZATION TABLES | DESCRIPTION OF 8/e OPERATIONS | | 16 | BUS LOGIC & 724 POWER SUPPLY | | 17 | DEVICE CODE SELECTION | | 18 | INTERNAL I/O EXAMPLE INSTRUCTION SET | | 19 | SKIP & INT. REQ I/O OUTPUT | | | DATA AC / DATA DO CAMERIO | | 21 | DATA AC / DATA PC GATING | | 22 | AC DATA, CLR AC | | 23 | PC + DATA PC | | 24 | INTERRUPT SEQUENCE DESCRIPTION, SHEET #1 | | | INTERRUPT SEQUENCE DESCRIPTION, SHEET #2 | | 25 | INTERRUPT SEQUENCE DESCRIPTION, SHEET #3 | | 26 | INTERRUPT SEQUENCE FLOW DIAGRAM, SHEET 41 | | 27 | INTERRUPT SEQUENCE FLOW DIAGRAM. SHEET #2 | | 28 | INTERROGATION ROUTINE, SHEET #1 | | 29 | INTERROGATION ROUTINE, SHEET #2 | | 30 | POSITIVE I/O BUS FLOW DIAGRAM, SHEET #1 | | 31 | POSITIVE I/O BUS FLOW DIAGRAM, SHEET #2 | | 32 | POS. I/O INTERFACE BLOCK DIAGRAM | | 33 | I/O & DATA BREAK BLOCK DIAGRAM | | 34 | DATA BREAK MAJOR STATES | | 35 | ODMIONS GOD DDBAR WATER CALL | | 36 * | OPTIONS FOR BREAK MAJOR STATE | | 37 | EXTENDED MEMORY CONTROL BLOCK DIAGRAM | | 38 | FUNCTIONS OF IF & DF REGISTERS, SHEET #1 | | | FUNCTIONS OF IF & DF REGISTERS, SHEET #2 | | 39 | FUNCTIONS OF IF & DF REGISTERS, SHEET #3 | | | | MAJOR STATES GEN. 3 PROCESSOR CHATES A AT 450 n. sec SOURCE = L, AT 500 n. sec RETURN = L IN ORDER TO DISABLE MEMORY READ CURRENT. ALSO AT 500 n. sec TP2 = H TO PRODUCE A LOAD FOR TS2. AT 550 n. sec INTO THE TIMING CYCLE, TS2 = H, AND TS3 = L. AT 650 n. sec INTO THE TIMING CYCLE, WRITE = H IN PREPARATION FOR A MEMORY WRITE. AT 750 n. sec INTO THE TIMING CYCLE, SOURCE, RETURN, AND INHIBIT = H TO PROPAGATE MEMORY WRITE CURRENT AND INHIBIT CURRENT AT 850 n. sec INTO THE TIMING CYCLE, TP3 = H TO PRODUCE A LOAD FOR TS3. AT 900 n. sec INTO THE TIMING CYCLE, TS 3 = H AND TS 4 = L. AT 1100 n. sec INTO THE TIMING CYCLE, SOURCE, AND INHIBIT = L. AT1150 n. sec INTO THE TIMING CYCLE, RETURN, AND WRITE = L. THIS IS DONE TO DISABLE MEMORY WRITE AND INHIBIT CURRENTS. @ 1200 n. sec TP4=H alow condin AT 450 n. sec INTO THE TIMING CYCLE, SOURCE = L AND AT 500 n. sec RETURN = L TO DISABLE MEMORY READ CURRENT. AT 700 n. sec INTO THE TIMING CYCLE, TP2 = H TO PRODUCE A LOAD FOR TS2. AT 750 n. sec INTO THE TIMING CYCLE, TS2 = H AND TS3 = L. AT 850 n. sec INTO THE CYCLE WRITE = H IN PREPARATION FOR A MEMORY WRITE. AT 950 n. sec INTO THE TIMING CYCLE, SOURCE, RETURN, AND INHIBIT = H TO PROPAGATE MEMORY WRITE CURRENT AND INHIBIT CURRENT. AT 1050 n. sec INTO THE TIMING CYCLE, TP3 = H TO PRODUCE A LOAD FOR TS3. AT 1100 n. sec INTO THE TIMING CYCLE, TS3 = H AND TS4 = L. AT 1300 n. sec INTO THE TIMING CYCLE, SOURCE, AND INHIBIT = L. AT 1350 n. sec INTO THE TIMING CYCLE, RETURN, AND WRITE = L. THIS IS DONE TO DISABLE MEMORY WRITE AND INHIBIT CURRENTS. @ 1400 n. sec TP4=H 4A ## EXAMPLE OF X READ LINE LAYOUT THIS OCTAL DIGIT, WHICH IS COMPRISED OF MA O---2, WILL SELECT A READ OR WRITE LINE IN THE UPPER LEFT HAND QUADRANT. THIS OCTAL DIGIT, WHICH IS COMPRISED OF MA 3---5, WILL SELECT A READ OR WRITE LINE IN THE UPPER RIGHT HAND QUADRANT. -THIS OCTAL DIGIT, WHICH IS COMPRISED OF MA 6---8, WILL SELECT A READ OR WRITE LINE IN THE LOWER LEFT HAND QUADRANT. THIS OCTAL DIGIT, WHICH IS COMPRISED OF MA 9---11, WILL SELECT A READ OR WRITE LINE IN THE LOWER RIGHT HAND QUADRANT. FIG. 2: ILLUSTRATES THE UPPER LEFT HAND QUADRANT OF PRINT 3. EACH 8251 HAS 8 OUTPUT LINES; 4 FOR READ AND 4 FOR WRITE FUNCTIONS. ONE READ OR WRITE LINE( DEPENDING ON THE FUNCTION) MUST BE SELECTED IN ORDER TO SELECT THE DESIRED ADDRESS. THIS IS DONE BY THE COMBINATION OF THE MA BITS ( THE OUTPUT LINES WIRED AS SHOWN IN HANDOUT ). THE ABOVE INFORMATION IS APPLICABLE TO THE OTHER 3 QUADRANTS OF PRINT 3. # MEMORY ADDRESS DECODER WHEN READING, USE OUT ACTIVE PINS 4,5,6,7 WHEN WRITING, USE OUT ACTIVE PINS 0,1,2,3 0123 tunis 4867 tunis | A | В | C | |---|---|---| | Н | Ï | Н | | H | L | L | | L | I | L | | L | L | | | A | В | .C | |---|---|----| | H | Η | Н | | Н | L | H | | L | H | Н | | L | L | L | | A | В | С | |---|---|---| | Η | H | L | | Н | L | Н | | L | H | H | | L | L | H | | A | В | С | |---|---|----| | H | T | i | | Н | L | L. | | L | Н | L | | L | L | H | | Α | В | C | |---|---|---| | Н | Н | L | | Н | L | Н | | L | Η | Н | | L | L | L | #### ADDER LOGIC TRUTH TABLES | ENO | EN1 | EN2 | RESULT | |-----|-----|-----|--------| | L | L | L | PC | | L | L | • н | MD | | L | Н | L | MQ | | L | н | н | M.A | | Н | х | x | ZERO | | scentist by water | Proposition T | DATA F | RESULT | |-------------------|---------------|--------|------------------| | while regal water | L | L | COMPLEMENT | | A SHANN | L | н | TRUE (aumence of | | | Н | L | ZERO | | | | | P - 2 | 15 (2) 1 (2) (2) (3) (2) (2) | |------|-------|------|--------------|------------------------------| | PAGE | RIGHT | LEFT | TWICE | RESULT | | L | L | , L | r | CURRENT PAGE | | Х | L | L | н | AND | | Х | L | Н | L | RIGHT 2 | | Х | L | н | н | RIGHT 1 | | Х | н | L | L | LEFT 2 | | x | н | L | н | LEFT 1 | | Х | , H | н | 1. | SWAP | | X | н | н | ; <b>H</b> . | NO SHIFT | | н | L | L | L | PAGE ZERO | | | I/O SIGNALS | | | | | | |------------|-------------|----|-----------------|--|--|--| | CO | C1 | C2 | RESULT | | | | | : <b>L</b> | L | L | DATA PC | | | | | L | . L | н | DATA-AC | | | | | M on L | Н | L | PC + DATAPC | | | | | L | н | Н | AC DATA, CLR AC | | | | | ter H | L | L | DATA ——⇒PC | | | | | н | L | н | AC/DATA ored | | | | | Lor H | н | L | PC + DATA PC | | | | | н | н | н | AC/DATA oredAC | | | | Type of Tomode. Andra Ham import outpell ADDER CONDITIONS | | | N COMBIT | | | | |------|-------|----------|-----|---------|--| | LEFT | RIGHT | CAR IN | SUM | CAR OUT | | | н | н | н | н | н | | | , н | L | н | ·L | н | | | L | L | н | , н | L | | | H | н | L | L | н | | | н | L | L | . L | н | | | L | L | Ľ | L | L | | | Add | er Qui | tput_ | mux | | |-------------------------------------|-----------------------------------------|---------------------|------------------------|---------------------------------------------------------------------| | RIGHT<br>L<br>L<br>L<br>H<br>H<br>H | LEFT<br>L<br>H<br>H<br>L<br>L<br>H<br>H | TWICE L H L H L H L | PAGE 1 X X X X X X X H | Z USE CURRENT PAGE AND RTR RAR RTL RAL BYTE SWAP NO SHIFT PAGE ZERO | | LEFT<br>H<br>H<br>L<br>H<br>H | RIGHT<br>H<br>L<br>L<br>H<br>L | L<br>H<br>H<br>H<br>CI | SUM<br>H<br>L<br>H<br>L<br>H | H<br>H<br>L<br>H<br>L | |-------------------------------|--------------------------------|------------------------|------------------------------|-----------------------| |-------------------------------|--------------------------------|------------------------|------------------------------|-----------------------| | ENO | EN1 | EN2 | ADDER | IN | |-----|-----|----------|-------|----| | L | L | L | PC | | | L | L | . H | MD | | | L | H | ${ t L}$ | МŨ | 1 | | L | H | Н | CPMA | | | Н | X | Х | ZERO | | Otto Color | DATA T | DATA F | ADDER IN | |--------|---------|----------| | L | ${f L}$ | DATA BUS | | L | Н | DATA BUS | | Н | L | ZERO | | | | | | IND1 | IND2 | RESULT | |------|---------|-----------| | L | ${f L}$ | AC -> BUS | | L | Н | BUS | | Н | L | M:Q → BUS | | Н | H | STATUS | | | | • | | CO<br>L<br>L<br>H<br>H<br>H | C1<br>L<br>H<br>H<br>L<br>L<br>H | C2<br>L<br>H<br>L<br>H<br>L<br>H<br>L | RESULT DATA PC DATA PC PC + DATA PC AC DATA, 0 AC DATA PC AC ored DATA AC PC + DATA PC AC ored DATA AC PC + DATA PC AC ored DATA AC | |-----------------------------|----------------------------------|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------| |-----------------------------|----------------------------------|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------| ## PDP 8/e # KEY FUNCTION SIGNALS HANDOUT A | IND 1 | IND 2. | Result | |-------|--------|------------------------| | L | L | AC <del>&gt;</del> BUS | | L | н | BUS->BUS | | н | L | MQ →> BUS | | Н | Н | STATUS>BUS | | | | KEY I | ı∧ | |-----|-----------------|-------|------------------------------| | (A) | KEY CONTROL | н | Qualification for MA LOAD | | (B) | MS DISABLE | L | Disables MAJOR STATES and IR | | (c) | MD DIR. IN. | L. | NO use for KEY LA | | (D) | BK DATA CONTROL | L | NO use for KEY LA | | (E) | SRBUS | Н | Enables SR to the DATA BUS | | •. | KE | Y EXAM | 6 | |-----|------------------------|--------|-----------------------------------------------------------| | (A) | KEY CONTROL | L | Allows one timing cycle only | | (B) | MS DISABLE | L | Disables MAJOR STATES and IR | | (C) | MD DIR, IN. | L | Enables MEM>MD LINES | | (D) | BK DATA CONTROL | L | Enables MD->MB | | (E) | SRBUS | L | Disables SR──→BUS | | | | | | | ' | KI | EY DEP | | | (A) | KEY CONTROL | L DEP | Allows one timing cycle only | | (A) | | | Allows one timing cycle only Disables MAJOR STATES and IR | | | KEY CONTROL | L | · · · | | (B) | KEY CONTROL MS DISABLE | L<br>L | Disables MAJOR STATES and IR | THE 1.5K RESISTOR AND THE DIODE ARE LOCATED ON THE M 8320 (on the M 832) BUS LOADS CARD. | | H724 P | OWER SUPPLY | | | | |----------------|--------|-------------|-------|--------|--| | OUTPUT VOLTAGE | +15 V | +5 V | -15 Y | +8 V | | | CURRENT OUTPUT | 1 A | 20 A | A 8 . | 2 A | | | CURRENT USED | .8 A | 6 A | 4.5 A | 1.25 A | | | UNUSED CURRENT | .2 A | 14 A | 3.5 A | | | +3 V # DEVICE CODE SELECTIO! 011 010 Ba - 348 378 Device greeden (code 32) Remember "1" is LO ## INTERNAL I/O ## EXAMPLE INSTRUCTION SET | INSTRUCTION | FUNCTION | |-------------|----------------------------------------------------| | 6321 | CHECK FLAG AND SKIP IF =(1) | | 6322 | SKIP ONCE IF FLAG "A" = 1, | | | SKIP ONCE IF FLAG "B" = 1, device may have a flag. | | | SKIP TWICE IF FLAG "A" AND | | • | FLAG "B" ARE = 1. | | 6324 | TRANSFER AC TO DEVICE | | 6325 | TRANSFER AC TO DEVICE, OAC | | | • | | 6326 | TRANSFER DATA FROM DEVICE TO | | | AC. | 6327----- TRANSFER DATA TO THE PC. #### GATING FOR SKIP AND INT. REQ. FIG. 1 THE PURPOSE OF THIS GATING IS TO ALLOW SENSING OF SKIP CONDITIONS AND ACKNOWLEDGING INTERRUPT REQUESTS FROM THE DEVICE. ## I/O OUTPUT TRANSFER GATING CO C1 C2 H H = $$ACVDATA---AC$$ FIG. 2 THE PURPOSE OF THIS GATING IS TO ALLOW THE TRANSFER OF THE AC TO A REGISTER IN THE DEVICE. THIS GATING HAS THE SAME FUNCTION AS THAT OF FIG.#2 PLUS THE DATA FROM THE DEVICE REGISTER CAN BE TANSFERED TO THE AC. DATA $\rightarrow$ AC = Co=L, C1=L, C2=H 22 Ask pop ? - 1. BEFORE THE CPU IS ABLE TO ACKNOWLEDGE ANY INTERRUPT REQUESTS FROM DEVICES, THE INTERRUPT SYSTEM MUST BE ENABLED. THE FOLLOWING IS A PROCEDURE IN ORDER TO ENABLE THE INTERRUPT SYSTEM. - a) AN ION INSTRUCTION, 6001, MUST BE PERFORMED. THIS INSTRUCTION WILL "TURN ON" THE INTERRUPT SYSTEM ONLY HALF WAY. - b) ANY INSTRUCTION THAT FOLLOWS THE 6001 WILL FULLY ENABLE THE INTERRUPT SYSTEM. - 2. WHEN THE INTERRUPT SYSTEM HAS BEEN ENABLED, THE CPU IS CAPABLE OF ACKNOWLEDGING INTERRUPT REQUESTS. THE FOLLOWING IS A GENERAL DESCRIPTION OF ACKNOWLEDGING AN INTERRUPT REQUEST: - AT TP3 TIME OF ANY MAJOR STATE PROVIDING THAT FETCH IS THE NEXT MAJOR STATE TO OCCUR. BY ACKNOWLEDGING THE INTERRUPT REQUEST THE NORMAL OCCURENCES OF TS4 ARE DISABLED. INSTEAD OF PERFORMING PC---MA ( OR PC + 1----MA FOR A SKIP CONDITION) O'S ARE FORCED TO THE MA. THEREFORE; THE NEXT ABSOLUTE ADDRESS TO BE REFERENCED IS OOOO. ALONG WITH FORCING THE CPU TO GO TO ADDRESS OOOO, THE IR IS FORCED TO DECODE A JMS INSTUCTION. NOW THE CPU IS FORCED TO PERFORM A JMS INSTRUCTION AT ADDRESS 0000. SINCE THE CPU'S IR IS FORCED TO DECODE A JMS AND ABSOLUTE ADDRESS 0000 WAS FORCED TO THE MA, THE CPU CAN ELIMINATE THE NEED FOR A FETCH CYCLE. THE CONTROLING LOGIC FOR CHANGING MAJOR STATES IS FORCED TO PRODUCE THE CONDITIONS THAT WILL ALLOW THE MAJOR STATE OF EXECUTE TO OCCUR NEXT. THE VALUE OF THE PC ( WHICH IS THE NEXT INSTRUCTION'S ADDRESS FOR THE MAIN PROGRAM) WILL BE STORED IN ADDRESS 0000. ADDRESS 0000 IS NOW THE ENTRANCE POINT FOR RETURNING TO THE MAIN PROGRAM. THE FIRST INSTRUCTION OF THE SUBROUTINE WILL BE PERFORMED AT ADDRESS 0001. AT THIS POINT AN INTERROGATION ROUTINE IS EXECUTED (SEE HANDOUT 28). AS THE JMS IS EXECUTED, THE INT. SYS. IS AUTOMATICALY SHUT OFF. - 3. UPON THE COMPLETION OF THE INTERROGATION AND THE SERVICE ROUTINES, PROCEDURES FOR RETURNIG TO THE MAIN PROGRAM ARE AS FOLLOWS: - a) BECAUSE THE INTERRUPT SYSTEM WAS DISABLED DURING THE JMS, WHICH ALLOWED THE INTERRUPT BEING PROCESSED NOT TO BE INTERRUPTED BY ANOTHER INTERRUPT, THE INTERRUPT SYSTEM SHOULD BE ENABLED TO ACKNOWLEDGE ANY LOWER PRIORITY INTERRUPTS BEFORE RETURNING TO THE MAIN PROGRAM. THIS IS ACCOMPLISHED BY PERFORMING AN ION INSTRUCTION AT THE NEXT TO THE LAST ADDRESS OF THE SERVICE ROUTINE PROGRAM. THE ION INSTRUCTION IS THEN FOLLOWED BY THE JMP INDIRECT TO ADDRESS 0000. IF ANY LOWER PRIORITY INTERRUPTS ARE PRESENT AT THIS TIME, THEY WILL BE ACKNOWLEDGED ( ACCORDING TO PRIORITY) AND THE ORIGINAL CONTENTS OF ADDRESS 0000, WHICH HOLDS THE PC OF THE FIRST INTERRUPT WILL NOT BE CHANGED. # INTERROGATION ROUTINE EXAMPLE PROGRAM 0000/ PC (XXXX) 0001/ DCAs 3050 0002/ GTF 6004 0003/ DCAs 3051 0004/ JMP Is 5405 0005/ 7000 7000/ 6XXX 7001/ SKP 7410 7002/ JMP 5250 7003/ 6XXX 7004/ SKP 7410 7005/ JMP 5300 7006/ 6XXX 7007/ SKP 7410 7010/ JMP 5350 # DESCRIPTION OF BASIC INTERROGATION ROUTINE THE ABOVE PROGRAM IS AN EXAMPLE OF A BASIC INTERROGATION ROUTINE. IN ADRESS 0000 THE PC (WHICH IS THE ADDRESS OF THE NEXT INSTRUCTION FOR THE MAIN PROGRAM) IS STORED FROM THE FORCED JMS OF THE INTERRUPT SYSTEM. THE DCA 3050 LOCATED IN ADDRESS 0001 IS USED TO STORE THE AC VALUE IN CASE THE DEVICE CAUSING THE INTERRUPT TRANSFERS INFORMATION TO THE AC. THE CONTENTS OF ADDRESS 0002, A GTF, IS USED TO BRING THE VALUE OF THE LINK INTO THE AC. THE GTF IS FOLLOWED BY A DCA 3051, IN LOCATION 0003, SO THAT THE VALUE OF THE LINK MAY BE STORED IN MEMORY. THE JMP I LOCATED IN ADDRESS 0004 IS USED TO EXIT PAGE "O". THE REASON FOR EXITING PAGE"O" IS THAT IT IS USED FOR AUTO INDEX PURPOSES AS WELL AS DIRECT ACCESS FROM ALL PAGES. - while are instructions, and desattain. THE JMP I TAKES THE PROGRAM TO ADDRESS 7000 WHERE THE INTERROGATION ROUTINE BEGINS. THE FIRST PART OF THE PROGRAM WAS WRITTEN FOR "HOUSE CLEANING" PURPOSES. THE INSTRUCTION LOCATED IN ADDRESS 7000, LISTED AS 6XXX, WILL CHECK INTERRUPT FLAG OF THE FIRST DEVICE (PRIORITY 0) FOR A SKIP CONDITION. IF THAT DEVICE'S INTERRUPT FLAG WAS SET, A SKIP CONDITION WOULD RESULT CAUSING THE PROGRAM TO REFERENCE ADDRESS 7002 INSTEAD OF 7001. THE INSTRUCTION AT ADDRESS 7002, AJMP 5250, WILL ENTER THE SERVICE ROUTINE FOR DEVICE PRIORITY 0. #### EXAMPLE PROGRAM IF DEVICE O'S INTERRUPT FLAG WAS NOT SET, THE PROGRAM WOULD REFERENCE ADDRESS 7001. AN UNCONDITIONAL SKIP, 7410, LOCATED AT ADDRESS 7001 WILL CAUSE THE PROGRAM TO SKIP OVER THE JMP 5250. THUS THE ENTRANCE POINT FOR THE SERVICE ROUTINE OF DEVICE O IS SKIPPED OVER. THE SAME SEQUENCE OF CHECKING THE INTERRUPT FLAGS APPLIES TO THE OTHER TWO DEVICES. THE NEXT PORTION OF THE EXAMPLE PROGRAM DEMONSTRATES HOW TO ENTER THE MAIN PROGRAM AND ALSO ENABLE THE INTERRUPT SYSTEM. THIS PORTION OF THE PROGRAM WILL BE EXECUTED AFTER THE MAIN PORTION OF THE SERVICE ROUTINE HAS BEEN COMPLETED. (AS AN EXAMPLE, DEVICE PRIORITY 1 WILL BE USED) 7124/ CLA 7200 7125/ TAD 1051 7126/ RTF 6005 7127/ CLA 7200 7130/ TAD 1050 7131/ ION 6001 7132/ JMP 5400 AT LOCATION 7124, A CLA CLEARS THE AC IN PREPARATION FOR RESTORING THE VALUES THAT WERE STORED IN MEMORY BY THE "HOUSE CLEANING" PORTION OF THE PROGRAM. THE TAD INSTRUCTION, 1051, LOCATED AT ADDRESS 7125 WILL BRING THE ORIGINAL CON-DITION OF THE LINK, PRIOR TO THE INTERRUPT, INTO THE AC. FOLLOWING THE TAD INSTRUCTION IS A RTF INSTRUCTION. THIS INSTRUCTION WILL RETURN THE ORIGINAL CONTENTS OF THE LINK, WHICH IS NOW IN THE AC, BACK INTO THE LINK. THE NEXT LOCATION, 7127, HOLDS A CLA INSRUCTION. THIS WILL BE USED TO CLEAR THE AC IN PREPARATION FOR RESTORING THE ORIGINAL AC, PRIOR TO THE INTERRUPT. AFTER THE AC HAS BEEN CLEARED BY THE CLA, THE TAD INSTRUCTION, 1050, AT ADDRESS 7130 WILL BRING THE ORIGINAL CONTENTS OF THE AC, PRIOR TO THE INTERRUPT, BACK INTO THE AC. THE 6001 INSTRUCTION, ION, WILL PARTIALLY ENABLE THE INTERRUPT SYSTEM. THE LAST INSTRUCTION. 5400. WILL FULLY ENABLE THE INTERRUPT SYSTEM AND ALLOW THE PROGRAM TO RETURN TO ADDRESS 0000. FROM THIS POINT THE PROGRAM CAN ENTER THE MAIN PROGRAM OR ACKNOWLEDGE ANY LOWER PRIORITY INTERRUPTS THAT MAY BE PRESENT. STRORE RIIS OF #### 3 CYCLE BREAK (layel reserrable inter) WORD COUNT CURRENT ADDRESS BREAK THE PURPOSE OF THIS STATE IS TO INCREMENT A MEMORY WORD LOCATED AT A KNOWN MEMORY ADDRESS. THIS KNOWN MEMORY ADDRESS IS SPECIFIED BY THE 3 CYCLE DEVICE. THE MEMORY WORD LOCATED AT THIS ADD RESS IS THE 2°S COMPLI MENTED VALUE OF THE NUMBER TRANSFERS TO BE PERFORMED. IF THE MEMORY WORD IS WORD COUNT OVERFLOW IS SENT TO THE DEVICE TO INHIBIT ANY MORE BREAK REQ. THE PURPOSE OF THIS STATE IS TO SPECIFY AN ADDRESS AT WHICH THE TRANSFER TAKES PLACE. THIS FUNCTION CAN BE DONE 2 WAYS. 1) A KNOWN VALUE, LOCATED AT THE INCREMENTED VALUE OF THE MEM-ORY ADDRESS OF THE WORD COUNT STATE WILL BE INCREMENTED EACH TIME THIS STATE IS REFERENCED. THIS INCRE-MENTED VALUE IS USED FOR THE MA OF THE BREAK STATE, THUS ALLOWING SEQUENTIAL DATA TRANSFER'S FROM MEM-ORY. 2) THE KNOWN VALUE NEED NOT BE INCREMENTED ALLOWING DATA TRAN-SFERS AT A CONSTANT ADDRESS. HOWEVER; THIS METHOD REQUIRES A BACK GROUND PROGRAM. THE PURPOSE OF THIS STATE IS TO PERFORM THE TRANSFERS. THERE ARE 4 FUNCTIONS WHICH MAY BE ACCOMPLISHED 1) DATA MAY BE TRANSFERED FROM THE DEVICE TO THE CPU. 2) DATA FROM THE CPU MAY BE TRANSFERED TO THE DEVICE. 3) DATA FROM THE DEVICE MAY BE ADDED WITH A MEMORY WORD FROM THE CPU. 4) A MEMORY WORD OF THE CPU MAY BE INCREMENTED. ALL 4 FUNCTIONS ARE PERFORMED AT A MEMORY ADDRESS SPECIFIED BY THE CURRENT ADDRESS STATE. ## OPTIONS FOR BREAK MAJOR STATE | WRITE (DATA OUT) D1 (0) THO (0) | (MEM!) MDL PERIPH. | CONTENTS OF MEMORY<br>SENT TO PERIPH AND<br>WRITTEN BACK INTO<br>MEMORY | |----------------------------------------|-------------------------------------------------------------|-------------------------------------------------------------------------------------| | READ<br>(DATA IN)<br>D1 (1)<br>INC (0) | DATA LINES—DATA BUS—MB MDL— (MEM) | DATA FROM PERIPH WRITTEN INTO MEMORY | | INC (MEM) DI (0) INC (1) | (MEM) - MDL DATA BUS = 1 DATA BUS + MDL - MB - (MEM) | CONTENTS OF MEMORY<br>+1 WRITTEN BACK INTO<br>MEMORY<br>(USED AS A COUNTER) | | DATA ADDED TO DI (1) INC (1) | (MEM) -> MDL DATA LINES -> DB DATA BUS + MDL -> MB -> (MEM) | BREAK DATA IS ADDED<br>TO THE CONTENTS OF<br>MEMORY AND WRITTEN<br>BACK INTO MEMORY | ## INSTUCTION PIELD AND DATA FIELD #### REGISTERS THE FOLLOWING INFORMATION DESCRIBES THE RELATIONSHIP BETWEEN THE CPU MAJOR STATES AND EXTENDED MEMORY FUNCTIONS. KEY FUNCTIONS: ALTHOUGH THE CPU IS IN NO MAJOR STATE, EXTENDED MEMORY MUST STILL CONTROL WHAT FIELD WILL BE REFERENCED DURING KEY FUNCTIONS. BECAUSE OF THIS. THE PROGRAMMER HAS A CHOICE OF ANY FIELD ( LIMITED, OF COURSE, TO THE AMOUNT OF CORE ON THE SYSTEM) TO MANUALLY DEPOSIT OR EXAMINE DATA. THE CONTENTS OF THE IF REGISTER DETERMINES WHICH FIELD WILL BE REFERENCED DURING KEY FUNCTIONS. FETCH: THE CONTENTS OF THE IF REGISTER WILL DETERMINE WHAT FIELD WILL BE REFERENCED TO OBTAIN INSTRUCTIONS. THIS CONDITION IS TRUE FOR ANY FETCH MAJOR STATE. DEFER: THE CONTENTS OF THE IF REGISTER WILL DETER-MINE FROM WHAT FIELD THE POINTER ADDRESS WILL BE OBTAINED. HOWEVER; AT TP4 TIME OF DEFER EITHER THE IF OR THE DF REGISTER CAN BE THE REGISTER THAT WILL SPECIFY THE FIELD AT TP4 TIME OF EACH MAJOR STATE EXT. MEM. CONT. LOGIC DECIDES #### FUNCTIONS OF ## INSTRUCTION FIELD AND DATA FIELD REGISTERS DEFER---- (cont.) \_\_ TO BE REFERENCED FOR THE EXECUTE MAJOR STATE. THIS IS DEPENDENT UPON WHAT TYPE OF INSTRUCTION IS BEING PERFORMED. IF AN AND, TAD, ISZ, OR DCA IS BEING PERFORMED, THE CONTENTS OF THE DF REGISTER WILL DETERMINE WHICH FIELD WILL BE REFERENCED TO OBTAIN DATA FOR THE EXECUTE MAJOR STATE. IF THE CONTENTS OF THE DF \( \neq \) IF THE PROGRAMMER NOT ONLY HAS THE CAPABILITY OF OBTAINING DATA FROM ANY MEMORY PAGE; HE ALSO HAS THE CAPABILITY OF REFERENCING A DIFFERENT MEMORY FIELD IN ORDER TO OBTAIN DATA. ON THE OTHER HAND; IF THE DF = IF, A NORMAL INDIRECT IS PERFORMED IN THE SAME PIELD THE INSTRUCTION AND THE POINTER WERE OBTAINED. IF A JMS OR JMP IS BEING PERFORMED, THE DF REGISTER WILL NOT SPECIFY THE FIELD TO BE REFERENCED IN EXECUTE; THE IF REGISTER WILL.THE REASON FOR THIS IS THAT A JMP NEVER ENTERS THE EXECUTE STATE. IF THE DF REGISTER COULD SPECIFY WHICH FIELD TO REFERENCE DURING THE NEXT MAJOR #### FUNCTIONS OF ## INSTRUCTION FIELD AND DATA FIELD #### REGISTERS DEFER ----- (cont.) INSTRUCTION WOULD BE FETCH, THE NEXT INSTRUCTION WOULD BE OBTAINED FROM THE FIELD SPECIFIED BY THE DF REGISTER. THIS WOULD DEFEAT THE PURPOSE OF THE DF REGISTER AS IT IS USED ONLY TO OBTAIN DATA; NOT INSTRUCTIONS. BECAUSE THE JMP INDIRECT CANNOT USE THE DF REGISTER TO SPECIFY A FIELD TO REFERENCE FOR THE EXECUTE MAJOR STATE, THE JMS INSTRUCTION IS FORCED TO DO THE SAME. IF THE JMS INSTRUCTION COULD USE THE DF REGISTER TO SPECIFY WHICH FIELD TO REFERENCE FOR THE EXECUTE MAJOR STATE, THE PC WOULD BE STORED IN THAT PARTICULAR FIELD. HOWEVER; UPON RETURNING FROM THE SUBROUTINE, WHICH REQUIRES THE USE OF A JMP INDIRECT TO THE ADDRESS WHERE THE PC IS LOCATED, THE FIELD WHERE THE PC IS STORED COULD NOT BE REFERENCED. WHY? A JMP INDIRECT CANNOT REFERENCE A FIELD SPECIFIED BY THE DF REGISTER. EXECUTE ----- THE EXECUTE MAJOR STATE CAN REDERENCE A FIELD SPECIFIED BY THE IF OR DF. (SEE ABOVE INFORMATION OF DEFER FOR EXPLANATION) not very good. PDP-8/E INTERFACING COURSE TRAINING NOTES PRELIMINARY (dury mine ing ) ## ABOUT THIS MANUAL This manual has been written to be used in conjunction with the PDP 8/e Family Interfacing Seminar, and as such should not be taken as the only reference for such information. # INDEX | PROCESSOR TIMING01 | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IOT INSTRUCTIONS05 | | OMNIBUS SIGNALS07 | | OMNIBUS SIGNAL DESCRIPTIONS10 | | DEVICE SELECTION20 | | INTERNAL vs. EXTERNAL I/O21 | | INTERNAL INTERFACES22 | | EXTERNAL INTERFACES | | POSITIVE I/O31 | | PROGRAM INTERRUPT35 | | DATA BREAK38 | | DATA BREAK SIGNAL DESCRIPTIONS45 | | | | | | DRAWINGS | | | | POSITIVE I/O TIMING02 | | POSITIVE I/O TIMING | | POSITIVE I/O TIMING02 | | POSITIVE I/O TIMING | | POSITIVE I/O TIMING | | POSITIVE I/O TIMING | | POSITIVE I/O TIMING | | POSITIVE I/O TIMING. 02 C.P. TIMING. 04 IOT INSTRUCTION FORMAT. 06 OMNIBUS SIGNAL LISTING. 08 INTERNAL DEVICE SELECTION. 24 CONTROL LINE TRUTH TABLE. 27 EXTENDED IOP GENERATION. 28 | | POSITIVE I/O TIMING. 02 C.P. TIMING. 04 IOT INSTRUCTION FORMAT. 06 OMNIBUS SIGNAL LISTING. 08 INTERNAL DEVICE SELECTION. 24 CONTROL LINE TRUTH TABLE. 27 EXTENDED IOP GENERATION. 28 DATA TRANSFER TRUTH TABLE 30 | #### PDP-8/e INTERFACING SEMINAR DAILY BREAKDOWN ## DAY 1 - A. Block Diagram - B. Timing - C. IOT Instructions - D. Omnibus Signals #### DAY 2 - A. Internal InterfacingB. External Interfacing #### DAY 3 - A. Data Break - B. Program Interrupt #### Interfacing Seminar Cont'd. #### VII. Data Break - A. Purpose - B. Theory of operation 1. Block diagram - Timing diagrams Interrelation to C.P. - 4. Sample usage #### VIII. Program Interrupt - A. Purpose - B. Theory of operation - C. Hardware implementation #### PROCESSOR TIMING Processor operations are broken down into cycles which are in turn broken down into time states and time pulses. Each cycle represents a reference to memory in which a word is removed from or put into memory, thus for each data word that an instruction requiples from memory a new cycle is initiated. Consequently, there may be one, two, or three cycles for each instruction. Our main concern with timing is not the individual cycles, but rather the various subdivisions of the cycle. Each cycle is divided into four parts referred to as time periods. A time period consists of a rather long time state (approx. = 300ns.) and a short time pulse at its end (100 ns.). The four time periods are referred to as T1, T2, T3, and T4. (See timing diagram No. INT-8). The time states in each cycle are used to enable data, that is they are used to determine what data is to be transferred. The time pulses are used to load registers, which is to say that they determine where the selected data is to go. Since the sequence for timing is a time state followed by a time pulse, this means that the processor first figures out what date is to be transferred and then were to put it. You will note that there are four time periods just as there are four major registers. Generally (though not exclusively) each time period is dedicated to a particular register, as follows: - 1. Tl is used for modification of the PC. - 2. T2 is used for modification of the MB. - 3. T3 is used for modification of the AC. (note that since it is the AC to and for which all data transfers take place for I/O operations, that these operations will have to take place during time 3, with time state 3 being used to enable data onto and off of the bus, and time pulse 3 being used to load the data into the AC or some peripheral buffer.) 4. T4 is used to modify the MA. (CPMA). When the type of interface being used is of the internal variety it is up to the user to see to it that all operations with the bus are concluded within the confines of T3. While if the interface is external, the positive I/O bus option will stall the processor timing in order to allow sufficient time to communicate with a peripheral that might be located at the end of a considerable length of cable (up to 50ft. in the case of the positive I/O. For a diagram of timing as applicable to the Positive I/O see drawing No. INT-7. (massing) #### IOT INSTRUCTIONS The instructions used by the computer to communicate with the peripherial devices are called IOT instructions. These instructions take the form of 12 bit numbers and carry three pieces of information. - 1. The first three bits from the OP CODE, which is a 6 to specify that the instruction is an IOT. - 2. The next six bits carry the device code, that is, a number which specifies the device to be dealt with. - 3. The last three bits of the instruction contain the function bits. These three bits specify to the device the function it is to perform. These last three bits can be interrpreted in one of two ways. - 1. If the device is an internal type interface the last three bits are converted from binary to octal to produce one of eight different commands. - 2. If the device uses an external type interface. The last three bits are picked up by the positive I/O interface which will in turn generate one, two, or three IOP pulses. The peripheral will then use these pulses to determine what function to perform. It should be kept in mind that when the C.P. executes these instructions that all 12 bits of the instruction code are available to the user on the MD bus lines. It is from here that they are taken to be used by the device to select a device code as well as to determine the function. It is not necessary for the device to consider the first three bits of the instruction, since the C.P. will generate the signal I/O PAUSE whenever it detects an IOT instruction. It will be shown later that the signal I/O PAUSE must be used by the device interface to gate all its data to and from the C.P. #### OMNIBUS SIGNALS A complete list of all signals on the omnibus is presented in drawing INT-9. The signals shown with an \* are the primary signals used in interfacing and are discussed in the section entitled "Signal Description". All signals on the Bus are low true (that is, they are grounded for assertion) except for those marked with a #, which are asserted by allowing them to float high (approx. = 3 volts). Note that a bus loads module in the computer pulls all low true signals to a high when they are not asserted. | | T | | |--------------------------|-----------------------------------------------------|-------| | BRK CYCLE | BL2 | * | | BRK DATA CONT | BK2 | * | | RK IN PROG | BE2 | * | | BUS STROBE | CK1 | * | | CPMA DISABLE | CUI | * | | C0 | CEI | * | | Cl | CH1 | * | | C2 | 3 | * | | DEFER | CJ1<br>DK2 | ^ | | DATA BUS 0 | 1 | _ | | DATA BUS 1 | ARI | * | | DATA BUS 2 | AS1 | * | | DATA BUS 3 | AUD1 | * | | | AV1 | * | | | BR1 | * | | DATA BUS 5 | BS1 | | | DATA BUS 6 | BUl | * | | DATA BUS 7 | BV1 | * | | DATA BUS 8<br>DATA BUS 9 | DR1 | * * * | | | DS1 | * | | DATA BUS 10 | DUl | * | | DATA BUS 11 | DV1 | * | | EMA 0 | AD2 | | | EMA 1 | AE2 | | | EMA 2 | AH2 | , er | | EXECUTE | DL2 | | | FETCH | DJ2 | | | F SET | DP2 | | | ROUND | AC1 | | | | AF1 | | | | ANl | | | | ATl | | | | AC2 | | | | AC2<br>AF2<br>AN2<br>AT2 | | | | AN2 | | | | AT2 | | | | | | | | BF1 | | | • | BNl | | | | BTÍ | | | | BC2 | | | | BF2 | | | | BN2 | | | | BT2 | | | | CC1 | | | • | CF1 | 1 | | | CN1 | - 1 | | | CT1 | | | · | CC2 | | | | CF2 | | | | CN2 | | | | BF1 BN1 BC2 BF2 BN2 BT2 CC1 CN1 CT1 CC2 CF2 CN2 CD2 | | | | DC1 | l | | | | | | GROUND (cont.) | 202 | | |--------------------------------|------|----------| | GROOND (CONE.) | DF1 | | | | DN1 | | | | DT1 | | | | DC2 | | | | DF2 | | | • | DN2 | | | | • | | | IR 0 | DT2 | 1 | | | DD2 | | | IR 1 | DE2 | | | IR 2 | DH2 | l | | IND 1 | CU2 | | | IND 2 | CV2 | | | INITIALIZE fram king | CR1 | *# | | INTERNAL I/O | CL1 | * | | INTERRUPT IN PROG | BP2 | | | INTERRUPT ROST | £ | * | | | CP1 | | | INTERRUPT STROBE | BD2 | | | INHIBIT | AP2 | | | I/O PAUSE or and the or parts | CD1 | * | | KEY CONTROL | DU2 | | | LINK | AV2 | | | LINK DATA | CR2 | | | LINK LOAD | CS2 | | | LOAD ADDR ENABLE | BM2 | | | MD 00 | 8 | * | | | AK1 | i 1 | | MD 01 | ALl | * | | MD 02 | AMl | * | | MD 03 pode<br>MD 04 don't sold | AP1 | * | | MD 04 | BK1 | * | | MD 05 | BLl | * | | MD 06 · | BM1 | * | | MD 07 | BP1 | * | | MD 08 | DK1 | * | | MD 09 | DL1 | * | | MD 10 | DM1 | * | | MD 11 | | <b>.</b> | | I : | DP1 | | | MA 00 | 2101 | * | | MA 01 · | AEl | * | | MA 02 | AH1 | * | | MA 03 | AJl | * | | MA 04 | BD1 | * | | MA 05 | | * | | MA 06 | | * | | MA 07 | | * | | MA 08 | DO 1 | * | | MA 09 | DE1 | * | | MA 10 | | * | | | DHl | | | MA 11 | DJl | * | | MA, MS LOAD CONTR | BH2 | * | | MD DIR | AK2 | | | MEM START | AJ2 | | | MS DISABLE | CV1 | * | | | | • | \* = primary signals used in interfereing. | | | | * | |-----------------|------|-----|----------------| | NOT LAST XFER | CMl | * | | | OVERFLOW | BJ2 | | | | POWER OK | BV2 | l | | | PULSE LOAD ADDR | 1 | 1 | | | | DR2 | · · | | | RETURN | AR2 | | | | ROM ADDR | AU2 | | | | RUN | BU2 | * | | | SKIP | CS1 | * | is not also FF | | SOURCE | AL2 | | | | STOP | DS2 | * | | | STROBE | AM2 | | | | SWITCH | DV2 | ' | 1 | | TP 1 | CD2 | | | | TP 2 | CE2 | | | | TP 3 | CH2 | * | | | TP 4 | 1 | ^ | | | | CJ2 | | | | TS 1 | CK2 | 1 | | | TS 2 | CL2 | | • | | TS 3 | CM2 | * | | | TS 4 | CP2 | | | | USER MODE | DM2 | | | | WRITE | AS2 | | · | | MISC. | | | | | | | i. | | | TEST POINTS | AA1 | - | ٠, | | | ABl | | <i>j</i> # | | | BAl | | | | | | | | | | BB1 | | | | | CAl | | 1 | | | CBl | | | | | DAl | | | | | DB1 | | | | RESERVED | BR2 | | | | | BS 2 | | | | | | | | | VOLTAGES | | | | | 702271620 | | - | | | +5 | AA2 | | | | | | | | | | BA2 | | | | | CA2 | | | | 15 | DA 2 | | | | -15 | AB2 | | | | | BB2 | | 4 | | · | CB2 | | | | | DB2 | | | | | i | | | | | | | | | | | | | | | | . [ | | | | | 1 | | | | | | | | | | į | | | | | 1 | • | | | | Į | | | | | - 2 | | DATA BUS BITS These are the 12 lines that carry data to and from the AC during internal I/O operations. NOTES: MD BUS BITS These are the 12 lines that carry data to and from memory. In interfacing they are primarily used to carry the device codes to all peripherals during I/O operations, and they also carry the function buts to the Internal interface deives. MA BUS BITS These 12 lines carry the address information to the memory. It is here that the new data break address is applied if the data break interface is being used. NOTES: CPMA DISABLE This signal is used to remove the CPMA from the MA bus. This feature is only used by the DATA BREAK interface which supplies its own MA information. MA, MS LOAD CONTROL This signal when asserted prohibits the MA and the major states from being loaded and thus changed. This is asserted during a data break transfer where the data break interface supplies its won major states. It also removes the CPMA from the MA bus. This is done because the DATA BREAK interface also supplies its own MA. NOTES: MS DISABLE This signal is used to disable the processors major states during break transfers. INTERNAL I/O This signal is controlled by the various peripherals and is used to distinguish between the internal and the external type of peripheral. When asserted it means internal, and when not asserted it indicates that the device is External, at which time it activates the positive I/O interface. NOTES: NOT LAST XFER When asserted this signal will cause the C.P. timing to stall. That is, it will cause the timing to remain in TS3 once it is entered, until a BUS STROBE occurrs after this signal is no longer asserted. BUS STROBE This is used as a substitute load pulse in the absence of TP3. It is used by EXTERNAL interfaces only, since this type of interface requires the stalling of C.P. timing. Keep in mind that no data transfers can be completed without loading the data into some register, and that a load pulse is required to do the loading. NOTES: CO, Cl, C2 These are the three control signals used by an INTERNAL interface to control transfers to and from the AC. TP3 is the pulse that the C.P. normally uses to load the AC and to clock the skip flip-flop. It is used for this by the INTERNAL interfaces, but since it is absent when using the EXTERNAL interfaces (due to the Positive I/O interface) it must be compensated for by the generation of BUS STROBES. It is during TS3 that all peripheral transfers to and from the AC must take place. It is also the time state in which the C.P. stalls when the Positive I/O is used. For INTERNAL type interfaces the user must gate his data on and off the bus with TS3. (Note that the signal I/O PAUSE occurrs during TS3 so that it is the best signal to use for this purpose). SKIP This is the skip bus used by INTERNAL INTERFACES only. If it it asserted during I/O PAUSE time a skip flip-flop in the C.P. will set causing the next sequential instruction in the program to be skipped. NOTES: Use in for ? I/O PAUSE This signal, when asserted, states that the processor is executing an IOT instruction. Because of this, I/O PAUSE is used as the enabling level to gate data onto and off of the data bus. It can also be used to gate the skip conditions onto the skip bus. INTERRUPT REQUEST This signal is asserted by a peripheral that wishes to trigger an interrupt sequence. If the interrupts are active when this signal is asserted, the C.P. will unconditionally execute a JMS 0000. NOTES: BRK CYCLE This signal indicates that the data break interface is in the break major state and that data is being transferred into or out of memory. INITIALIZE This signal is generated in one of two ways, it is generated from the front panel by pressing the clear key, and it also can be generated by the CAF (clear ALL FLAG) instruction. In either case the signal is used to clear the AC and the LINK as well as the flags in all the peripherals. NOTES: <u>RUN</u> Whenever RUN is asserted it simply indicates that the C.P. is in the process of executing instructions. (C.P. not halted) STOP If STOP is asserted it will cause the processor to halt at the completion of the next cycle. (That is, the next reference of memory) #### **DEVICE SELECTION** When an IOT instruction is executed by the C.P. it is up to the individual devices to determine which one is being referenced by the instruction. This is accomplished by device codes. The device codes, as discussed in the section on IOT instructions, are the two digit numbers located in the center six bits of the instruction. These bits are available on the MD bus (bits 3 through 8). The purpose of the device selector logic in the interface is to compare the code coming from the instruction with the code selected for the device. This is don@e as indicated in drawings INT - 3 and INT-5. It is a further function of the device selector to generate a signal that can be used to enable all logic in the interface once it is determined that this is the device being referenced. #### INTERNAL vs. EXTERNAL I/O For all input-output operations, the processor is controlled by the following signals: CO, Cl, C2 BUS STROBE SKIP An internal interface is one in which the device interface itself directly controls these signals on the OMNIBUS to govern the I/O operation. An external interface utilizes the Positive I/O BUS option to control these signals and in effect puts an interface between the C.P. and the actual device interface. #### INTERNAL INTERFACES ADVANTAGE: The primary advantage to utilizing the internal type of interface is speed. Since the IOP generator is not required a great savings in time can be realized by employing this type of interface. Where a typical external I/O instruction may require 4.25 micro seconds to execute, a comparable instruction for an internal device would only take 1.2 us. DISADVANTAGE: The main disadvantage to an internal interface is the complexity of the design. While an internal interface is not basically a difficult design problem, it is none-the-less more difficult than employing the external type design. The reason for this is that when using an external interface, all of the C.P. control is accomplished by the Positive I/O Bus option. CONSIDERATIONS: As with any type interface, we must consider the problem of device selection. Since this is the same for all interfaces you will find it covered under a separate section entitled: "DEVICE SELECTION". For the internal interface it is important that the unit assert the signal INTERNAL I/O L whenever it detects it's device code. This is necessary because it is the only way the Positive I/O option has of knowing if it should generate IOP pulses. If INTERNAL I/O is asserted it in effect turns off the Positive I/O. Even if no external interfaces currently exist in the system it is still good policy to assert the signal since an external device may be added in the future requiring the use of the Positive I/O. Once device selection has been accomplished it is next necessary to decode the individual IOT instructions. Since an internal interface uses all possible combinations of IOT instruction bits 9, 10, and 11 it is now necessary to do a binary to octal conversion on these three bits. There are two easy ways that this can be accomplished. - If you are assembling the interface by using standard modules, a DEC type M161 Binary to decimal converter would be best. - 2. If you are designing your own modules from an IC level, a Signetics 8251 Binary to Decimal converter will do the job. function description In either case use the output of your device selector to activate the binary to octal converter. (See drawing #INT-3) After the three function bits from the IOT instruction have been converted, the resultant octal output will be used to control the CO, Cl, and C2 signals which control processor operation. (See chart #INT-2) Keep in mind that all transfers are completed with the occurance of a Bus Strobe signal, which is generated by the C.P. at TP3 time. ### CONTROL LINE TRUTH TABLE | YPE OF XFER | CO | , C1 | , C2 | | AC→BUS | BUS-ADDER | AC LOAD | PC LOAD | |-------------------------|----|-----------------------------------------|------|------------------|--------|-----------|---------|---------| | C OUTPUT<br>C UNCHANGED | Н | Н | Н | | YES | YES | YES | NO | | C OUTPUT<br>C CLEARED | L | н | Н | | YES | NO | YES | NO | | C INPUT<br>C OR INPUT | H | L | H | | YES | YES | YES | NO | | C INPUT<br>ATA TO AC | L | L | H | | NO | YES | YES | NO | | C INPUT<br>C PLUS DATA | L | Н | L | 1.44<br>1.<br>1. | NO . | YES | NO | YES | | C INPUT<br>ATA TO PC | L | L | L | | NO | YES | NO | YES | | | | • • • • • • • • • • • • • • • • • • • • | | | | | | · | #### EXTERNAL INTERFACES ADVANTAGE: The advantage to external rather than internal interfaces is simplicity. Since you are using the Positive I/O option to control all input-output functions it is not necessary to design any logic to control the C lines, or any other control signals in the processor. DISADVANTAGE: The problem with external interfaces is the simple fact that they are comparitively slow, requiring nearly three times the instruction execution time of commands for internal interfaces. This is brought about by the need to generate up to three very long (approx. 750 ns) I/O pulses. CONSIDERATIONS: After the interface has decoded the device code, the output of the decoder should be used to gate with the incomming IO pulses to decode the appropriate instructions. A typical logic circuit is shown in figure INT-4. This particular diagram illustrates how only three IOT's can be decoded. It is possible to decode up to 7 different functions even though only three pulses are generated. This can be accomplished by gating the three IOP pulses with the various combinations of bits 9, 10, and 11 as shown in figure INT-5. It should be noted that even though seven combinations are decoded there are still only three discrete time periods for these functions. The three time periods being derrived from the three IOP pulses. Since the positive I/O interface option will handle the bulk of the input-output operations, there are only two signals which the designer must concern nimself with. These are: - 1. SKIP - 2. AC CLEAR BUS - This signal is used to allow a peripheral to control program sequence. When the positive I/O generates any of its three IOP's, it monitors this signal. If the signal is asserted (grounded) during the IOP, an internal counter will be incremented in the positive I/O. At the end of the IOT instruction the counter will be automatically added to the Program Counter in the processor, thus giving the interface the ability to skip from Ø to 3 instructions in the processor's program. - AC CLEAR BUS: The purpose of this signal when asserted is to prevent the processor from enabling the AC on to the Data Bus. Since your interface will transmit data to the processor via the bus, the use of this signal becomes quite important. To see its application in I/O Data Transfers check the chart on INT-6. device must do this -30- | TYPE OF XFER | AC CLEAR BUS | PERIPH DATA -> BUS | BUS DATA → PERIPH | |-----------------------------|--------------|--------------------|-------------------| | PERIPH → AC | L | YES | NO | | PERIPH or AC → AC | <b>H</b> | YES | NO | | 0 → AC | L | NO | NO | | AC → PERIPH<br>AC UNCHANGED | н | NO | YES | | AC → PERIPH<br>AC CLEARED | L | NO | YES | DATA TRANSFER TRUTH TABLE FOR EXTERNAL INTERFACES Int-6 ### POSITIVE I/O INTERFACE The positive I/O interface option serves as a link between the users peripheral and the PDP-8/e. As seen in the discussion on external interfaces the positive I/O does not take care of all interfacing problems, some signals still must be controlled by the users interface. The following is a discussion of the functions that are controlled by the interface, and a description of how it operates Since not all peripherals on a system will be of the external type, the positive I/O will not always be active. The positive I/O is activated by not grounding the signal INTERNAL I/O. This indicates that the assumed type of interface is to be external. Once the interface is activated, it will pick up bits 9, 10, and 11 of the IOT instruction. These bits will be used to determine which IOP pulses will be generated. If bit 11 is set, IOP 1 will be generated; if bit 10 is set IOP 2, and if bit 09 is set IOP 4 will be generated; if bit 10 is set IOP 2, and if bit 09 is set IOP 4 will be gen. The duration of these pulses and the separation between them is adjustable, with the normal settings being 750 ns for duration and 300 ns for separation. The function of each pulse is not determined by the positive I/O, it is left to the users interface to decide what each pulse is to be used for. There is however, a standard usage for these pulses which is: - IOP 1 Normally used for testing flags and generating skip conditions. - IOP 2 Normally used for clearing buffers and the AC It should be carefully noted that these are only the normal usages and that they are not manditory. Each pulse can be used in any manner desired. It should also be noted that only the desired pulses are generated. For example, if an IOT instruction of the form 6xx5 were executed, IOP 1 would be generated immediately followed by IOP 4 (following the normal separation delay). Since the use of each I/O pulse is left to the user, the Positive I/O must consider each possible application at the time the pulse is generated. The possible applications being: - 1. Skip the next instruction on a given condition. - 2. Transfer data to the AC. - 3. Transfer data to the peripheral (AC cleared). - 4. Transfer data to the peripheral (AC unchanged). Because of the varied possibilities, the positive I/O will cause the following common events to occur each time that an IOP is generated: - 1. If the device grounds the signal SKIP BUS the positive I/O will increment a skip counter at Bus Strobe time. - 2. Unless the peripheral grounds the signal AC CLEAR BUS the AC will be placed onto the data bus. - 3. At bus strobe time the positive I/O will unconditionally load the AC from the data bus. (For an explanation of how to implement data transfers using these common events see the section on External Interfaces.) After all IOP pulses have been generated, the positive I/O interface will then take what ever value is in the skip counter and add it to the Program 2 Counter thus causing the computer to skip either 0, 1, 2, or three times depending on how many skip conditions were encountered during the IOP generation time. BUS STROBE TIME Exactly 100 ns before the end of each IOP pulse the positive I/O interface will generate a BUS STROBE signal which can be used as a load pulse in the C.P., hence, BUS STROBE TIME occurs 100 ns before the end of each IO pulse. INTERVENTION WITH PROCESSOR TIMING Since a great deal of time is required to generate the I/O pulses, it is necessary for the Positive I/O generator to stall the processor timing. This is accomplished as follows: When the positive I/O determined that it is to be used (the presence of an IOT instruction with the absence of the signal INTERNAL I/O) it generates a signal to the C.P. called NOT LAST X ER L, this causes the processor to remain in time state three once it is entered and to remain there until such time as the interface lifts this signal and generates one additional BUS STROBE signal. The occurrance of a BUS STROBE without the signal NOT LAST XFER L, will restart C.P. timing which will pick up at time state 4, and run normally from there. The following should be noted: 1. Even though the C.P. is forced to wait in time state 3, time pulse 3 will still be generated at the usual time. (It is the absence of TP3 later on in the I/O timing that makes the presence of BUS STROBES necessary, since there is no other pulse present that can be used for loading puposes). 2. Even though the C.P. is stalled, the memory timing will run to its normal completion and simply wait for a new cycle to begin (this will take place when the processor is restarted). For a graphic illustration of timing see drawing number INT-7. ### PROGRAM INTERRUPT Because of the great difference in timing between the C.P. and most peripherals, it becomes necessary from a programming standpoint to determine if a device is ready to transfer data to or from the C.P. before the transfer actually takes place. This is accomplished in one of two ways; first, the programmer could issue a skip instruction which would cause the program to skip the next sequential instruction if the device ready flag is set, indicating that the device is ready to transfer. The second technique is to have the device flag automatically and notify the C.P. when it is ready. This is a far better method since it does not require the C.P. to dedicate all of its time to flag checking. This second method can be accomplished by using the program interrupt feature of the This works by having the hardware monitor all device flags (to accomplish this all the programmer need do is issue an ION instruction). If the hardware detects a flag it will automatically execute a JMS 0000. From an interface standpoint all that is necessary to use the interrupt facility is to design the device flag so that when it sets it will assert the signal INT REQST on the OMNIBUS. (See drawing no. INT.-10.) Since the hardware in the C.P. is designed with only one interrupt request line it must monitor all flags tied to it, consequently if the programmer wishes to ignore a given device he has no easy way of doing it. For this reason it is desirable to have the device flag designed so that the programmer can issue a command that would eliminate that particular flag from the interrupt request line. This can be accomplished by using the technique shown in drawing no. INT.-1). INTERRUPT REQUEST Int-10 INTERRUPT ENABLE Int-11 #### DATA BREAK When interfacing mass storage devices to the computer such as disks and magnetic tape units, a new interfacing problem is encountered that did not appear in the simpler devices. With a non-mass storage device such as the teletype, we were dealing with speeds that were so slow that we were able to transfer data to the computer via the program interrupt system. Under that system whenever the device had a word ready to transfer to the C.P. it set a flag which generated an interrupt request. When the C.P. saw the request it did a JMS 0000 and a program was then run using individual IOT instructions to obtain the data from the peripheral, or transfer to the peripheral. The problem is that this takes time. In fact it takes an absolute minimum of 16 us. before the program could reach the word that the device had waiting. If the device were fast enough that it could have a new word ready in less than 16 us. the program could not possibly access the data fast enough. Because of this speed problem, and also due to the fact that in a mass storage device we are normally going to be transferring large quantities of data, the DATA BREAK system was designed. When using data break the theory is that the peripheral will set a flag as each data word is ready for transfer. Once the C.P. acknowledges the flag it will allow the device to transfer the data directly into or out of memory. This direct memory access will take place completely without program intervention. That is to say that the transfer will be handled completely by the hardware. Since the DATA BREAK INTERFACE module does the bulk of the work in a direct memory transfer, we will concentrate on the control information which must pass from the device itself to the DATA BREAK interface. DATA BREAK OPERATION There are two forms of data break transfers to be considered, first there single cycle data break. This is the fastest of the two, and also the most complex, involving a rather fancy interface. The second called THREE CYCLE DATA BREAK is three times slower, requires a far less complex interface. The first to be discussed will be single cycle data. SINGLE CYCLE DATA BREAK The basic theory of single cycle break is that when the device is ready to transfer a word it sets a BREAK REQUEST flag. The device then sends an address to the data break interface. This is the address at which the transfer will take place. The interface will then accept a word from the peripheral and send it to memory at that address, or else send a word to the device from that memory address. This entire operation takes place between normal processor cycles. In effect the interface steals a cycle from processor time in order to use memory for the peripheral. Since the hardware does all the work, and since this happens between cycles of standard instructions, no program intervention is necessary. The exact sequence, and the signals necessary to make it work is as follows: (See Drawing No. INT. 12). - The device generates a BRK RQST signal to the DB (data break) interface. - 2. In addition to the request the device must specify the address at which the transfer is to take place. - 3. As soon as the DB interface detects that the C.P. - has completed the current cycle, it will enter its own major state called BREAK. At this time it will generate MA DIS to remove the CPMA from the MA bus. In its place it will put the address specified by the peripheral. To notify the device that this has taken place the DB Interface will generate a signal to the device called ADDRESS ACCEPTED. - 4. Since it is possible for data to be going to or from memory the device must also specify the direction of data transfer. This is done at the same time that the address is sent by use of the signal DATA IN. IN is at ground, the data will go from the device to the memory, otherwise the data will go from memory to the device. It is also possible at this point that rather than transfer data to or from memory, the device merely wants to increment a number in memory. be accomplished by use of the MB INCREMENT signal. MB INCREMENT is grounded and the DATA IN signal is high, the DB interface will cause the content of the specified memory location to be incremented. If MB INCREMENT is low and so is DATA IN, the DB interface will take a data word from the peripheral and add it to the data in the memory location specified. When using the MB INCREMENT signal if the increment or the addition causes the CP to produce a 13 bit result a signal will be sent to the peripheral called W.C. OVERFLOW. 5. Once the transfer is completed, the DB interface will lift the signal MA DISABLE, thus allowing the C.P. to continue on with its program as if nothing had happened. LEST WE FORGET Since the transfer mentioned above occurs without any program intervention, it is necessary to arrive at some method of determining when all the necessary data has been transferred. This can only be done by the device itself. be necessary for the device to keep track of the number of words transferred, and when all the words are transferred, notify the C.P. that this has taken place. This can be done via the interrupt facility. The actual word counting is best handled by loading into the device (under program control at the beginning of the program) a negative number representing the number of words to be transferred. As each word is sent the device must increment this value and check to see if the result is zero. If it is then all words have been sent, and an interrupt can be generated, if not then the device will simply get its next word and continue breaking until the transfer is completed. One other consideration is that the device will have to update the address it sends to the DB interface as each word is sent so that all words will go into or come from sequential memory locations. You can see from the above considerations that the interface in the device can become rather complex, since it necessatates the use of two 12 bit, self incrementing, programmable registers. And in addition the register used to count words must be able to detect a result of zero so that it can generate an interrupt. The advantage to the three cycle break approach is that these two functions are performed automatically in the C.P. THREE CYCLE DATA BREAK The actual transfer of data under three cycle break is the same as for single cycle. The only difference is that in three cycle the counting of words and the updating of the address is taken care of in this processor. This makes it necessary for the break to take three cycles rather than the single cycle used earlier, hence the name three cycle break. The three cycle break is initiated in the same manner as the single cycle, that is, it is still necessary to generate a break request, send the address, specify the direction of transfer, and whether or not to use the MB increment feature. The difference is as follows: - this address is taken as the location in memory of the word count. When the break is started the computer will go to the address specified where it will remove the contents of that memory location and increment. If this number ever goes to zero the DB INTERFACE will generate the signal WC OVERFLOW. Even if the word count should go to zero at this point the DB INTERFACE will still complete the current data transfer. This cycle is referred to as the WORD COUNT major state. - 2. After the computer counts off the current word, the DB interface will then take the original address and add 1 to it. This new address is the pointer to the memory location which contains the address at which the data transfer is to take place. Once the new address is generated, the DB interface enters the CURRENT ADDRESS major state, where it takes the incremented address and obtains the content of that memory location. At this point, unless the device generates a signal called CA INCR INH the DB interface will increment the number it has obtained from memory. This is the address at which the transfer will take place. The DB interface now enters the BREAK major state and proceeds as with a standard single cycle data break. Note that even though this break took three cycle rather than one, it still only managed to transfer a single word. The two additional cycles were necessary in order to have the word count and current address taken care of in the C.P.'s memory. ONE LAST THOUGHT Since there are two types of data break one additional signal must be sent along with the others. That is a signal called CYCLE SELECT which is used to tell the DB interface whether the break is to be single or three cycle. If this signal is grounded that indicates a three cycle break, and single cycle if high (3 volts). ### DATA BREAK SIGNAL DEFINITIONS BRK RQST This signal is generated by the device wishing to make a direct memory access. DATA ADDRESS These 12 lines carry the address at which the transfer is to take place for a single cycle break. For three cycle break this is the address in memory at which the word count value will be found. In either case this address is sent from the device to the DB interface. CYCLE SELECT This signal generated by the device, specifies whether the break is to be single or three cycle. If it is at ground, it indicates 3 cycle. If it is a +3 volts it indicates single cycle. DATA IN This is used by the device to specify to the DB interface the direction of data transfer. If it is at ground it says data into the C.P. If it is at +3 volts it means data out of the C.P. MB INCREMENT When this is asserted by the device it can have one of two meanings. If it is asserted in conjunction with DATA IN being at ground, the result will be that a data word is taken from the device and added to a word in memory at the address specified by the device. If it is used with DATA IN at +3 volts, it will cause the word in the memory location specified by the device to be incremented. DATA These are the 12 lines that carry data from the device to the DB interface which in turn passes it on to memory. To receive data from the C.P., the device must obtain its data from the MD BUS. ADDR ACC This signal is generated by the DB interface at the time when it accepts the address from the device. It is normally used by the device to clear the BREAK REQUEST flag. In the case of single cycle break peripherals, it is also used to indicate that the word count, and data address registers must be updated. W C OVERFLOW There are two ways that this signal gets generated. It can be generated in the word count major state of a three cycle break if the word count goes to zero. It can also be generated during the BREAK major state of any data break if the MB INCREMENT signal is being used, and if the data being incremented, or added to, should produce a 13th bit. CA INCR INH This signal is only used by three cycle break. It is used whenever the device does not want the address being taken from memory during the CURRENT ADDRESS major state to be incremented. INT - 1 APPENDIX A CABLE LISTINGS ## M8350 POSITIVE I/O BUS CABLES | SIGNAL MD 00 H MD 01 H MD 02 H MD 03 H MD 03 L MD 04 H MD 05 H MD 05 H MD 06 L MD 06 H MD 07 H MD 07 L MD 08 H MD 08 H MD 09 H MD 09 H MD 10 H MD 11 H | #1 BERG D J N X T FF BB RR LL F V R DD Z JJ NN TT | M953A B1 D1 E1 J1 H1 M1 L1 S1 P1 E2 D2 K2 H2 P2 M2 S2 T2 V2 | SIGNAL AC 00 AC 01 AC 02 AC 03 AC 04 AC 05 AC 06 AC 07 AC 08 AC 09 AC 10 AC 11 TS 3 TS 1 INIT BIOP 1 BIOP 2 BIOP 4 | #2 BERG D I N T X BB FF LL RR F L R I N T V Z DD | M953A B1 D1 E1 H1 J1 L1 M1 P1 S1 D2 E2 H2 V2 K2 M2 P2 | |--------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|-------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|-------------------------------------------------------| | | | | i i | | | | SIGNAL DATA 00 DATA 01 DATA 02 DATA 03 DATA 04 DATA 05 DATA 06 DATA 06 DATA 07 DATA 08 DATA 09 DATA 10 DATA 11 | #3 BERG D J N T X BB FF LL RR F L | M953A<br>B1<br>D1<br>E1<br>H1<br>J1<br>L1<br>M1<br>P1<br>S1<br>D2<br>E2 | |----------------------------------------------------------------------------------------------------------------|-----------------------------------|-------------------------------------------------------------------------| | RUN AC CLEAR BUS INT ROST SKIP BUS | JJ<br>Z<br>V | S2<br>P2<br>M2<br>K2 | ## M8360 DATA BREAK CABLES | | #1 | | #2 | | |-------------|---------------|---------------------|----------|-------| | SIGNAL | BERG M953A | SIGNAL | BERG | M953A | | DATA ADD 00 | D <b>B1</b> | BRK DA <b>TA</b> 00 | D | B1 | | DATA ADD 01 | J Dl | BRK DATA 01 | j - | Dl | | DATA ADD 02 | N El | BRK DATA 02 | N | E1 | | DATA ADD 03 | T 4 4 4 4 4 1 | BRK DATA 03 | ${f T}$ | H1 | | DATA ADD 04 | X J1 | BRK DA <b>TA</b> 04 | X | J1 | | DATA ADD 05 | BB L1 | BRK DATA 05 | BB | Ll | | DATA ADD 06 | FF M1 | BRK DATA 06 | FF | Ml | | DATA ADD 07 | LL Pl | BRK DA <b>TA</b> 07 | ${f LL}$ | P1 | | DATA ADD 08 | RR S1 | BRK DATA 08 | RR | s1 | | DATA ADD 09 | F D2 | BRK DA <b>TA</b> 09 | F | D2 | | DATA ADD 10 | L E2 | BRK DA <b>TA</b> 10 | L | E2 | | DATA ADD 11 | R H2 | BRK DATA 11 | R | H2 | | INIT | TT V2 | WC OVERFLOW | DD · | P2 | | BREAK | DD P2 | CYCLE SELECT | V | K2 | | ADD ACC | JJ S2 | CA INC INH | ${f z}$ | M2 | | BRK RQST | V K2 | EXT DATA ADD () | ${f TT}$ | V2 | | DATA IN | Z M2 | EXT DATA ADD 1 | NN | T2 | | MB INCR | NN T2 | EXT DATA ADD 2 | JJ | S2 | | | | • | • | | ### M8360 DATA BREAK INTERFACE MODULE # APPENDIX B DEVICE CODE DISTRIBUTION ## PDP 8/e DEVICE CODES | 00 | CENTRAL PROCESSOR | |-----------|---------------------------------| | 01, 02 | HIGH SPEED READER/PUNCH | | 03, 04 | TELETYPE | | 05, 07 | VC8-E VIDEO DISPLAY | | 10 | KP8-E POWER FAIL | | 11 | DP8-EP REDUNDANCY CHECK CONTROL | | 12 | CARD PUNCH AND CONTROL | | 13 | REAL TIME CLOCK | | 14-17 | CUSTOMER'S USE | | 20-27 | EXTENDED MEMORY | | 30-35 | RESERVED | | 36, 37 | GENERAL PURPOSE INTERFACE BB08 | | 40-47 | SYNCHRONOUS DATA INTERFACE | | 50, 51 | RESERVED | | 52 | AMB-EA | | 53 | AD8-EA A/D CONVERTER | | 50-57 | DR8-EA BUFFERED DIGITAL I/O | | 60-62 | DF-32D DISK | | 60-62, 64 | RS08 DISK | | 63,67 | CARD READER | | 65 | X-Y PLOTTER | | 66 | LINE PRINTER | | 70-72 | MAGNETIC TAPE TRANSPORT | | 70-77 | INCREMENTAL TAPE TRANSPORT | | 73-75 | RK8 DISK | | 76,77 | DECTAPE CONTROL |