# digital interoffice memorandum 8-0012-70 SUBJEOT: PDP-15 Floating-Point TO: Engineering Committee DATE: August 19, 1970 FROM: Tom Holmes J.H. DEPARTMENT: PDP-15 Engineering The attached writeup is an introduction to the PDP-15 Floating-Point Hardware project - E-15-07635. It serves as a brief orientation in preparation for a presentation before the Engineering Committee on August 20, 1970. Included in the writeup are an opening introduction from Marketing, a discussion of floating-point architecture, an estimate of cost and development schedule, and several explanatory appendices. /jan Enclosure # ENGINEERING COMMITTEE - K. Olsen - R. Cady - D. Chertkow - A. Kent - F. Wilhelm - L. Gale - J. Cudmore - R. Doane - R. Dow - J. Milton - D. Best - G. Butler - B. Melesky - E. Correll PDP-15 FLOATING-POINT PROCESSING UNIT (FPU) ARCHITECTURE THOMAS G. HOLMES 24 JULY 1970 EXT. 3440 # TABLE OF CONTENTS | | MARKETING INTRODUCTION | | |-----|--------------------------------------------------------|----------| | ١. | DESIGN GUIDELINES | Ľ. | | 2.• | ORGANIZATION | } | | 3• | HARDWARE IMPLEMENTATION | 5 | | 4. | DEVELOPMENT SCHEDULE AND MANUFACTURING COST ESTIMATE 7 | 7 | | | APPENDIX A INSTRUCTION SET | 1 1 | | | APPENDIX B HANDLING OF INTERRUPT EXCEPTIONS | 3 1 | | | APPENDIX C OPERATING FEATURES AND CONSTRAINTS | ; 1 | | | APPENDIX D | 6<br>1 € | ### MARKETING INTRODUCTION # PRODUCT DEFINITION AND CONCEPT THE FLOATING-POINT PROCESSOR IS DESIGNED TO BE A SEPARATE HARDWARE DEVICE WITH UP TO 16 INSTRUCTIONS PERFORMING SINGLE AND DOUBLE PRECISION ARITHMETIC. THE UNIT IS DESIGNED TO SIT ON THE PDP-15 MEMORY BUS AND OPERATE AUTONOMOUSLY FROM THE CENTRAL PROCESSING UNIT: IT, THUS, ACTS AS A SEPARATE PROCESSOR PROVIDING THE USER WITH FOUR DISTINCT UNITS: MEMORY, CPU, I/O, AND FLOATING-POINT. ### MARKET ING THE FLOATING-POINT HARDWARE PROVIDES A FURTHER COMPLEMENT TO THE PDP-15. IT SERVES MANY MARKETS AND CONSTITUTES A NECESSARY PRODUCT ENHANCEMENT. IT WILL ALSO HELP TO FURTHER DIFFERENTIATE PDP-11 AND PDP-15 PROSPECTS. MARKETS THAT WILL BE AFFECTED BY THIS HARDWARE INCLUDE THE PHYSICS AND ANALYTICAL INSTRUMENTATION WHERE APPROXIMATELY 20% (15-20% FOR PHYSICS, 25% FOR AI) OF THE MACHINES ARE USED PRIMARILY FOR NUMERICA ANALYSIS; THE HYBRID MARKET WHERE ALMOST ALL MACHINES (90-100%) REQUIRE THE CALCULATION SPEED EITHER FOR PACING OR FOR DIGITAL SIMULATION; AND OUR GENERAL SCIENTIFIC MARKET WHERE HIGH SPEED ARITHMETIC IS DESIRABLE TO ACHIEVE BETTER PROGRAM THROUGHPUT (30% OF MACHINES). THE HIGH SPEED CAPABILITY WHEN COMPLEMENTED BY FORTRA SOFTWARE CAN REDUCE CALCULATION TIME BY AN ORDER OF MAGNITUDE AND MACHINE PDP-15 TO ENTER THE TRADITIONAL COMPUTATION MARKET NOW SERVED BY THE IBM 1130. THE SCIENTIFIC MARKET IS PRESENTLY VERY TIGHT ON FUNDS. WE THEREFOR SEE THIS OPTION AS PRIMARILY AN ADD-ON. SCIENTISTS ARE PRESENTLY BUYING BASIC SYSTEMS; LATER AS END-OF-YEAR FUNDS AND A LOOSER ECONOM PERMIT, THE FLOATING-POINT PROCESSOR WILL BECOME A DESIRABLE ADD-ON. WE EXPECT THAT THE DEMAND WILL START UP SLOW, ACCELERATE AS THE POPULATION OF PDP-15'S EXPANDS AND SLOW DOWN AS THE PDP-15 IS PHASED OUT. THE PRODUCT LIFE IS ESSENTIALLY THAT OF THE PDP-15 ALTHOUGH THERE SHOULD STILL BE SOME RESIDUAL ADD-ON LIFE PAST THE PDP-15 PHASE OUT. # COMPETITION FLOATING-POINT HARDWARE WILL ALLOW THE PDP-15 TO PERFORM WELL ON BENCHMARKS. CURBENTLY WE BENCHMARK POOPLY EVEN COMPARED TO MACHINES WITH SLOWER CYCLE TIME DUE TO OUR SOFTWARE FLOATING-POINT ARITHMETIC IMPLEMENTED VIA EAE. HEVILETT PACKARD HAS DEMONSTRATED BUT NOT YET DELIVERED FLOATING-POINT HARDWARE AT AN APPROXIMATE PPICE OF \$20K. DELIVERY IS PLANNED IN JANUARY, 1971. THE HARDWARE WILL PEFFORM TRIGONOMETRIC FUNCTIONS AS WELL. AS FLOATING-POINT ADD, SUBTRACT, MULTIPLY, DIVIDE, AND NORMALIZE. OUR PROPOSED HARDWARE WILL GIVE US A SIGNIFICANT ADVANTAGE IN THE MARKET OVER XDS AND HONEYWELL AND HELP IN THE MATCH WITH HEWLETT PACKARD. THE HARDWARE INTEGER ARITHMETIC ALLOWS US TO PERFORM DOUBLE PURCISION INTEGER CALCULATIONS AND THUS ANSWERS ONE OF HONEYWELL'S SELLING ARGUMENTS. IT ALSO PROVIDES AN EFFECTIVE MARKETING TOOL IN COMPARISON WITH THE HEWLETT PACKARD HARDWARE. ### VOLUME AT A SELLING PRICE OF \$10-12K UE EXPECT TO SELL AROUND 250 FLOATING-POINT PROCESSORS. | | 1972 | | | | | 1974 | | | |-------------|------|----|---------|----|----|------|----|----| | ැබ <b>1</b> | 98 | 03 | ્<br>ત4 | 01 | 68 | 03 | 04 | | | 15 | 30 | 25 | 40 | 25 | ለማ | 35 | 40 | řø | ROBERT L. KATZ PDP-15 MARKETING #### 1. DESIGN GUIDELINES THE FLOATING-POINT PROCESSOR MUST BE ABLE TO BUN THE EXISTING FORTRAN COMPILER AT AN IMPROVED SPEED AND WITH A MINIMUM NUMBER OF CHANGES TO THE COMPILER. THIS IS ACCOMPLISHED BY REPLACING EACH FLOATING-POINT SOFTWARE SUBROUTINE WITH AN EQUIVALENT HARDWARE INSTRUCTION. GLENN WICKELGREN'S MEMORANDUM OF JANUARY 6, 1970, SPECIFICATION FOR FLOATING-POINT HARDWARE FOR PDP-15, GIVES THE FOLLOWING: # "II. FLOATING-POINT INSTRUCTION FORMAT THE FORTRAN IV COMPILER GENERATES A CALL TO A SUBROUTINE FOR EACH FLOATING OPERATION TO BE PERFORMED. THIS CALL LOOKS AS FOLLOWS: JMS SUB • DSA ARG /FLOATING OP. /ARGUMENT /RETURN THE SUBROUTINE SUB IS DIFFERENT FOR DOUBLE PRECISION ARGUMENTS THAN IT IS FOR SINGLE PRECISION ARGUMENTS. THE ADDRESS ARG POINTS TO THE FIRST WORD (IS THE ADDRESS OF THE FIRST WORD) OF THE ARGUMENT OF THE FLOATING-POINT OPERATION (15 BIT ADDRESS). THE BITS 0-2 OF THE ARGUMENT ARE ZERO EXCEPT WHEN INDIRECTION IS INVOLVED. IF BIT 0 OF THE ARGUMENT IS 1 THEN BITS 3-17 CONTAIN THE ADDRESS OF A LOCATION WHOSE CONTENTS (BITS 3-17) POINT TO THE FIRST WORD OF THE ARGUMENT CONLY 1 LEVEL OF INDIRECTION IS INVOLVED AND BITS Ø-2 OF THIS WORD MUST BE IGNORED) \*\* AFTER THE OPERATION IS COMPLETED CONTROL IS RETURNED TO THE NEXT REGISTER FOLLOWING THE ARGUMENT ARG. FLOATING-POINT HARDWARE IS TO OPERATE SUCCESSFULLY WITH THE COMPILER. A HARDVARE INSTRUCTION MUST BE AVAILABLE WHICH CAN REPLACE THE INSTRUCTION (JMS SUB) WHICH TRANSFERS CONTROL TO SOFTWARE BOUTINES WHICH HANDLE THESE OPERATIONS. IN OTHER WORDS AN IOT (OR OTHER OP CODE) INSTRUCTION MUST REPLACE THESE ROUTINES. \* THE HARDWARE FLOATING-POINT PROCESSOR MUST ALSO PERFORM THIS ONE LEVEL OF INDIRECTION WHEN DIRECTED." THE NECESSITY OF EXECUTING IN-LINE CODE GENERATED BY THE COMPILER MADE IT NECESSARY TO PLACE THE FPU ON THE MEMORY BUS. INSTEAD OF PLACING IT ON THE I/O BUS. THE FORTRAN COMPILER HAS DICTATED WHAT CONSTITUTES THE FPU. EARLIER DESIGNS OFFERRED A MORE POWERFUL FLOATING-POINT PACKAGE, BUT THE SERIOUS LIMITATION WAS THAT THE PRESENT FORTRAN COMPILER COULD NOT TAKE ADVANTAGE OF SUCH A UNIT WITHOUT UNDERGOING AN EXTENSIVE BEWRITE. A COMPILER REWRITE WAS CONSIDERED, IT WAS BEJECTED AS IMPRACTICAL SINCE THE MAJORITY OF PDP-15 USERS DEAL AT THIS POINT IN TIME. EXCLUSIVELY WITH FORTRAN, THE PROPOSED DESIGN WILL OFFER ONLY WHAT CAN BE EASILY IMPLEMENTED IN THE PRESENT FORTRAN COMPILER. SINGLE EXCEPTION TO THIS IS THE INCLUSION OF INTEGER ARITHMETIC, WHICH TAKES ADVANTAGE OF MOST OF THE FLOATING POINT HARDWARE AND PROVIDES MARKETING WITH AN ATTRACTIVE MATH PACKAGE TO DISTINGUISH IT FROM ITS COMPETITION. ### 2. ORGANIZATION # INSTRUCTION FORMAT THE FPU HAS BOTH SINGLE AND DOUBLE LENGTH INSTRUCTIONS. BITS 00-05 OF THE FIRST WORD CONTAIN AN OCTAL "71" TO SPECIFY A FPU INSTRUCTION. THE "71" APPEARS AS A NO-OPERATION IN THE CPU. - OP BITS 06-09 DECODE INTO SIXTEEN UNIQUE INSTRUCTIONS - BIT 10=0, SINGLE LENGTH INSTRUCTION BIT 10=1, DOUBLE LENGTH INSTRUCTION - P BIT 11=0, SINGLE PRECISION BIT 11=1, DOUBLE PRECISION - F BIT 12=0, INTEGER FORMAT BIT 12=1, FLOATING FORMAT - \* BITS 13-17 MODIFY THE LOAD AND STORE INSTRUCTIONS - 13 UNASSIGNED - 14 ROUND FROM DOUBLE TO SINGLE PRECISION - 15 MAKE POSITIVE - 16 MAKE NEGATIVE - 17 COMPLEMENT - I BIT 00=1 SPECIFIES INDIRECTION - A BITS Ø1-17 SPECIFY THE ADDRESS OF THE FIRST WORD OF THE ARGUMENT # DATA FORMAT . \$ THE FPU SINGLE AND DOUBLE PRECISION DATA FORMATS ARE THE SAME AS THOSE IN THE EXISTING POP-15 FLOATING-POINT SOFTWARE. NOTE: THE FLOATING-POINT MANTISSA IS KEPT IN SIGN AND MAGNITUDE FORMAT. ALL OPERANDS ARE ASSUMED NORMALIZED. INTEGER ARITHMETIC ALSO HAS BOTH SINGLE AND DOUBLE PRECISION. DOUBLE PRECISION INTEGER (36 BITS) SINGLE PRECISION INTEGER (18 BITS) NOTE: THE INTEGER OPERAND IS IN TWO'S COMPLEMENT FORMAT. OPERATION THE FLOATING-POINT SYSTEM CONFIGURATION HAS THE FPU "BLACK BOX" PHYSICALLY OR'D ON THE MEMDRY BUS BETWEEN CORE MEMORY AND THE PDP-15 CPU. THUS SITUATED, THE FPU MONITORS ALL INSTRUCTIONS FETCHED FROM CORE AND EXAMINES EACH FOR THE "71" IN BITS 00-05. THE "71" APPEARS AS NO-OPERATION IN THE CPU, BUT IT IMMEDIATELY FLAGS THE FPU TO ANNOUNCE ITS OCCURRANCE. THE FPU ACKNOWELDGES BY DISABLING THE CONTROL CIRCUITRY WHICH ALLOWS THE CPU TO MAKE A MEMORY REQUEST. I/O MEMORY REQUESTS ARE STILL ALLOWED ACCESS TO CORE. THE BITS TO THE RIGHT OF "71" PROVIDE INFORMATION ON THE INSTRUCTION TYPE, INSTRUCTION LENGTH, DATA PRECISION, AND DATA FORMAT. IF A DOUBLE LENGTH INSTRUCTION IS SPECIFIED, THE CPU IS ENABLED TO ALLOW FOR ONE MEMORY ACCESS TO OBTAIN THE SECOND WORD OF THE INSTRUCTION. THE CPU PC WILL INCREMENT PAST THIS SECOND WORD AND BE CORRECTLY POSITIONED FOR CONTINUED EXECUTION WHEN CONTROL IS PETURNED. THIS TECHNIQUE OF ALIGNING THE PC REQUIRES THAT THE SECOND WORD BE MADE TO LOOK LIKE A NO-OPERATION TO THE CPU. THE ACTUAL SECOND WORD IS LOADED INTO THE FPU. THIS SECOND WORD CAN BE EITHER THE ADDRESS OF THE MEMORY OPERAND (NO INDIRECTION) OR THE ADDRESS POINTING TO THE ADDRESS OF THE MEMORY OPERAND (INDIRECTION). EVENTUAL TRANSFER OF THE OPERAND TAKES ONE, TWO, OR THREE ACCESSES TO CORE MEMORY, DEPENDING ON THE PRECISION AND DATA FORMAT TRANSFERBED. THE LAST PHASE OF THE INSTRUCTION IS TO RELEASE THE HOLD ON THE CPU MEMORY PROUEST CIRCUITRY. #### (PAGE 6) ### 3. HARDWARE IMPLEMENTATION SEVERAL MSI (MEDIUM SCALE INTEGRATION) DEVICES ARE PLANNED TO BE USED IN THE FPU. | DEC74181 | 4-BIT ARITHMETIC LOGIC UNIT | |----------|-----------------------------------| | DEC74182 | CARRY LOOK AHEAD | | DEC74153 | 4-LINE TO 1-LINE DATA SELECTOR | | DEC74154 | 4-LINE TO 16-LINE DECODER | | DEC7495 | 4-BIT SHIFT REGISTER | | DEC74193 | 4-BIT SYNCHRONOUS UP/DOWN COUNTER | THREE GENERAL PURPOSE BOARDS HAVE BEEN MADE TO UTILIZE THE ABOVE IC'S. | 50-08912 | TWO 16-PIN IC'S, ALL PINS BROUGHT OUT, POWER | |----------|----------------------------------------------| | | ON PINS 16 AND 8. SEPARATE GROUND LOOP FOR | | | EACH IC. AVAILABLE AS W961. | | 50-08908 | ONE 24-PIN IC, ALL PINS BROUGHT OUT, POWER | | | ON PINS 24 AND 12, AVAILABLE AS W962. | | 50-08914 | TWO 14-PIN IC'S, ALL PINS BROUGHT OUT, POWER | | ř | ON PINS 14 AND 7, SEPARATE GROUND LOOP FOR | | | EACH IC. AVAILABLE AS W963. | THE FIRST PROTOTYPE WILL MAKE EXTENSIVE USE OF THESE BOARDS IN THE DESIGN. SPECIAL PARTITIONING HAS ALREADY BEEN DEVELOPED FOR THE SECOND PROTOTYPE WHICH WILL COMBINE SIX OF THESE SINGLE HEIGHT CARDS INTO ONE DOUBLE HEIGHT CARD. THIS NEW CARD WILL BE USED TO REDUCE THE 96 MODULE SLOTS REQUIFED FOR REGISTERS AND ADDERS IN PROTOTYPE I TO 32 MODULE SLOTS IN PROTOTYPE II. IF THE MODULE SLOTS REQUIRED FOR CONTROL LOGIC CAN BE KEPT TO LESS THAN 60% OF THE TOTAL COUNT, THE FPU CAN BE PACKAGED IN TWO MOUNTING PANELS (128 MODULE SLOTS). AS A COMPARISION, THE PDP-15 CPU IS CONTAINED IN 2 1/4 MOUNTING PANELS AND USES 79 OF THOSE MODULE SLOTS FOR CONTROL. IF THE FPU CAN BE CONSIDERED TO BE NO MOBE COMPLEX (AND/OR COMPLICATED) THAN THE CPU, THE LIKELIHOOD OF FITTING THE FPU IN THE ALLOTTED SPACE IS GOOD. # (PAGE 7) # 4. DEVELOPMENT SCHEDULE AND MANUFACTURING COST ESTIMATE IN ARRIVING AT MANUFACTURING COST, AN AVERAGE COST OF TEN DOLLARS PER MODULE MAS USED FOR EXISTING MODULES AND PRESENT INTEGRATED CIRCUIT COSTS WERE USED TO DETERMINE THE COST OF NEW MODULES. INFORMATION FROM THE PURCHASING DEPARTMENT INDICATES THAT THE MSI COMPONENTS ON THE NEW MODULES WILL EMPERIENCE A 40 - 54% COST PROUCTION BYTTHE FIRST QUARTER OF FISCAL 1978. # MANUFACTURING COST | MOUNTING PANEL WITH A2, C2, & T1 BUSSED | 2 | 36.75 | 73.54 | |----------------------------------------------|----|---------|----------| | I/O CARLES USING M904 CONNECTORS | 3 | 15.69 | 46.89 | | M775 CLOCK AND TIME STATE GENERATOR | 1 | 28.31 | 28 • 31 | | MIREMPAP SERVICE 2,000 WIRES 0 S0.14 | 1 | 2004.00 | 204-40 | | MANTISSA ADDER MODULE (PARTS AND MANE. COST) | 9 | 34.25 | 270.00 | | ADDRESS ADDER MODULE (PARTS AND MANE. COST) | 5 | 24.64 | 128.43 | | ADDITIONAL STANDARD MODULES | 64 | 1-3-046 | 604.00 | | | | | | | | | | CONT. C. | 31,334.61 | MATERIALS | | 81,339.90 | |-----------------------|----------|------------| | INSTALLATION IN FIELD | (1-8HRS) | 29.40 | | CHECKOUT (3 MANDAYS) | | 849.00 | | | | | | | | \$1,599.90 | AFTER CONFERRING WITH J. GALVIN AND M. SIMEONE. PROVISION WAS MADE FOR THE POSSIBLE LATER ADDITION OF A POWER SUPPLY AND FOR A THI PERCENT INCREASE IN COST. | P()#) | to chooll | | | \$1,599.90<br>150.49 | |-------|-----------|----|------|----------------------| | | | | | | | | | | | 51,743.33 | | 19% | INCREASE | IN | COST | 174.98 | | | | | | \$1,693.98 | | المحقوم معدات المتد | بيسده خداك | | | | | |---------------------|------------|--------|--------|--------|----| | DICITA | . I Q | ULPMEN | AL COR | CRATIC | L1 | DISCRETE PROJECT AUTHORIZATION Discrete Project Code | | n 7 6 3 5 e assigned by accounting) | | |----------------------------------|----------------------------------------------|--| | | | | | Project Manager: T. Holmes | ROCESSOR Date: 6-26-70 Supervisor: E. Aumann | | | Complete Description of Project: | | | | | Estimated Total \$1s:.\$1893 | | Product Code Market Code | | | | Fi | scal Quart | ers | | |--------------|--------------|------------------------------------------------------------------|--------------------------------|-----------------|-----------------|-----------------| | Act,<br>Code | Cost<br>Ctr. | Expense Centers | FY <u>71</u><br>Qtr <u>. 1</u> | FY 71<br>Qtr. 2 | FY 71<br>Qtr. 3 | FY 71<br>Qtr. 4 | | E<br>D | 324<br>325 | Model Shop G. Gerelds Drafting R. Melanson | 1.3 | 20.0 | 13.0<br>9.0 | 4. | | D | 330<br>339 | Mechanical Eng. L. Prentice Process Eng. T. Stockebrand | 0.5 | 0.5 | | | | V | 360<br>360 | Systems Programming L. Portner Diagnostic Programming L. Portner | 3.7 | 18.0 | 18.0 | 18. | | D<br>D | 374<br>386 | Production Eng. R. Puffer Special Projects J. St. Amour | | 2.0 | 6.0 | 3. | | N<br>Y | 551<br>552 | Hardware Manuals J. Bellantoni Software Manuals G. Arnold | | | 4.0<br>3.0 | 3.<br>3. | | | | Product Line Eng. | 9.0 | 15.5 | 30.5 | 9. | | | | | | , | | | | T<br>A | <b>28</b> 7 | Advertising & Promotion G. D'Annunzio<br>Product Line Marketing | | | | | | | | | | | | | | | | | | | | | | | <u> </u> | TOTAL EXPENSE | 14.5 | 56.0 | 83.5 | 35. | If this is a new project, have Product Line Manager sign below and submit to Accounting for assignment of a project number. The appropriate Vice President should sign for any projects shared by more than one Product Line. Authorization of this project does not constitute budget approval. Each project must operate within and under the control of their appropriate Product Line and its budget. | QTP. 4 1970 | | QTR. 1 1971 | | | QTR. 2 197 | 1 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------------|----------------------|-------------------|-------------------|---------------------| | JUNE | JULY | AUGUST | SEPTEMBER | OCTOBER | NOVEMBER | DECEMBER | | LAYOUT A | ND DESIGN OF PF | OTOTYPE I | DOCUMENT | LAYOUT AN | D DESIGN OF PRO | TOTYPE II | | | lE | 1.5E lT | 1E | 1.5E 1T | 1.5E 1T | 1.5E lT | | | WIF | RELIST | | | | | | | lD lT | lD lT | | | | | | Maria de la composición del composición de la co | MECHANICAL LAY | OUT AND DESIGN | OF SYSTEM | 2 | FINAL DESIGN | | | | | 0.1E 0.5D | | | 0.2E | | | | | SPECIFY PARTS | BUILD<br>PROTOTYPE I | CHECK | OUT OF PROTOTY | PE I | | | | 0.5T | 0.5T | 1T | 1T | 0.5T | | | | | DIAGN | OSTIC PROGRAMMI | NG | | | | • | 1PR | 1PR | 2PR | 2PR | 2PR | | | 1E<br>1T<br>1D | 1.6E<br>2.5T<br>1.5D 1PR | lE<br>0.5T<br>lPR | 1.5E<br>2T<br>2PR | 1.7E<br>2T<br>2PR | 1.5E<br>1.5T<br>2PR | | | QTR. 3 1971 | TR. 3 1971 OTR. 4 1971 | | | | | |----------------------------|--------------------------|--------------------------|-----------------------------------|-----------------------|----------------------------------------------------------------------------------------------------|----| | JANUARY | FEBRUARY | MARCH | APRIL | MAY | JUNE | | | DESIGN<br>PROTOTYPE II | ENGINE | CERING SPECIFICA | ATION | 3 | 5 | | | 1.5E 1T | lE | 1E | 1E | | | | | WIRE | LIST | FINAL DRAW | VINGS | 1<br>2<br>3<br>4<br>5 | - LOGIC DESIGN RE<br>- MECHANICAL REVI<br>- FINAL REVIEW<br>- RELEASE TO BUIL<br>- RELEASE TO PROF | LD | | 1D | 4D | <b>3</b> D | 3D | | | | | BUILD PROT | 'OTYPE II 6 PRE | E-PRODUCTION | CHECKOUT | 4 | | | | 0.5T | 1T | 1T | 2T 1FS 1TW 17 | rng | | | | | | SYSTEMS | S PROGRAMMING | | | | | 2PR | 2PR | 2PR | 2PR | 2PR | 2PR | | | | | HARDWARF | E AND SOFTWARE M | MANUALS | | | | 1TW 0.1E | 1TW 0.1E | 1TW 0.1E | 1TW 0.1E | 1TW 0.1E | 1TW 0.1E | | | 1.6E<br>1.5T 1TW<br>1D 2PR | 1.1E<br>1T 1TW<br>4D 2PR | 1.1E<br>1T 1TW<br>3D 2PR | 1.1E<br>2TW 2T 1TNG<br>3D 2PR 1FS | 0.1E<br>1TW 2PR | 0.1E<br>1TW 2PR | | (PAGE A1) ### APPENDIX A # INSTRUCTION SET #### INSTRUCTION LENGTH ADD DOUBLE SUBTRACT DOUBLE REVERSE SUBTRACT DOUBLE MULTIPLY DOUBLE DIVIDE DOUBLE REVERSE DIVIDE DOUBLE LOAD. SINGLE AND DOUBLE STORE DOUBLE FLOAT SINGLE AND DOUBLE FIX SINGLE AND DOUBLE DIAGNOSTIC DOUBLE SWAP MO SINGLE UNASSIGNED UNASSIGNED UNASSIGNED UNASSIGNED THE FIRST OPERAND LOCATION IS A 54-BIT HARDWARE ACCUMULATOR IN THE FPU. FOR DOUBLE LENGTH INSTRUCTIONS THE SECOND OPERAND IS HELD IN CORE MEMORY. WHEN THE INSTRUCTION LENGTH IS SINGLE. THE FPU HARDWARE ACCUMULATOR IS USED AS THE SECOND OPERAND. IN FLOATING-POINT MULTIPLY THE NORMALIZED RESULT HAS THE MOST SIGNIFICANT BITS IN THE FPU HARDWARE ACCUMULATOR AND THE LEAST SIGNIFICANT BITS IN THE FPU MQ. THE MQ. A 36-BIT EXTENSION OF THE HARDWARE ACCUMULATOR, MAY BE ACCESSED WITH THE DIAGNOSTIC AND SWAP MQ INSTRUCTIONS. IN INTEGER MULTIPLY, THE LEAST SIGNIFICANT BITS OF THE RESULT ARE IN THE FPU HARDWARE ACCUMULATOR AND THE MOST SIGNIFICANT BITS ARE IN THE FPU MQ. MULTIPLICATION IS BETWEEN TWO 36-BIT OPERAND REGISTERS AND RESULTS APPEAR IN THE 36-BIT MANTISSA PORTION OF THE FPU HARDWARE ACCUMULATOR AND THE 36-BIT FPU MQ. BOTH FLOATING-POINT DIVIDE AND INTEGER DIVIDE RESULT WITH THE QUOTIENT IN THE 36-BIT MANTISSA PORTION OF THE HARDWARE ACCUMULATOR AND THE REMAINDER IN THE MO. INTEGER DIVISION IS WHOLE NUMBER DIVISION. IF THE DIVIDEND IS LESS THAN THE DIVISOR, THE QUOTIENT IS ZERO. # PROGRAM INTERRUPTIONS: OVERFLOW - MAGNITUDE OF RESULT EXCEEDED MAXIMUM REPRESENTABLE NUMBER LIMIT. UNDERFLOW - MAGNITUDE OF RESULT EXCEEDED MINIMUM REPRESENTABLE NUMBER LIMIT. DIVIDE - DIVISION BY ZERO IS ATTEMPTED. ### (PAGE A2) ADD THE SECOND OPERAND IS ADDED TO THE FIRST OPERAND, AND THE SUM IS PLACED IN THE FIRST OPERAND LOCATION. PROGRAM INTERRUPTIONS: UNDERFLOW OVERFLOW SUBTRACT \_\_\_\_\_ THE SECOND OPERAND IS SUBTRACTED FROM THE FIRST OPERAND, AND THE DIFFERENCE IS PLACED IN THE FIRST OPERAND LOCATION. PROGRAM INTERRUPTIONS: UNDERFLOW OVERFLOW REVERSE SUBTRACT THE FIRST OPERAND IS SUBTRACTED FROM THE SECOND OPERAND, AND THE DIFFERENCE IS PLACED IN THE FIRST OPERAND LOCATION. PROGRAM INTERRUPTIONS: UNDERFLOW OVERFLOW MULTIPLY \_\_\_\_\_ THE PRODUCT OF MULTIPLIER (THE SECOND OPERAND) AND MULTIPLICAND (THE FIRST OPERAND) REPLACES THE MULTIPLICAND. PROGRAM INTERRUPTIONS: UNDERFLOW OVERFLOW DIVIDE THE DIVISION (THE FIRST OPERAND) IS DIVIDIED BY THE DIVISOR (THE SECOND OPERAND) AND REPLACED BY THE QUOTIENT. THE REMAINDER IS LEFT IN THE MQ. PROGRAM INTERRUPTIONS: UNDERFLOW OVERFLOW DIVIDE ### (PAGE A3) # REVERSE DIVIDE THE DIVIDEND (THE SECOND OPERAND) IS DIVIDED BY THE DIVISOR (THE FIRST OPERAND). THE QUOTIENT IS PLACED IN THE FIRST OPERAND LOCATION. PROGRAM INTERRUPTIONS: UNDERFLOW OVERFLOW DIVIDE LOAD --- THE SECOND OPERAND IS PLACED IN THE FIRST OPERAND LOCATION. BITS 13-17, M, OPERATE ON THE SECOND OPERAND PRIOR TO THE LOAD. USE OF THESE BITS CREATES A SUBSET OF LOAD INSTRUCTIONS: LOAD ROUNDED LOAD POSITIVE LOAD NEGATIVE LOAD COMPLEMENT PROGRAM INTERRUPTIONS: OVERFLOW (OCCURS ONLY ON LOAD ROUNDED) STORE ---- THE FIRST OPERAND IS STORED AT THE SECOND OPERAND LOCATION. BITS 13-17. M. OPERATE ON THE FIRST OPERAND PRIOR TO THE STORE. USE OF THESE BITS CREATES A SUBSET OF STORE INSTRUCTIONS: STORE ROUNDED STORE POSITIVE STORE NEGATIVE STORE COMPLEMENT PROGRAM INTERRUPTIONS: OVERFLOW (OCCURS ON STORE ROUNDED AND WHEN POSITIVE EXPONENT BITS ARE LOST ON SINGLE PRECISION STORE) UNDERFLOW (NEGATIVE EXPONENT BITS LOST ON SINGLE PRECISION STORE) NOTE: LOAD ROUNDED AND STORE BOUNDED CHANGE DATA PRECISION FROM DOUBLE TO SINGLE BY ADDING 00000000000 TO THE MANTISSA AND RENORMALIZING. # FLOAT THE DATA FORMAT OF THE SECOND OPERAND IS CHANGED FROM INTEGER TO FLOATING-POINT. THE SECOND OPERAND IS A 18 OB 36-BIT INTEGER. THE PESULT IS PLACED IN THE FIRST OPERAND LOCATION. PROGRAM INTERRUPTIONS: NONE FIX THE DATA FORMAT OF THE SECOND OPERAND IS CHANGED FROM FLOATING-POINT TO INTEGER. THE RESULT IS A 18 OR 36-BIT INTEGER AND IS PLACED IN THE FIRST OPERAND LOCATION. PROGRAM INTERRUPTIONS: OVERFLOW (SIGNIFICANT BITS LOST ON FORMAT CHANGE) #### DIAGNOSTIC \_\_\_\_\_ THIS INSTRUCTION WILL BE IMPLEMENTED TO DIAGNOSTIC PROGRAMMING SPECIFICATIONS. IN GENERAL, IT WILL ENABLE THE DIAGNOSTIC PROGRAMMER TO PUT THE FLOATING-POINT UNIT IN SINGLE-STEP CHECKOUT MODE AND PROVIDE ACCESS TO ALL ESSENTIAL CONTROL CIRCUITRY AND HARDWARE REGISTERS. THIS INSTRUCTION WILL ALSO SERVE TWO OTHER FUNCTIONS. FIRST, IT WILL ALLOW USER INFORMATION IN THE FPU TO BE SAVED OR RESTORED WITH A SINGLE INSTRUCTION. SECOND, IT WILL GIVE ACCESS TO AN INTERRUPT EXCEPTION REGISTER, WHICH MAY BE EXAMINED TO DETERMIN THE CAUSE OF THE FLOATING-POINT INTERRUPT. SWAP MQ THE 36-BIT MANTISSA PORTION OF THE FPU HARDWARE ACCUMULATOR AND THE 36-BIT FPU MQ ARE SWAPPED. PROGRAM INTERRUPTIONS: NONE (PAGE B1) APPENDIX B # HANDLING OF INTERRUPT EXCEPTIONS OUERFLOW - MAGNITUDE OF RESULT EXCEEDED MAXIMUM REPRESENTABLE NUMBER LIMIT. UNDERFLOW - MAGNITUDE OF RESULT EXCEEDED MINIMUM REPRESENTABLE NUMBER LIMIT. DIVIDE - DIVISION BY ZERO IS ATTEMPTED. WHEN AN INTERRUPT EXCEPTION OCCURS, EXECUTION STOPS AND THE FPU AUTOMATICALLY FORCES THE CPU TO JMS TO THE EXIT ADDRESS. THE EXIT ADDRESS IS KEPT IN A 15-BIT REGISTER IN THE FPU, WHICH CAN BE ACCESSED BY THE PROGRAMMER THROUGH USE OF THE DIAGNOSTIC INSTRUCTION. UPON COMPLETION THE EXIT ADDRESS LOCATION WILL CONTAIN THE ADDRESS OF THE LAST WORD OF THE LAST FPU INSTRUCTION EXECUTED PLUS TWO. E • G • | | А | FLOAT . ADD | |-----------------------|-----|-----------------| | FPU INTERRUPT OCCURS | A+1 | ADDRESS OF ARG. | | | A+8 | LAC B | | EXIT ADDRESS LOCATION | A+3 | DAC C | | WILL CONTAIN "A+3" | • . | • | | | • | • | PRESUMABLY, THE EXIT ADDRESS WILL POINT TO THE ERROR HANDLING ROUTINE FOR FLOATING-POINT. THE DIAGNOSTIC INSTRUCTION MAY BE USED TO LOOK AT THE STATUS OF THE OVERFLOW, UNDERFLOW, AND DIVIDE INTERRUPT FLOPS AND THE INSTRUCTION LENGTH OF THE INTERRUPTED INSTRUCTION. ### (PAGE C1) #### APPENDIX C # OPERATING FEATURES AND CONSTRAINTS - MAXIMUM OF ONE LEVEL OF INDIBECTION - OPERANDS MUST BE NORMALIZED - RESULTS ARE AUTOMATICALLY NORMALIZED - IF A CALCULATION RESULTS IN A ZERO MAGNITUDE, THE EXPONENT IS ZERO'D AND THE SIGN MADE POSITIVE - NEGATIVE ZERO IS NOT ALLOWED - THE ADDRESS OF THE ARGUMENT IS A 17-BIT NUMBER - ROUNDING TAKES PLACE AFTER ALIGNING AND AFTER NORMALIZING (+1 IS ADDED TO THE LEAST SIGNIFICANT BIT OF THE MANTISSA IF THE NEXT BIT OFF THE LSB END OF THE MANTISSA IS 1) - I/O MEMORY REQUESTS ARE GIVEN PRIORITY OVER FPU MEMORY REQUESTS - THE PROGRAMMER MAY LOAD A 15-31T REGISTER IN THE FPU WITH AN INTERRUPT EXIT ADDRESS. WHEN A FLOATING-POINT INTERRUPT OCCURS. THE FPU AUTOMATICALLY FORCES THE CPU TO JMS TO THE EXIT ADDRESS. THE EXIT ADDRESS LOCATION WILL CONTAIN THE ADDRESS OF THE LAST FPU INSTRUCTION EXECUTED PLUS TWO. E • G • | | Α | FLOAT. ADD | |-----------------------|-----|-----------------| | FPU INTERRUPT OCCURS | A+1 | ADDRESS OF ARG. | | | A+2 | LAC B | | EXIT ADDRESS LOCATION | A+3 | DAC C | | WILL CONTAIN "A+3" | • | • | | | _ | | ### (PAGE D1) #### APPENDIX D # EXAMPLE PROGRAM CODING | OP CODES USED: | LOAD=20, ADD=34 | STORE | = 70 | |------------------------|-----------------|---------|----------------------------------| | MNEMONIC: AD | DOUBLE PRECISIO | | ING-POINT ADD | | L.D | DOUBLE PRECISIO | | ING-POINT LOAD | | STD | DOUBLE PRECISIO | N FLOAT | ING-POINT STORE | | • | | | | | 000100 | •LOC | 1.00 | | | 000100 340112 | TAD | DATAI | /CPU INSTRUCTION | | 000101 040113 | DAC | STOR | /CPU INSTRUCTION | | 00010 <b>2 71234</b> 0 | L.D | NUM1 | /DOUBLE PRECISION F.P. LOAD | | 900193 900114 | | | /ASSEMBLES INTO TWO 18-BIT WORDS | | 900104 - 713740 | AD | SMUN | /DOUBLE PRECISION F.P. ADD | | 000105 000117 | | | /ASSEMBLES INTO TWO 18-BIT WORDS | | 000106 717340 | STD | ANSW | /DOUBLE PRECISION F.P. STORE | | 000107 000122 | | | /ASSEMBLES INTO TWO 18-BIT WORDS | | 000110 200125 | LAC | DATAS | CPU INSTRUCTION | | 000111, 600126 | JMP | NEXT | /CPU INSTRUCTION | | 000112 101127 | DATA1 101127 | | | | aaa <b>113</b> | STOR Ø | | | | 999 <b>114</b> 999947 | NUM1 47 | | /EXPONENT | | 000115 364211 | 364211 | | SIGN AND HIGH ORDER MANTISSA | | 000116 373642 | 373642 | | /LOW ORDER MANTISSA | | <b>000117 000036</b> | NUMA 36 | | /EXPONENT | | 000120 207416 | 207416 | | /SIGN AND HIGH ORDER MANTISSA | | 000121 477135 | 477135 | | /LOW ORDER MANTISSA | | 000122 000000 | ANSW Ø | | /EXPONENT | | 000123 000000 | Ø | | /SIGN AND HIGH OPDER MANTISSA | | 000124 000000 | Ø | | /LOW ORDER MANTISSA | | 000125 000001 | DATAS 1 | | | | 00 <b>0126 74</b> 0000 | NEXT | | /CPU INSTRUCTION | | | | | | WHEN THE INSTRUCTION AT LOCATION 000102 IS FETCHED, THE WORD, 712340, IS A NO-OPERATION IN THE CPU. HOWEVER, THE FPU IMMEDIATELY RECOGNIZES THE "71" AS A FLOATING-POINT INSTRUCTION WORD. AT THIS TIME, THE FPU DISABLES THE CPU FROM MAKING FURTHER MEMORY REQUESTS, AND THE REST OF THE FLOATING-POINT INSTRUCTION IS DECODED - 2340. SINCE L=1. THE CPU IS ALLOWED TO MAKE ITS NEXT REQUEST TO MEMORY. THE CPU NOW THINKS IT IS FETCHING THE NEXT INSTRUCTION. FROM LOCATION 000103. THE CONTENT OF 000103 IS REALLY MEANT TO BE THE SECOND OPERAND ADDRESS FOR THE FLOATING-POINT INSTRUCTION. CONSEQUENTLY, THE CPU MUST NEVER SEE THE "GARBAGE" INSTRUCTION IN 000103. THIS IS ACCOMPLISHED BY DISABLING THE CPU FROM STROBING THE CONTENTS OF 000103 INTO ITS BUFFER. BECAUSE OF THE "STIMULUS- ### (PAGE D2) RESPONSE" OPERATION OF THE CPU WITH CORE MEMORY, THE CPU WILL WAIT IN LIMBO UNTIL IT IS ALLOWED TO STROBE THE MEMORY BUS INTO ITS BUFFER. MEANWHILE THE FPU TAKES OVER WHERE THE CPU LEFT OFF, STROBES THE CONTENT OF 000103 INTO THE FPU BUFFER, AND ISSUES THE NECESSARY ACKNOWLEDGE SIGNALS TO END THE MEMORY CYCLE. A DUMMY NO-OPERATION INSTRUCTION WORD IS THEN PUT ON THE MEMORY BUS BY THE FPU, FOLLOWED BY A STROBE SIGNAL TO THE CPU. THE FPU NOW PLAYS THE ROLE OF A CORE BANK AND ISSUES THE NECESSARY SIGNALS TO THE CPU TO END THE CYCLE. AGAIN, THE FPU DISABLES THE CPU FROM MAKING A MEMORY BEQUEST. OP CODE = 20 IS A LOAD INSTRUCTION. P = 1 AND F = 1, COMPLETE THE DESCRIPTION OF THE INSTRUCTION, LABELING IT DOUBLE PRECISION FLOATING-POINT. THE DESTINATION OF THE LOAD IS A 54-BIT THE DESTINATION ACCUMULATOR IS LOADED WITH FPU HARDWARE ACCUMULATOR. THE EXPONENT, SIGN AND HIGH ORDER MANTISSA, AND THE LOW ORDER MANTISSA FROM LOCATIONS 000114, 000115, AND 000116 RESPECTIVELY. THE CONTENT OF 000103 IS THE SECOND OPERAND ADDRESS. SINCE BIT 0=0, THERE IS NO INDIRECTION, AND THE EFFECTIVE ADDRESS IS SIMPLY 000113. WHEN THE INSTRUCTION IS FINISHED, THE CPU IS ENABLED FOR MEMORY REQUESTS AND THE NEXT WORD FETCHED BY THE CPU IS FROM LOCATION 000104. THE OTHER FLOATING-POINT INSTRUCTIONS ARE EXECUTED IN A SIMILAR MANNER. NOTE: I/O MEMORY REQUESTS ARE GIVEN PRIORITY OVER FPU REQUESTS TO MEMORY.