Scholars' Mine
Masters Theses

Student Theses and Dissertations

1973

A formal description of the Nova-800 computer in computer
design language
Ronald Lee Engelbrecht

Follow this and additional works at: https://scholarsmine.mst.edu/masters_theses
Part of the Electrical and Computer Engineering Commons

Department:
Recommended Citation
Engelbrecht, Ronald Lee, "A formal description of the Nova-800 computer in computer design language"
(1973). Masters Theses. 4195.
https://scholarsmine.mst.edu/masters_theses/4195

This thesis is brought to you by Scholars' Mine, a service of the Missouri S&T Library and Learning Resources. This
work is protected by U. S. Copyright Law. Unauthorized use including reproduction for redistribution requires the
permission of the copyright holder. For more information, please contact scholarsmine@mst.edu.

A F0Rf,1AL DESCRIPTION OF THE NOVA-800 COMPUTER
IN COMPUTER DESIGN LANGUAGE
BY
RONALD LEE ENGELBRECHT, 1947A THESIS
Presented to the Faculty of the Graduate School of the

UNIVERSITY OF MISSOURI-ROLLA
In Partial Fulfillment of the Requirements for the Degree

MASTER OF SCIENCE IN ELECTRICAL ENGINEERING
1973

T2864
62 pages

c.l

Approved by

ii
/

'

ABSTRACT

J~
'

This paper presents a formal description of the operation of the
NOVA 800 in Computer Design Language (COL).

For simplicity, the

description does not include specific input/output devices, the
multiply/divide option, or data channel operations.

The description

is intended to be used as a supplement in a basic course in computer
organization, and an example of its use is included.

iii

ACKNOl~LEDGEf'1ENTS

The author wishes to express his appreciation to Dr. Paul Stigall
for his guidance and advice during the writing of this paper.
The author also wishes to thank Dr. James H. Tracey and Dr.
Hugh F. Spence for their helpful discussions.

iv

PUBLICATION THESIS OPTION
This thesis has been prepared in the style utilized by the
IEEE Transactions on Education.

Pages ii, 1-3, and 15-46 will be

presented for publication in that journal .

The remainder of the

paper has been added for purposes normal to thesis writing.

v

TABLE OF CONTENTS
Page

ABSTRACT ........ . ................................................. . i i
ACKNOWLEDGEMEtlTS .•....

. iii

LIST OF ILLUSTRATIONS.

.vi

I.

INTRODUCTION ......•.

.1

II.

GENERAL DESCRIPTION.

.4

A.

ARITHMETIC AND LOGIC UNIT.

.4

B.

DATA TRANSFERS.

.7

c.

THHI~G

..

.8

D.

CONTROL.

.10

. .......................................... . .12
I I I. SYt·1BOLIC DESIGN. ........................................... • 15
A. DECLARATIONS. . .......... ............................... . . 15
B. TRANSFERS. . ............................................ . • 27
c. EXAMPLE. ............................................... . • 39
IV. CONCLUSIONS. . .............................................. . . 45
BIBLIOGRAPHY . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .. . . . . . . . . . 46
E.

HEI~ORY

..

VITA .................... . .............................. ·.········· .47

APPENDICES • . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

.48

LANGUAGE.

.48

OF Cm1PUTER

A.

A

B.

CHANGES AND NOTES ... . ................... ............... . . 50

c.

PROGRAr~

D.

STUTTER TIMING . .. ............... . .. . ... . .......... ·· .. · .. 54

sur~r~ARY

DESIGt~

LOAD OPTION. . ................. ....... .......... . • 52

vi

LIST OF ILLUSTRATIONS
Figure

Page
PAT~iS Af~D

1.

DATA

ALU ...•...••.•••.••....•••.••••.•••••.•.•..•..••• 5

2.

MULTIPLEXOR TRUTH TABLES ......•................................. 6

3.

TIMif4G SIGNALS ••.•..•..•.••••..•••....•••.••..•.••...••••..•.•.• 9

4.

MACRO-STATE DIAGRAI·1•...•......••....•.....•.....•...•.......... 11

5.

MEMORY SIGNALS ••.•••.••..•..•..•••..•.•••..••.•••.•••...••••••• 14

6.

STUTTER TIMING SIGNALS .......................•.....•.....•..... 56

1

I.

INTRODUCTION

In the electrical engineering or computer science curriculum
of many schools, a basic course in computer organization is taught
to either third or fourth year students.

The course typically begins

with a review of number systems and of the algorithms for performing
arithmetic in these number systems, particularly the two•s complement
system.

The elements of a computer (adder, memory, registers, and

clock) are then explained, and an attempt is made to combine these
elements and to demonstrate to the student the basic operational
scheme of a simple computer.

A number of excellent texts exist

which follow this basic scheme [1,2,3,4].
The simple machine which is usually described in the latter
portion of these texts is very necessary in order to introduce the
student to computer organization at an understandable level.

This

simplicity, hO\.'Iever, often leads to one or more of the following
shortcomings:
1)

The machine is hypothetical, making it impossible for the student
to get any practical experience on it.

This fact also makes the

student question the value of studying the machine.
2)

The machine is described in general terms, making it hard for the
student to follow register transfers and control states on a
clock-pulse by clock-pulse basis.

3)

In an attempt to remain simple, the computer may not demonstrate
current techniques such as indirect addressing, autoindexing,
memory protection, interrupts, I/0 operations and parallelism.

2

These faults point to the need for a supplemental computer description
in the course.
It has been the practice of the Electrical Engineering Department
of the University of

t~issouri

at Rolla to supplement the text used in

this course with a formal description of a modern machine which is
·available to the students.

This description is done on a clock pulse-

by-clock pulse basis so that the student may see exactly what the
machine does and how it does it.

The class work is combined with

laboratory problems to demonstrate the validity of the description
and give the student practical experience on the machine.

It has been

found that this approach is extremely valuable in later courses in
computer organization.

Since the student has a very detailed know-

ledge of one machine, other organizations and techniques can be
taught by comparison and contrast to that machine.

It serves as a

standard reference point from v-1hi ch variations may be easily compared
and assessed.
For several years, the department has used a formal description
of the SCC-650 computer by Pottinger [5], however, due to the increased
availability of the NOVA family of computers on campus and the more
modern features of this computer, it was considered desirable to
substitute a formal description of this machine in the course.

The

purpose of this paper is to provide this formal description.
It is desirable that the language used for the formal description
possess as many of the following characteristics as possible [6,7]:
1)

Capable of expressing ideas easily

2)

Easily understood

3

3)

Capable of showing timing and control

4)

Concise

5)

Precise

6)

Non-ambiguous
Yaohan Chu's Computer Design Language [1,6] was chosen for this

description because it possesses most of these attributes [7], and
because a language translator is available to take the COL description
as an input and produce the Boolean equations for the register
inputs [1].

The language uses ALGOL-like statements to declare

registers, control signals, memories, and combinational network
outputs.

It then specifies all data transfers between registers and

memories, as well as the signals used to control these transfers.
Synchronous timing is easily expressed since the control signals are
separated from the transfers.

Parallel operations may be shown since

there is no restriction that the control signals be mutually
exclusive [7].

4

II.
A.

GENERAL DESCRIPTION [8]

Arithmetic and Logic Unit
The arithmetic and logic unit (ALU) of the NOVA 800 consists

of a 16 bit adder, 4-16 bit accumulator pairs (source and destination), a 16 bit arithmetic holding register (AR), a 15 bit program
location counter (PC), a 16 bit processor memory buffer (Pt1B), a
source multiplexor (SX), a destination multiplexor (D), and a memory
buffer output multiplexor (MBO).

These elements and their basic

interconnections are shown in figure 1.
Much of the flexibility of the ALU of the NOVA is due to the
source and destination multiplexors which serve to select the inputs
to the adder.

Diagrams showing inputs, control signals, and truth

tables for the multiplexors are shown in figure 2.

As shown, the

SX multiplexor has as inputs the PC, the AR, and the four source
accumulators; its output may be zero, one, any of the inputs, or the
complement of any of its inputs.
The 0 multiplexor must be considered to be two multiplexors.
0(8-15) handles the low order byte and has as inputs the four desti-

nation accumulators and the PNB; note that the inputs can not be
complemented.

0(0-7) handles the most significant byte and has the

same inputs as 0(8-15), but the control signals are different and
the outputs include the complements of the inputs.

The ability to

manipulate bytes of an instruction vmrd is needed during effective
address calculation.

In that case, the input to the adder from SX

is either the PC or a source accumulator .

The input from 0(8-15)

5

f1Er10RY

I

\7

\1

I

t,1A
\/

l

_\/

J

f'1B

ALU

(/)

:::>

ca

v

I

I

pf,18

I

.~

I I

AR

t

t

4-16 BIT

~
PC

~

1--

c:::(

Cl

I

4-16 BIT

DESTINATION

SOURCE
ACCU ~~U LATORS

ACCU f~ULAT OR S

(/)

(/)

:::>

:::>

::a

C!l

~

::2::

""-

I

:::>

t
D-HULTIPLEXOR

+

PC

~

I r~Bo -~,1UL n

t

+

I

I

~

I

SX- f,1UL TI PLEXOR

v

PLEXOR

UJ

(/)

t
t
ADDER OUTPUT
t1AfH PULATOR
GATES

l'

f ADDR.

\i
LI GHTS

I I DATA
I DATA

~
LIGHTS

I

S\HTCHES

J

I'
Fig . 1.

I

DATA PATHS AND ALU

\7
IR

J

G

ACSX

SX COfvJ
SX- H-SEL
SX-L-SEL

PC

AR

SX-H-SEL
0

SX i·1UL TI PLEXOR
OUT

SX-COI1
OUT
0

SX-L-SEL
0

SX-CO~'l

OUT
1

0

1

J\CSX

ACSX

1

0

PC

PC

1

1

AR

AR

(a)

J\COX
(0-7)

ACOX
~1Q
(mult/d i o option) (8-15)

P~·1B

(0-7)

O-t·1-Cm1

PlvJB

(8-15)

t~Q

0-L- H - S E~

0(~- 7)

0- r~ -H-SEL

0(8-15)

0-L-SEL

D-L-SEL

OUT

OUT
0- f~ -Cot~

OUT

0-1,-H-SEL

0-L-SEL

0

0

0

0

1

A CDX(~ - 7)

1

0

Pt1B (~-7)

1

1

11Q

O-M-Cm1
OUT
1

D-L-H-SEL D-L-SEL
0

0

0

ACDX{~-7 ~

0

1

ACDX(8-15

Pr1B (~-7)

1

0

Pt~ B ( 8-15)

1

1

t1Q

(b )

Fig . 2.

OUT

MULTI PLEXOR TRUTH TABLES

t'lQ

7

is the least significant byte from the Pt1B (the displacement), while
the input from D(0-7) is either all zeros if the displacement is
positive or all ones if the displacement is negative.
Data in the NOVA 800 are in two's complement integer representation.

The adder performs binary addition on pairs of inputs and

produces a carry out if the sum exceeds 216-1.
be incremented by the signal PLUS ONE

~'lhich

The adder sum can

forces a carry into the

least significant bit of the sum; this is used in forming the two's
complement of one number (NEG instruction) and in subtracting two
numbers.
The output of the adder is gated through the adder output
manipulator gates \'/here it may be shifted or have the two bytes
swapped.

The data is then transmitted via the SUM bus to the PC

(if it is the result of an effective address calculation for a JMP
or JSR) or to the AR (if it is the result of an arithmetic or logic
instruction).

The adder output also goes directly to the MBO multi-

p1ex or from which it may be transmitted to memory vi a the
B.

t~BO

bus.

Data Transfers
The NOVA 800 is organized around four 16-bit wide data busses;

Memory

U~ Et'1),

(DATA) bus.
ME!~:

(1)

Memory Buffer Output U1BO), SUt1, and the Input/Output
Their functions are as follows:

Carries information (instructions or data) from the memory
or console switches to the ALU or console indicators .

(2)

During I/0, data from an l/0 device controller is loaded
into t he t·1B r egi s t er and transferred to th e ALU vi a r-tEtL

8

t~BO:

(1)

Transfers information from the ALU to the memory and the
console indicators.

(2)

During I/0, data is transferred to the MB register via
the MBO bus, then transferred from MB out onto the DATA
bus.

SUM:

Carries the output of the adder to the PC (for JMP or JSR
instructions) or to the AR (for arithmetic and logical instructions).

DATA:

Provides a bidirectional data path between memory and the I/0
device controllers; it has no logical connection to the ALU.

C.

Timing
In the NOVA 800, a 20 f.1hz crystal controlled oscillator

functions as the primary clock source.

1·1EI'1 CLK, \vhi ch synchronizes

memory functions, is driven by a toggle flip-flop (CLKA) at one half
the frequency of the source.

CPU CL K, v1hi ch synchronizes memory

functions, is driven by a pair of countdown flip flops (CLKA and CLKB)
at one fourth the frequency of the source.

Logical operations in

the computer occur with the negative going edge of the CPU CLK.
PC CLK, which clocks the PC register, is essentially the inverse of
CPU CLK.

This is necessary because the PC responds to the positive

going edge of the clock pulse.

Also, PC can be pulsed while CPU CLK

is inhibited by FETCH SKIP for SKIP instructions.

The PTG (processor

timing generator) and TS (timing state) signals are produced by count
dmvn decoding logic by the two bit Gray code counter, TG(0- 1), and

9

FETCH SKIP
20 t·1hz
SOURCE

CLKA
DIVIDE
BY 2

1----1...----l

f~H1

RUN
COUNT
AND
DECODE

CLKB
DIVIDE
BY 2

CLK

PC CLK CPU CLK

~ 100 k-ns I
CLKA
CLKB
MH1

CLK
CPU
CLK
PC
CLK
t-E--200

ns--+-1

PTGl
PTG2
PTG3

s
TSM
TS3
Fig . 3.

TitUNG SIGNALS

PTGO
PTGl
PTG2
PTG3
TS0
TSivl

TS3

10

associated NAND gates.

The relationships between these timing signals

are shown in figure 3.
Note that each of the 200 ns PTG intervals may be broken into
4-50 ns intervals designated by the states of the flip flops CLKA and
CLKB.

For instance during PTG0, we have the four intervals

PTG0*CLKB*CLKA, PTG0*C[KB*CLKA, PTG0*CLKB*C[KA, and PTG0*CLKB*CLKA.
For brevity, these intervals are called PTG0(1), PTG0(2), PTG0(3),
and PTG0(4), respectively, in the formal description.
D.

Control
In addition to the timing control signals, operational control

is furnished by a number of flip flops in the machine.

There are

basically six macro states or types of cycles for the machine and each
of these cycles are controlled by a flip flop or the immediate decode
of a flip flop.
The KEY cycle is entered (KEY flip flop set) whenever an
instruction other than STOP or RST is keyed in from the console
instruction switches.

If this instruction requires the use of memory,

the KEYrt cycle wi 11 be entered after the KEY cycle and the
flop set.

KEYt~

flip

The other four cycles of the machine are Fetch (F),

Defer (D), Program Interrupt (PI), and Execute (E).

There is no

individual control · flip flop for each of these states, but rather
each is indicated by a decode of the output of the major states
register, S(0-1).

The major states are inhibited by the STATE

SUPPRESS signal if the machine is in either a KEY or a KEYI1 cycle;
when this cycle is completed, the machine will be permitted to ente r

11

.,I ,....'
ANY
\
\

STOP R

\

STATE

'

-

)
I

/

DP+DPN+EX+EXN+PL
IlHRQ* (AL C+
IR'5"*Jf~P
JSR)
PL LAST

/

/ ANY
l STATE
\

.......

--

NTRQ*(HAS t CYC[E+IR5
*Jf,1P or JSR)

CYCLE

INTR
Fig. 4.

r~ACRO

STATE DIAGRAr-1

12

the state indicated by the contents of the major states register.
All transitions between states take place at the end of PTG3, and
the conditions for transitions are shown on the macro-state diagram,
figure 4.
E.

Memory
The memory read operation occurs during PTG1 when the STROBE

pulse occurs.

This enables the output of the memory sense lines to

be unconditionally jam transferred into the memory buffer (MB)
register.

The outputs of the MB register are placed on MEM(0-15)

unless the INH TRANS signal is present, and on DATA0-15 during PTG2
if DRIVE IO is present.
For a write operation, the MB register may contain the data just
read (rewrite), MB0(0-15), or DATA(0-15).

The latter two sources are

selected by READ IO or READ IO, respectively, and loaded into the MB
register during the last 50 ns of PTG1 by the MB LOAD signal.

The

effective address was loaded into the memory address register by the
MA LOAD signal during PTG3 of the previous cycle; it is loaded from
the 15 least significant bits of either MB0(0-15) or DATA(0-15).
Writing requires an INHIBIT signal from the control logic along with
the SELECT signal, which is a decode of MA(1-3) to select the proper
block of memory.

These produce signals to turn on the memory current

logic and to strobe the reset outputs of the MB register into the
inhibit line drivers.

The presence of inhibit current in any core

winding reduces the coercive effect of the normal memory current such
that the associated core will not be set.

Thus, the contents of the

13

MB register will be effectively written into core.
signals are shown in figure 5.

These memory

14

r~BO (r.J-15)

DATA (0-15)

4K t·1Et10RY BLOCK

DRIVE IO

DATA(r.J-15)

SELECT

'""""'
WORD
SELECT

I.!)
.--i

SENSE

I

&

At~P

co

INH TRANS

'-

OUTPUTS

~

STROBE

INHIBIT LINE
DRIVERS
INHIBIT

PTG1

-.....-.~

F*PTG1

--+--~

Fig. 5.

MEMORY SIGNALS

../

15

III.

SYMBOLIC DESIGN

A description of the NOVA-800 computer logic in Computer Design
Language is now presented.
A.

Declarations

Clock

Cp ; $ 20 Mhz master clock pulse $

Constants

MSK1=0000000011111111 , $ Dummy mask used in effective
address calculation sequence, does not
physically exist $
t~SI<2=1111111100000000

Memor,Y

Rot~(PC(ll-15))

; $ Same as t1SK1 $

= Rot1{0-32,0-15) , $ Read only memory for
program load option $

~1(r~A)

Registers

= r~ (0-32, 768, 0-15) ; $ t·1a in memory $

AC-H-WRITE ; $ Used with AC-L-WRITE to specify which of
the 4 accumulators will be written into
during PTG0' $
AC-L-~~RITE

ACDX(0-15)

$ Destination accumulator, X=0-3 $

ACSX(0-15)

$ Source accumulator, X=0-3 $

ACWRF ; $ When on, allows specified accumulator (both
source and destination) to be written into
during PTG0 $
AR(0-15) ; $ Arithmetic holding register in ALU $
AUT DEC ; $ When true with AUT INC OR DEC true, indicates
that an autodecrementing location, (30-37) 8 ,
has been indirectly addressed $

16

CLKA

$ Divides CP by 2, 10 t1hz output $

CLKB

$ Divides CLKA by 2, 5 f,thz output $

CRY ; $ Carry flip flop $
DEVBUF(0-15) ; $ Data buffer on I/0 device $
FSKIP ; $ Used in generating FETCH SKIP signal for skips $
INHIBIT

$ When on, permits MB register to be written

into M(MA) $
IR(0-15) ; $ Instruction decoding register $
INTRQ ; $ Interrupt request flip flop, set by external
I/0 device $
ION ; $ Interrupt on flip flop $
IO SKIP SYNC ; $ Timing flip flop for I/0 skip operations $
MA(1-15)

$

t~B (0-15)

$ Memory buffer register $

f~emory

address register $

MID ; $ Control flip flop used in stutter timing$
OVFLO

$ When true, generates overflow signal $

PC(1-15) ; $ Program location counter $
Pt1B (0-15)

$ Processor memory buffer register $

READ CY ; $ When set, allows memory to cycle$
READ 2 ; $ Used to provide correct timing in memory cycle $
RUN ; $ Allows generation of PTG timing signals when set,
machine is in STOP state when reset $
RUN SET ; $ Used to set and reset RUN and READ CY $
S(0-1) ; $

r~ajor

states register, outputs decoded to

produce F, PI, D, and E signals $
STP

$ Used in producing STOP RQ signal $

17

STROBE

$ When on, causes M(MA) to be jam transferred
into MB $

TA

$ Used with TB and TC to control stutter timing $

TB
TC
TG(~-1)

$ Gray counter whose output is decoded to

produce timing pulses

PTG~-PTG4, TS~,

TSM, and

TS3 $
WRITE

$ Memory timing flip flop used to guarantee

adequate write time for memory $
WRITE SYNC

$ Used to set and reset INHIBIT $

SWITCHES Comment Begin

The following are manual control switches.

All are momentary contact except the data switches,
S11-S26.

End.

S11-S26(0N,OFF)

$ Console data switches $

ACXDP(ON,OFF) ; $ Deposit value in data switches into
accumulator X $
ACXEX(ON,OFF)

$ Display value in accumulator X in data

lights $
CONT(ON,OFF)

$ Continue in state specified by major
states register $

DP(ON,OFF)

$ Deposit the value in the data switches
into the memory location shown in the console
address lamps (present value of PC) $

18

DPN (ON, OFF)

$ Add one to value of PC shown in address
lights and store the value set into the data
switches at this location $

EX(ON,OFF)

$Displays in the data lights the contents
of the location shown in the address lights $

EXN (ON ,OFF)

$ Adds one to the value of the PC shown in

the address lights and displays the contents
of this memory location in the data lights$
ISTP(ON,OFF)

$ Causes computer to execute a single
instruction and halt before fetching the
next instruction $

MSTP(ON,OFF)

$ Causes the computer to perform a single
processor cycle in the state indicated by
the major states register $

RST (ON, OFF)

$ Causes the computer to stop at the end of

the current processor cycle $
STOP (or~, OFF)

$ Causes the computer to stop after

execution of current instruction $
STRT(ON,OFF)

$ Causes the computer to load the address
held in the console data switches into the
PC and begin normal operation by executing
the instruction at the location specified
by the PC $

19

TERMINALS
ADDER ZER0=(5UMW*SUM1* ... *SUM1~)*(SUM11+ZERO ENABLE)*(SUM12+ZERO
ENABLE)*(SUM13+ZERO ENABLE)*(SUM14+ZERO ENABLE)*(SUM15+
ZERO ENABLE) ; $ Used for incrementing PC and for autoincrementing and decrementing $
ADDER TO MEM=[KEYM*PL*READ IO*PC TO MEM]*[PTG3+PI SET]
output onto
ADDER(~-15)

ALC =

MB0~-15

$ Gates adder

$

; $ Adder output lines $

IR~*F*TS~

; $ Arithmetic logic class instruction $

AND = ALC*AND ENABLE ; $ Logical "and" signal to adder $
AND ENABLE = IR5*IR6*IR7
ALC OR IO SET =

MEM~

+ MEM1*MEM2

$ ALC or I/0 instruction set into

instruction register $
CG ; $ Carry generate signal from adder $
CLR = MID*IR8*IR9*E*IO ; $ Used to clear ION FF $
CON DATA = (KEY*RUN)+(DAT1A*CPU INST) ; $ Allows configuration set
into console data switches to be placed onto MEM(~-15) $
CON INST = KEY*KEY SEEN*(CONT+ISTP+MSTP) ; $ Allows console control
switch data to be placed on

MEM(~-15)

if not Continue,

Instruction Step or Memory Step $
CON RQ = ACXDP+ACXEX+STRT+DP+DPN+EX+EXN+CONT+ISTP+MSTP ; $ Sets KEY
SEEN, generated 25 ms after a switch is activated $
CPU CLK = CLKA*CLKB*FETCH SKIP*TC*[IO STUTTER*(PTGl+MB LD EN+WRITE
SYNC)*(TA+TB)] ; $ Synchronizes CPU operations $
CPU INST = IRl~*IRll*IR12*IR13*IR14*IR15
instruction $

$ Central processing unit

20

CR ; $ Ripple carry output of adder $
CRY TO AR = CRY*[AND+CG+CR]+CRY*CR*CG*AND ; $ If true, shifts a one
into AR during shift (left) operation $
CRY SET = (CRY*CRY TEST)+(CRY*LOAD CRY)+(CRY TEST*LOAD CRY)

$ Set

control for CRY FF $
CRY TEST = (SEL N*CRY TO AR)+(SEL L*ADDER ZERO)+(SEL R·ADDER 15)
+(SEL S•CRY TO AR) ;
Suppress*S~*Sf

D = State
DATA(~-15)

; $ Defer state signal $

; $ I/0 bus lines $

DATIA = IR5*IR6*IR7*E*IO*PTG1 ; $ Data in A, generated by processor
during a D1A to place the A buffer in the device selected
by DS0-5 on the data lines $
DATIB = IR5*IR6*IR7*E*IO*PTG1

$ B buffer in selected device placed

on data lines $
DATIC = IR5*IR6*IR7*E*IO*PTG1

$ C buffer in selected device placed

on data lines $
DATOA = IR5*IR6*E*IO*MID*PTG2 ; $ Generated by the processor after ACC
has been placed on the DATA bus in a DOA to load the data
into the A register in the device selected by DS0-5 $
DATOB = IR4*IR6*MID*E*IO*PTG2 ; $ Loads the data on the DATA bus into
B register of selected device $
DATOC = IR5*IR6*MID*E*IO*PTG2 ; $ Loads the data on the DATA bus into
C register of selected device $
D-H-READ = IR3 ; $ Used with D-L-READ to select destination
accumulator $
D-L-READ

= IR4

;

21

D-L-SEL = Pl*TS3*HALT*E*IO+(KEY*PRESET*IRO*IR1)+ALC*IR5)+(ALC*E*STA)
$ Destination multiplexor- low order selection line$
D-L-H-SEL = MEM OUT + EFA ; $ Destination multiplexor - least significant byte - high order selection line $
D-M-H-SEL = MEM OUT ; $ Destination multiplexor - most significant
byte - high order address selection line $
O-M-COM = EFA*PMB8*(PMB6+PMB7) ; $ Complement output of destination
multiplexor $
DRIVE I/0 = PTG2*IO OUT EN

$Allows MB register to be gated onto

DATA bus $
DSZ = NON ACD INST*IR3*IR4 ; $ Decrement and skip if zero instruction $
DS(~-5)

=

IR(l~-15)

; $ I/0 device selection lines $

E = State Suppress *
EFA =

TSO*F*IR~*TO

S~*Sl

; $ Execute state $

; $ Indicates that the effective address calculation

is required $
F = State Suppress *

S~Sl

; $ Fetch state signal $

Fetch skip= (IO SKIP SYNC)*(IO SKIP)*(FSKIP)+FSKIP*ALC*[IR15(IR13*
ADDER ZERO+IR14*CRY TEST)+IR15(ADDER ZERO+IR13)+IR15
(TRI4+CRY TEST)] ;
Force SEL X = ALC*IR8 ; $ Used with Force SEL Y to produce shift and
swap signals to adder output manip. gates $
Force SEL Y = ALC*IR9 ;
F Set = State Suppress *

S~*Sf

+ State Suppress*[has E cycle*INTRQ*

(SET*PI*(EFA+IR5)*(PTGl+D+MEM~))J

; $ Indicates that F

will be the state set into the major states register
during the next cycle $

22
HALT = IR5*IR6*IR7*CPU INST*E*IO ; $ Halt instruction $
HAS E Cycle = ALC*s-*(JMP OR JSR) ; $ Indicates that fetched
instruction has an execution cycle $
INC PC = FETCH SKIP+PTG2*E*IO*PTG2*IR7*KEY*PRESET+PTG2*LAST WORD
+PTGl*ADDER ZERO*E*NON ACD INST ; $ Conditions for
incrementing program location counter $
INH TRANS = PI + KEY SEEN + RESTART + CON DATA ; $ Inhibits transfer
from MBR onto MEM

b~s

$

INTA = DATIB*CPU INST ; $ Interrupt acknowledge, generated by the
processor during the INTA instruction $
ION SYNC = SYNC*(F SET+PI SET) ; $ Interrupt on synchronization $
IO OUT EN = E*IO*IR7 ; $ I/0 output enable $
IORST = RESET + CPU INST*DATIC ; $ I/0 reset, generated by the
processor in the IORST instruction or when the console
reset switch is pressed to clear the control FF•s in all
interfaces $
IO SKIP = AND ENABLE*TSO*F*IO
IO SKIP PEND = IR9[(IR8*CPU INST*SE0D)+(TR8*CPU INST*SYNC*SELB)]
+IR9[(IR8*CPU INST*SELD)+(IR8*CPU INST*SYNC*SELB)] ;
,IO STUTTER = (PTG2*IO SKIP)+(E*IO*PTG3)*(IR8+IR9)+(PTGl*E*IO*READ IO)
+PTG2*IO OUT EN*E*IO ; $ Used to extend selected PTG
signals during I/0 operations $
IO = IRO*IR1*IR2 ; $ Decode of an I/0 instruction $
ISZ = IR3*IR4*NON ACD INST ; $ Increment and skip on zero instruction $
JMP OR JSR = IR3*NON ACD INST
JSR =

IR3*IR4*~0N

ACD INST ;

23

LAST WORD =

PC1~+PL+KEYM

; $ Indicates that the last word of Bootstrap

has been read in from the ROM $
LOAD AR = (PTG1+PTG3)*(EFA+JSR)*(KEY+KEY*Cont+lSTP+MSTP+State Suppress
SUM~-15

*JUM OR JSR) ; $ Loads data on

into AR $

LOAD PC = (PTG3*State Suppress*JMP OR JSR)+(PTGl*F*ALC OR IO SET)
+PTG2[PL+IR5+(KEY SEEN+RESTART)]*IR1*KEY*PRESET+PL(IR1
SUM(~-15)

+KEY+PRESET) ; $ Loads data on

into PC $

LDA = IRO*IR1*IR2 ; $ Load accumulator instruction $
LOAD CRY = PTG3*ALC*IR12 ; $ Causes destination ACC to be written into
and CRY FF set $
MA LOAD = PTG3*CLKA*CLKB*RUN SET*MEM CY SET

$Allows MA to be loaded

from MBO 0-15 $
MB CLR = READ CY*READ 2 ; $ Resets MBR at

PTG~

$

MB LD EN = E*NON ACD INST + D*AUT INC OR DEC ;
MB LOAD = PTG1*(MB LD EN + OMIT STROBE) ; $ Allows MB to be loaded
from
MB0(~-15)

MB0~-15

$

$ MBO bus $

MEM CLK = CLKA ; $ Clock for memory $
MEM CY SET= F SET+ PI SET+ IO SET

$Allows Read CYFF to be set

at PTG3, starting memory read-write cycle $
MEM LATCH = PTG1+PTG2 ; $ Used to latch data on MEM~-15 into PMB when
PTG1 goes 1-+0 $
MEM OUT = E*D-L-SEL + D + KEY*PRESET*PL*D-L-SEL
MEM(~-15)

$ Mem bus, during console operations the following signals

are placed on this bus :
MEM0 = ACXEX+ACXDP
MEMl = ACXDP

24

r·~Er12

= DP+DPN

~1E~13

= AC2EX+AC2DP+AC3EX+AC3DP

~1H14

= AC1EX+AC1DP+AC3EX+AC3DP

~1EH5
~1EM6

= EX+~T~T+J!:CXD~
= EX+EXN+DP+DPN+P[

MEM7

=

EXN+DPN

$

MSKO = CPU INST * DATOB ; $

~~ask

out, generated b.v the processor

during the t,1SKO instruction after ACC has been placed on
the data lines to set up the interrupt disable flags in
all devices according to mask on lines $
NON ACD INST = Tmr*T!IT*ill ; $ Non-des ti nation accumulator instruction $
01-HT STROBE = READ IO + KEY*PRESET + KEYt·1(PL+1R2)+(STA*7IT'"C*E)+PI
+(VT*~*E*IO)

; $ Omit memory strobe, outputs of memory

sense amps not jam loaded into MBR $
PC CLK = C[KA + C'C'J<B + TC + (iA+TB)(IO STUTTER+PTG1*~·1B LD EN*WRITE
SYNC) ;
PC TO t1H1 = RUN+[PTG3*READ ID*PI

SEi]*[(KEY*Cont+ISTP+t~STP)

+(State Suppress*JMP OR JSR)+(F SET*Pl LAST*JMP OR JSR)]
PLUS ONE

=

(PI*TS3)+(ID*PT*F)+(PTG1*D*AUT DEC OR INC*AUT DEC)
+(ALC*IR7)+(i\IT*E*ISZ) ; $ Forces a 1 into

101'1

order bit

of adder $
PI = State Suppress * S0*Sl ; $ Programmed interrupt state $
PI SET = (State Suppress*S0*Sl)+State Suppress*has E cycle*INTRQ*
[set*PT* (ITA+IRS)+ ( PTGl +D+f1Ef10)] ;
PRESET = RESET + KEY

SEEI~

flip flops $

* i<'EV * Cont + ISTP + MSTP

$ Initializes

25
PTG0 = ~*iGI ; $ Processor timing generator signal $
PTG0(1)

= TG0*TGl*CLKB*CLKA

PTG0(2)

=

TG0*1GT*CIK'B*CL KA

PTG0(3)

=

TG0*TGl*ClKB*CLKA

PTG0(4)

=

TG0*TG1*CLKB*CLKA

; $ Subinterval of PTG0 $

PTGl = TG¢*TG1

$ PTGl(l), etc., are formed as for PTG0 $

PTG2 = TG0*TG1

$ PTG2(1), etc., are formed as for PTG0 $

PTG3

$ PTG3(1), etc., are formed as for PTG0 $

=

TG0*TGT

PL LAST = PL*KEYM*LAST WORD ; $ Indicates end of Bootstrap load $
READ IO = PTG1*IR7*E*IO
RESET =

£r (5VOK+RST)

$ Allows data on

DATA0-15~1BR

$

$ Becomes true on o~l transition of 5VOK

or R3i $
RQENB = TS0*RUN*RUN SET*i<EY ; $ Request enable $
SEL-L = FORCE SEL X * FORCE SEL Y ; $ Left shift signal to adder
output manipulator gates $
SEL-N = FORCE SEL X * FORCE SEL Y ; $ No shift signal to adder output
manipulator gates $
SEL-R

= FORCE

SEL X * FORCE SEL

Y;

$ Right shift signal to adder

output manipulator gates $
SEL-S = FORCE SEL X * FORCE SEL Y ; $ Swap signal to adder output
manipulator gates $
STA = lRO*IRl*IR2 ; $ Store accumulator instruction $
State Suppress = KEY+KEYM ; $ Inhibits all normal instruction
decoding/control $

26

=

STOP RQ

RST + (lmf*KEY*Cont+ ISTP+MSTP )+KEYt1*'Pr+SVO'K+R'IT*STP
*(ISTP*FSETH1STP)+(STOP*KEY*FSET) ; $ Will cause RUN SET
to be reset when true $

STRT IO = PTG3*tUD*IR8*TR'9*E*IO ; $ Used to clear Done, set Busy and
clear the INT REQ flip flop in the device selected by
DS0-5 $

=

SUM CRY

SU~1(0-15)

CRY TO AR + AR0
; $Sum bus lines, basically the adder output which may
have its bits shifted or swapped-- e.g., SUM0

= SEL

N

*ADDER0 + SEL L*ADDER! + SEL R*SUt,1 CRY + SEL S*ADDER8 $
SX COivl

=

(PTGl*D*AUT INC OR DEC*AUT DEC)+(ALC*TR'6)+iliC*E*DSZ

$ Complement output of SX multiplexor $
SX-H-READ

= ALC*IRl+ALC*EFA

; $ Used with SX-L-READ to select the

source accumulator $
SX-L-READ
SX-H-SEL

= ALC*IR2+AIC*EFA*IR7
=

;

(1U:'C*EFA*lm>*IR7 )+(State Suppress*PL*IfE11 OUT*D-L-SEL)
+(PI*TSO)+'J5T*TS'3*F) ; $Used with SX-L-SEL to select the
output of the SX multiplexor $

SX-L-SEL

= ALC+ (ACC*EFA*IR6 )+State

TSr~

=

PTGl+PTG2

TS0

=

PTG0+PTG1

TS3

=

PTG2+PTG3

WRITE AC

=

Suppress*PL*MEt~ OUT*D-L-SEL

(E*LDA)+(TRr*KEY*PRESET)+[E*IO*AND ENAB[E*IR7
*(~+CPO 1NST)]+(EFA*JSR)+(ALC*TRI2*PTG3)

$ Used to

set ACWRF $
ZERO ENABLE
5VOK ;

= D*~

$ Generated

;

by power supply when +5V supply is on $

27

B.

Transfers

1.

Asynchronous

~1anua 1

Control

if (PRESET=!) then S0+0
Sb-0

l,JRITE+O

AUT DEC OR INC+-0

t·1I D+-0

AUT DEC+-0

TA+-0

READ CY+-0

TB+-0

READ 2+-0

TC+-0

STROBE+-0

RUN SET+-0

~~RITE

2.

INHIBIT+O

SYNC+-0

Stop Sequence

Comment Begin

The NOVA-800 may be placed in the STOP state either

by the HALT instruction or by manually activating either the RST or
STOP switches on the console.

The following statements describe the

sequence followed if the switches are activated.

Note from the

definition of the terminal STOP RQ and from this sequence that RST
will stop the machine at the end of the current cycle, while STOP \.Yill
stop it at the end of execution of the current instruction.
PTG2(4)

if (STOP RQ=l) then (RUN SET+O)

PTG3(4)

if (RUN SET=O) then (RUN+O) ;

3.

End

Memory

Comment Begin

The following sequence defines memory read and write.

fv1emory is cycling continuously while RUN and RUN SET are set. and the
entire memory cycle lasts 800 ns.

The cycle begins during PTG3 \'/hen

the MA register is loaded with the next effective address.

The t1B

register is cleared during PTG~ and the read operation occurs with

28

the STROBE pulse during PTG1.

During PTG2, the rewrite occurs i f

MB LOAD was false during PTGl, or a write operation takes place i f i t
was true.

End

PTG3(3)

if(ADDER TO !,1Et~*t·1A LOAD*READ 10=1) then(r.1A+ADDER(l-15)),
i f (PC TO t1E~1*MA LOAD*READ IO= 1) then (r1A+PC),
j_f.(~1A LOAD*READ IO= 1) then (r~A+DEV BUF);

PTG0(1)

j_f.(RUN SET*MEt~ CY SET=l) then(READ CY+-1),

-i f (MB. CLEAR= 1)

then (t1B+O);
--

PTG0(3)

if(READ CY=1) then(READ 2+1);

PTG1(1)

if(READ 2=1) then0~RITE SYNC+-1),
if(READ 2*oiHT STROBE-l) then(STROBE+-1);

PTG1(2)

J..!..(STROBE=1) then(r·1B+H(t1A)) ; $ Read operation $

PTG1(3)

STROBE+-0,
j_f.(HRITE SYNC=1) then(READ CY+-0, READ 2+0);

PTG1(4)

if(MB LOAD*READ IO*ADDER TO t~Et1=1) ~(f1B+ADDER),

$ Transfer write data to t1B from ALU $
i f (t~B LOAD*READ IO= 1) then (t1B+DEV BUF);
PTG2(1)

INHIBIT+-1, $ START WRITE $
t1 (t1A ) +f,1B ;

PTG2(3)

if(INHIBIT=1) then(WRITE+-1);

PRG3(1)

if0JRITE=1) then(HRITE SYNC+-0, INHIBIT+-0); $ End of
write

PTG3(3)

-if(INHIBIT=O)

4.

Key Cycle

Seguence

Comment Begin

$

-then(HRITE+-0);

The following sequence defines the KEY cycle, which is

initiated whenever a console instruction switch other than STOP or RST
is activated .

The switch activation causes CON RQ to go high, setting

29

KEY SEEN if RUN is reset.

The CON INST signal then gates an encoded

version of the states of the instruction switches into IR(0-7).

Note

that neither the STOP nor the RST switch will generate CON RQ; these
switches are considered separately.

End

CON RQ

j_f_(RUN=0) then (KEY SEEN+1) ;

CON INST

if(ACXEX*ACXDP=OFF) then(IR0+1) else(IR0+0)
if(ACXDP=OFF) then(IR1+1) else(IR1+0) ,
ifDP*DPN=OFF) then(IR2+1) else(IR2+0) ,
j_f_(AC2EX+AC2DP+AC3EX+AC3DP=ON) then(IR3+1)
else(IR3+0) ,
if(AC1EX+AC1DP+AC3EX+AC3DP=ON) then(IR4+1)
else {IR4+0) ,

-if(EX*STRT*ACXDP=OFF) -then(IR5+1) -else(IR5+0)
-if(EX*EXN*DP*DPN=OFF) then(IR6+1) -else(IR6+0)
~

-if(EXN*DPN=OFF)

-then(IR7+0) -else(IR7+0)

,
,

,

IR(S-15)+1 ;
KEY SEEN*PC CLK : KEY SYNC+1 , STP+1 ;
KEY SYNC*CPU CLK : KEY+1 ; $ Start key cycle $
KEY*KEY SYNC*CPU CLK : RUN+1 ; $ Start generation of PTG signals $
KEY*PTG0(1)

KEY SEEN+0

KEY*PTG0(3)

KEY SYNC+0

KEY*PTG1(1)

PMB+SW(11-26) ; $ Transfer of data from console data

STP+O ;

switches to PMB.

A one is transferred if the switch

is on $
KEY*PTG1(4)

if(I'R'0*IR1=1) then(M£3+ACDX) ; $ ACXEX; t1B places data

-

-

on MEM bus so it is visible in data lights $

30

KEY*PTG2(4)

if(IR1*TR5=1) then(PC+PMB(l-15)) , $ STRT or EX $
if(HALT*STOP RQ=l) then(RUN SET+l) , $ STRT, memory is
cycling whenever RUN SET is set$
if(HALT+STOP RQ=l) then(RUN SET+O) , $ ACXEX or ACXDP,
inhibits start of next memory cycle $
if(INC PC=l) then(PC+PC add 1) ; $ DPN or EXN $

KEY*PTG3(3)

if(F SET+IR6+!Rl*IR5=1) then(MA+PC) , $ STRT, DP, DPN,
EX, EXN, ISTP, MSTP $
if(PI SET=l) then(MA+O) ; $ Happens if machine was halted
with interrupt pending $

KEY*PTG3(4)

if(IR1*IR2=0) then(AR+PMB) , $ ACXDP, DP, DPN $
if(RUN SET=0) then(RUN+0) , $ ACXEX or ACXDP , machine
goes into stop state, PTG signals not generated $
if(IR6=0) then(KEYM+l) , $ DP, DPN, EX, EXN, machine
enters KEYM cycle $
if(WRITE AC=l) then(ACWRF+l)
if(FSET=l)

~(S0+0,Sl+O)

if(PI SET=l) then(S0+0,Sl+l)
AC-H-WRITE+ I R3 ,
AC-L-WRITE+IR4 ,
KEY+0 ; $ Note that if RUN is on and KEYM is off, the
next state is determined by the output of the major
states register $
PTG0(2)

if(ACWRF=l) then(ACDX+AR)
AC-L-WRITE $

$ ACDX chosen by AC-H-WRITE and

31

PTG~(4)

ACWRF ~ ; $ Note that PTG~ is available even if the machine
has entered the stop state since it is the decode
of

5.

TG~*TGT

$

Sequence KEYt·1Cycle

Comment Begin

This sequence is entered after the KEY cycle if DP,

DPN, EX, or EXN was activated.
\..,rite into memory.

It allows a read from memorv or a
y

End.

KEYt1*PTG0 ( 1)

t·1B+-0 ;

KEYM*PTG1(3)

if.(OMIT STROBE=0) then(MB+-M(t·1A)) ; $ True for EX or
EXN, data placed on MEM bus and visible in data
1i ghts $

-then(MB+-AR)

KEYN*PTG1(4)

-if(IR2=0)

; $ DP or DPN $

KEYM*PTG2(1)

t1(t1A)+-t·1 B; $Write or rewrite$

KEYt1*PTG2(4)

if(PI SET=O) then(RUN SET+-0)

KEn1*PTG3 ( 3)

if.( PI SET= 1)

~(MA+-0)

KEYM*PTG3(4)

if(PI SET=1)

then(S~+-0,

S1+-1) , $ Go to PI state $

if(PI SET=O) then(RUN+-0) ; $ Enter STOP state $
6.

Sequence Fetch Cycle

Comment Begin

The fetch cycle begins VJith the Ar being transferred

to the selected source and destination accumulators if ACWRF was set
during the previous PTG3.

Also during PTG0, the MB is being cleared

by t1B CLR in the memory cycle.

During PTG1, the t·1B and IR are loaded

with the word fetched from memory, however, decoded signals from the
IR are not available until PTG2.

The AR is loaded with PC add 1

(utilized for data channel operations and the JSR instruction) and the
PC is incremented if the instruction being loaded is an ALC or an I/0

32

instruction; this is determined by a decode of the MEM bus signals
since the IR decode is not yet available.
Execution of ALC instructions takes place during PTG2 of the
fetch cycle if the ALC signal is decoded; alternately, calculation of
the effective address of the data or next instruction occurs during
PTG2 if the signal EFA is decoded.

During PTG3, if an ALC instruction

is being processed, the data placed on the SUM bus during PTG2 will be
latched into the AR.

The machine will remain in the fetch state

(S0 & Sl reset) and ACWRF will be set to enable the AR to be written
into the proper accumulators during PTG0.

If the skip conditions are

true, the PC will be incremented (for the second time in this cycle)
before being transferred to the MA.
If an effective address calculation was performed during PTG2,
this value is latched into MA from the MBO bus during PTG3.

The

machine will then enter either the execute or defer state, depending
on the indirect bit (IR5).
If a JMP or JSR instruction is being processed during PTG3, the
primary jump address wi 11 be 1atched from the SUt1 bus into both the
PC and r~A during PTG3.

Note that in this case, the AR still holds PC

add 1 from PTGl and that a JSR will cause this value (the return
location) to be written into ACS3 and ACD3 during the following PTG0.
The machine may remain in the Fetch state, or switch to Defer,
depending on whether or not the indirect bit is set.
If an I/0 instruction has been fetched, the machine will enter
the Execute state next.
skip conditions are true.

The PC will be incremented again if the I/0
End .

33

F*PTG0(1)

MB+O ;

F*PTG0(2)

.i.f.(ACHRF=1) then(ACDX,ACSX+AR)

$ Final step of previous

instruction, X=3 if it was a JSR instruction $
F*PTG0(4)

ACWRF+Q ;

F*PTG1(2)

MB+M(HA) ; $ Memory read $

F*PTG 1 ( 4)

I R, Pt1B+f1B
AR+PC add 1 ,
.i.f.(!1B0+(M'BJ*t1B1*t1B2)=1) then(PC+PC add 1)

$ ALC, IO,

or HALT $
F*PTG2 ( 1)

~1 (r1A )+MB

F*PTG2 ( 4)

IO SKIP SYNC+0 ;

Comment Begin

; $ Re\·J ri te $

In the following statements, the source and destina-

tion accumulators are selected by decodes of IR(1-2) and IR(3-4),
respectively.
F*ALC*PTG3(1)

End
if(IR5*IR6*ffi?*SEL N=1) ~(AR+ACSX) , $ CDr·1 $
if(IR5*IR6*IR7*SEL 1~=1) then(AR+neg ACSX) , $ NEG $
if(IR5*IR6*IR7*SEL N=1) then(AR+ACSX) , $ t10V $
if ( IR5*IR6*IR7*SEL N=1) ~(AR+ACSX add 1) , $ INC $

if.( IR5*IR6*IR7*SEL

N= 1) then (AR+ACSY add ACDX)

$ ADC $
.if.{IR5*IR6*IR7*SEL N= 1) !t!!:.!l(AR+ACDX sub ACSY) ,

$ SUB $
if(IR5*IR6*IR7*SEL N=1) then(AR+ACSY add ACDX) ,

$ ADD $
if(IR5*IR6*IR7*SEL N=1) then(AR+ACSY add ACDX)

$ AND $

34

Comment Begin

Three additional sets of equations similar to the

above may be written with SEL R, SEL L, or SEL S, substituted for
SEL N.

The transfers then take the fo 11 owing forms

F*PTG3(2)

SEL R

AR~cirr (transfer quantity)

SEL L

AR~cirl

SEL S

AR~wap (transfer quantity)

(transfer quantity)

-if((ALC+IO)*FETCH

End

SKIP*INC PC=1) then(PC~Pc add 1) ;

-

$ Skip condition true for ALC or IO instruction $
F*PTG3(3)

.:Lf.(INTRQ*HAS

E CYCLI*IR5*Jf~p OR

JSR=1) thenU1A~)

$ Prepare for interrupt cycle $
if(INTRQ*(ALC+I0)=1 then(t·1A~Pc) ;
F*EFA*PTG3(3) : if(TRb*1'Ri=1) then(t,~A~Pt1B*t·1SK1) , $ Direct
addressing $
if(Jt~P OR JSR*TR'6'*TR7) then(PC~Pt·1B*t1SK1) ,

-if (TR6*IR7*IR8= 1) -then U1A~Pc add

( Pt·1B*t~SK1)) •

$ Relative addressing, positive displacement,
PC as base $

.:Lf.(JMP OR lJSR*"fRb*IR7*"iRB=1) then(PC~PC add(Pt~B*t~SK1),
then (~1A~PC
-if (T'i<6* I R7* IR8= 1) --

add ( Pt1B+f.1S K2)) ,

$ Relative addressing, negative displacement,
PC as base $

jf(J~1P OR JSR*"i'Rb*IR7*IR8= 1) ~(PC~PC add (P~~B+MSK2)),

if.( IR6*TR'i*l'R8=1)

then(t1A~ACS2 add(Pt·1B*t1SK1)) ,

$ Relative addressing, positive displacement,
ACS2 as base $
.:Lf.(Jf'·1P OR JSR*IR6*1Ri*TR'8=1) ~(PC~ACS2 add(Pf·113*t·1 SK1)),

35
if(IR6*IR7*IR8=1) then(MA~ACS2 add(PMB+MSK2)) ,

$ Relative addressing, negative displacement,
ACS2 as base $
if(JMP OR JSR*IR6*TR7*IR8=1) then(PC+ACS2 add(PMB+
MSK2)) ,
if(IR6*IR7*IR8=1) then(MA~ACS3 add(PMB*MSKl)) ,
$ Relative addressing, positive displacement,

ACS3 as base $
if(JMP OR JSR*IR6*IR7*IR8=1) then(PC~ACS3 add(PMB*MSKl))
if(IR6*IR7*IR8=1)

then(MA~ACS3

add(PMB+MSK2)) ,

$ Relative addressing, negative displacement,
ACS3 as base $
if(JMP OR JSR*IR6*IR7*IR8=1)
F*PTG3(4)

then(PC~ACS3

add(PMB+MSK2))

AC-H-WRITE~(JSR+IR3)
AC-L-WRITE~IR4

,

if(WRITE AC=l) then ACWRF=l , $ Enables ACC write at PTG0 $
AUT

DEC~MA

12 , $ If on, indicates that the effective

address is an auto-decrementing location $
if(MA11*IR5*EFA*ADDER ZERO=l) then AUT INC OR

DEC~l

,

$ Indicates that the effective address is either

an autoincrementing or autodecrementing location $
if(INTRQ*(HAS E CYCLE+JMP OR JSR*IR5))

then(S~0,Sl~l)

,

$ Go to PI Cycle $

if(IR5*(JMP OR JSR+HAS E CYCLE)=l)
to Defer cycle $

then(S~l,Sl~0)

, $ Go

36

if(IO+(IR5*HAS E CYCLE)=!) then(S0+l,Sl+l) , $ Go to
Execute cycle $
if(INTRQ*(ALC+IR5*JMP OR JSR) then(S0+0,Sl+O) , $ Remain
in Fetch cycle $
if(CPU INST*STRT 10=1) then(INTRQ+0, ION+l) , $ Start IO
signal, also clears DONE, sets BUSY, and clears
!NT REQ in the selected device $
if(CRY SET=!) then(CRY+l) ,
if(CRY SET=O) then(CRY+O) ,
if(CPU INST*CLR=l) then(ION+O)
7.

Sequence Defer Cycle

Comment Begin

The following sequence defines the Defer cycle, which

is used to resolve indirect addresses.

The word which is read from

memory during PTGl contains the address of the data needed for execution of the current instruction.

If this word is from an autoincre-

menting location, (20-27) 8 , its contents are counted up by one before
being used and restored ; if the word is from an autodecrementing
location, (30-37) 8 , its contents will be counted down by one before
being used.

During PTG3, preparations are made for the next cycle.

If IR0 is one, the next cycle will be another defer cycle, otherwise
the machine will enter the execute cycle.

Since the JMP and JSR

instructions have no execute cycle, the machine will check for
interrupts and then enter the fetch state.
D*PTG0(1)

MB~

D*PTG0(2)

if(ACWRF=l) then(ACS3,ACD3+AR)

D*PTG0(4)

ACWRF~

End

;
$ JSR, indirect $

37

D*PTG 1 ( 2)

t·1B+r1 (f1A) ;

D*PTG 1 ( 3)

if.. (AUT · INC OR DEC* AUT DEC= 1) then (r1B+-f.1B add 1)
$ autoincrementing $

if(AUT

INC OR DEC*AUT

DEC=l)

then(r~B+f~B

sub 1)

$ autodecrementing $

D*PTGl ( 4)

Pt~B+f·1B

D*PTG2 (1)

t1 (t~A )+N13

D*PTG2(4)

-if(Jt,1P OR JSR=l) then(PC+f1B)

D*PTG3(3)

.if.(HAS E

;

~

CYCLE+ItHRQ*Jt~P

-if (I NTRQ*HAS
D*PTG3(4)

OR JSR=l)

then(t~A+Pf·1B)

E CYCLE= 1) then (11A+0)

--

AUT DEC+f.1Al2 ,
ZERO*Pl~B!2l=l)

if(t1All*ADDER

-

if(HAS E

CYCLE*~=!)

-then(AUT

INC OR DEC+l) ,

then(S!2l+l,Sl+l) , $ Go to execute

cycle $
if(Pl~B!2l=l) ~(S0+1,Sl+0)

if(~*INTRQ*HAS

, $Go to defer cycle $

E CYCLE=!)

then(S0+0,Sl+O) , $ Go to

fetch cycle $
if{~*INTRQ*HAS

-

E CYCLE=!) then(S0+0,Sl+l)

-

$ Go to

program interrupt cycle $
8.

Sequence Execute Cycle

Comment Begin

The following sequence defines the execute cycle of

I/0 instructions and of those instructions which require memory access,
including LOA, STA, ISZ, and DSZ.
E*PTG0 ( 1)

t~B+-0

E*PTG1(2)

-if(STROBE=l)

End

;

-then(l~B~(MA))

$ Strobe omitted for STA $

38

E*PTG1(4)

if(STA+( IO*TR/)=1) ~(r1B+-ACDX) , $ STA or I/0 output
instruction $
if{IO*IR7=1) ~(r1B+-DEV BUF) , $ I/0 in $

if. (I SZ= 1)

~ (r.1B+-f'1B add 1) ,

jf(DSZ=1) ~(t1B+f.1B sub 1) ,
lf.(ADDER ZERO*NON ACD INST=1) then(PC+PC add 1)

$ SKIP

condition true for ISZ or DSZ $
E*PTG2 ( 1)

t1 ( MA )+118 ;

E*PTG2(4)

if(I0=0) ~(PC+-PC add 1)
if{I0*00=1) ~(DEV+-BUF MB) ,
if(IO SKIP PEND=1) ~(IO SKIP SYNC+-1) ,
Pt1B+f·1B ;

E*PTG3 ( 3)

E*PTG3(4)

-if (I NTRQ=0)
-if (I NTRQ= 1)

then (r1A+-PC)

~

then (r,1A+O)

~

AC-H-WRITE+-IR3
AC-L-WRITE+-IR4 ,

-if(WRITE

AC=1) then(ACWRF+-1) ,

-

if(LDA=1) then(AR+PMB) , $ Will be written into accumu1a tors at PTG0 $
.if.{INTRQ=1) then(S.0+0,S1+-1) , $ Enter PI state $
if(INTRQ=0) then(S,0+0,S1+0)
9.

$ Enter Fetch state $

Seguence Program Interrupt Cycle

Comment Begin

The following sequence defines the program interrupt

cycle, which is entered at PTG.0 if INTRQ is set and the previous
instruction has completed execution.

The INTR signal shown below is

provided by an I/0 device when its INT REQ flip flop is set.

During

the sequence, the current value of the PC is stored at location 0 and

39

the PC is set to zero while the IR is zeroed out.

Control then

transfers to the defer cycle to obtain the address of the first
instruction of the interrupt service routine.

Excluding the execution

of indirect memory reference instructions, the maximum interrupt
waiting time is 4.6

~sec.

if(INTR=l) then

PTG2(2)

End.
INTR~l

$ Can happen during PTG2 of any

type of cycle $
MB~Pc

PI*PTG1(4)

, $ Will be stored at M(MA) during PTG2 $

IR+0 ; $ Note that this will be decoded as JMP during
the Defer cycle which follows $
M(0)+MB ; $ MA was set to zero during PTG3 of the previous

PI*PTG2(1)

cycle $
PI*PTG3(1)

PC(15)~1

PI*PTG3(3)

MA~PC

PI*PTG3(4)

S0~1,Sl+O

C.

PC(l-14)+0

;
$ Go to Defer cycle $

Example
The following short program is intended to be used as an example

of the use of the formal description in CDL .

The formal description

may be used to show all data transfers and control involved in
executing this program.
instruction

machine codes

100

LOA @ 0,6,3

023406

101

ADDL

0,2,SZC

113102

102

STA

2 '20 '1

040400

103

JSR

10, 3

005410

104

HALT

locations

063077

40
Initial Conditions

sw ( 11-26 )= 1008

AC3=15 8

AC~=~

r1(23)=so 8

AC1=200 8

t1( 51)= 1228

AC2=333 8
The first instruction is an indirect load of accumulator

~

from

a primary address of 23 8 ; since this is an autoincrementing location;
its contents (50 8 ) are first counted up by one, and then the accumulator is loaded from location 51 8 •
accumulator

~

The second instruction adds

to accumulator 2, shifts the sum left one bit position,

and loads it into accumulator 2.

If the carry bit is zero after the

circulating shift, then the third instruction is skipped .

The third

instruction, if executed, will store accumulator 2 at memory location
(PC add 20 8 ).

The fourth instruction causes a jump to the memory

location which is the sum of the contents of accumulator 3 and 108 •
At the conclusion of this subroutine, the program will jump back and
execute the HALT.

The execution of this program is described by the

following sequence
STRT=ON
CON RQ
CON INST

KEY

SEEr~+ 1

: IR5+0,IR(0-4)+1,IR(6-15)+1

KEY SEEN*PC CLK

KEY SYNC+l,STP+l

KEY SYNC*CPU CLK

KEY+l

KEY*KEY SYNC*CPU CLK : RUN+l
KEY*PTG9(1)

KEY SEEN+O

KEY*PTG~(3)

KEY SYNC+O,STP+O

KEY*PTGl(l)

P~1B+SW(ll-26)

$ Start PTG signals $

41
KEY*PTG2(4)

PC+-PMB(1-15),RUN SET+-1

$ PC=100, start

memory cycling $
KEY*PTG3(3)

MA+-PC

KEY*PTG3(4)

AC-H-WRITE+-1

$ MA=100 $

AC-L-WRITE+-1
s~.s1+-91

KEY+-9)
F*PTG~(1)

MB+-9)

F*PTG~(4)

ACWRF+-0

F*PTG1(2)

MB+-M(MA)

F*PTG1(4)

PMB,IR+-MB

$ MB=023406 $

AR+-PC add 1

$ AR=101 $

F*PTG2(1)

M(MA)+-MB

$ Restore $

F*PTG2(4)

IO SKIP SYNC+-9)

F*EFA*PTG3(3)

MA+-ACS3 add (MSK1*PMB)

F*PTG3(4)

AC-H-WR ITE+-0

$ MA=23 $

AC-L-WRITE+-0
AUT DEC+-0
AUT INC OR DEC+-1
S~l

,S1+-0

D*PTG~ (1)

MB+-0

D*PTG0(4)

ACWRF+-0

D*PTG1(2)

MB+-M(23)

$ MB=50 $

D*PTG1(3)

MB+-MB add 1

$ MB=51 $

D*PTG1(4)

PMB+-MB

$ PMB=51 $

42
D*PTG2(1)

M(23)+MB

D*PTG3(3)

MA+-Pt1B

D*PTG3(4)

AUT DEC+-1

$ MA=51 $

AUT INC OR DEC+-0
S(IJ+-1,$1+-1
E*PTG(IJ(1)

MB+-0

E*PTG1(2)

MB+-M(51)

E*PTG2 (1)

M(51)+MB

E*PTG2(4)

PC+-PC add 1

$ PC=101 $

PMB+-MB

$ PMB=122 $

E*PTG3(3)

MA+-PC

$ MA=101 $

E*PTG3(4)

AC-H-WRITE+-0

$ MB=122 $

AC-L-WRITE+-0
ACWRF+-1
AR+-PMB

$ AR=122 $

S(IJ+-O,S1+-0
F*PTG(IJ(1)

MB+-0

F*PTG(IJ(2)

ACD(IJ,ACS(IJ+-AR

F*PTG(IJ(4)

ACWRF+-0

F*PTG1(2)

MB+-M( 101)

$ MB=113102 $

F*PTG1(4)

IR,PMB+-MB

$ IR, PMB=113102 $

PC,AR+-PC add 1
F*PTG2(1)

M( 101)+-MB

F*PTG2(4)

IO SKIP SYNC+-0

F*PTG3(1)

AR+-cirl(ACS(IJ add ACD2)

F*PTG3(2)

PC+-PC add 1

$ AC(IJ=122 $

$ PC,AR=102 $

$ AR=001132 $
$ PC=103 $

43
F*PTG3(3)

MA-+-PC

F*PTG3(4)

AC-H-WRITE-+-1

$ MA=103 $

AC-L-WRITE-+-0
ACWRF-+-1
AUT DEC-+-0
AUT INC or DEC-+-0

CRY-+-0

S~-+-O,S1-+-0

F*PTG~(1)

MB-+-0

F*PTG~(2)

ACD2,ACS2-+-AR

F*PTG~(4)

ACWRF-+-0

F*PTG1 (2)

MB-+-M ( 103)

F*PTG1(4)

IR,PMB-+-MB
AR-+-PC add 1

$ AC2=001132 $

$ IR=005410 $
$ AR=104 $

F*PTG2(1)

M(103)-+-MB

F*PTG2(4)

IO SKIP SYNC-+-0

F*EFA*PTG3(3)

MA-+-ACS3 add(PMB*MSK1)

$ MA=25 $

PC-+-ACS3 add(PMB*MSK1)

$ PC=25 $

F*PTG3(4)

AC-H-~~RITE-+-1

AC-L-WRITE-+-1
ACWRF-+-1
CRY-+-0
F*PTG~(1)

MB-+-0

F*PTG~(2)

ACS3 ,ACDJ-+-AR

F*PTG~(4)

ACWRF-+-0

F*PTG1(2)

MB-+-t'<'l ( 25 )

$ AC3=104 $

f

Body of subroutine, ending with JMP 0,3

44
F*EFA*PTG3(3)

MA+ACS3 add(PMB*MSK1)

$ MA=104 $

PC+ACS3 add(PMB*MSK1)
F*PTG3(4)

AC-H-WRITE+O
AC-L-WRITE+O
CRY+O
S~+O,S1+0

F*PTG~(1)

MB+O

F*PTG~(4)

ACWRF+O

F*PTG1(2)

MB+M( 104)

F*PTG1(4)

I R, PI~B+MB

AR,PC+PC add 1
F*PTG2(1)

M(104)+MB

F*PTG2(4)

RUN SET+O

F*PTG3(3)

MA+PC

F*PTG3(4)

RUN+O

$ MB=063077 $

$

AR,PC=105 $

45

IV.

CONCLUSIONS

In summary, this paper has presented a detailed formal description
of the operation of a particular modern computer, the NOVA 800.

This

description is suitable for use as a supplement in a course in basic
computer organization, especially if this computer is available to the
students.

The addition of a description such as this one to the course

has the advantage of introducing the students to more advanced concepts
of computer organization than are usually covered in the simple
textbook machine.

Also, this detailed knowledge of one machine may

easily be built upon in later courses.
This description may be expanded to include other features of
the machine, such as data channel operations, the multiply/divide
option, or the program load option.

In addition, it is advisable to

provide an informal description of the machine to first familiarize
the student with the ALU capabilities, bussing scheme, timing and
control, and instruction format.

46

BIBLIOGRAPHY
1.

Chu, Yaohan. Introduction to Computer Organization.
Cliffs, N.J.: Prentice-Hall-,-Inc., 1970.

Englewood

2.

Foster, Caxton C. Computer Architecture.
Reinhold Co., 1970.

3.

Sobel, Herbert S. Introduction to Digital Computer Desi~n.
Reading, !1assachusetts: Addison U'esley Publisliing Co., 170.

4.

Hill, Fredrick J. and Peterson, Gerald R. Dinital S~stems:
Hardware Organization and Design. !~ew York, lew Yor : John tJiley
& Sons, Inc., f973.
-

5.

Pottinger, Hardy J. A Formal Description of the SCC-650 Computer.
t"lasters Thesis, University of rHssouri-Rolla, 1968.

6.

Chu, Yaohan. 11 An Algol-like Computer Design Language, 11 Communications of the ACt~, VIII (October 1965), 607-615.

7.

Rouse, David M. A Desi~n Oriented Di~ital DesiBn Language.
t·1 asters Thesis, Univers1ty of Missoun-Rolla, 1 69.

8.

Data Genera 1 Corp. Techni ca 1 t.,anua 1 for the tlOVA-800 Computer,
Vol. I-III. Southboro, f1assachusetts--;-T97T.""

9.

Bell, Gordon G., and Newell, Allen. Computer Structures:
Readings and Examples. New York: McGraw Bill, Inc., 1971.

New York: Van Nostrand

47

VITA

Ronald Lee Engelbrecht was born on September 11, 1947, in
Jefferson City, Missouri.
education in that city.

He received his primary and secondary
He received a Bachelor of Science degree in

Electrical Engineering from the University of Missouri-Rolla, in
Rolla, Missouri, in June 1969.

He served as an officer in the United

States Army from September 1969 until April 1972.
He has been enrolled in the Graduate School of the University of
Missouri-Rolla since June 1972.

He worked under a research assist-

antship from June until August 1972 and has held a National Science
Foundation Fellowship since September 1972.

48

APPENDIX A
A SUMMARY OF COMPUTER DESIGN LANGUAGE
Computer Design Language [6] is an ALGOL-1 ike 1anguage which can
be used to describe the logical design of a digital system and to
provide design documentation.

When used in conjunction with a

translator program, it may also be used for logic simulation and
debugging, cost- performance evaluation, integration of design automation, and the design of more complex machines.
Computer Design Language has a rather extensive vocabulary, and
only those elements actually used in this paper are listed below:
Classification

Symbols

1.

Digits

0/l/ ... /9

2.

Letters

A/8/ ... /Z/a/b/ ... /z

3.

Values

on/off

4.

Operators
Arithmetic

add/sub

Logical

*1+/ffi/-

Functional

cirl/cirr/swap

Relational

=If

Sequential

if/then/else/ ~

5.

Separators

,/;/:/(/)/[/]/comment/begin/end/$

6.

Declarators

register/terminal/memory/switch/constant/clock

Only a few of these elements need explanation.

The functional

operator "cirl" (circulate left) causes the contents of a register
to be shifted l eft one bit position, wi th bit~ being shifted into
the carry bit and the carry going to bit 15.

The .. cirr .. operator is

49

similar, only with a right shift.

The

11

SWap

11

operator causes the two

bytes of a word to be exchanged; that is, bits
and vice-versa.

The

11

terminal

11

~-7

become bits 8-15

declarator is used to designate the

output signal of a combinational network.
Statements, except comment and declaration statements, are
operations which are performed by the hardware.

Each statement may

have a label, and the sequential order of statements within a swquence
is defined by the labels.

When the label conditions are true, the

operation prescribed by the statement is executed.

Since statement

labels need not be mutually exclusive, parallel operations may be
easily expressed by simply sharing a label.

A computer design such

as the one presented in this paper consists of many sequences of
statements, each of which describes a portion of the overall operation
of the computer.

50
APPENDIX B
CHANGES AND NOTES
Some changes \vill be noted when comparing this formal description
with the NOVA-800 logic diagrams.

Several terminals and control flip

flops were omitted from the description, especially those involved
in data channel operations and the multiply/divide option.

Likewise,

the equations for terminals were often simplified by removing terms
pertaining to these two features.
Several flip flops, which were unnamed in the logic diagrams,
were given names in the description, as shown below.

Also, several

terminals were slightly re-named to avoid confusion in the logic
equations.

Finally, some signals were merely complements of other

existing signals; in this case, only one of the two signals was used
throughout in the description.

These changes are listed below:

Losic Di a9rams

Description
TG(0-1)

unnamed (chip U-34)

S(0-1)

unnamed (chip U-39)

STP

unnamed (chip U-81)

PMB(0-15)

t1B

FSKIP

unnamed (chip U-102)

AUT INC OR DEC

AUT INC + DEC

IO

10 UNPROTECTED

STRT IO

STRT (IO instruction which could be
confused with STRT switch)

ALC OR IO SET

ALC + IO SET

ZERO ENABLE

=0

ENABLE

51

ADDER ZERO

ADDER =

CRY TEST

NEW CRY (duplicate)

D-L-SEL

FORCE D-L-SEL (duplicate)

PLUS ONE

FORCE PLUS ONE

SX COM

FORCE SX-COM

SX-H-SEL

·FORCE SX-H-SEL

SX-L-SEL

FORCE SX-L-SEL

SX-H-READ

FORCE SX-H-READ

SX-L-READ

FORCE SX-L-READ

PI SET

MBO INH

LAST WORD

PL * LAST WORD

DEV BUF

unnamed

MSKl

does not exist

MSK2

does not exist

~

52

APPENDIX C
PROGRAM LOAD OPTION
The program load option is a feature of the machine which automatically loads the bootstrap loader program of the machine from a
small read only memory into main memory.

Two Ror~·s of 32 words x 8

bits are addressed in parallel by PC(11-15).
load, the

~·1A

At the start of program

register is forced to zero and the RQt.1 data is loaded

into memory locations 0-37 octal via the
KEY~·1 cycles.

t~BO

bus during a sequence of

At the conclusion of program load, the PC and MA are

both zeroed to start the next fetch from memory location 0.

The

following transfers show the sequence of events:
if..(PL=ON) then(KEY SEEN+-1)
KEY SEEN*CON INST : IR6+-0 , IR(0-5)+-1 , IR(7-15)+-1
KEY SEEN*PC CLK

KEY SYNC+-1

KEY SYNC*PC CLK

KEY+-1

KEY*KEY SYNC*CPU CLK : RUN+-1
PL*KEY*PTG0(1)

KEY SEEN+-0

PL*KEY*PTG2(4)

PC+-0

PL*KEY*PTG3(3)

~·1A+-PC

PL*KEY*PTG3(4)

KEYt~+-1

I

KEY SYNC+-0

RUN SET+-1

$
I

KEY+-0

PL *KEY~1*PTG0 ( 1)

t~B+-0

PL *KEY~1*PTG1 ( 3)

~1B+-R0t1 (PC)

PL *KEYI1*PTG2 ( 1)

r1(r~A ) +-t·1B

PL *KEn1*PTG2 ( 4)

if(PC10=0) ~(PC+-PC add 1)
if(PC10=1) ~(PC+-0)

~1A=0

$

53

PL*KEYM*PTG3(3)

MA+PC

PL *KEYf1*PTG3 ( 4)

if ( PC10=0) then KEYt1+1
if ( PC10= 1) then ( KEYt1+0, S1+0, S2+0)

54

APPENDIX D
STUTTER THHNG
One somewhat unique feature of the NOVA-800 is its ability to
change the duration of the timing pulses when needed.

Normally,

PTG0-3 are each 200 ns in length, however, any of these may be
independently extended if needed; for instance, PTGl is extended to
400 ns during the Execution cycle of a DSZ or ISZ instruction, and
during the Defer cycle if autoindexing is evoked.

PTGl is extended

to 800 ns during programmed input instructions, and PTG2 is extended
to 800 ns during programmed output instructions.

The mechanism by

which these extensions are accomplished is shown in figure 6.
When the STUTTER signal is true, its inverse is used to disable
the

11

and 11 gates which produce CPU CLK and PC CLK; the r1EI1 CLK signal

is not affected by stutter operations.

The MB LD EN signal will be

true for two occasions; for theE cycle vlith NON ACD INST true
(indicating that an ISZ or DSZ signal is present) and for the D cycle
with AUT INC OR DEC true, indicating autoindexing.

If MB LD EN is

true during PTGl, then the STUTTER signal will be true, since TB is
reset (all flip flops are normally reset).

The feedback path causes

TB to be set 200 ns later (at the falling edge of the clock), STUTTER
becomes false, and CPU CLK will again be generated.

Thus, PTGl has

been extended by 200 ns.
For I/0, the 3-bit register is used in a shifting mode.

The

10 STUTTER signal is true during PTGl of a programmed input
instruction and during PTG2 of a programmed output instruction.

A

timing diagram is shown in figure 6 for a programmed out instruction.

55

It can be seen that STUTTER is true if TB is reset and IO STUTTER is
true.

In addition, IO STUTTER is used to shift a one (iA) into

rno

and zeros into the other flip flops; this occurs on the falling edge
of the first clock pulse during PTG2 .

On the falling edge of the

second clock pulse, HID and TA are set and TB remains reset.

On the

third clock pulse, however, TB becomes set, causing STUTTER to become
false.

This will enable CPU CLK to be generated on the fourth clock

pulse, which will advance the timing counter and cause PTG3 to be
decoded.

56

iA

IO STUTTER

s
C

s
C TA

~1ID

R

R

s
C

TB

R

CLKB*CLKA
CPU
CLK

t~H1

STUTTER
PTGl
MB LO
EN

CLK

CLKB*CLKA
CPU CLK

PTG2

ro

STUTTER

MID
TA
TB

STUTTER
Fig. 6.

STUTTER Tit'liNG SIGNALS

