# ! digi.tal! INTEROFFICE MEMORANDUM

TO: Jupiter CPU Project Members

DATE: 4-Jan-82

CC: List FROM: Scott G. Robinson

DEPT: LSG Hardware Engr

LOC: MR1-2/E85

DTN: 231-6988

POLE: MP18.6 (or so)

SUBJ: Jupiter FPA

The Jupiter FPA (aka APA) is an add-on to the base CPU which accelerates a subset of KCl0 instructions. It is intended to make the Jupiter fit customers requiring interactive scientific computing.

### 1.0 ACCELERATED INSTRUCTIONS

The following KCl0 instructions will be accelerated by the FPA:

- o Conversion and Scaling FSC (132), FIX (122), FIXR (126), FLTR (127)
- o Rounded Single Precision Floating FADR? (144-147), FSBR? (154-157), FMPR? (164-167), FDVR? (174-177)
- o Unrounded Single Precision Floating FAD?
   (140,142,143), FSB? (150,152,153), FMP? (160,162,163),
   FDV? (170,173,173)
- o Double Precision Floating DFAD (110), DFSB (111), DFMP (112), DFDV (113)
- o Extended Prevision Floating EFAD (102), EFSB (103), EFMP (106), EFDV (107)
- o Double Word Moves DMOVE (120), DMOVEM (124), DMOVN (121), DMOVNM (125)
- o Integer Mulitplication MUL? (224-227), IMUL? (220-223)

All accelerated instructions will be processed directly or when XCT'd. Immediate mode instructions (FSC, FADRI, FSBRI, FMPRI, FDVRI, MULI, IMULI) will require EBOX intervention to obtain the instruction EA for the FPA because the FPA has no path to IBOX EA buffers. Instructions with indirects are treated by the EBOX as if they are XCT'd; thus, no special FPA processing is required to execute them.

## 2.0 EBOX/IBOX/FPA INTERFACE

## 2.1 Interface Diagram

The FPA Interfaces to the KCl0 as shown in the following diagram:



The FPA receives Operand and AC data on MD or LBUS. The data is written into buffers maintained in the FPA. Instruction, OP2, and the AC set are redundant with other buffers in the IBOX and

EBOX. Results from FPA operation are passed on ABUS to the EBOX and written into memory or ACs when an accelerated instruction is selected by SELI. The flags are updated similar to normal EBOX ALU flags update.

## 2.2 Data And Flags Injection

Data and Flags Injection requires complex timing. The FPA must present the data on the ABUS for the EBOX at the correct time based upon 5 cases. The FPA must update processor flags and ensure timing for TRAP1/TRAP2 traps. In all cases below the new flags are assumed to be updated similar to an AD FLAGS or EXP TEST given during the 'First Cycle' of the EBOX. The data to be stored is passed from A-BUS to L-BUS through RF-MUX and L-MUX.

## 2.2.1 Single AC Store -

Single AC Stores always store at Y-AC address and can be done completely within the EBOX 'First Cycle'. The equivalent microcode is:

. DCODE

; For this instruction to work RF-MUX is forced to ABUS; because RF-MUX is not controlled by fast ram microwords. IC: Y, X1\_[RF],MVE X1,L MVE,FPA FLAGS,LAST

Data is supplied by the FPA at Clock 3 so that RF can latch it at next Clock 0 and L-BUS latches RF at next Clock 1. Flags are updated at next Clock 2.

#### 2.2.2 Double AC Store -

Double AC Stores always store at Y-AC and Y-AC +1. These stores can be done with an EBOX 'First Cycle' and an early 'Last Cycle' if X-AC is forced to Y-AC +1 during 'First Cycle' or Y-AC is incremented after 'First Cycle'.

. DC ODE

; For this instruction to work RF-MUX is forced to ABUS!

IC: Y, X1\_[RF], MVE\_X1, L\_MVE, FPA FLAGS

IC: E,X (or Y), RF\_[ABUS],X1\_[RF],MVE\_X1,L\_MVE,LAST

Data is supplied by the FPA at both Clock 3s of the above sequence. The flags are updated at ECODE Clock 2.

## 2.2.3 Single Memory Store -

Single Memory Stores require 'First Cycle' and an early 'Last Cycle' because of data path timing for conversion of a memory store to an AC store. The data is always stored at (EA).

. DCODE

; For this instruction to work RF-MUX is forced to ABUS! IC: M, X1\_[RF], MVE\_X1, L\_MVE, FPA FLAGS
.ECODE

; This instruction holds Memory Data and selects on WR-MUX for 22ns. IC: E, X1\_[RF], MVE\_X1, L\_MVE, WR VMA, LAST

Data and flags are presented just as for the Single AC store case.

## 2.2.4 Double Memory Store -

Double Memory Stores require 'First Cycle' and several additional EBOX cycles because of data path timing for conversion of a memory store to an AC store. The data is always stored at (EA) and (EA+1).

. DCODE

; For this instruction to work RF-MUX is forced to ABUS! IC: M, X1\_[RF],MVE\_X1,L\_MVE,FPA FLAGS
.ECODE

; This instruction holds Memory Data and selects on WR-MUX for 22ns; and updates EA with assistance of the IBOX.

IC: E, X1 [RF], MVE X1, L MVE, WR-VMA,
EA EA+1

; This instruction stores the second memory word and holds; memory data and WR-MUX selects for 22 ns.

E,M, RF\_[ABUS],X1\_[RF],MVE\_X1,L\_MVE

E, LAST

The FPA supplies data at first Clock 3, Flags at next Clock 2, additional data at fourth (4th) Clock 3.

## 2.2.5 Single AC And Single Memory Store -

Single AC and Memory Stores require 'First Cycle' and several additional EBOX cycles because of data path timing for conversion of a memory store to an AC store. The data is always stored at (EA) and Y-AC.

; For this instruction to work RF-MUX is forced to ABUS! IC: Y, X1\_[RF], MVE\_X1, L\_MVE, FPA FLAGS
.ECODE

; This instruction stores the memory word. It also holds

; memory data and WR-MUX selects for 22 ns. E,M, Xl [RF],MVE Xl,L MVE

E, LAST

The FPA supplies data at first Clock 3 and flags at next Clock 2.

## 2.3 Flags

The following table lists cases of flags update required for accelerated instructions.

| Case                                                                                    | ov | CRYØ | CRY1                                         | FOV                    | Tl                            | FUN            | NODV   |
|-----------------------------------------------------------------------------------------|----|------|----------------------------------------------|------------------------|-------------------------------|----------------|--------|
| FP Overflow     FP Underflow     INT Overflow     DIV Check     FP Check     Zero Check | 1  |      | <br> <br> <br> <br> <br> <br> <br> <br> <br> | 1<br>  1<br>  1<br>  1 | 1<br>  1<br>  1<br>  1<br>  1 | <br>  1<br>  1 | ++<br> |
| +                                                                                       |    | +    | +                                            | +                      | +                             | +              | ++     |

As can be seen there are six cases and five independent bits (OV, FOV, FUN, NODV, CRY1). CRYØ is derived from (CRY1 and -OV); T1 is set directly from OV. Thus the signals for flags from FPA to SCA are:

- o ENA FPA FLAGS Set to force Flags Update during current clock 2
- o OV Overflow Flag
- o FOV Floating Overflow Flag
- o FUN Floating Underflow Flag
- o NODV No Divide Flag
- o CRY1 Carry 1 Flag



149 EXIST
20 NEED TO BE ADDED