Functional requirements for design of the Space Ultrareliable Modular Computer (SUMC) system simulator by Hornfeck, W. A. & Curran, R. T.
FUNCTIONAL REQUIREMENTS FOR DESIGN
OF THE SPACE ULTRARELIABLE MODULAR COMPUTER
(SUMC) SYSTEM SIMULATOR: INTERIM REPORT
By
R.T. Curran
W. A.: Hornfeck
Prepared for
NATIONAL AERONAUTICS AND SPACE ADMINISTRATION
George C. Marsha II Space Flight Center
Marshall Space Flight Cente r. Alabama
CONTRACT NASa-2669a
(5r? -/~3S?r
. February 1972
(NASA-CR-123574) FUNCTIONAL REQUIREMENTS
FOR DESIGN OF THE SPACE ULTRARELIABLE
MODULAR COMPUTER (SUMC) SYS'.fEM SIMULATOR
Interim R.T. Curran, et al (Computer
sciences Corp.) Feb. 1972 43 p CSCL
~ \NASA CR OR TMX OR AD NUMBER) (CATEGORY)
Reproduced by
NAT10NAl TECHNICAL
INFORMATION SERVICE
U S Department of Commerce
Springfield VA 22151
https://ntrs.nasa.gov/search.jsp?R=19720012529 2020-03-23T11:16:10+00:00Z
TECHNICAL REPO'~T STAND/IRD TITLE' PAGE
~ 0 t q P q gug q
for the simulator are discussed in terms of a SUMC configuration which may vary according
. to the application. Conclusions and recommendations concerning future development are
also included.
1. REPORT NO. \2. GOVERNMENT ACCESSION NO.
1
3 i;'1?-': '~''lJc't:;°1~_..----..
4. TITLE AND SU01'lTlE
Functional Requirements for Design of the Space Ultrareliable
5. REPORT DATE
Modular Computer (SUMC) System Simulator: Interim Report o. PERFORMING ORGANIZATION CODE
7. AUTHOR is} 8. PERFORMING ORGANIZATlOt~ REPORT ::
f-.R • T. Curran and W. A. Hornfeck
9. PERFORMING ORGANI ZAT10N NAME AND ADDRESS 110 . WORK UNIT NO.Computer Sciences Corporation
Field Services Division, Aerospace Systems Center 11. CONTRACT OR GRANT NO.
8300 South Whitesburg Drive NAS8-26698
Huntsville Alabama 35802 '3. TYPE OF REPORT 8: PERIOD COVERED12. SPONSORING AGENCY NAME AND ADDRESS ,_.
National Aeronautics and Space Administration Contractor Interim Report
Washington
D. C. 20546 14. SPONSORING AGENCY CODE
15. SUPPLEMENT ARY NOTES
Work performed for Marshall Space Flight Center Computation Laboratory.
,-16. ABSTRACT
This interim report presents the functional requirements for the design of an interpretive I
simulator for the Space Ultrareliable Modular Computer (SUMC). A review of applicable
existing computer simulations is included along with constraints on the SUMC simulator
functional desip'll. Inout re uirements out ut re uirements and Ian a 'e re uirements
17. t<E Y WORDS
Simulation
Microprogram
Microinstruction
Diagnostics
Subroutine
Digital Computer
Target Computer
Host Computer
Operating System
Link Editor
lB. DISTRIBUTION STATEMENT
Unlimited
B. Hodges, NASA
Contracting Officer
Unclassified
t---.-::-=-__------------r---------4----------~--------r--------_4
19. SECURITY CLASSIF. ioC this report) 20. SECURITY CLASSIF. (oC thin poge) 21. tWo OF PAGES I 22. PRICE
45I Unclassified
~ -
MSfC - Form 3292 (Mny 1969)
FUNCTIONAL HEQUIREMENTS FOR DESIGN
OF THE SPACE ULTRARELIABLE MODULAH COMPUTER
(SUMC) SYSTEM SIMULATOR: INTERilVI REPORT
By
R. T. Curran
W. A. Hornfeck
Prepared Under
CONTRACT NAS8-26698
Prepared For
NATiONAL AERONAUTICS AND SPACE ADMINISTRATION
GEORGE C. MARSHALL SPACE FLIGHT CENTER
MARSHALL SPACE FLIGHT CENTER, ALABAMA 35812
COMPUTER SCIENCES CORPOHATION
8300 South Whitesburg Drive
Huntsville. Alabama 35802
FOREWORD
The studies reported here were administered in the Systems Research
Branch, Computer Systems Division, Computation Laboratory, MSFC, with
Mr.. Bobby C. Hodges as Contracting Officer's Representative. We wish to
express our appreciation for Mr. Hodges' help in planning and for his cogent
comments and suggestions.
Acknow!edgement'is also due Mr. James L. Lewis of the Astrionics
Laboratory and Mr. Thomas E. Hill of the Computation Laboratory for their
assistance in the definition of the simulator functional requirements.
ii
Section
I
II
III
TABLE OF CONTENTS
INTRODUCTION . . • . . . . . • . •
EXISTING COMPUTER SIMULATORS. •
A. ·Review of Existing Simulators . . .
B. Other Related Computer Simulators. •
C. Summary and Conclusions ; • . .
CONSTRAINTS ON THE SIMULATOR
FUNCTIONAL DESIGN. . . . . . . .
A. Baseline Target SUMC . • • . . •
B. Simulator Operating Environment. .
C. Simulator Development Environment
.e
o
•
Page
2
3
3
7
7
10
io
12
14
IV FUNCTIONAL REQUIREMENTS AND DESIGN CONCEPTS
A. Methodology Overview. . . . . . . . .
B. Input Requirements . . . .
· · · ·C. Output Requirements . . . . . . .
· · · ·D. Language Requirements '.
E. Future Simulator Enhancement.
V CONCLUSIONS AND RECOMMENDATIONS
· · · ·
APPENDIX: SUMC SIMULATOR ANNOTATED FLOW CHART.
iii
18
18
20
22
24
24
26
28
Figure
l.
2.
3.
4.
5.
AI.
Table
l.
2.
3.
4.
LIST OF ILLUSTRATIONS
Title
SUlVIC .Scratch Pad and Main Storage Layout. . . . .
Simulator- Peripheral Device Commu:hication
Interrupt Detection al1d Service Subroutine . . . .
Siuulat'01.. 't£.Jfu:.'i.u{al. L s Diagram. . . . . • •
Integration of Simulator Into' SUlVIC Support Software·.
Simulator Interpretive Operation. . . . . • . . . .
other Related Simulators . . . • .
Critical SUMC Design Parameters .
Pr0bra.."TI. l\1:odule Definition . . .
Phased Simulator Development.
iv
Page
lla
13
13a
15
19
29
8
11
16
27
FUNCTIONAL REQUIREMENTS FOR DESIGN
OF THE SPACE ULTRARELIABLE MODULAR COMPUTER
(SUMC) SYSTEM SIMULATOR: INTERIM REPORT
SUMMARY
TIns report contains the results of the functional requirements deter-
mination phase for an interpretive softwa.re computer simulator. This simulator
must permit variation of certain design parameters of the target SUMC such as
instruction definition, Scratch Pad, main storage and computer word organization
and, additionally, must provide the capability to interface with anticipated periph-
eral device simulators ~
The preceding requirements are met by designing software subroutines
to accomplish specific SUMC instructions. The subroutines are summoned by
a mainline subprogram upon detection of execution commands present in a sim-
ulated SUMC program resident in the host computer. Detection is aided by the
analysis of the specification parameters for the particular SUMC design.
In addition to the foregoing, the simulator enhances debugging efforts by
providing output of the simulated progranl history such as traces, snapshots
and memory dumps. To effect these outputs, the mainline subprogram must
detect the appropriate request parameter and cause consequent collection and
publishing of the selected program information.
While the SUMC family is the chosen target for simulation, the selection
of the host computer must be free of constraints to the feasible limit. For this
reason the simulator will be written in the FORTRAN language. In addition to
the }'ORTRAN coding, -modularity in the construction of the program will ensure
that any computer dependencies Will be isolated and easily changed to permit
transfer between host computers.
I
.1
SECTION 1. INTRODUCTION
This report presents the results of the functional requirements and
design definition phase of the study for the generation of the SUMC family
simulator. Relevant results of a survey of reports describing active simula-
tors are discussed. A bibliography containing additional references to reports
with a general rather than a particular impact on the functional requirements
and design of the simulator is included. >
Following the review of existing simulators, the simulator environmental
constraints are analyzed. Salient simulation-oriented characteristics of the
SUMC family target machines are presented. The host machine and simulator
Operating environment effect on the simulator design is discussed in terms of
their effect on the software organization.
Given the definition of the impact of the simulator environment on the
simulator functional design, attention is then directed to the simulator itself.
The role of the simulator within the SUMC development software is described,
and then, input, interpretive simulation and output process functional require-
ments and design considerations for the simulator are related. Finally, the
report is summari7.ed and recommendations are presented.
The myriad problems associated with simultaneous development of the
hardware and software for (prototype) computer systems have led to the utiliza-
tion of l.arge existing computers for software development. Consonant with this
trend, software executing on a commercial computer will be provided for the
Space Ultrareliable Modular Computer (SUMC) family. An important subset
of this software is a computer simulator which permits debugging and verifica-
tion of SUMe programming in parallel with the computer hardware development.
-2-
,
.,
SECTION II. EXISTING COMPUTER SIMULATORS
A. Review of Existing Simulators
A large number of computer programs presently exist which simuiate
or emulate* the operation of one computer system on another. Unfortunately,
most simulation problems are of a specialized nature which in turn causes
simulators to be tailored to individual needs. Many simulation programs
make use of special purpose simulation langu!lges, while others employ a
standard source language either at the assembly language level or at a much
higher level. A further disparity arises from the fact that different levels of
simulation may be performed. For example, the simulation of a given target
computer may be desired at the machine register level(l). In this case, all
hardware registers. and their logical contents are ma.intained by the host
computer throughout the simulation. This type of simulation yields informa-
tion for the designer ,vhich reveals the sequence of target computer hardware
operations that take place under a given set of input instructions. On the other
hand, the simulation may be at the system level(2) . Here the' designer is not
concerned with validation of target machine hardware, but with validation of
the target computer as an efficient data processing system. For this type of
simulation, the designer is interested in CPU loading, I/O chalmelloading,
and application program queues/overruns.
A number of existing simulators have been studied in order to
determine their degree of applicability to the problem at hand. While none of
the simulators could be used directly in the simulation which is proposed, in-
formation and ideas gleaned from these studies should prove valuable in the
formulation of a SUMC simulator. The following paragraphs will present brief
summaries of the more pertinent papers and reports on existing simulators
which have been investigated.
""Simulation can be defined as the process of modeling the physical behavior
of one machine on another, whereas emulation is defined as a combined
hardware-software approach to simulation.
1. Space Ultrareliable Modular Computer (SUMC) Microinstruction Simulator,
Tech. Rpt. Space Support Div., Sperry Rand Corp"., Huntsville, Alabama.
2. Simulating the Operation of an Aerospace Computer System, E. C. Day,
AIAA Paper No. 69-973, September 1969.
-3':"
1. SU:MC Microinstruction Simulator. This simulation program is
written in XDS extended FORTRAN IV and uses the Sigma 5 as the host computer.
The SUMC is, of course, the target computer and is simulated at the machine
register level. This provides a software tool for functionally duplicating SUMC
hardware operations specified by the control words in the microprogrammed
read-only-memory.
a. The simulator is programmed to:
(1) Perform solution of microinstructions in the same
manner as SUMC insofar.as possible;
(2) Compute contents of registers, multiplexers, and
arithmetic units used to perform microinstruction solutions;
(3) Provide instruction traces or microinstruction traces
of computed values for program or microprogram analysis, respectively.
b.The simulator is designed to operate in the following two
phases:
(1) Initialization - accepts initial conditions and initiates
simulation of application programs;
(2) Simulation - performs application program simulation
and outputs information required for analysis.
c. The output information Which may be requested by the user
includes: Instruction Address Read-Only-Memory (IAROM) dumps, Micropro-
grammed Read-Only-Memory (MROM) dumps', and Scratch Pad Memory (SPM)
dumps. Microinstruction or instruction traces of the elements required for
microprogram or program analysis may be output follOWing execution of each
microinstruction or instruction. The trace information includes the contents
of the Sequence Control Unit, Iteration Counter, Scratch Pad Memory location
accessed, Memory Register, Product-Remainder Register, Memory Address
Register, Multiplier-Quotient Register, and Exponent Register; the status of
the Arithmetic Logic Unit (ALU) overflow, ALU1.carry latch,ALU2 carry
latch, and Exponent Arithmetic Logic Unit (EALU) overflow; and also the
address of the Scratch Pad Memory location accessed. .
2. IBM TC-1 & CP-2 Simulators. These are very similar simulation
programs, designed to perform interpretive simulation of flight programs written
for the IBM TC-1 and CP-2 aerospace computers. Each simulator provides a
means for the dynamic analysis, modification, and control of TC-1 or CP-2
flight programs. In doing so, the simulators assist in debugging operational
-4-
modules written for the target computer by precisely duplicating operation of
the subject CPU and providIng associated I/O device handling.
a. General Design. The simulator acts as a subroutine available
to a user control program written in FORTRAN IV with an IBM/360 acting as the
host computer. The user control program can communicate information to the
simulator and obtain information in return through the following set of interface
program.s:
(1) User-written simulation control program,
(2) A set of programs comprising the interface programs,
(3) A machine instruction interpreter,
(4) Data collection routines, and
(5) Reporter.
b. Th~ simulated execution of flight programs proceeds in three
phases:
(1) Accept initialization parameters (specified by the user
control program) and prepare simulator and associated interface programs for
-execution;
(2) Perform computer simulation and collect information
required by programmer (as specified during phase [1] ;
(3)
a meaningful format.
Process the information collected during phase [2] into
c. The output information which can be obtained by the user
includes:
(1) Dump of requested portion of core in a hexadecimal
format;
(2) Output of requested type of trace information; either
full trace", block trace or branch trace;
(3) - Output of variable quantities whenever a specific loca-
tion is reached; requires the specification of array of snap addresses, modules
in which snap items are found, addresses of snap items desired, and number of
snap items;
and·
(4) Comments in the form of a line of EBCDIC information;
(5) A line of EBCDIC information to be used as a title at
the top of each output page.
-5-
I
i
I
3. Logicon Generalized Aerospace Computer Simulator. The Logicon
Aerospace Computer Simulator (ACS) is an assembly language program which
operates on the UNIVAC 1108 under EXEC II. All input to the ACS is handled by
the 1108 assembler, which eliminates the need to write elaborate translators or
input processors.
a. Basic ACS Simulator. The basic ACS simulator is a skeletal
program which becomes complete after the user defines the target computer by
assembling its characteristics into the simulator. The four types of input handled
by the 1108 assembler are:
(1) Specification of the target computer,
(2) Input of the target computer program,
(3) Construction of the interface routines, and
(4) Specification of the simulator outputs and diagnostics.
b. Operating Modes. The user can select the number and type of
operands used. by each instruction and the applicability of indexing, extension
register usage, and indirect addressing. The target computer may be word or
byte oriented with l's complement, 2's complement, or sign-magnitude arithmetic.
Double-precision or floating point arithmetic may be included.. Registers may be
in memory or may be entirely separate, and any number of registers as well as
register types can be included in the target computer specifications.
The simulator may run in an open-loop mode or, through construction of
interface routines, in a closed-loop mode with a vehicle/environment simulator.
In any event, the target computer program to be executed may be assembled
directly using macroinstructions and commands to the assembler in a symbolic
format chosen by the user.
c. Output Options. Simulator output options include timing data,
error diagnostics, traces, periodic listings of variables, debugging routines,
and summaries printed at run termination. A more detailed explanation of the
output options available to the user is given in the following paragraphs.
(1) SNAPS - octal printout obtained by keying target compu-
ter locations. When such a location-keyed instruction is executed, the contents
of the selected target memory location are saved. The items saved are printed
for every major or minor loop of the program. User specifies target location
to be keyed, target location whose contents are to be saved, the scaling, and the
symbolic name of the variable.
(2) Print Function - location-keyed function that prints out
the octal contents of one target computer location. User specifies the target
computer location to be keyed, the target location to be printed, the scaling, and
the symbolic name of the variable. The scaled value is printed along with its
symboHc name.
-6-
(3) Traces - full trace, in which every instruction executed
causes a trace print to occur; partial trace, in which each I/O and/or branch
instruction results in a print. Trace outputs may be started or stopped by location-
keyed functions, timed inputs, or both. There are 10 trace variables and these
can be varied by input. They are:
(a) Host computer instruction address (QHIA)
(b) Operation Code (QOPC)
(c) Operand address 1 (QOPAD1)
(d) Operand 1 (QOPN01)
(e) Target computer accumulator (QACCUM)
(f) .Target computer Q-register (QREQ)
(g) Blank field (QBLI\TK)
(h) Blank field (QBLNK)
(i) Blank field (QBLNK)
(j) Master clock in cycles (QMTIME)
(4) Data Tapes - SNAP print sets may be written on tape in
addition to being printed.
(5) Clocks - six clocks are available for timing execution
betw'een selected instructions and are controlled by location-keyed functions. A
clock may be turned on or "read.
(6) Error Diagnostics - as each input or simulation error
is discovered, an error diagnostic is printed indicating the type of error and
action taken.
(7) Summary Information - max and min values of snapped
variables are printed; the number of times each instruction is used and its sim-
mated op code are printed; a dump of the target memory is printed. An asterisk
before the word indicates that an instruction has been executed from that location.
B. other Related Computer Simulators
The simulation studies described in the previous section merit special
attention since they represent interpretive simulators having many of the charac-
teristics envisioned for SUMC. However, some other existing simulators, which
are not directly related to the SUMC simulation, have also been investigated.
Table I contains information on the most prominent features of these simulators.
C. Summary and Conclusions
The simulator envisioned for use in checkout of SUMC programs will be
constructed to handle the simulated machine at a block diagram level. Ihis is
-7-
I 00 I
TA
BL
E
1.
OT
HE
R
RE
LA
TE
D
SIM
UL
AT
OR
S
SIM
UL
AT
IO
N
LE
VE
L
TA
RG
ET
HO
ST
SIM
UL
AT
OR
OF
IN
PU
T
OU
TP
UT
.
CO
MM
EN
T
LA
NG
UA
GE
SIM
UL
AT
IO
N
CO
M
PU
TE
R
CO
M
PU
TE
R
CI
SC
O
C
O
M
PI
LE
R
,
LO
AD
ER
,
CI
SC
O
P
L
/I
-
D
ES
C
R
IP
TI
O
N
O
F
AN
D
IN
TE
R
P
R
E
TE
R
AR
E
R
EG
IS
TE
R
G
EN
ER
AL
G
EN
ER
AL
TR
A
C
E
IN
FO
R
M
AT
IO
N
O
R
IE
N
TE
D
E
Q
UI
PM
EN
T
IN
C
LU
D
ED
AS
P
A
R
T
O
F
q,
r~
,
SI
M
U
LA
TI
O
N
P
A
C
KA
G
E.
S
E
L-
81
0A
M
AC
H
IN
E
E
FF
IC
IE
N
C
Y
HA
S
N
O
T
BE
EN
SE
LM
A
M
AD
C
AP
IN
TE
R
P
R
E
TI
V
E
S
E
L-
81
0A
M
A
N
IA
C
II
D
IA
G
NO
ST
IC
S
LA
N
G
U
AG
E
ST
RE
SS
ED
.
PR
O
G
RA
M
S
L1
BR
AS
CO
PE
LI
B
R
A
SC
O
PE
H
O
ST
M
AC
H
IN
E
H
AR
D
W
AR
E
IN
TE
R
P
R
E
TI
V
E
G
U
ID
AN
C
E
M
AC
H
IN
E
TR
A
C
E
IN
FO
R
M
AT
IO
N
,
IS
US
ED
W
IT
H
SI
M
U
LA
Tf
O
N
L1
CO
S
FO
R
TR
AN
IB
M
70
90
C
O
M
PU
TE
R
FL
IG
H
T
M
A
TR
IX
R
ES
UL
TS
W
HI
CH
AR
E
N
O
T
IN
ST
R
U
C
TI
O
N
S
M
O
D
EL
S
1
&
3
B
IT
-F
O
R
-B
IT
.
.
IB
M
SY
ST
EM
/
CO
M
PU
TA
TI
O
N
TI
M
IN
G
IN
FO
R
M
AT
IO
N
,
S
P
E
C
IF
IC
A
LL
Y
TA
IL
O
R
ED
CS
S!
36
0
CS
S!
36
0
.
'"
4
P
I-
E
P
IB
M
SY
ST
EM
!
R
EQ
UI
RE
M
EN
TS
,
PR
O
G
RA
M
AN
D
I/
O
TO
W
AR
D
M
O
D
EL
IN
G
FU
N
C
TI
O
N
AL
M
U
L
T
I-
36
0
EQ
UI
PM
EN
TS
Q
UE
UE
S,
LO
AD
IN
G
C
O
M
PU
TE
R
FU
N
C
TI
O
N
S.
PR
O
CE
SS
O
R
BE
IN
G
M
O
D
EL
ED
P
A
R
A
M
E
TE
R
S
S
E
LF
-R
E
P
A
IR
IN
G
P
R
O
TO
TY
PE
M
AC
H
IN
E
SN
AP
SH
O
TS
O
F
ST
AN
D
AR
D
FO
R
TR
AN
IB
M
A
P
'B
LO
C
K
S
E
LF
-
D
E
SC
R
IP
TI
O
N
,
"
S
T
A
T
E
"
O
F
T
H
E
R
O
U
TI
N
ES
A
R
E
US
ED
FO
R
D
IG
IT
A
L
C
O
M
PU
TE
R
IB
M
70
94
SI
M
U
LA
TO
R
D
IA
G
R
AM
R
E
P
A
IR
IN
G
M
EM
O
RY
M
AP
,
TA
R
G
ET
M
A
C
H
IN
E
'
I/O
FU
N
C
TI
O
N
S.
C
O
M
PU
TE
R
C
O
N
TR
O
L
PR
O
G
RA
M
.1
I
contrasted with a functional simulation which is too far removed from the hard-
ware for the purposes of this project or to a logic simulation which leads to
excessively slow simulation and yields results which require considerable reduc-
tiODo The SUMC simulator will be an interpretive simulator in which all program-
mable registers are maintained. The simulator will also maintain a memory map
of the target computer and simulation results will precisely duplicate those which
would be obtained by the target machine.
The SUMC simulator will resemble certain existing simulators which have
been developed for aerospace computers. The TC-l and CP-2 simulators are
examples of interpretive simulators which have been developed for use in checkout
of flight ~oftware. The Logicon Generalized Aerospace Simulator is another
example of interpretive simulation designed to' provide target computer program
checkout. However, the SUMC simulator will be unique in the sense that sim-
ulation of a family of SUMC machines will be possible. In addition, the simulator
will be programmed in a high-level language so that host machine independence
is achieved to the fullest practical extent.
-9-
SECTION III. CONSTRAINTS ON THE SIMULATOR FUNCTIONAL DESIGN
A. Baseline Target SUMC
The simulator must have the capability to model the SUMC family. This
computer family is expected to consist of computers with design parameters
that may vary with the envisioned application. .Of particular interest to the
simulator design are the SUMC definition parameters given in table 2. The
simulator must provide and maintain the contents of pseudo registers and
storage locations· that appear to be identical to these parameters; These pseudo
locations must be updated by the simulator at the level of visib~1ity of the pro-
grammer.
1. storage Organization. The target storage for simulation programs
of the SUMC will consist of a main or bulk storage in which programs and data
reside with an accompanying scratch pad memory (SPM) which contains various
register contents. status indicators. the program counter. and other variables
with requirements for rapid access. To ensure generality in the simulation no
other assumptions concerning storage will be made. Specific storage organiza-
tions will be provided as input parameters to the simulator.
2. Register Organization. Although register organization is, strictly
speaking, a subset of storage organization since register contents reside in
SPM, conceptually the various classes of registers can be considered logical
entities for purposes of discussion of their organization. The simulator must
accept descriptive input, discussed more fully later, that specifies this register
organization and format for an arbitrary SUMC. A typical pseudo register
representation of a SUMC is shown in figure L
Conversion of the descriptive input into the pseudo register organization·
will be discussed later. This conversion must be valid for the range of param-
eters shown in table 2 to permit the simulator to accept the variety of SUMC
designs antiCipated for future space-oriented missions.
3. SUMC InstructIons. Computer comrl1ands defined by the Op Code
segment of an instruction are implemented by software subroutines; Each sub-
routine, in addition to performing SUMC operations at programmer level of
visibility, must update the elapsed time counter for the program and must con-
tain any unique error response procedures. The initial version of the simulator
will have the capability for executing the basic SUMC commands(3).
3. IBM Systems Reference Library, IBM System/360 Principles of Operation,
GA22-6821-8, Systems Development Division, Product Publications, Pough-
keepsie, N. Y•• November 1970.
-10-
Table 2. Critical SUMC Design Parameters
I
Minimum Maximum Increment
.
Word Length (bits) 16 32 4
Accumulators 1 16 1
Base Registers 1 . 16 1
Index Registers 1 16 1
General Registers 0 16 1
Scratch Pad Memory (words) 64 TBD* TBD
Main Storage' (words) 128 32,768 TBD
-*TBD To be defined
-11-
PR
O
G
R
AM
U
N
D
ER
TE
ST
o
32
76
7
'
-
-
-
-
-
1
A B
8
X
9 0
PC
1
IN
TR
P
T
ST
AT
U
S
2
ST
AT
U
S
3 ~~
TE
M
P
ST
G
.
~~
3o 6lS 16 17 1 1 2 2 2 2
I i-
'
i-
'
~ I
TA
RG
ET
CO
M
PU
TE
R
FO
RT
RA
N
RE
PR
ES
EN
TA
TI
O
N
Fig
ure
10
SU
MC
SC
RA
TC
H
PA
D
AN
D
MA
IN
ST
OR
AG
E
LA
YO
UT
TY
PI
CA
L
HO
ST
FO
RT
RA
N
RE
PR
ES
EN
TA
TI
ON
OF
SU
MC
ST
OR
AG
E
t
)
IM
AI
N
M
(1
)
A
.
PR
O
G
RA
M
U
N
D
ER
TE
ST
)
B X
PR
O
G
RA
M
C
O
U
N
TE
R
IN
T
ST
AT
U
S
ST
AT
U
S
E
TC
,
32
76
8
~~
.
~ I
D
A
TA
G
LO
BA
L
4
PR
O
D
U
C
T
R
E
M
A
IN
D
E
R
M
EM
O
RY
R
EG
IS
TE
R
I
6(16 1
7 18 19 20 21 22 23
IS
PM
(1
I I-
'
I-
'
0"
'
I
Fig
ure
1.
SU
MC
SC
RA
TC
H
PA
D
AN
D
MA
IN
ST
OR
AG
E
LA
YO
UT
(CO
NT
'D)
4. Input/Output (I/O). The simulator must perform I/O operations in
conjunction with a software interface and peripheral device simulation subroutines
as shown in figure 2. The simulator will maintain the appropriate status informa-
tion in the COMMON scratch pad memory representation and will additionally
place and retrieve data in the Product Remainder Register (PRR) location in
COMMON. Peripheral Device simulation subroutines act in a corresponding,
cooperative manner. Peripheral device elapsed time will be maintained by tJ:1e
peripheral device simulation subroutine.
Handshaking protocol must be defined as more specific information becomes
available. :Presently the I/O process simulator will:
a. Place the datum in the PRR,
b. Set/Reset appropriate status, and
c. Issue a CALL to the specified peripheral device simulator.
Upon completion, control will be relinquished to the simulator.
5. Interrupt Procedures. The simulator will emulate the SUMC sequence·
of detecting and responding to an interrupt as demonstrated in figure 3. Prior to
each instruction FE TCH the simulator will interrogate the scratch pad memory
(SPM) interrupt status word for presence of interrupts. If interrupts are present,
each bit in the word will be examined for an interrupt request (=1). For each of
the above interrupt requests a response subroutine must be provided. This
response subroutine will be called, and the request bit reset. When all interrupts
have been serviced, the simulator is free to FE TCH the next in-line program
instruction.
This interrupt simulation procedure allows program debugging in order
that an operating system with its allied applications programs can be verified
using the simulator.
B. Simulator Operating Environment
Presently the simulator is thought of as executing in a batch mode under
the operating system of large commercial computers. Candidate computers
are the UNIVAC nos for production, and the IBM 7094 for development. This
difference in host computers implies a design goal of machine independence to
the feasible limit. This goal conflicts with the requirement that the simulator
utilize host machine hardware to a high degree in the execution of target computer
instructions. Candidate host computers must be studied to assess the impact of
computer hardware differences on utilization of host computer hardware in a
machine-independent environment.
Initial versions of the simulator will run in the batch mode as an applica-
tions program and will be self-contained; for instance, I/O statements will be
-12-
IS
PM
01
AC
CU
M
UL
AT
OR
S
16
PR
OG
RA
M
CO
UN
TE
R
1 2
BA
SE
RE
GI
ST
ER
S
PE
R
IP
H
ER
AL
SI
M
UL
AT
O
R
3
D
EV
IC
E
SI
M
UL
AT
IO
N
IN
D
IC
AT
O
R
ST
AT
US
RE
GI
ST
ER
SU
BR
OU
TI
NE
S
1
,
£
2
IN
D
EX
RE
GI
ST
ER
S
3
IN
TE
R
R
UP
T
S
fA
TU
S
RE
GI
ST
ER
,
.
TE
M
PO
RA
RY
ST
OR
AG
E
39
LO
CA
TI
O
NS
64
-
.
-
o
r-
,.
.
PR
O
DU
CT
RE
M
AI
ND
ER
RE
GI
ST
ER
t
,t
..
Fig
ure
20
SI
MU
L.A
TO
R-
PE
RI
PH
ER
{\L
DE
VI
CE
CO
MM
UN
ICA
TIO
N
SC
R
AT
C
H
P
A
D
M
EM
O
RY
IN
TE
R
R
U
P
T
ST
AT
U
S
W
OR
D
1I
J=
r]
~
.
.
.
.
.
.
i
~TAT
USBIT
S
.
ZE
R
O
IN
TE
R
R
U
P
T
IN
D
E
X
I
N
O
·
YE
S
C
A
LL
IN
TE
R
R
U
P
T
SE
R
VI
C
E
R
O
U
TI
N
E
I
R
ES
ET
R
EQ
UE
ST
I
NO
YE
S
NO
IN
C
R
EM
EN
T
IN
TE
R
R
U
P
T
IN
D
E
X
Fig
ure
3.
IN
TE
RR
UP
T
DE
TE
CT
IO
N
&
SE
RV
IC
E
SU
BR
OU
TIN
E
utilized for job description input. Later versions may utilize job control language
options of the operating system to perform input of job description parameters
such as snap, trace, or dump functions. Early versions of the simulator will
exhibit minimum interactions with the host computer operating system, while
later versions may utilize facilities provided by the more sophisticated operat-:-
ing systems. Additionally, the requirement for program transfer among several
computer installations impacts program modularity. Specifically, the simulator
must be constructed as a set of quasi-independent modules, regulated by a control-
ling module as shown in figure 4 and defined in table 3.· Host computer dependence
must be constrained to the minimum number of these modules, preferably to one
module. This strategy permits transfer of the simulator among host computers
with minimum interference and program modification.
C. Simulator Development Environment
Development efforts will take place utilizing the IBM 7094 computer as the
testing environment. This model computer, however, is not expected to be the
primary host computer for production versions of the simulator. The fact that
pr.oduction host computers will be different from the development host computer
impacts the trade study relating machine independence, utilization of host compu-
ter hardware, and program execution time as noted. The following will denote
specific instances in which carefully detailed functional design is required to
circumvent conflicts generated by the chosen development process.
The input development language will be FORTRAN IV(4). This high
level language is a descendant and extension in capability of FORTRAN. This
language capability is considered intermediate between FORTRAN II and FORTRAN
V. For development of the simulator on the IBM 7094, FORTRAN IV provides
the capability of FORTRAN II, with the additional ability to use logical variables
and to perform single bit manipulation. Relevant to us, FORTRAN V, available
on the UNIVAC 1108, would permit byte (subword) designation and operation, an
important enhancement for construction of the simulator.
Considerable effort has been invested in the development of additional.
supporting software for the IBM 7094(5). Results of this work were carried
forward into the implementation of the support software for the UNIVAC 1108.
4. IBM Systems Reference Library, IBM 7090/7094 IBSYS Operating System
Version 13, FORTRAN IV Language, GC28-6390-4, IBM Programming &
Publications, New York, N. Y., November 1968.
5. MSFC, Marshall Space Flight Center, Preliminary Reference Manual for
the IBM 7094, Huntsville, Alabama.
-14-
SU
M
C
SU
PE
R
VI
SO
R
M
A
IN
LI
N
E
I 1-
'
c.n I
I
P
R
E
-
PR
O
CE
SS
O
R
I
I JOB
D
E
SC
R
IP
TI
O
N
I
I
C
O
M
PU
TE
R
C
O
N
FI
G
U
R
A
-
TI
O
N
I
I
I
IN
IT
IA
LI
Z
E
R
I
I
F
E
iC
H
I
I OP
CO
DE
KE
Y I
I
O
PE
R
AN
D
K
E
Y I
I
P
R
IN
T
ER
R
O
R
TE
R
M
IN
A
TI
O
N
PO
ST
PR
O
CE
SS
O
R
iN
ST
R
U
C
TI
O
N
SU
BR
OU
TI
NE
~
TI
M
E
R
ST
AT
IS
TI
C
S
OP
CO
DE
T
A
B
LE
SE
AR
CH
C
LO
C
K
&
IN
TE
R
R
U
P
T
SE
R
VI
C
E
D
A
TA
N
O
TE
:
TA
B
LE
3.
CO
NT
AI
NS
A
FU
N
C
TI
O
N
AL
SU
M
M
AR
Y
FO
R
EA
CH
M
O
DU
LE
:F
igu
re
4.
SIM
UL
AT
OR
MO
DU
LA
RI
TY
DI
AG
RA
M
Table 3. Program Ivlodule Definition
Program Modules Function Summary
Preprocessor
Job Description
Computer
Configuration
Initializer
Mainline
Fetch
Op Code Key
Operand Key
Op Code Table Search
Instruction Subroutines
Timer·
Print
Error Termination
Post Processor
Statistics
Interrupt Service
Data
Reads output of the Liilk Editor and transforms it to the appro-
priate internal host machine format for execution by the simula-
tor.
Reads input parameters designating the selection of trace
options, run size, execution time limits, storage boundaries
and other pertinent information associated with this particular.
simulation run.
Inputs descriptive parameters defining the SUMC configuration
to be considered the target machine for this simulation.
Sets the initial conditions in simulation variables, e. g. SPM,
based on input parameters and Link Editor output, and builds
key tables.
Controls execution of other program modules including. overlay
control, if required.
Gets the next target computer instruction for execution,
extracts sub-fields for Op Code, Registers and Operand def-
inition. Checks interrupt status.
Searches the Op Code request table for action based on Op
Code key, calls appropriate response subroutine.
Similar toOp Code key, above, but searches the Operand
request table.
Searches Op Code table for match with instruction Op Code,
performs error checks, calls response subroutines.
Target computer instruction set is simulated at the level of
visibility to the programmer.
Maintains a cumulative record of calculated target machine
elapsed time for program execution.
Prints output as requested by a calling subprogram.
Handles abort situations arising from anomalies in the program
under simulation.
Handles termination of a simulation run outside of the failure
mode. Run parameters are output based on selection.
Utilizes Summary routine, Print routine.
Tabulates and outputs pertinent program measurement param-
eters such as number of executions of a specific instruction.
Provides the response demanded by an interrupt condition.
Data required by all program modules (global) will be avail-
able in COMMON and will il1clude SPlVI, Main Storage and sub-
routine communication variables. Temporary storage and data
unique to a particular sub-program may be allocated within the
sub-program.
-16-
.(
We must utilize this IBM 7094 software for enhancement of the basic FORTRAN IV
input language and for a similar carry-over to the UU08 to permit a closer
approach to machine independence.
-17-
SECTION lV. FUNCTIONAL REQUIREMENTS AND DESIGN CONCEPTS
A. Methodology Overview
.L Simulator Interplay with SUMC Development Software. The SUMC
interpretive simulator is an important member of a well-conceived set of programs
devoted to support of the SUMC family as shown in figure 5, Integration of Simulator
into SUMC Support Software. As indicated, the simulator must operate under
control of a subexecutive in the UNIVAC. 1108 operating system. Programming
generation will proceed from translation of input statements, either high level
language or assembler statements, into relocatable modules; relocatable modules
are put together and converted to a computer load module by the Link Editor.
The load module is executed on a SUMC, either a hardware SUMC or a host .
computer-microcode-software entity simulating a SUMC. The simulator must
enact the role of the software portion of the above entity.
2. Simulation Mode. The simulator will operate interpretively by
examining each target computer instruction to determine the functional response
required and subsequently accomplishing the functional requests through use of
the host hardware. Fidelity in yielding the correct result for an arbitrary instruc-
tion is the criterion rather than fidelity in executing the precise SUMC sequence
to obtain the result. Determination of the validity of a result will occur at the
level of visibility to the programmer. This means that, during an execution
sequence, the simulator must maintain the contents of computer storage that
are available to the programmer and is not responsible for registers, status
indicators and other computer information storage not available for reference
by the programmer.
3. Simulation Process. The simulator requires a Link Editor or
other identically formatted input of the program under test accompanied by
further job description and computer configuration identification parameters,
which are utilized to select the trace options and to establish the pseudo
register and storage layout representing the target SUMC.
A set of program modules required to accomplish the simulation functions
and a functional logic flow diagram for the overall interpretive simulation is
given in the Appendix. The process of simulation occurs in the following phases:
a.
memory map;
b.
Input of job description, computer configuration, and program
Definition of the target SUMC configuration;
-18-
11
0B
O
PE
R
A
TI
N
G
SY
ST
EM I t
SU
M
C
SU
PE
R
V
IS
O
R
"
R
ES
U
L
TS
M
IC
RO
SI
M
U
LA
TO
R
M
IC
RO
A
SS
EM
BL
ER
SU
M
C
LO
AD
M
O
D
U
LE
S
I
1
--
--
-'
-·
--
--
,-
--
"
-
J
-
-
,-
-
-
-
-
,-
-
-
-
-
-
i-
-
l
_
-
-
-
'
-
-
-
-
-
.
I I I
1
0
-
,
-
-
,
-
-
-
-
-
1
I I I V
-
-
-
CO
N
TR
O
L
-
-
-
IN
FO
RM
A
TI
O
N
,
,
"
f
V
V
CO
M
PI
LE
RS
M
OD
UL
E
FO
RT
RA
N
A
SS
EM
BL
ER
~
LI
N
K
ED
IT
O
R
SI
M
U
LA
TO
R
LI
B
R
A
RY
PL
!I
H
A
L
I
I
/
/
R
EL
O
C
A
TA
B
LE
SU
M
C
PR
O
G
RA
M
LO
AD
M
OD
UL
ES
R
ES
U
L
TS
M
OD
UL
ES
~
I ~ <P I
,Fi
gu
re
5.
IN
TE
GR
AT
IO
N
OF
SIM
UL
AT
OR
IN
TO
SU
MC
SU
PP
OR
T
SO
FT
WA
RE
c. Decomposition of target program instructions, register
identification and effective address calculation;
d. Error checking;
e. Trace, Dump and Snap implementation;
f. Instruction interpretive execution;
g. Printout of requested results and/or error notification; and
h. Exit to SUMC Supervisor upon detection of end of program.
The level of effort required for implementation of the a1:?ove functions is
dependent upon the sophistication of the debugging options provided. Simulation
execution times are similarly dependent.
B. IIiput Requirements
1. Computer Configuration. The SUMC has been designed as a highly
modular machine and is therefore capable of being configured in a great number
of different ways. This characteristic presents a unique problem in the simula-
tion of such a machine in that the simulator must be capable of processing flight
programs for any particular SUMC configuration. The simulator for the SUMC
family of machines must therefore be designed such that the user, vvith a minimum
of effort, is able to specify the exact SUMC configuration or environment in which
the flight programs will be run.
a. Word Length. Since theSUMC is a 4-bit byte modular compu-
ter, different configurations may have different word lengths. It will be necessary
to design the simulator so that SUMC programs may be run which have been
written for 16, 20, 24, 28, or 32-bit word length machines. It will of course be
required that the user supply information on target machine word length.
b. Scratch Pad Memory Size and Organization. The organization
of the SUMC Scratch Pad Memory (SPM) is another area of design which is inher-
ently flexible. The designer' may choose to maintain a minimum of SPM or he
may choose to include a rather extensive SPM layout. In addition, the registers
which make up the SPM may be organized in many different ways. These SPM
registers are programmable registers and as such will be maintained by the
SUMC simulator. This will require a user-supplied definition of SPM size, in
words, and also SPM register layout.
c. Main Memory Size and Organization'. The size of the SUMC
main memory will be variable from one configuration to the next. It will there-
fore be the responsibility of the user to specify target machine main memory
-20-
size in some way. This will be the only memory specification needed if it is
assumed that main memory consists of a fixed number of contiguous storage
locations. However, if it becomes necessary to partition main memory into
blocks of contiguous storage, the memory specification problem will become
considerably more complex.
d. Floating Point Instructions. The SUMC may be configured.
to include a floating point arithmetic unit which adds considerable depth to the
associated instruction set. Since the absence of a floating point unit results
in a much less extensive instruction set, the set of floating point instructions
will be included in the target machine instruction set only when user input
requirements specify floating point capal;>ility.
e. Special Instructions. The simulator will perform the execu-
tion of target machine instructions through the use of subroutines. The basic
capabilities of the SUMC will be simulated using a fixed set of instruction sub-
routines. However, additional subroutines may be called by the main program
in the event that target machine capabilities dictate their usage. The addition
of floating point routines as described in the previous section is an example of
this. In a similar manner, any other special instructions such as Input/Output
which must be included as part of the simulator must be specified as part of the
inputrequirements. In addition, any special instructions which are specified
must be present in the complete library of instructions which are available to
the simulator. It should be pointed out here that the SUMC is a microprogram-
mabIe machine and therefore could be capable of implementing a virtually infinite
number of machine instructions. The possibility would certainly exist that a
special instruction is not included in the library of subroutines, in which case
an error message could be output to the user.
2. Job Definition. In addition to specifying the SUMC configuration,
the simulation job definition must also be supplied to the simulator. In defining
a particular simulation, the user must provide:
a. Target progr~.m entry point and boundaries,
b. Target machine initial conditions,
c. Simulation output, and
d. Number of simulation runs and time for each.
The user's method for specifying the SUMC program entry point will
simply consist of a first word address which is supplied for each target program
to be run. The simulator will read the designated first word address, make an
appropriate transformation to obtain the host machine address, and begin the
simulation with an instruction FETCH from this location.
The user will provide target machine initial conditions for all volatile
registers by means of a map of SUMC Scratch Pad Memory. This is possible
-21-
since the SUMC architecture provides for location of all programmable registers
in Scratch Pad Memory.
The output information provided by the simulator will depend heavily on
the specific data which is requested by the programmer.' A number of different
output types, such as memory dumps and instruction traces, will be available
to the user. A number of different options will also be available for each basic
type of output. A detailed explanation of the types of output which will be avail-
able is given in the next section.
Finally, in the event that a n:umber of simulations ar~ to be run in succes-
sion. the user must specify the number of runs and also the maximum allowable
.run-time for each simulation. A maximum run-time will be designated in terms
of both simulated elapsed time and host machine run-time.
3. Link Editor. The SUMC Link Editor will be capable of generating
a complete map of the target machine main memory. This simulated main
memory map will be the primary input to the SUMC simulator. Once the sim-
ulator is provided with the initial conditions for SPM along with the address of
the first target instruction, simulated execution of SUMC flight programs will
proceed according to the instructions and data present in the SUMC simulated
main memory.
C. .Output Requirements
1. General. The output specifications for the SUMC simulator will
include both standard forms and special forms of diagnostic aids. Since the
purpose of the simulator is primarily one of testing and checkout of SUMC
flight programs, output diagnostics will perform one of the most important
functions of the simulation program. The SUMC simulator will make available
to the programmer several different types of output diagnostic aids. Each type
of output will also have a number of options available so that different levels of
output information can be obtained from the program at the discretion of the
user. The following paragraphs will describe the output options which will be
available for use when simulating SUMC programs.
2. Dumps. The user will be concerned with memory dumps for both
the simulated SUMC main memory and Scratch Pad Memory. Three types of
memory dumps will be available to the user, all of which yield a listing of
specified memory contents in an octal format. They are:
a. SPM· Dump. An output listing of the octal contents of each
SPM location. An SPM dump will be available to the user following the comple-
tion of a~y target machine instruction.
b. MM Dump. An output listing of the contents of each main
memory location. A main memory dump will be available to the user folloWing
-22-
termination of a target machine program regardless of the cause of the termina-
tion.
c. Block MM Dump. TIns output listing will be the same as the
complete main memory dump with the exception that only the memory information
between selected locations will be dumped.
3.- Traces. Several different types of instruction traces will be avail-
able for use when the contents of certain key registers are of interest to the
programmer ~
a. When an instruction trace is in effect; the following informa-
tion will be outputted after execution of each applicable SUMC instruction:
(1) Instruction Register contents,
(2) Program Counter,
(3) Next Program Counter,
(4) Contents of Accumulator, Base and Index Registers
used by the instruction,
(5) Operand Addresses and Operands used by tqe instruc-
tion, and
(6) Contents of Status Registers.
b. The four different types of traces which the user will have the
option of using are:
(1) Block Trace. Contents of key registers will be outputted
after each instruction .execution in a specified block of instructions.
(2) JUMP Trace. Contents of key registers will be out-
putted after· execution of each JUMP instruction.
(3) ·TEST Trace. Contents of key registers will be out~
putted after execution of each TEST instruction.
(4) Keyed Trace. Contents of key registers will be out-
putted after each instruction which involves a keyed op code, address, or address
contents.
4. Snaps. This debugging aid is similar to the keyed instruction trace
in that information is outputted whenever a specified op code or address is
-23-
I
I
encountered. The contents of the same key registers will be outputted, but in
addition, the contents of programmer specified main memory locations will be
prInted. The user will provide snap codes and arrays of snap addresses.
Addresses of snap items desired and number of snaps desired must also be
specified.
5. Error Messages. As each input or simulation error is discovered,
an error diagnostic will be printed indicating the type of error and action taken.
The error messages will always be outputted in the event of program recogniz-
able errors and the user will not have the option to delete error messages.
D. Language Requirements
The SUMC simulator will be designed so that a number of different target
computer configurations may be simulated and also so that a number of different
host computers may be employed in performing the simulation. The latter has
an impact on simulator source language requirements. In order to meet the
requirement ~f host machine independence, a high level language must be used;
however, the source language which is chosen must also be acceptable for pro-
cessing on many different host machines. FORTRAN IV will be used as the
simulator source language since this language comes closest to meeting both
of the stated requirements. Although FORTRAN IV is fairly universal in its
use, careful attention will still be given to maintaining machine independence
since FORTRAN program processing capabilities differ from one maphine to
the next. '
E. Future Simulator Enhancement
The basic simulator is designed to be independent of the host computer
operating system. Given a system supervisor prograrri for all SUMC develop-
ment software, the simulator can be modified to utilize features unique to this
supervisor. Allocation of some of the functional responsibilities from the sim-
ulator to the supervisor permits amplifying programming capabilities.
One promising area for this shift concerns the problem of causing a "snap"
using variable names in place of addresses. If the system supervisor can recognize
job control commands such as SNAP, then a possible program input could be the
following: '
SNAP COSBETA, ALPHA, SINGAM.
This command could cause output of the current values of the variables COSBETA,
ALPHA, and SINGAM to a designated output device. The system supervisor would
handle all variable symbolic translations. Similar featUres would allow ready
programmer accumulation of other debugging data using variable names as operands
for the system supervisor.
-24-
In considering future development paths for the simulator, the use of an
on-line time-shared terminal must not be ignored. To utilize the terminal
effectively, capability must be added to permit the programmer to interact with
the simulator during execution. The programmer must have the power to halt
simulation, examine or modify any location, and to perform any function present
in the initial version of the simulator.
As the SUMC development proceeds, requirements for high data rate
peripherals such as disks, drullls and CRT displays can be expected. Such
considerations, while not directly affecting the simulator functional design,
impact to the extent that the design must permit ready expansion at some future
data dependent on SUMC support software development trends.
-25-
SECTION V. CONCLUSIONS AND HECOMMENDATIONS
Study of active and historical efforts in simulating computers coupled
with experience in similar applications indicates that the most fruitful imple- .
mentation process is stepwise. The SUMC family interpretive simulator,
therefore, will be first implemented as a modular program designed to allow
convenient expansion. The initial version will constitute a basis for an extended
version which possesses additional capability noted in table 4, Phased Simulator
Development.
CSC believes that the SUMC interpretive simulator can permit verifica-
tion of SUMC software with considerably less effort than would be required by
utilization of the prototype computer hardware.
-26-
I l\.:
)
-
;] I
T
ab
le
4.
Ph
as
ed
Si
m
ul
at
or
D
ev
el
op
m
en
t
Fu
nc
tio
na
l
R
eq
ui
re
m
en
ts
.
In
iti
al
Si
m
ul
at
or
Si
m
ul
at
io
n
o
f
SU
M
C
fa
m
il
y
fo
r
Sc
ra
tc
h
Pa
d
M
em
or
y
-
64
w
o
rd
s
-
M
ai
n
s
to
ra
ge
-
u
p
to
32
K
w
o
rd
s
SU
M
C
w
o
rd
le
ng
th
v
a
ry
in
g
fr
om
16
-3
2
bi
ts
B
as
ic
in
st
ru
ct
io
n
re
pe
rt
oi
re
(3
)
In
te
rr
up
tc
a
pa
bi
lit
y
I
In
pu
t/O
ut
pu
ti
nt
er
fa
ce
c
a
pa
bi
lit
y
Sn
ap
,
B
lo
ck
T
ra
ce
,
Ju
m
p
T
ra
ce
a
n
d
T
es
t
T
ra
ce
I
O
pe
n-
en
de
d
fo
r
c
o
n
v
e
n
ie
nt
e
x
pa
ns
io
n
C
ap
ab
le
o
f
de
bu
gg
in
g
in
it
ia
l
s
ys
te
m
s
so
ft
w
ar
e
IEx
te
nd
ed
Si
m
ul
at
or
E
xp
an
si
on
o
fb
as
ic
in
st
ru
ct
io
n
re
pe
rt
oi
re
I
A
ss
em
bl
y
la
ng
ua
ge
c
o
di
ng
o
f
se
gm
en
ts
o
f
th
e
s
im
ul
at
or
I
D
et
ai
le
d
de
si
gn
a
n
d
im
pl
em
en
ta
ti
on
o
f
pe
ri
ph
er
al
de
vi
ce
si
m
ul
at
io
n
su
br
ou
ti
ne
s
O
th
er
c
a
pa
bi
li
ti
es
n
o
te
d
in
pr
ev
io
us
s
e
c
ti
on
I
IMo
di
fi
ca
tio
ns
de
em
ed
n
e
c
e
s
s
a
ry
by
o
pe
ra
ti(
;m
al
e
x
pe
ri
en
ce
I
APPENDIX: SUMC SIMULATOR ANNOTATED FLOW CHART
The operation of the Simulator is depicted in the following flowchart
(figure A-I). Note that the operations required to execute the interpretive
simulation are shown along with explanatory comments to clarify functions
of the Simulator.
-28-
ENTRY
SIMULATOR
INITIALIZATION
INTERPRET
NEW
CONF IGURATION
PARAMETERS
CALCULATE SPM LOCA.
OF ACCUMULATOR,
, BASE, INDEX REGISTERS,
INTRA-WORD
SUBFIELDS
NO
IF NEW PARAMETERS ARE INPUT USING JOB CONTROL
LANGUAGE (JCL) CARDS, THEN READING IS UNNECESSARY.
IF INPUT IS RESPONSIBILITY OF PROGRAM, THEN CARDS
MUST BE READ.
BASED ON INPUT PARAMETERS, PSEUDO REGISTERS
(SPM LOCATIONS) ARE MAINTAINED IN HOST MAIN
STORAGE.
IF PARAMETERS ARE INPUT VIA JCL, THEN READING IS
UNNECESSARY. INPUT PARAMETERS DESCRIBE NUMBER
OF RUNS, TRACE, SNAP REQUIREMENTS, RUN TIME
LIMITATIONS, AND OTHER DESCRIPTIVE VARIABLES
REQUIRED FOR EACH RUN.
FIGU~E A-l., SIMULATOR INTERPRETIVE OPERATION (SHEET 1 OF 7)
-29-
EXIT
NO SIMULATION REQUESTS CAN BE STACKED.
RETURN TO THE SYSTEM SUPERVISOR.
UPDATE
PSEUDO LOCATION
COUNTER (PCTR)
IF COMPUTER CONFIGURATION PARAMETERS ARE TRANSFERRED
USING THE LINK EDITOR, THEN PRECEDING INPUT METHOD
MUST BE REVISED. LINK EDITOR OUTPUT. MAY BE TRANSFORMED
TO A MORE CONVENIENT FORMAT BY THE PREPROCESSOR·
ROUTINES.
nZERO STORAGE AND RELOAD REGISTERS AS
DEFINED BY INPUT PARAMETERS.
SUMC UPDATES COUNTER BEFORE FETCHING
AN INSTRUCTION.
MUST CHECK INTERRUPT STATUS WORD IN SPM•
. c
FIGURE A-t SIMULATOR INTERPRETIVE OPERATION (SHEET 2 OF 7)
-30-
INTERRUPT
SERVICE
ROUTINE i
ERROR
TERMINATION
NO
NO
INTERRUPT SERVICE SUBROUTINES MUST BE PROVIDED.
ALL INTERRUPTS ARE CHECKED.
RUN LIMIT IS PROVIDED AS AN INPUT PARAMETER.
PROBABL Y CAUGHT IN A LOOP.
FIGURE A-L SIMULATOR INTERPRETIVE OPERATION (SHEET 3 OF 7)
-31-
GET NEXT
INSTRUCTION
OUTPUT TRACE
OR
SNAP DATA
SHAKE OUT
OP CODE FROM
INSTRUCTION
NO
NO
SNAP. TRACE IS DESIGNATED UTILIZING AN
APPROPRIATE INPUT PARAMETER.
OP CODE SEGMENT,IS EXTRACTED FROM THE
INSTRUCTION WORD.
"HALT" TERMINATES THE RUN, ALL PENDING
OUTPUT IS PRINTED, NOTE: OTHER TERMINATION
CRITERIA MAY BE USED.
FIGURE A-I. SIMULATOR INTERPRETIVE OPERATlO'i\! (SHEET It OF n
-32-
I
I
I
TERMINATE
SEARCH TABLE
FOR OP CODE
FOUND VALID OP
COPE-JN TABLE. NO
or CODE ERROR
OP CODE ERROR MESSAGE FOUND
INVALID OP CODE.
FIGURE A-·L S!MULATOR INTERPRETIVE OPERATlm~ (SHEET 5 OF 7)
-33- .
OP CODE KEY
REQUEST ROUTINE
OP CODE
EXECUTION
SUBROUTINE
I
I
• ,PR£DEF,INEl:: .~,CTION FOR PRESENCE OF A
SELECTED OP CODE,
EACH"NON-BASIC INSTRUCTION WILL BE
IMPLEMENTED AS A SUBROUTINE. BASIC
INSTRUCTIONS CAN BE CODED IN LINE
(SUBROUTINE LINKAGE OVERHEAD GREATER
THAN EXECUTION TIME).
A TYPICAL INSTRUCTION WILL BE EXECUTED
USING THE FOLLOWING SEQUENCE OF
OPERA TIONS.
FIGURE A-L SIMULATOR INTERPRETiVE OPERATION.(SHEET 6 OF 7)
-34-
FETCH REMAINI"lG
INSTRUCTION ..
_ SUB-FIELDS·
REQUEST
ACTIVATED BY
APPROPRIATE
INPUT
PARAMETER
VALUE.
PREDEFINED
RESPONSE TO
.KEY REQUEST. t--------1
REQUEST SERVICE
SUBROUTINE
OP CODE
EXECUTION
VIA SOFTWARE
NO
INSTRUCTION
ERROR
TERMINATION
ERROR
MESSAGE
ACCUMULATOR, BASE, INDEX AND
DISPLACEMENT FIELDS ARE SEGREGA TED BY
THE FETCH SUBROUTINE. ADDITIONAL --
OPERANDS MAY BE ACCESSED AS REQUIRED.
LOCATION COUNTER (PCTR) MUST BE _
UPDATED TO ACCOUNT FOR ADDITIONAL
OPERANDS.
VALIDITY CHECK ON EXTRACTED
PARAMETERS (E.G.RANGE),
SOFTWARE EXECUTION WILL--BE AT THE
LEVEL VISIBLE TO THE PROGRAMMER.
ALL f'UNCTIONS UNIQUE TO AN INSTRUCTION
MUST BE EXECUTED HERE.
.
FIGURE A-I. SmQULATOR INTE~{PRETIVE OPERATION (SHEET 7 OF 7)
-35-
REFERENCES
1. Techniques in the Generation of Support Software for the SUMC
Functional Requirements, Tech. Rpt., MDAC Contract No.
NAS8-27202, August 19, 1971.
2. Techniques in the Generation of Support Software for the SUMC -
Preliminary Design Specification, Tech. Rpt., MDAC Contract
No. NAS8-27202, Augtlst 19, 1971.
3. Program Description - Generalized Aerospace Computer Simulator,
Tech. Rpt. No. CS-6921-R0128, Logicon, August 1969.
4. Shuttle Computation System, E. Eastin, Contractor Rpt. SP-233-0252
.prepared for MSFC by Sperry Rand Corp. under NASA Contract No.
.NAS8-20055, Huntsville, Ala., June 8, 1970.
5. MSFC Advanced Aerospace Computer, E. Eastin et aI, Contractor
Rpt. SP-232-0384 prepared for MSFC by Sperry Rand Corp. under
NASA Contract NAS8-20055, Huntsville, Ala., July 6, 1970.
6. Proposed Instruction Set for SUMC System, E. Thompson et aI,
Contractor Rpt. SP-232-0405-1 prepared for MSFC by.Sperry
Rand Corp. under NASA Contract NAS8.:...20055·, Huntsville, Ala. ,
S.eptember 4, 1970.
7. . tICOS - An Interpretive Simulation of the Librascope Computer
Model-1 and Model-3, M. McLemlan, Contractor Rpt. prepared
under NASA Contract NAS3-3232, December 20, 1963.
8. Simulation of the SEL-810A Computer on Maniac II (SELMA),
N. Metropolis et aI, Report prepared by Los Alamos Scientific
Laboratory of the University of California, Los Alamos; New
Mexico, November 1966.
9. A Burroughs 220 Emulator for the IBM 360/25, T. A. Schoen and
M. R. Belsole, Jr., IEEE Transactions on Computers, July 1971.
10. Microprogramming: Principles and Practices, S. S. Husson,
Prentice-Hall, Englewood Cliffs, N. J., 1970.
-36-
REFERENCES (Continued)
11. IBM Systems Reference Library, IBM 7090/7094 Support Package
for IBM System/360, C28-6501-2, IBM Programming & Publications,
New York, N. Y., 1964.
12. FORTRAN IV Computing and Applications, R. L. Nolan, Addison-
Wesley Publishing Co., Inc., 1971.
13. Programming the IBM 7090, J. A. Saxon, Prentice-Hall, Inc.,
Englewood Cliffs, N. J., 1963.
14. .Computer Software, 1. Flores, Prentice-Hall, Inc.-, Englewood
Cliffs, N. J., 1965.
15. Investigation and Simulation of a Self-Repairing Digital Computer,
1. Terris, University Microfilms, Inc., Ann Arbor, Mich., 1965.
16. IBM Systems Journal, Volume Eight, Number Four, 19.69, pp. 251-350.
17. The Use of Simulation in the Design of a Real-Time, Multiprocessing
Computer System, C. E. Price, Fourth Annual Simulation Symposium
Record of Proceedings, Gordon and Breach Science Publishers, New
York: N. Y., 1971.
18. The PMS and ISP Descriptive Systems for Computer structures,
C. G. Bell and A. Newell, Proc. AFIPS Spring Joint Computer
Com., 1970, pp. 351-374.
19. Evaluation of Aerospace Computer Architecture, M. D. Anderson
and V. J. Marek, Contractor Rpt. prepared under NASA Contract
NAS12-589.
20. M<;>dular Design of Computers through the Use of Multi-Level Simula-
tion, K. A. Duke et aI, Rpt. RC2872 (#13504), IBM Thomas J. Watson
Research Center, Yorktown Heights, N. Y., May 8, 1970.
21. Evaluation of Hardware-Firrnware-Software Trade-offs with Math-
ematical Modeling, H. Barsamian and A. De Cegama, Proc. AFIPS
Spring Joint Computer Conf., 1971, pp. 151-162.
-37-
