HARDWARE MANUAL

## VOLUME II

## FLOIV DIAGRAIIS

HARDWARE MANUAL
VOLUME II
FLOW DIAGRAilS

# $109 \%$ <br> $\lambda * / \quad \vdots=0$ COMPUTER SYSTEMS <br> NORD-1 

# Hardware Manual Volume II Flow Diagrams 



AIS NORSE DATA-ELEKTRONIKK

# TABLE OF CONTENTS 

1 Introduction
2 Flow Diagrams
3 Signal Definitions


| DRAWN BY EML | Remarks | Replacement for | Date |
| :--- | :--- | :--- | :--- |
| APPROVED BY |  | Replaced by | Date |
| DATE 31.10 .69 |  |  |  |

## INTRODUCTION TO NORD-1 DOCUMENTATION

Summarizing the development of NORD-1 may give a coarse idea of the structure of the documentation.

The first step in the design process was to decide the number of programmer oriented registers and the instruction format and repertoire.

The next step was to draw flow diagrams of all instructions. Part of this work is also the design of CPU-arithmetic and timing control (Time Counter and Cycle Counter).

To translate the flow diagrams into logical equations is a straight forward mechanical work, and the equations may be regarded as a rewriting of the flow diagrams.

The last step, drawing of logic diagrams, is even more straight forward. The problem at this stage consists of distributing circuits on circuit boards and definition and labelling of subsignals.

The basic operation of NORD-1 is illustrated in the figure below.


One register is enabled at a time and presented at the IB terminals, and as input to the arithmetic. Data from memory goes via the H -register and the BM input to the arithmetic. For inter-register operations one of the operands (source) is first transferred to the H -register before IB is switched to the other operand. The output of the arithmetic is then routed back to all registers where it may be strobed into register flip-flops.

The purpose of the control logic therefore is to generate the appropriate sequence of register enabling signals and register strobe pulses and to control the arithmetic to give the desired function, all as a result of the instruction decoded.

The operation of the logic is synchronous, i.e. controlled by a common timing source (Time Counter and Cycle Counter). To avoid timing hazards the timing signals, after being decoded from the time counter flip-flops, always passes three stages of logic circuits before reaching the register flip-flops.

Example: Generation of A-register set pulse.


The timing synchronization of all registers in CPU is similar to the example shown for the A-register.

As further introduction to the NORD-1 documentation three instructions will be taken as examples and all important active signals connected to each block in the flow diagrams will be described in detail.

The example instructions are:

1. add 120
2. skp dx gre zro
3. shad rot 5

The reader is advised to find the mentioned signals in the logic diagrams, to familiarize himself with the documentation.
add 120
Relevant flow diagrams: Pages 1 and 12
The instruction add is a two-memory cycle instruction requiring two 16 bit words to be read from core memory, first the instruction itself ( C 0 ) and then the data word (C2).

The Time Counter control signals BACK and NEXT are both 0 in both cycles, and the Time Counter therefore produces the short sequence
t0-1-2-3-8-9-10-11-0
t0 lasts until DATA READY is received from the memory control and is approximately 800 ns with a $1.5 \mu \mathrm{~s}$ memory. All other time intervals are 100 ns .

| $(R) \rightarrow H$, IR | When entering to in C0 the R-register contains the <br> actual address and a Memory Request signal is <br> generated by CPU (RQ1). (Note: Last instruction <br> ended with a transfer of $P$ to R). The address is <br> enabled to the memory address input MR (158), and <br> a Read/Restore is intiated (INIT, RRA 169). The <br> content of the specified memory location is trans- <br> ferred to the MB-register (Memory Control Module) <br> and a Data Ready signal is returned to CPU (RY1). <br> RY1 restarts the Time Counter and t1 is entered. |
| :--- | :--- |
| The memory communication bus MJ is now equal to <br> MB (enabled by CPUE) and is strobed into IR (IS1) <br> and the H-register (HS1, ME1). |  |
| This addition is done via the address arithmetic. <br> First P is set to all ones (PS3) and then the appro- <br> priate zeroes are transferred to P via the flip-flop <br> clear terminal (PS4). RE1 enables the R-register <br> as input to the arithmetic and CY2 generates the 1 to <br> be added as a carry input to the least significant stage <br> of the adder. |  |

$$
R+120 \rightarrow R \quad \text { Address arithmetic addition (RE1, HE2, SX1, RS1) }
$$

$R$ is equal to the address of current instruction. 120 is the displacement of the instruction with sign extension, i.e. bits 8 through 15 equal to bit 7 . 120 is transferred via the H-register and SX1 controls the sign extension mechanism.

The flip-flop $D$-input is used since the input to $R$ is a function of $R$ itself.
$(R) \rightarrow H \quad$ Similar to $(R) \rightarrow H, I R$
$\mathrm{A}+\mathrm{H} \rightarrow \mathrm{A}$
$P \rightarrow R \quad$ Transfer via address arithmetic (PE1, RS1).
Input to the arithmetic is enabled by HE1 and AE1, which makes $\mathrm{BM}=\mathrm{H}$ and $\mathrm{IB}=\mathrm{A}$.
The output of the arithmetic is the sum of BM and IB if no other control signal is active. $\quad\left(P L U S=X R_{0} I D_{0} B D_{0}\right)$. The sum is strobed into A at t11 by AS2.


Relevant flow diagram:
Page 5
This instruction is a one cycle instruction (C0). The Time Counter control signal NEXT depends upon resulting skip condition and selects one of the following two time pulse sequences.
skip not effective: skip effective:

```
t0-1-2-3-8-9-10-11-0
to - \(1-2-3-8-9-10-11-12-13-14-15-0\)
```

$(\mathrm{R}) \rightarrow \mathrm{H}, \mathrm{IR} \quad$ same as example 1
$R+1 \rightarrow P \quad$ same as example 1
S.R. $\rightarrow \mathrm{H} \quad$ In the instruction above the source register code is 0 , which means that no register is enabled and therefore $\mathrm{IB}=0$. This zero is transferred to the H-register (IE1, HS1).
$P \rightarrow R$

$$
P+1 \rightarrow R
$$

shad rot 5
Relevant flow diagram:
Page 7
Double shifts (AD connected, 32 bits) are done in two phases, 16 bits shifted at a time. SA1 is a phase control flip-flop being complemented at each shift pulse.

SA1 $=0$ : shift the $D$-register
SA1 = 1: shift the A-register
No shift direction specified means left shift.

| $(\mathrm{R}) \rightarrow \mathrm{H}, \mathrm{IR}$ | Same as example 1 |
| :---: | :---: |
| $R+1 \rightarrow P$ | same as example 1 |
|  |  |
| $0 \rightarrow$ SA1, SC | Reset Shift Counter (SC) and the phase control flip-flop (SA1). |
| $5-$ SC | 5 , the number of places to be shifted, is transferred from the H-register to the shift counter via the main arithmetic (required by floating point instructions). (HE1, BD, SS8). |
| $\mathrm{SC}-1 \rightarrow \mathrm{SC}$ | If SA1 = 1 the shift counter is decremented. |
| $\mathrm{SA}_{0} \rightarrow \mathrm{SA}$ | Complement the phase control flip-flop. |
| shift D | If SA1 $=0$ shift the $D-$ register one place to the left. (DE1, IL, ID, DS2, DX1). |
|  | IL enables left shift of IB. ID makes the output of the arithmetic equal to the IB-input and DX1 selects A15 as input to D0. The discarded bit (D15) is transferred to the link flip-flop M. |
| shift A | If SA1 = 1 shift A-register one place to the left (AE1, IL, ID, AS3, DX1). In this case DX1 selects M as input to A0, and the discarded bit (A15), which has already been transferred to D0, replaces the previous content of M . |
|  | If the content of the shift counter is not zero go back to SC-1 $\rightarrow$ SC. This is controlled by the Time Counter control signal BACK (BK1), which repeats pulses t8-9-10-11 the required number of times, ten in our case, five for each phase. |
| $\mathrm{P} \rightarrow \mathrm{R}$ | same as example 1 |

Below follows a list of symbols and abbreviations used in the FLOW DIAGRAMS together with a short explanation.

AW Anything written
DP
SA
SI
ST
TR

SR Source-Register
DR Destination-Register
S
DR - SR (Sum output)
(R)

The contents of the cell which address is contained in the R -register
REG (i) Bit in the register
$\triangle$
Displacement of the instruction (lower half of H with sign extension)
$A \leftrightarrow G \quad$ The $A-$ and the $G-r e g i s t e r ~ i s ~ e x c h a n g e d ~$
$T 14_{0} \rightarrow$ T14 $\quad$ Bit 14 in the $T$-register is complemented
$2 X \rightarrow X \quad$ Left shift of the $X$-register
$1 / 2 \mathrm{X} \rightarrow \mathrm{X} \quad$ Right shift of the X -register
T15 $\bigoplus \mathrm{H} 15 \rightarrow$ SG1 Exclusive or of bit 15 of the T - and the H-register.
If T 15 is the oposite of $\mathrm{H} 15,1 \rightarrow$ SG1
$\mathrm{T} 15 \oplus \mathrm{H}_{15} \rightarrow$ SG1 If T15 is equal to $\mathrm{H} 15,0 \rightarrow$ SG1
$A 0 \cdot 2^{15}+1 / 2 D \rightarrow D$ Right shift of the D-register with A-register bit 0 shifted into D-register bit 15

$\boldsymbol{\Delta}=$ Lower half of $H$ with sign extension.

| DRAWN BY EML | Remarks |  | Replacement for | Date |
| :--- | :--- | :--- | :--- | :--- |
| APPROVED BY | ADDRESSING SEQUENCE GO -5 |  | Replaced by | Date |
| DATE 14.10 .69 |  |  |  |  |


| A/S NORSK DATA- <br> ELEKTRONIKK | Title | Drawing no. |
| :--- | ---: | ---: |



$$
\text { NOTE: } \frac{\text { tl2-15 is "inserted" only if jump not }}{\text { effective and does not exist with jump }} \text { effective. Controlled by signal NEXT to }
$$ time counter.



1100110001101010


If D.R. $=P \quad P \rightarrow R$ is replaced by $S \rightarrow R$.
If IR T=1 H is replaced by one's
complement of $H$ in the diagram above.
swap $=I R 10_{0} 9_{0} 8_{0}$
cid = 100 (IR)
rad $=2000$ (IR10)
$\mathrm{cm} 1=200$ (IR)



| DRAWN BY EML | Remarks |  |  |  |
| :--- | :--- | :--- | :--- | :--- |
| APPROVED BY | Replacement for | Date |  |  |
| DATE 15.10 .69 |  |  |  |  |



$0 \leqslant$ REGISTER ADDRESS $\leqslant 63$

$$
\begin{aligned}
\mathrm{tra} & =150.000 \\
\mathrm{trr} & =150.100 \\
\mathrm{mcl} & =150.200 \\
\mathrm{mst} & =150.300
\end{aligned}
$$

| Replacement for | Date |
| :--- | :--- |
| Replaced by | Date |


| A/S NORSK DATA- |
| :---: | :---: | :---: |
| ELEKTRONIKK |$\quad$| Title |
| :---: |
| PLOwing no. |
| Page 9 |


$\Delta=$ displacement
DRAWN BY EML

APPROVED BY


| A/S NORSK DATA- |
| :---: | :---: | :---: |
| ELEKTRONIKK | | Title |
| :---: |
| PLOWing no. |
| Page 11 |



| DRAWN BY EML | Remarks |  |  |  |
| :--- | :--- | :--- | :--- | :--- |
| APPROVED BY | Replacement for | Date |  |  |
| DATE 15.10 .69 |  |  | Replaced by | Date |






| DRAWN | $B Y$ | $E M L$ |
| :--- | :--- | :--- |
| APPROVED BY |  |  |


| Replacement for | Date |
| :--- | :--- |
| Replaced by | Date |



Floating control 134

## Continue page 17

$$
\begin{gathered}
\theta_{1}=S 14,13,12,11,10,9,8_{1} 7,6,51+S 14_{0} 13_{0} 12_{0} 11_{0} 10_{0} 9_{0} 8_{0} 7_{0} 6_{0}^{5} 0 \\
):(T-H)<32
\end{gathered}
$$

| DRAWN | $B Y$ | EML |
| :--- | ---: | ---: |
| APPROVED BY |  |  |


| Replacement for | Date |
| :--- | :--- |
| Replaced by | Date |


DRAWN BY EML

APPROVED BY

| Replacement for | Date |
| :--- | :--- |
| Replaced by | Date |




DRAWN BY EML
APPROVED BY
DATE 20.10 .69

| Replacement for | Date |
| :--- | :--- |
| Replaced by | Date |



| DRAWN | BY | EML | Remarks | $F M U$ | Replacement for | Date |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| APPROVED BY |  |  |  |  |  |  |
| DATE |  | 0 |  |  | Replaced by | Date |



| DRAWN BY EML | Remarks | F M U | Replacement for | Date |
| :--- | :--- | :--- | :--- | :--- |
| APPROVED BY |  |  |  |  |
| DATE | $21,10,69$ |  | Replaced by | Date |

