Design of a modular digital computer system, CDRL no. D001, final design plan by Easton, R. A.
General Disclaimer 
One or more of the Following Statements may affect this Document 
 
 This document has been reproduced from the best copy furnished by the 
organizational source. It is being released in the interest of making available as 
much information as possible. 
 
 This document may contain data, which exceeds the sheet parameters. It was 
furnished in this condition by the organizational source and is the best copy 
available. 
 
 This document may contain tone-on-tone or color graphs, charts and/or pictures, 
which have been reproduced in black and white. 
 
 This document is paginated as submitted by the original source. 
 
 Portions of this document are not fully legible due to the historical nature of some 
of the material. However, it is the best reproduction available from the original 
submission. 
 
 
 
 
 
 
 
Produced by the NASA Center for Aerospace Information (CASI) 
https://ntrs.nasa.gov/search.jsp?R=19760004647 2020-03-22T19:20:32+00:00Z
AML '	
_._.
NASA CR-144038
HUGHES
ruGr.i	
_ aCa>i	 ..	 ..
G RoUNU SYSTEMS GaUUP
(NA:3A-Ck-144038)	 UL'S i'^iti	 A :i^)U".	 N7b- I I !_t
DIGITAI. COMP!IFF aY!^TEM, C . iL NC.	 JO 1,
FINAL CESIGN PLAN IPchnicai 
1974 - 1 SeP. 1	 ^i`7'i ^vyhes Aiccrait  C c - )	 Uucla
120 p }ic $9.90	 CSCL use 63/60 01499
a
1
,0\N bl b I116",7'9^
ti0
° tiq 'pF y-^
_I	 I	 I	 I_i__^_

FORWARD
a
This report documents the engineering breadboard implementation developed during
the logic design phases of contract NAS8-27926 from January 1, 1974 through
September 1, 1975. This effort is a follow-on to the architecture study completed
under the earlier phase of this contract on December 31, 1973 and documented in
Hughes Report FR-73-11-998 (DRL 4 and 5) previously submitted. Hughes Data
Processing Products Division in Fullerton, Calif has performed this design under
direction of Dr. J. B. White of the Data Systems Laboratory of NASA's Marshall Space
Flight Center in Huntsville, Alabama. The design applies the architecture concepts
developed previously under this contract to MSFC's SUMC computer and is intended to	 1
fulfill all design requirements set forth in this contract's scope of work.
i
This report was prepared by R.A. Easton. Major contributors to the described imple-
mentation are R.A. Easton - system, CCE, memory, MPSE and CPE designs;
G. H. Ullom and S. Y. Chung — CPE design, E. E. Erlandson — IOP design, and
J. E. Bartling -mechanical packaging.
CONTENTS
1. Introduction	 ..........	 ............
	
............... 1-1
2. Breadboard Packaging .............................. 2-1
3. Central Control Element
	
............	 ...	 ..	 ........ 3-1
F
4. Central Processing Element
	
*......................... 4-1
5. Memory	 ...................................... 5-1
6. Input/Output Processor	 ............................. 6-1
7. _ Maintenance/Status Panel and Electronics 	 .............. ... 7-1
y
t
J
1. INTRODUCTION
The ARMS Engineering Breadboard (EB) described in this report is designed to verify
the concepts of a fault tolerant, automatically reeonfigurable, modular version of the
SUMC general purpose digital computer system developed under the architecture study
phase of this contract. ARMS has a microprogrammed 32 bit word length, general
register architecture and an instruction set consisting of a subset of the IBM System
360 instruction set plus additional fault tolerance firmware.
The ARMS EB consists of the following modules:*
1— Central Control Element (CCE)
4 — Central Processing Elements (CPE)
4 Memory Modules (MEM)
1— Input/Output Processor (IOP)
1— Maintenance/Status Panel and Electronics (MSPE)
1— Interconnect Board (IC)
An overall block diagram of the ARMS EB is shown in figure 1-1. The detailed inter-
. module wire lists are discussed under each module later in this report. The functions
of each module are as follows:	 ^I
The CCE provides system control, configuration, and fault and status monitoring func-
tions for the ARMS EB. The CCE automatically reconfigures ARMS when a fault has
been detected. In addition it initially configures the breadboard with respect to which
modules are active and passive, and to which physical memories will respond to given
logical page assignments, and it provides for synchronized system clock distribution
and for d. c. power control and power fault master clear signals to other ARMS mod-
ules. The CCE module is implemented in simplex in the ARMS EB to minimize cost.
In a flight version it is recommended that 3 copies of the CCE be implemented with
all control outputs voted. The CCE is described more fully in section 3 of this report.
The CPE modules for the ARMS EB are based at a register level on MSFC's 32-bit
in-house breadboard version of the SUMC processor with modifications where neces-
sary to meet ARMS fault tolerance demonstration objectives or to make cost effective
*Although all module designs_ are complete only 1-CCE, 1-CPE, 1-MEM, 1-MSPE
and 1-IC have been fabricated in the initial fabrication* phase. Fabrication of the
	 !
fOP and remaining CPE and MEM modules is anticipated under future funding.
1-1
t	 I	 I	 I	 I -
	i-I
use of currently available MSI circuits. It's instruction set includes all 86 fixed point
and 8 floating point instructions compatible with IBM System 360 and SUMC plus
2 special instructions for use in fault tolerance demonstration. Remaining system
360 floating point instructions can be easily added by adding additional ROMs to the
CPE at a later date if desired. The CPE design includes fault tolerance features
recommended in the ARMS architecture study including voting and parity logic to
complement total system wide fault tolerance techniques. The CPEs are designed to
operate in either simplex, duplex, or triply modular redundant (TMR) modes. The
CPE module is described more fully in section 4 of this report.
Memory modules for the ARMS EB each consist of a commercial EMM micromemory 	 i9
2000 series core memory in a 4096 word by 39 bit configuration with a custom interface
providing for fault tolerance including Hamming-parity error detection and correction
coding of data, and for control and processing of accessing requests from CPEs and
IOPs on 4 sets of data buses in simplex, duplex, and TMR modes. The memory module 	 i
is described in detail in section 5 of this report.
The IOP provides the communications link between ARMS and external devices. It
	
..	 contains two subchannels (one to interface with MSFC's DMS and one to interface with
a TTY) which can operate independently once initiated by the CPE (s). The IOP accesses
memory via buses shared with the CPEs but on which the IOP has first priority. Like
the CPE it contains fault tolerant circuits complementing overall system fault tolerance
techniques. The IOP for the ARMS EB is designed to simulate the effects of multiple
IOPs operating in simplex, duplex, and TMR modes at system interfaces without
incurring the costs associated with actual fabrication of multiple IOPs. The IOP mod-
ule is described more fully in section 6 of this report.
a
The MSPE provides for operator access to and control of all modules in the ARMS
breadboard including the controlled introduction of faults for study. The panel also
provides for status scanouts in both binary and hexidecimal form of approximately
3500 key register and control bits within the various ARMS modules. Section 7 of
this report describes the MSPE.
The interconnect board (IC) contains all inter-module wiring within the breadboard
	
f	
including the 4 sets of buses to and from memory. Each module physically connects
to the IC by means of pigtail connectors for easy maintenance and expandability. A
1-2
_. T T -----.. 
discussion of all interface signals at each module follows the functional description
of that module.
The ARMS EB is packaged in a single 6 1/2 foot rack using commercial TTL integrated
circuits as described in section 2 of this report. Since no accurate reliability figures
are available for these parts no overall reliability discussion is included in this
report. However the final complexity level of the various modules compares favorably
with that assumed in the reliability analysis of our previous phase report (except for
the CPE which has more ROM than originally assumed since the original CPE con-
cept was not System 360 compatible). Based on-that analysis an ARMS flight prototype
using an LSI implementation of the breadboard design and flight qualified memories
instead of the commercial core memories included in the breadboard should have no
difficulty meeting ARMS goal of 0.99 probability of successful operation over a 5 year
mission, despite the enlarged CPE. Discussion of specific module gate counts and
reliability features are included later in this report in the sections dealing with each
module.
Additional documentation pertaining to the ARMS breadboard but beyond the
scope of this report is listed below:
Ref 1. IBM System/360 Principles of Operation.. IBM document No. GA-6821-8
SDD Product Publications, Poughkeepsie N.Y. (1970)
Ref 2. Design of a Modular Digital Computer System. Final and Phase III
Report FR73-11-998 Hughes Aircraft Co., Fullerton, Cal. (1973)
i
In addition an ARMS Breadboard 'Engineering Drawings and Documentation Package
containing ARMS engineering notebook entries not incorporated into this present report
will be submitted to MSFC in connection with this contract. The Package consists of:
1. CPE Microprogram Documentation Explanation
2. CPE Microprogram Flowcharts
3. CPE Microprogram Computer Listing
4. IOP PROM Contents Table
5. Logic Diagrams for all ARMS modules
6. Wire Lists for all ARMS modules* by physical sequence (connector
sequence lists) and alphabetically by signal names (ADDS IC Maintenance
Reports).
*not available for IOP module at this tip
1-3
i7. Integrated Circuit Layouts and IC lists by Function for all modules.
8. Maintenance Panel Sca.nout Maps listing both functions and signal
mnemonics displayed as testpoints in all modules.
9.!' Documentation supplied with commercial core memories.
10. Cabinet Assembly Wiring and Detailed Intermodule Wiring Diagrams.
11. Explanations of Wire Plane Designation and Configuration Plan and of
Iaterconnectboard special Wiring Requirements.
12. Mechanical Design Drawings.
k
MEMORY MEMORY MEMiNtY MEMORY
1, 2 3 4
c^cc Cua2
—CuaF- coYit
MEM	 V 3IEM	 V /MCM	 V wteM	 V
MEMORY DATA BUSSES (4)
-c G E
.CENTRAL
CONIROL
ELEMENT(SIMPLEX)	 -
V V V __V V
CPE(MODIFIED c ptCMODIFIED cPE( MODIFIED CPF-MODIFIED I/OP
SUMC SUMC SUMO SUMC (SIMPLEX)
PROCESSOR) PROCESSOR) PROCESSOR). PROCESSOR
CONTROL LINES
-
DATA
TT Y f MANAGEMENT
V —VO(ER. AND. Bus :SVYI"rCli. -SYSTEM
BREADBOARD
MAINTENANCE	 TO/FROM ALL MODULESAND CONTROL
PANEL
BULK	 KEYBOARD PRINTER
STORE
F t.Irt I —
Automatically Rcconfigurable Modular Computer
i+ I	 I ^^
2. ARMS BREADBOARD PACKAGING
The ARMS breadboard is assembled using commercial techniques and readily available
parts. The single string version uses approximately 2800 DIP packaged integrated
circuits, predominantly of the 7400 series. The full breadboard uses nearly 7000 DIPS.
These ICs are interconnected using AMP sockets with termipoint wiring mounted on
EECO 2-D packaging frames.
The breadboard packag:^a concept is shown in Figure 2-1. The logic except for the
commercial memories are contained on up to 7 vertical frames with each having space
for up to * 1296 DIPs. The single string breadboard uses only 3 frames — one each for
CPE and IOP modules and one shared between memory interface, maintenance elec-
tronics, and CCE. The full version of the breadboard contains 3 more CPE frames
and one additional frame holding 3 more copies of the memory interface logic. All
wiring between modules including pull-up resistors are contained on an interconnect
board perpendicular to the DIP frames. All DIP frames are mounted on hinges allow-
ing easy access to both IC and wiring sides of each frame. Forced air cooling is pro-
vided by fans mounted beneath the circuit frames as shown in Figure 2-2. This figure
also shows the locations of the maintenance panel, above the circuit frames at eye
level, and of the 4 commercial memory modules. All modules are contained in a
6 1/2 foot x 24 inch: rack except for logic power supplies. The breadboard logic
requires approximately 75A @ 5V for the single string and 190A @ 5V for the full
version. Either version requires t12V supplies at 300 ma for the TTY interface in
addition to the main 5 volt supplies. The commercial core memory power supplies
are self contained within the memory packaging.
TABLE 2-1. IC COUNT AND POWER REQUIREMENTS
No. of*
	
Amps @ +5V
Module	 ICS	 Required
CCE 254 4.56
CPE 949 30.25
Memory 351 7.11
IOP 1133 30.44
MSPE 46 2.26
Interconnect 58
2791 74.82
*includes flat-pack resistors
2-1
.tt

/}_MS PNCle-A(,IJ( Goy_
	C CIRC ulT F^ ES•^	 /	 /
LC
Ai
	
^`oA^, 0
	
CPLC
Lop
	
^^	 C n E ,aeL 1
	
1 +	 c 	 1E
3. CENT AL CONTROL ELEMENT (CCE)
The Central Control Mement distributes power and clock signals to other
ARMS modules and ccwt-dir rtes ARMS reconfiguration either due to new
assignments from the maintenance/status panel or in response to fault
interrupts from other ARMS modules. In order to minimize costs the
breadboard CCE does not include redundancy that could be implemented in
a flight version. For maximum reliability a TMR CCE with voting between
the parts on all outputs would be desirable.
The CCE consists of individual status controllers for each ARMS module
to be controlled fault correlation logic, an overall program initiator and
reconfiguration controller, switching logic for power supplied to other
modules,-a crystal controlled central clock source, and external interrupt
routing logic. The CCE has no internal processing or main memory bus
access capabilities but is capable of utilizing CPE software or hardware to
enhance its own hardwired capabilities by means of interrupts. A block
diagram of the CCE'is shown in Figure 3-1. The following is a description
of the specific embodiment of the CCE used in the ARMS breadboard:
CPE Module Status Controller. One CPE module status controller is required	 1
for each of the 4 CPE modules in the ARMS breadboard. Each controller	 9
keeps track of the CPE's status (spare, active normal, active abnormal,
failed) outputting a stream assignment bit corresponding to that CPE's
hardwired processor (to memory) bus. Together the 4 CPE module status
controllers provide a 12 bit stream assignment to all CPE's identifying
which CPE's are active and which are passive. When the CCE is powered
initially, each CPE module status controller places its CPE in the spare
state. A signal from the maintenance/ status panel causes one or more of
these controllers to place their CPE's in the "active normal" state. If a
)
x_
1fault interrupt from either a CPE or a memory module indicates that a specific
CPE may have failed that CPE's status controller is planed in the "active abnormal"
state. Figure 'I4-2a shows the various states that a module status controller may take on.
If the CPE is operating in the simplex mode when the fault was detected, or
if it is operating in the duplex mode and the fault is detected by a memory
module without being internally detected within the CPE, the CPE module
status controller causes the Program Initiator and Reconfiguration Controller
(PIRC) logic discussed in the next sectiomto issue a stop CPE interrupt immedi-
ately. If the CPE is operating in the TMR mode when the fault was detected, i
or if it is operating in the duplex mode and the fault is internally detected
within the CPE, the controller issues a stop CPE interrupt immediately
following receipt of a CPE available/rollback pace signal from the CPE, or
after a prescribed time interval, whichever is shorter. Once in the "active
abnormal" state one of the following events occurs in the CPE module status
controller:
a) If the CPE issues a CPE available/rollback pace signal
prior to receipt of another fault interrupt concerning	 j
this CPE the status controller returns the CPE to the
"active normal" state.
a
b) If, another fault interrupt concerning the CPE is received
prior to receipt of the CPE's available/rollback pace signal
the controller enters the failure pending state. From this
r state the reconfiguration controller either replaces the
I	 faulty module if it has sufficient priority and a spare is
b) continued
controller returns the CPE module status controller
to the active abnormal state. Thus modules that cannot
be immediately replaced continue to be retried, and ARMS
continues to operate in the presence of maskable failures.
Fault interrupts from IOP or main memory modules cause issuance of a
f
stop CPE interrupt immediately if the CPE is operating in the simplex mode
or immediately following receipt of a CPE available/rollback pace signal
from the CPE if the CPE is operating in the duplex or TMR mode. The CPE
module status controller remains in the active normal state during this
operation in the absence of a fault interrupt placing blame on the CPE. The
CPE module status controller also issues stop CPE interrupts prior to any
external command update of assignments from the maintenance/ status panel
or due to an emergency such as an impending power failure.
IOP Module Status Controller. The IOP module status controller design
requirements are similar to those for the CPE module status controller
with the following exceptions:
a) A stop IOP interrupt will not be issued unless the
IOP does not stop within a prescribed time interval
after all CPEs have halted.
b) An IOP will not be returned to the "active normal"
state from the "active abnormal" state unless all
active CPEs issue CPE available/rollback pace
signals prior to the receipt of another fault interrupt
concerning this IOP.
1-3
r
41
dMain Memory Module Status Controller. One main memory module
` y	 status controller will be required for each of the 4 main memory modules
in the ARMS breadboard. These controller's design requirements will be
similar to those for the CPE module status controller with the following
F	 exceptions:
r	
a) A stop memory interrupt is not required.
t	 b) A main memory module will not require stream
i
assignment status bits but will require page address	 y
and output bus assignments. The output bus assign-
ment determines if a memory module will transfer
data to CPEs or IOPs on the lower, (middle), or upper
3	
numbered memory(to processor)bus paired with the
z,	 processor(to memory).buses to which access was granted.
;;	 1
An "essential/non-essential" memory status bit is also 	 3
i	 required internal to the main memory module status 	 a
controller to determine the proper memory replacement
	
	
3
a
G t
	
	
algorithm for the reconfiguration concroller in response
to a memory fault interrupt. An essential memory
contains programs and important data the loss of which
could disable a stream. A non-essential memory contains
working storage and other contents the loss of which would
not disable a stream.
c) 'A main memory will not be returned to the "active
normal" state from the "active abnormal" state unless
all active CPEs issue CPE available/rollback pace signals
prior to the receipt of another fault interrupt from this
memory.
3- 4
Program Initiator and Reconfiguration Controller. The program
initiator and reconfiguration controller (PIRC) restarts the ARMS CPEs
initially, or if they have been stopped for any reason, and controls the
transfer of status assignments between individual module status controllers
when ARMS reconfiguration is required.
I
The program initiator logic is activated whenever a load request is re-
ceived from the maintenance/ status panel, any faults are detected, or
CPE available/rollback pace signals are not received from all CPEs within
an interval timed by the PIRC logic. The various states that the PIRC logic
can assume are shown in Figure 3-2b. Once activated, the program initiator
logic issues-stop interrupts to the CPEs as discussed in the previous section,
issues a panic halt signal *to all CPEs and IOP , waits for CPE available/
rollback pace signals from all CPEs and an IOP available signal to stabilize
in the available states,and then takes one of the following actions in descending
priority:
a) In the case of an essential memory failure in the duplex j
or TMR mode the program initiator logic issues a clear
memory interrupt to the questionable memory, forcing
its output to "0" pending completion of initialization;_folldwed
by an initialize memory interrupt, along with control
information specifying the memory page to be initialized,
to the highest priority CPEs. These CPEs enter a program
that alternately reads from and then writes into every word
in that memory page duplicating data from the good memory(s)
into the newly assigned memory. All zero output conditions
from the memory being initialized shall be considered to be
normal until this operation is completed as signalled
9i 
t
3 5
a)	 continued
by a rollback pace signal from the CPE in question.
Upon receipt of this signal the program initiator logic
issues start interrupts to any remaining active CPEs
if more than one processing stream is used in ARMS
and restores the newly initialized memory to normal
operation. Upon completion the memory initialization
program automatically returns to the appropriate rollback
point of the program in progress at the time of the interrupt.
b)	 In the case of any other failure the program initiator logic
issues start CPE interrupts to all active CPEs causing them
to return to the appropriate rollback point(s) for the program(s)
in progress at the time of the interrupt.
Figure 3-3 shows the PIRC logic necessary to respond to CPE rollback pace
signals and to issue the interrupts discussed above. The reconfiguration
controller controls the transfer of status assignments between individual
module status controllers in response to commands from the breadboard's
maintenance/status panel or to any of the individual module status controllers
entering the failure pending state. Transfers of status assignments from
failed active modules to newly activated spare modules occur once the program
initiator logic verifies that the IOP and all CPEs are available (i. e., stopped)
and prior to issuance of any interrupts by the program initiator logic with the
following restrictions:
a)	 Only one module of any given type can be replaced at
a time and a spare module of that type must be available.
For.• example, one memory plus one CPE may be replaced
but not two CPEs at one time. If two CPEs did fail at once,
one would be retried a second time and if it still malfunctioned
k	 i,
and an additional spare CPE was available it would then be
k 	 " 	 replaced.
f
b) Essential main memory modules operating in simplex
cannot be replaced by spares since no mechanism for
initializing them is available. A permanent failure in
such a memory module requires outside intervention for
correction.
The logic for transferring • assignments between status controllers is shown
in Figure 3-4.
Fault Correlation Logic. The fault correlation logic allows the CCE to
maximize the probability of correctly isolating a fault to a specific ARMS
module within limitations dictated by a reasonable level of hardwired logic
complexity and allows the CCE to determine that certain faults are maskable
so'that critical programs can continue to completion. The CCE correlates
received fault interrupts from each CPE, IOP, and main memory module with
appropriate status information from their status controllers as shown in
Figure 3 - 5.
_	 f
Many CPE and IOP faults may be isolated due to fault interrupts from the
module in question. Single memory module fault interrupts indicate failures
within the interrupting memory. In duplex and TMR modes simultaneous fault
interrupts from two or more memories can isolate a failure to a CPE or IOP
module whose identity is encoded in the interrupt. In the duplex mode these
interrupts may only isolate the fault to one of two CPEs or IOPs in the absence
of a direct fault interrupt from the offending module: However an arbitrary
replacement of one of these modules provides 50% probability of success in
cases that otherwise would result in an ARMS system failure.
In simplex mode detectable faults (other than maskable single bit failures 	 x
within main memory modules) result in immediate rollback or replacement
of the offending module. In the absence of a fault interrupt from the CPE or
IOP the fault is blamed on non-essential memories or on the CPE or
a
3-7
IOP accessing an essential memory in the case of an ambiguous fault.
If a fault is unambigiously isolatable to an essential memory the fault is
insolvable since no mechanism exists for initializing a spare in this mode.
Some faults maybe undetectable in simplex mode.
In duplex mode virtually all faults are detectable and at least those detectable
	
i	 in simplex allow the program to continue to its next rollback point and then
	
V	 are correctable in real-time through rec onfiguration so long as spare modules
are available. In all modes ARMS breadboard is capable of continued compu-
tation in the presence of faults so long as these faults aremaskable. The
choice between rollback and continued computation is software determined
in that it is dependent upon whether the program is stopped before or after the
program status block is updated. If the block has been updated the next program
is executed, if not, then the resent program is repeated.I
	
	
P	 P ^'	 P	 Programs shall be
constructed so that they can be repeated if necessary.
Power Switching Logic. The CCE.distributes power to all other ARMS modules.
The power switching logic provides power to each ARMS module whose}
individual status controller places it in either an "active normal", "active
abnormal", or "failure pending" state.
Crystal Controlled Clock. The CCE contains a crystal controlled oscillator
providing central clock signals to all ARMS modules to assure their synchron-
ization.
External Interrupt. Logic. The CCE holds external interrupts when they are
received and routes them to the CPEs for which they were intended. When
a CPE responds to a given interrupt it sends a response to the CCE which clears
the interrupt once it receives response from a majority of the CPEs to which
the interrupt was sent. As in the case of the power and clock distribution
external interrupts are routed through the CCE since it is the only element in
ARMS which remains stable throughout system reconfiguration. Clock Distri-
bution and External interrupt logic is shown in Figure 3-6.
3-8
CCE Technology and Component Count. A CCE is being breadboarded out
of T2  small scale integrated circuit logic. For maximum reliability it
should ultimately be implemented with CMOS LSI technology. Table 3-1
shows the number of gates and flip-flops required by each part of the CCE.
_Clearly the CCE complexity would increase for larger numbers of controlled
modules but for ARMS it contains less than 1200 equivalent gates (600 of the
complexity used for reliability calculations in Reference 2) and is simple
enough to be readily implemented on 2 or 3 large scale integrated circuits
if desired.
Relating the Functional Description to Logic Diagram. Table'3-2 relates
states shown in the diagrams in this document to mnemonics used in logic
diagrams for the CCE. Table 3-2a covers states shown in Figure 3-2a.
Table 3-2b covers states shown in Figure 3-2b; Table 3-2c relates the . module
status controller mnemonics to paths-in Figure 3-4 while Table 3-2d lists
the 4 bit codes used in the memory fault interrupts followed by the mnemonics
related to paths in Figure 3-5.
Table 3-3a lists CPE status controller stream assignment codes by status
and priority and Table 3-3b lists memory status controller output mode codes
by function. It should also be noted that for essential memories QESSM = 1.
c^hPost^f Fww.t ^+^wl^t.
, o TML
 
14T -t^iur^TS^tE>i'ua^"
^^ MtM• ct.T,^+'t.,t'a fnct•^ .NE•►»^lY
CfE 1	 ATAL
	 P906QAM IMITIAToel	 AYr.I^^RIE 'all:fi^ll f^lorti i° ^CrtcPE,+^t'
•_	 asr-/	 RECON 1= ka	 c orlT.	 ^_._.^1'lEM IN+T^n^12E T. fAcFr CIE
TOIA NM G.
	 SIART
CPty	 % %Top P+t-Gan es+ -r(, E4C01 cPf^ Iult
CLOC K , 3Mt. TO A it M%OQL&S
,E,-f ^N7E.cRYJT
T•)f+l^w
Ewctrt^E
ErT . 017E01t+•PT ACAt,
EuT.
I'viefl4vPT
Lo{ilc.
fi{vwe	 1
ARM S C C E BLOC K OIAG RA M
R 
n M.	 PRGE Qv S	 s.,+TCnen IIYr+e^t•	
_
ASb tVMtIJTS	 /15: ► iNMfN'ts	 ?+a MoaUllS
FANL7 1MA+CATIOWS 'BY MUOULE
tilt . MAf ►tw.l^[/ N^^_3 MYf!6t^^	 ►. / ^	 i i	 ..	 I
FAV►T INTL240 s
r•	 iW 1 h. 5 ^{ - Al M _^ r	
_	 '
•	 1	 t	 '`
F-AV LT 	 ^ E 	 e .= I 1	 +	 ^^, l
^f,
	 I - Sw l?cN,Ntt	 M
MEny	 C0KMEtAT1 0	 100wif)VAL MODULE 5TAPS CONT.
1_0614L
MuJucE Moot fl^lw	 R6COIlFIG^rLAilu►! 	
gcT10El fA
C^Nf0.ul
lop
P
Ow
Cr
rARM S
	
STATE 71?AAjsi Tr o A/ DIA CRAM
g/co.!►os.rs ^B Pgce
........^...^..
all C/E 4/5'ACt fAv4-T Fi"fs &is 2 0 MAftf +i cLEAK F06UOS P14G. 'ro ••A" /i •r4 wIS =a
R E CEwiq
^..W /.v ►<rivA L... 40 Ap [iQ, " It #A
uR D/S•D r.•I1StraL Uri
.	 O/f z O ^WTtdV4< YP^
0 ! A/ T[iYrs..L 015 C/ < u8 uQ lwaF tT rr	 ^^ FA•IK Nwt-t	 p^sf a..K.t o	 .,.s.
IMiT.A►.A►. ntM.li	 ..
'M.T S^t'csffF•L
P MEMYQ'( 4w are, #alpc.. AVAILA^^
Cuh.htstD
iii	
_e. ^^^WiKWZ A^111 ^rnyl 	 .
ILAr c.u0►tTt : A..•	 .
.
+KlTny
Mi ►.•d'( M•-LAY •l.t►rtA. .FA•tt /MNr^t.
F'.
/
c
firAjr/2F
7WO ADJ. ITAT..3
AM.r.Y•. AC'rN^	 Ml^"	 r• a• r r	 El REhdFKOiE tE2
Fr	 .••HCwrto 0LK rnATCPF	 14 IL
	 niL iYwoPf	 ri.+	 /	 .	 !1
V '	 P40G<i1N INITIATOR/ ^	 AMO A•• YMEF SMTQs e..q	 t.aA.' w
REto.JF^r4AM:lSV WMTQL^	 _ .. ,
F.►ID STA1i	 M	 irt 	 7p f.'wlf.NOrit Poviti 4&A-94 TO #100" Vwtiss to 3rn.►<i/i ♦wI sPAR! ORA	 ^	 AfT	 c.cA{ ftsu" t•«
^: INp ,.u^OVAL M01u T^ ^TATr3 Cr.rrR•^.
c ►E 414 PAcf POt clE--
C•.+hf .w MA IACE Pail L• ^, NFM j
_' a
SpA4E	 R4c•.lF^sw^E Ac'rsVE	 AcTIVt FAILLD
•R
LEAP
^MA^.	 a•^o^t	 AfIMoRwt.
FAILS	 8
Movwi
FArj
\,	 /A" a STAT43 C0.8y.	 ADv STATUS +^ •
H	
!
^ r `
c..rT-
i^ Rsa.c^
•N.r ROIMC! ^T
N•DYLf,
' /.3 . trw <.
 
/KT. M.t•Lt FAIL. PEA O
(NrwYRYo^►TI
AI
^ A
E
0.'+v..3 ..
C j
I
6
r
'	
t.^CcE' J'Ro^-^2^M rw^ try ^c^2 J^eFC^r.^,,c,^ ^^^u^1 c.,vr2oc (^^/Lc) Lo^•^G	 ---^-r
LOi3D RKWC$T
ANY FAVLT
{	
s
PTQCA ( AM amAL)	 PIRCF WSTAWFOSS)	 /	 TiMpuT PIRA	
^^tups
U/ 5	 (S(n^4T)	 iS Eq UCN CE2
c PE
kavLo3nck eACr
- J	 Q
E	 ^ Ft—	 -'	 SToP(^^wpccc^ crt,aP n^wl.Awis/
	
Rottsnc,t Act	 RUA# iiwwji
14,we
	
rMsc ^A^3 rE•+^	 ^^ac^
f	
^	 C^'E,; S1NllfcK
	 (^AN)C NAI,'/
	 7	 ,^
f
ANY FAULT
R.^a.9+ac ac	 S TOP CPEC '
r2c c	 s Yiuc
i	 CPE,• 11^6X	 FF
CPE Fn..ar	 2. SMf(A CcucK
13y McN
(^,/eN
-MnsKn^cF)
	 PIIlCtr
g	
_
`k	
STAQT CPCi_
IAnr• E4s mE	 -a -
CLEAQ MEM^:	 P 2cFEsf nE^ n3•+
	 =
i	 ANoof wtowtr E,acF
IRLM1^iV	 _
Ctf-wa ANy .4f.
-
^•	 CPf.' &01"
'_`	 ♦NIT- ME.M-
r	 MEM 12A6F sic	 INiT. HCM 1^A &E ,LPs •iMHil-ilas Pav ejo d 5yl1rA
comill•C Tu tPCs
^^	
I /
Fop,
CC- E MODUL& :S-rA't%j$ C-o*JT 5L6LL-F-2 L.*"C-
o 9C Tnbmv C- JA-L-	 -SPAieE--Al lDfV#I)U, L Mo OJILI-c
aE6- A
CC# AVREQ
K OO 0% FAV64	 cs M REC-**
MOPULE A	 40*0 AJ464i
4'raAAAFlitt
cl, IL	 6-
tv aft
d&;SIG W&SE40'r 6
CC c FAULT Ca2Q El A Tio.3 ^. o t iC
A N( -A
MEwMOnYA -MEMORY IOP ^-H
FAa^T
	 _
A
FAULT CPE II- A FIW►TfNOKATwW
U$cuoE2 /s.CATrjp T^ MEM A
c^'EY-A
MEM A
i
E AV-1 FAULT •
AN ^P •
mfmoav P
MEFAORY Tof -
FAULT	 _
FAVLT
c PE 1 -^
\fw.)^tATl..i DE tt^4E 2 I ^ I#O D MCM Q
CPE y _J
M	 a
-i-AEE%i 4
a
2 OZAW
 iE MCp
06146C1 A LAVb7
CoRRE^AT42
q«Y IMGM i
oE.r^cT ^
C	 I FAULT
JOP FAf4 TS % cwv^T +
CPC / FANtTf To C /►Gc	 _
c 1 E •/	 FAv^TS
Co4QF^ATo+L ;;
Es,cwl^ns.
S^MPt.dk
MFMoR {OGTbcTS
Ass^4Mww.^*S 	 c 161	 Fnu^T '
w
Z
7
_^'sR+'#+xv[ eaeefrur•	 :w.,^- ..	 ^+R	 'a.	 -^_ ^.:.	 ...	 .-	 _
r
_	
^	 _.. s	 e	 _....n..%it.i	 _.. -	 _	 _	 - .., .._...,—
FS1, •re 3-Co
CCE	 CLOC14 DOV21 uT1oN t^r2Ru0T ^.oC-^^^ ExTE/twAf- 1N^	 C
c C—
s, v m fr : 2
kiAL
USC
IV NA Ola
SYNC
SIN^cr
^—	
2. S Mtt
CLouC )^_/ -	 ^
SIw`CE Cc-It CoNT. &h F^ERS 1=(^NUUT
S O ml
Mo	 L ETO.	 0uNORMAL
GLOCIC ,	 CLoCIC
C^eCK AcT1Yl►tt LO NT
Axr zs64AUrT PIS
a
S Yac
LuG/C.
nac
EXT. ra;Ea	 T To c 17
of a
J
$ TZ EAM ._
__—^ KEXT• IN7. -	 : VoT62/
-
6  SKIT JWat	 To CaEII'/
ACKIJcwtEdGC
	
- •y(Fitaw t ('Efl $ W I T C E^ '
n.
P—L 1 mo	 m "^,i I 'm A ' 100!	 RON
I
i
TABLE 3-1
i
CCE COMPONENT COUNT
Total
p
Function	 Gates Flip/Flooms Equiv.
	to
9,
f
t	 i
1 - CPE Status Controller 131 28 299
i
` 2. IOP Status Controller 51 8 99
3. Memory Status Controller 159 36 375
4. Program Initiator/Reconfiguration Control 119• 13 197
50 Fault Correlation, 134 0 134
6. Clock Control/Distribution 14 4 38
7. Ext. Interrupt Logic 20 2 32
628 91 1,17+
1
3
1
M
_ _ ,;:_16
Rij
TABLE 3-2
A.	 IlVDNIDUQI,	 CQNTROLLER STATES '
i
f
SCT	 2. 3.
SPARE 0	 0 0 0
IlVI'I'=ZE (Mem only) 0	 0 1 1
NORMAL 0	 0 1 0
ABNORMAL A 0	 1 0 1
ABNORMAL B 0 1 0 0
FAIL PEND 1	 0 0 1
FAILED 1	 0 0 0
i
B.	 PROGRAM INITIATOR	 CONFIGURATION CONTROL STATES
STATE QRCTI.D, C, B . A, 9TIM©UT i
NORMAL (RECON A) (0	 0) 0 0 l
RECM C (0	 0) X 1 0	 7
s
PANICHALT (RECOND) (0	 0) 1 1 0
RECON E 0	 0 1 0 0
REC'M F 0	 1 (1 0) 0
RECON F' 1	 0 (0 0) X
RECON G 1	 1 (0 0) 0
NOTE;
	
In Figure 2a
RECON -B	 =	 RBRCVA, B, C, D all =_1 r
RECON D' =	 RECON`E prior to all RBPACi = l
1
I
jIf
ti
TABLE 3-2 - Continued
C. MODULE STATUS CONTROLLER LOGIC
1.	 A register may be clocked under up to 3 conditions . :
l	 i a.	 ENE_	 Load new assignment if module is highest priority spare
b.	 XLDRPL	 Load assignment from highest priority register if module
is highest priority spare and no new assignments are
pending.
c.	 XPURGE	 Purge current assignment if a spare is available and
a' a XLDRPL is true
All loads and purges are enabled by REr-ONE from PIRC	 id
k" Descending priorites for replacement are:. 	 1, 2, 3, 4, or A, B, C. D
{ D. FAULT CORRELATION LOGIC
TMFLTX 1, 2, 3,
IOP	 0 1 X X	 (if multiple IOPs were used this could be fully decoded)
F CPE #1
	
1 0 0 0 }
CPE #2
	
1 0 0 1	 r
CPE #3	 l 0 1 0
CPE #4	 1 0 1 T
NOTES
1. XDU F_	 signals signify 2 or 3 memories isolated a fault to one processor
2. XSI_F	 signals signify an essential simplex memory detected a fault that
may be in the memory or may be in the processor.
3. Fault is,placed on memory unless either any XDU F or XSI_F pointing to that
memory occurs.[XMFL7_,1	Any XDU_F or XSI_F pointing to a specific
	
x
processor or a processor fault from that processor indicates a processor
{
fault XCFLU.
i
i
t$
000 4 MR Snare/I0 used 1 - I/O (HI)
001 TMR/bUI for TMR 4i
Oil TMR/DUl, used for 4
010 TMR/bU2 duplex 5
100 SIlAPLEX 1 2
101 SIMPLEX 2 3
110 _ SMeLEX 3 &
ill SMPLEX 4 7	 (LO )
NOTES	 only StPeam with.00X priority initializes memories in duplex.or TNT
CPEs interpret 010 and 011 codes as Duplex 1 001 as TM
B.	 Memory Output Mode Assignment Codes
,,	 1
r OTMD_2, 1 STATUS
00 _	 SMLEX
Ol
10 -'	 LO
1
t 11 _	 MIDDLE
;;
z
f
a
w
--
.3	 (^
4^j
	 CCE INTERFACE
CCE - MEMORY
1. Page Assignment (2/memory) CCE to Memory -TPAGE
2. Output Bus Assignment (2/memory) CCE to Memory -TOTMD --
3. Clear Memory Interrupt (1/memory) CCE to Memory TCLRMM-
4. Clock,Sync (2/memory) CCE to Memory TCLK, TSYNC
5. Power Protect Inhibit (1) CCE to Memory TPWRHLT
6. Memory Fault Interrupt (4/memory) Memories to CCE -TMFLT__
f"1 0V - f-113L,
1. CPE Stream Assignment (12) CCE to CPE -TSASN
2. Power Control (VCPE) CCE to CPE -TPWRON
3. Clock )Sync (2/CPE) CCE to CPE TCLK, TSYNC
4. Stop CPE Interrupt (1/CPE) CCE to CPE TSTOP
5. Start CPE Interrupt (1/CPE). CCE to CPE TSTART
6. CPE Available/ Rollback Pace-(l/CPE) CPEs to CCE TXBPAC
7. Initialize Memory Interrupt (1/CPE) CCE to CPE TINITM
8. Initialize Memory Control(2) CCE to CPE TPGCTL
9. CPE Fault (1/CPE) CPEs to CCE -TCPFLT-
10. Panic Halt Interrupt (1) CCE to CPE TPANICH
11. External Interrupt (1/CPE) CCE to CPE -TEXTIN
12. External Interrupt Acknowledge (1/CPE) CPEs to CCE TEXIAK
CCE - IOP
1. IOP Stream Assignment (4) CCE to IOPs -TSASN
2 Clock Sync (2/IOP) CCE to IOP TCLK, TSYNC
3. Panic Halt Interrupt (1) CCE to IOPs TPANICH
4. IOP Available (1/IOP) IOPs to CCE TRBPAC5
5. IOP Fault (1/IOP) IOPs to CCE -TIOFLT
Zo
C	 .
l	 CCE-MAINTENANCE PANEL/ ELECTRONICS
1. Fault Entry Switches (6) Panel to CCE SFLTIN
2. Scanout Source Select (2) Panel to CCE SSOC
3. Scanout Buss (66) CCE to Electronics TSBUS_
4. Scanout Enable (1) Electronics to CCE TSOMS
5. Master Clear (1) Electronics to CCE -TCLR
6. Panel Control (12)* Electronics to-CCE -
7. Clock, Sync (2) CCE to Electronics TCLK, TSYNC
* Not included in motherboard cabling.
t;
rr
CCE INTERFACE
CCE - MEMORY
1. Page Assignment (2/memory)- The CCE sends each memory a two (2)-bit code
specifying the page assignment for that memory.
2. Output . Buss Assignment (2/memory) - The CCE sendseach memory a two (2)-bit
4
code specifying which memory -buss to output data on in the TMR
and duplex modes.
3. Clear Memory Interrupt (1/memory) - The CCE sends each memory an interrupt
E line which causes the memory to output all '"Q's" on the memory bus
i	 during the execution of a software routine that cycles through and clears all
t locations. This is required when initializing essential memories.
4. C1ock,Sync (2/memory) - The CCE sends each memory the system clock at the
f	 highest frequency required in the system and a sync signal at 1/2 this frequency..
5. Power Protect Inhibit (1) The CCE sends each memory a Power Protect
Inhibit Memory line which specifies the power is going out of.
 tolerance or that
system reconfiguration is about to occur and the memories should be shut down.
6. Memory Fault Interrupt (4/memory) - Each memory sends the CCE a-4-bit
encoded fault line specifying what type of fault has occurred.
I^
^r
3 2
0 -	 no fault
:u	 4 - IOP I failure
5 - IOP 2 failure
6 - IOP 3 failure
7 -	 IOP 4 failure*
8 - CPE 1 failure
9 - CPE 2 failure
10 - CPE *3 failure
11 - CPE 4 failure
15 - memory internal
x
* XT_	 d' h b	 All 	 fi	 ation1 f use m t e rea oar con gur
CCE - CPE
1. CPE Stream Assignment (12) - The CCE sends all CPEs 12 lines specifying each
CPEs stream assignments for voter switch and output bus control and memory
access priority. Each group of 3 bits specifies a CPE in the stream.
2. Clock,Sync (2/CPE) The CCE sends each CPE the system clock at the
highest, frequency used in the system and a sync signal at 1/2 this
k
frequency.
3. Stop CPE Interrupt (1/CPE) - The CCE sends each CPE a line which causes the
a
CPE to complete the instruction ixuprogress and store the old PSW in a
specified location in memory dedicated to this interrupt and then send the CCE a
the "CPE Available" signal and then wait in the Fetch cycle for an interrupt
from the CC E.
4. Start CPE Interrupt (1/CPE) - The CCE sends each CPE an initialize signal
which causes the CPE to fetch the new PSW and start processing. This
insures synchronization of the CPEs during a Duplex or TA PIR mode of
processing.
5. CPE Available/ Rollback Pace (1/CPE) - Each CPE sends the CCE a signal
which specifies that the CPE is halted in the Fetch cycle waiting to be activated
or that the program progress alert instruction is being executed.
u
i ZZ
f!	 b. Initialize Memory Interrupt (1/CPE) - CCE sends each CPE an initialize memory
interrupt. The CPE fetches a new FSW from a designated memory location for
this interrupt and then initializes the specified memory contents to match the
contents of the on-line memory it will be paired with in duplex or TMR.
7. Initialize Memory Control (2) - The CCE sends all CPEs a 2-bit code to designate
which memory to initialize. These lines are used in conjunction with the
Initialize Memory Interrupt.
8. CPE Fault (1/CPE) - Each CPE sends the CCE a signal indicating a fault
condition has been detected.
9. Panic Halt Interrupt (1) - The CCE sends all CPEs a Panic Halt Interrupt which
causes the CPE to terminate the operations in progress and stop.
10. External Interrupt (1/CPE) - The CCE receives the external interrupt and routes
it to appropriate CPEs.
11. External Interrupt Acknowledge (1/CPE) - Each CPE sends an. external interrupt
acknowledge line to the CCE to indicate acceptance of the external interrupt for
processing.
s
CCE IOP
1. IOP Stream Assignment (4) - The CCE sends IOP 4 lines specifying the stream
assignments for voter switch and output bus control.. Each bit specifies an
IOP in the stream.
2. C1ock,Sync (2)	 The CCE sends IOP the system clock at the highest frequency
used in the system and a sync signal at 1/2 this frequency.
3. Panic Halt Interrupt (1) - The CC E sends each IOP a Panic Halt Interrupt which
causes the IOP to terminate the operations initiated and stop.
4. IOP Available (1/IOP) - Each IOPs sends the CCE a signal which specifies
the IOPhas completed all; outstanding operations and is quiescent.
5. IOP Fault G /IOP) - Each IOP sends the CCE a line which specified that a fault
condition has occurred in the IOP.
3-Z3
CCE-MAINTENANCE PANEL/ELECTRONICS
1. Fault Entry Switches (6) - The fault entry switches allow the insertion
of switchable faults into any 6 desired points in any modules for fault
tolerance studies.
2: Scanout Source Select (2) - The scanout source select switches allow
j
i
selection of 2 different CCE scanout sources independently for each of
the two 33 bit scanouts on the maintenance panel.
3. Scanout Buss (66) -	 The tri-state scanout bus multiplexes inputs from
scanout sources in each module into the maintenance panel scanouts.
4. Scanout Enable (1) - The maintenance electronics decodes the scanout
module select switch output to provide an enable to the scanout multi-
plexers in the CCE when selected.
5. Master Clear (1) - A master clear is provided to all modules when the
h master clear pushbutton on the maintenance panel is activated.
6. Panel Control (12) - Panel control lines to the CCE include Panel Data
(5), Panel Function (2) and Load Initiate to allow loading new configuration
assignments to the CCE from the panel; a STOP/run line forcing ARMS to
stop for reconfiguration, single clock activate and initiate lines; and an
external interrupt line.
i
7. Clock, Sync (2) - The CCE sends the maintenance electronics the system
l clock at the highest frequency used in the system and a sync signal at
1/2 this frequency.
E
^_,
3_Z y
The CPE provides general purpose computational capabilities for the ARMS EB. It's
architecture is based on the MSFC's 32=bit in-house SUMC-I breadboard. Its instruc-
tion set (with the exception of 2 added instructions related to fault tolerance) is a sub-
set of that for SUMC and consequently a subset of that for the IBM System 360.
The CPE is a high performance processor with a 400 nsec microinstruction cycle, two
level microprogramming, multi-byte word lengths, fixed and floating point arithmetic,
16 fixed point plus 4 floating point multi-usage registers, a multi-level interrupt
structure, and a high speed ALU. Two's complement number representation is used
for fixed point data and sign plus absolute number representation for floating point.
Addressing capabilities include use of both base and index registers. Sixteen bit
Register to Register (RR), thirty-two bit Register and indexed storage (RI), Register
and storage (RS), and storage and immediate operand (SI), and forty.-eight bit storage
to storage (SS) instruction formats operating on half word (16 bit), full word (32 bit)
and double word (64 bit) operands are available providing compatibility with IBM Sys-
tem 360. The CPE's Program Status Word (PSW) is also compatible with that of the
System 360
The CPE instruction set is summarized in Table 4-1 and is discussed in detail in
Ref. 1. This reference also provides the system 360 specification to which the CPE
is expected to conform. The instructions and data formats are shown in Figure 4-1.
It consists of the full system '360 standard instruction set (86 instructions) a represent-
ative subset of IBM's floating point instruction set (8 instructions) and two added ARMS
instructions for use in establishing fault tolerance rollback points. Provisions have
been made for incorporating the remainder of IBM's floating point instructions simply
by adding more words to the CPE microprogram.
To enhance its fault tolerance the CPE module incorporates parity generating logic
at the Processor bus interface at the output of the ALU, and at the outputs of the
Memory Address Register and Multiply Quotient Register multiplexers. Parity checks
are made at the outputs of the Memory Data Register, Indirect Address Format Control
PROM (IAROM), -ROM Address Register, Microprogram PROM (NIROM), and Multi
Usage Registers (MUR), overall these parity checks detect odd numbers of bit errors
in over 75% of the CPE logic, as summarized in the CPE Component Count Table 4-2,
} 4-1
i_^,^
but add less than 6% to the overall CPE (rate count. The areas of CPE logic effected
are shown cross-hatched in Figure 4-2. A voter/switch allows selection, comparison,
Y	 or voting on Memory Bus Data on any combination of 1 to 3 memory buses in simplex,
duplex, and TMR modes respectively. Internally detected faults force the CPE output
to its processor bus to zero until the program is restarted by the CCE allowing a good
CPE to over-ride a bad CPE in duplex mode. The fault tolerance design discussed in
our architecture study Final Report (Ref 2) has been followed very closely both in the
CPE implementation and in the overall system logic design. The only departure from
this design has been the decision not to provide redundant ALUs in the ARMS EB in the
interest of reduced cost since adding this redundancy to the breadboard would prove
little that cannot be shown on paper.
The CPE provides address generation capabilities consistent with IBM system 360.
The method of address generation during the fetch microprogram depends upon the
instruction format involved. The effective address capabilities consist of base and
indexing of a displacement field in the instruction format yielding a byte address inter-
nal to the CPE. Due to ARMS EB memory limitations the maximum effective byte
address must not exceed 19 bits. The effective address calculation uses the entire
32 bit registers for base and/or indexing and it is the responsibility of the programmer
not to exceed the maximum effective address value. Any half word or byte address
calculated is presented to the ARMS memory module as a full word address by dropping
the 2 lsbs. The CPE extracts the appropriate portion of the word for its use.
A priority interrupt structure is provided to start, stop, or modify its software pro-
gram execution. Interrupts from the CCE module (stop, start, and initialize memory)
have highest priority followed by the IOP interrupts. One external interrupt is provided,
routed through the CCE. This interrupt has third priority. Supervisor call and other
program interrupts have lowest priority. No machine check interrupts are provided
since the CCE controls fault recovery in ARMS. Each of the interrupts listed have
j	 associated old and new PSW locations at fixed locations in main memory as shown
in Table 4-3 which also lists word locations for communicating with the IOP module.
The I/O, external, and program interrupts can be masked out by means of bits in the
PSW. In a similar fashion the fixed point overflow, Decimal overflow, exponent under
flow, and significant program interrupts can be masked. The remaining interrupts
can not be masked by the program. Program interrupt code assignments are shown in
`	 Table 4-4. The CPE is only interruptible at a specific point in its fetch cycle.
4-2
1	 I	 i	 I	 1	 f^	 I
Referring to Figure 4-2 the CPE logic will be lumped into the following functional
blocks for discussion: 1) the processor-memory interface logic unique to ARMS, over	 t
and above SUMC's requirements consisting of the voter/switch, Memory Data Register
(MR), Processor Bus Output Multiplexer, and Memory Interface control logic; 2) CPE
sequence control logic consisting of the Instruction Address and Format Control
PROMs (IAROM), the Microprogram Read Only Memory PROMS (MROM), the ROM
address register, shift register (SR) and instruction registers (IR), the Program Status
Word Register (PSV) and some discrete miscellaneous control and system interface
logic in addition to the PROMs; 3) the Arithmetic Logic Unit (ALU) and Exponent ALU
(EALU) including their input multiplexers, and exponent registers; 4) multiplexer
register logic consisting of discrete product-remainder register and multiplexer (PRR),
Memory Address Register and Multiplexer (1VIAR), Multiply-Quotient Register and
Multiplexer (MQR) plus 48 words of RAM and 16 words of PROM making up an address-
able multi usage register file.
MEMORY INTERFACE LOGIC
I
The memory interface operates asynchronously from the remainder of the CPE once a
read or a write operation is initiated by the microprogram. The memory interface 	 i
control logic has a clock rate twice that of the rest of the CPE (5.0 MHz vs 2.5 MHz)
This allows maximum data rates on the buses to and from memory where there are no
PROM delays in the control path. The stave diagrams for the memory interface
.control logic are discussed in the section of this report dealing with the memory. Logic
is included to generate as odd parity bit over 32' bits of output data prior to transmis-
sion of the data over the processor bus and to check odd parity of data loaded into the
32 bit plus parity memory Data Register. This register is loaded in 11 bit increments
as the data is received over the selected memory buses through the voter/switch.
This selection is determined by the stream assignment bits received from the CCE.
The MR also can be loaded from Panel Data or Address switches or from MR data
with half words swapped depending on the state of the MROMs MR' SELECT field.
SEQUENCE CONTROL LOGIC
i
The CPE sequence control logic contains the registers, PROMs, and discrete logic
necessary to control the requesting of instructions and data and the sequence of these
instructions execution. It operates as follows:
_	
4-3
The instruction register and its associated multiplexers allow the execution of 16, 32,
and 48 bit instruction formats. The IR is configured in three 16 bit sections with each
section having an associated load indicator flip-flop IRL 00, 01, 02. When a load
indicator equals 11 1" the data in the associated IR section is valid. The 16 msbs of the
IR (Bits 00, ... , 15) can be loaded with MR data, MR data shifted left by 16 bits,
the 8 lsbs of the ALU shifted left by 16 bits or 1R data shifted left by 0, 16, or 32 bits
depending upon the states of the 3 bits of the MROMs IR control field (IRS 0, 1, 2),
the full word boundary indicator (MAR30), the state of this section of the Ms load indi-
cator (IRL00), and the bits of the instruction up-code indicating whether or not the
instruction has an RR (16 bit) format. The middle 16 bits of the IR can be loaded from
the MR, the MR right, shifted by 16 bits, or the IR left shifted by 0 or 16 bits depending
upon the states of XIRS 0, 1, 2 and IRL00, The 16 lsbs of the IR can be loaded from
MR right shifted by 16 bits or by unshifted IR data depending upon the state of IRS
0, 1, 2 and IRL00. The overall effects of loading the IR and its load indicators before
and after execution of the IR load microinstruction in the fetch subroutine are shown
in Table 4-5. An overview of IR interconnection is shown in Figure 4-3.
The Program Status Word is implemented according to the specifications given for the
IBM system 360 (Ref 1) except for the Protect Key field which does not apply to the
ARMS EB. It holds all information not contained in storage or registers but required
for proper program execution. By storing the PSW the program can preserve the
	
detailed status of the CPE for subsequent use when the program is interrupted or a 	 j
LPE must be replaced during reconfiguration. The PSW format is shown in Figure 4-4.
System mask bits 0, 1, 7 allow masking I/O channel 0, 1 or external interrupts respec-
tively. Bit 11 allows masking the CCEs Halt interrupt until ongoing interrupt handling
isj completed to avoid confusion during the reconfiguration process.. It is controlled by
the Set Halt Mask instruction unique to ARMS. Bit 12 determines if ASCII or BCD
results are generated during decimal instructions. Bit 14 is the CPE run flip-flop,
Bit 15 determines if the CPE is in the problem state (bit on) or the supervisor state.
Bits 32, 33, the instruction length code, indicates the number of half words in the last
interpreted instruction when a program or supervisor call interruption occurs, Bits
34, 35 store the condition code according to system 360 specs (see Ref 1). Bits 36,
. , 39 (Program Mask) allow masking interrupts due to fixed point overflow, decimal
overflow, exponent underflow, and significance respectively. The instruction address
field is taken from the 24 lsbs of location 25 of the MURs which is the instruction
address register. The interruption codes (bits 16-31) are from MUR constant storage}	 -
4-4i
locations. The remaining bits of the PSW are identically equal to zero in. the ARMS
breadboard.
The shift register is used to control the sequencing of instructions which require an
iteration of events such as shifts, and floating point alignment and normalization. This
logic is shown in Figure 4-5. Shift register outputs related to byte, character, and
bit shifts are decoded. Shift counting in various increments can be done by either the
exponent adder (EALU) or the main ALU depending upon which multiplexer inputs are
selected. The 6 lsbs of the ALU can be selected for general shift counting of up to
63 bits or the 2 lsbs of the .ALU can be selected for fast half word shifts in certain
instructions. The unshifted output of the exponent adder can be selected for control of
the alignment of floating point mantisses by subtracting the exponents of each number
in the EALU. The EALU output left shifted by 2 bits can be used for character mani-
pulation instructions. Finally the output of the normalize logic can be selected to
determine how many blocks of leading zeros remain in a floating point result during
normalization. The SR=O test is enabled when the MISC B field of the MROM is
equal to 3. The SR multipexer is controlled by the 3 bit SR SELECT field of the MROM.
The miscellaneous control and interface logic performs control functions required
over and above those performed directly by the microprogram and interfaces with
other ARMS modules except for the memory. These functions include program wait
and proceed, test and set, and carrysave, preprocessing of branch conditions, detection
of instruction format errors such as R-field and branch exceptions and of arithmetic
errors such as overflow, decoddng of the PROM y Miscellaneous control fields, intro-
duction of panel functions into the CPE and synchronization of CCE and IOP signals
to and from the CPE.
The IAROM is addressed by the instructions op-code and provides an indirect address
pointer to the starting location in MROM corresponding to that instruction along with
format control flags specifying if the instruction will operate on , half , full, or double
word data, if an operand must be read from memory, if the operand is in floating or
fixed point format, if tests must be made to determine if the R1 or R2 fields of an
r
instruction are even (this is necessary when double words are being fetched from the
MURs since double words can start only on even addresses), and finally to determine
if an instruction is priveleged or non-priveleged (i. e. whether or not the CPE must be
r	 in the supervisor state to execute it). To save parts the IAROM uses three 512 word by
4-5
^_j	I 	 ^ ­­'I	
. -	 I I
4 bit PROMS in a 256 word by 24 bit configuration by selecting 2 words out of each
PROM for each op-code. Which half is selected is determined by the IARSEL flip-
flop which is controlled by the ROMAR select . field of the MROM. Once the address
pointer has been accessed from the IAROM it is placed in the ROM Address Register
(ROMAR). This register can also be loaded from the BRANCH ADDRESS field of the
MROM or from the 11 lsbs of the ALU output depending upon the state of the ROMAR
select field (1, 2, 3 respectively) allowing for both non-conditional and conditional pro-
gram branches. When a multiplexer input is not selected (ROMAR SELECT=O) the
register is connected as a binary counter allowing the MROM to step sequentially,
through the microprogram. The format and mnemonic definitions for the IAROM
are shown in Figure 4-6.
The MROM contains the main CPE microprogram in a 1024 word x 96 bit configuration
ash shown in Figures 4-7 and 4-8. The first figure lists control field definitions, the,
second lists the associated mnemonics. The various branch conditions as a function
of the BRANCH CONDITION field of the MROM and the MISCELLANEOUS CONTROL
field functions are listed in our supplementary microprogram documentation. The
sense and wait bits 76 ... 79 are decoded to cause a sense and wait condition to be
dependant on nothing, proceed, memory data transfer complete, exponent adder=0,
or I/O interrupt acknowledge for codes 0, ... , 5 respectively. The remaining con-
trol fields are discussed in connection with the CPE functional units that they control.
ARITHMETIC LOGIC
The main Arithmetic Logic Unit (ALU) in the ARMS EB consists of 745181 MSI ALUs
with external carry-look-ahead logic for maximum speed with a 4 input multiplexer
at the ALU's "A ll input and an 8 input multiplexer at its "B" input. The ALU is shown
in Figure 4-9. This unit performs 32 bit, 2's compliment addition and subtraction
plus logical AND, OR, Exclusive-OR and miscellaneous operations. The ALU function
is ;controlled by the ALU FUNCTION CONTROL field of the MROM. The 6 bits of this
field directly control 745181 mode, forced carry, and function select S3, ... , SO
respectively from left to right except during the divide microprogram where the lsb of
The adder "A" input multiplexer is a 32 bit wide multiplexer providing a choice of
"all 0"; PRRO-31, MARO-31, MURO-317, or ER0-7, PRR8-31 inputs under control of
the 3 bit MROM ALU "A" INPUT field. The latter code is used in floating point opera-
tion, the others are used in a variety of instructions.
The Adder "B" input multiplexer is a 32 bit wide multiplexer providing a choice of
MRO-31, MR16-31, to ALUB16-31 with MR16 to more significant ALU MUX inputs for
half-word operations; MURO-31, ER20-31 to ALUB20-31 with 110" to more significant
ALU MUX inputs for operations involving the Displacement fields of an instruction;
IRO-7 (op-code) to ALUBO-7 and IR8-15 to ALUB24-31 with 11 0" to other ALU MUX
inputs for performing arithmetic or logic operations on bits 8, ... , 15 (i2 or L fields)
of an instruction, PSWO-15 to ALUBO-15 and MUR16-31 to ALUB16-31 for storage of
the first half of the PSW and finally PSW33-39 to ALUBO-7 and MUR8-31 to ALUB8-31
for storage ofthe second half of the PSW. This multiplexer is controlled by the MROM
ALU "B" INPUT field.
The Exponent ALU *(EALU) in the ARMS EB also consists of 74S181 MSI ALUs with a
4 input multiplexer at the ALU's "A ll input and an 8 input multiplexer at its "B" input.
The EALU is shown in Figure 4-10. This unit performs 8 bit 2's compliment addition
and subtraction on the exponent field of floating point number. These exponents are
represented in excess 64 notation. The EALU function is controlled by the EALU
FUNCTION CONTROL field of the MROM. The 6 bits of the field perform the same
functions for the EALU as the corresponding bits in the ALU FUNCTION CONTROL
field do for the ALU.
The EALU "A" input multiplexer is an 8 bit wide multiplexer providing a choice
of "all 0", ERO-7 (for exponent manipulation), or SR0-7 (for shift register incrementa-
tion) under control of the MROM EALU "A" INPUT field. The EALU "B" input multi-
plexer is an 8 bits wide multiplexer providing a choice of zero sign plus MR1-7 to
EALUB1-7, zero sign plus MUR1-7 to EALUB1-7 or ERO-7 all for exponent manipula-
tion or SR0_ 5 to EALUB2-7 with other bits zero for use in conjunction with the shift
register for character manipulation instructions, or the. 8 lsbs of the Branch Address
field of the MROM when the MROM "PRR SR COUNT" field.of the MROM equals "0"
or the output of the SR count decode logic when "PRR SR COUNT"=1 for iterative and
shift operations, or of the output of the normalize logic for floating point normalization.
h
t
_	 4-7
n
I	 I	 l	 1	 I	 I	 II
The output of the EALU is routed directly to the SR multiplexer and is stored in the
8 bit Exponent Register when the MROM's ER Load bit is on. The ER register holds
the result for further operations by the EALU when this bit is off.
MULTIPLEXER — REGISTER LOGIC
The Multiple Usage Registers (MUR) are shown logically in Figure 4-11. Their address
assignments are shown in Figure 4-12. They are organized as 16 fixed point 32 bit.
multi usage registers, 4 floating point 64 bit multi usage register pairs, dedicated
program counter and instruction address register, 16 temporary scratchpad 32 bit
registers, (all from a 33 bit by 48 word RAM), plus 16 constant locations (contained
in PROMS) which are used as masks in certain instructions and as interrupt codes in
the PSW. ,These constants are listed by location in Table 4-6. The MURs are
addressed in blocks of 16 locations by the R1, R2, B1, B2, or X2 fields of the CPE
instructions. These addresses are obtained from the instruction register and can be
used direct or, in the, case of even addresses, can be incremented by one in the MUR.
address multiplexer.
When a floating point instruction is to be executed (as designated by the. *FLTPT bit
of the IAROM being on) the address specified by the instruction field is incremented
by 16. In addition to instruction fields the MUR address can be obtained from the
6 lsbs of the Panel Data switches, or of the MQR, or from the MUR ADDRESS field
of the MROM. The MUR address source is selected by the 3 bit MUR ADDRESS
SELECT field of the MROM. The MUR write mode is enabled by the MUR WRITE bit 	 a
of the MROM. When this bit is off the MURs are in this read mode. When valid data
is to be read out of the MURs the MUR READ bit is turned on enabling a parity check	 i
to be made over the MUR outputs. The data source for MUR WRITE operations is
selected by the MUR DATA SELECT field of the MROM. This data can come from the
following sources: Panel Data switches, PRR, MAR, or MQR, PRR multiplexer, or
PAGE 16,17 specifying which memory bank to initialize when the CPE processes an
initialize memory interrupt from the CCE. The output stage of the MUR bank in a set
of latches which can change ,state except during MUR WRITE operations. This allows
MUR data to be either passed through or modified by the ALU or shift multiplexers
and fed back to the same MUR location or to a new MUR location in a single micro-
instruction. The flexibility as to address and data sources for the MURs significantly
enhances CPE processing, capabilities. By checking parity at the MUR output most
4-8
errors in the MURs or in its various data sources can be detected for a very small
increase in complexity as noted in our architecture studies.
In addition to the MURs, the CPE contains 3 discrete hardware multiplexer-register
assemblies: the PRR, MAR and MQR registers. This logic is shown in Figure 4-13.
The first 2 registers are used respectively for holding memory data and address during
accesses to main memory and are used together or separately for 64 and 32 bit mani-
pulations during arithmetic and logical operations when the PRR DOUBLE bit of the
MROM is on. The MQR' is used to hold the multipler during multiply operations
to develop the quotient during divide operations, and for general temporary storage
outside the MURs during various other operations. MAR data can be shifted into the
MQR and visa versa when the MQR DOUBLE bit of the MROM is on. Together this
3 register structure can handle 96 bit data manipulations. Data in any combination
of the 3 registers can either be changed or left alone depending on the states of the
PRR, MAR, and MQR LOAD bits of the MROM.
The PRR Multiplexer can perform either logical or arithmetic right shifts depending
on the state of the PRR LOGICAL bit of the MROM. When this bit is a zero vacated bits
are filled with the sign bit of the ALU. This multiplexer is 33 bits wide and has 8
inputs allowing shifting the main ALU output either left or right by 0, 1, 4 or 8 bits.
Iti also allows for an all zero output. It is. controlled by the MROM PRR SELECT
field. The output of the PRR Multiplexer goes directly to the PRR register and also to
the MAR and MQR multiplexers.
The 33 bit wide MQR multiplexer also allows selection of zeros,, or MQR data left or
right shifted by one bit or of quotient (ALU carry) bits into bit 31 during certain steps
of the divide algorithm. This multiplexer is controlled by the MQR SELECT field of
the MROM.	 1
The MAR multiplexer is an 8 input 33 bit wide multiplexer controlled by the MAR
SELECT field of the MROM. It allows selection of PRR multiplexer data of zeros, or
of MAR data shifted either right or left by 1, 4, or 8 bits.
Parity bits are generated over the combinations of bits selected into each of the 3 	 :y
registers and are stored whenever corresponding data is updated in a register in
l	
accordance with the design discussed in our architecture study (Ref 2). Parity is
i
	 checked whenever stored data is retrieved from MURs or from main memory.	 1
__	 4-9
ia
COMPONENT COUNT
i
i
	
	
The overall component count for the CPE module (Table 4-2) indicates that in an LSI
version. at least half of its complexity would lie in its read only memories (ROMs). The
overall CPE equivalent gate count of 25, 843 is approximately 3 times that of the CPE
proposed in our previous phase report. The bulk of this increase is in the ROM area
where complexity increased tenfold due to the added requirements of the IBM system
360 instruction set which were not assumed in the earlier study. The remainder of the
increase was due to the added performance provided in the instruction fetching, and
r
multi-usage register areas, the requirements of the system 360 instruction set, and
inefficiencies due to use of existing MSI parts. This latter reason would not be a
factor in an LSI implementation of course. It is not anticipated that an LSI version of
ARMS using this CPE design would have any difficulty in operating successfully over a
5 year mission despite the increase in performance and complexity.
RR OP CODE R,/M'	 R2
0
	
78
	 11 12	 15
RX OP CODE R1/M1 X2 B2 D2
0	 78	 1112	 1516	 1920 31
RS i 01, CODE R1 R3 B2 D2
0	 7 8	 11'12	 15 16	 19 . 20 31
SI OP CODE. I2 Bi D1
0	 78	 15 16	 1920 31
OP CODE Li L2 B1 D1
0	 7 8'	 11 12	 15 16	 19 20 31
SS
l( B2 DZ
32	 35 36 47
OP CODE	 - Instruction Operation Code
R1, R2 , R3	- Operand resister specification
X2 	- Index register specification
M1
	- Mask
Li, L'	 - Operand length specification
IZ	 - Immediate data
Bi t B2 	- Base register specification
Di t D2	 - Displacement'
}
Figure 4- lai' 3NSTRUCTION FORMATS
c
r
	.
:.>:..
Figure 4- lb
DATA FORMATS
FIXED POINT
HALFWORD
INTEGER
.
01
15
FULLWORD
Isl INTEGER
0 1 31
DOUBLEWORD
IS INTEGER
0 1 63
FLOATING- -POINT
t
_
SHORT FLOATING- POIN`1' NUMBER
.
(ONE WORD)
G S CHARACTERISTIC FRACTION
0 . 1	 78 31-
LONG FLOATING -POINT NUMBER DOUBLE-WORD --
Fs CHARACTERISTIC I	 FRACTION
0 1	 78 63
t
N
r
i
a
ri
	
MF.MORY/PROGESsoR Cos
	 PROCESSOR/nEK°RY guy
	
II) 1) 6 1 ) 111)	 MoRY CouTROLt . 	COMTROL (1)	 11
	
Jf	
CAE STREAM — — — — — — -- — — —' — — — — — — — —
eb	 VOTER^Sw rTc"I	 !	 19$SIGIUMEgT	 INTERFACE	 r^NTERFACE ^^
1	 l© td
	 I	 sFQuENCflR >r	 MvtT ►PLl:XER ^'	 I
PANEL	 coNrRo I S	 fbu 5/ 
j 
r
M	 PARIrY U	 II PAR tpj
MEMo1,f/p TARE (33CNEcK
	
	 GEN.
M Ew+aaY IAOT"fxe
— —	 — — — —
	 — — — — — — — — — — —
	 — — 12 --i — — -- — —
AF
-	
+
ZN STRUOTION REG, (483
	 ^p	 MEX7ERAIAL	 I	 ^ucT RE: AINDrc CG	 ^M Empiq ADDAE56 REG	 N,uMPIY/,JUoTIEN
INTERRUPT
	
»	 Cam)•
	
r	 ^^`^^
PAR^^Y	 PARrrY
GEN,	 GEN.
26P Nlssc.
	 j r ;Coi^TRoL	 SHIFT	 / MULTIPLEXER (8,
' Ic	 REG .	 -	 -	 / ),	 MULTIPIEYER (4/ILo tZ	 ,^	 r 3	 3
Mix
(^)	
o o 	 : 	1	 MUL IPLEXE	 /s, ^	 ^ c3^ 	 PARt7Y	 MuLT1PIEI► 1Er't rZEt-1f►Ts4 PARTY
IuDIRfcT ADDRESS	 ^`^' "	 Sh.{t RI'L
	
<	 .. Orr EXPoNe.uT	 GEN,r	 VrJ ► 	 CNfCFoRMAT C.O.7 t, 	 >ap. 'I' W ^ ^ ^ ^ REG. (g^ I	 $#`#_, _o	 Y	 K.
T R M 512 AIZ --
1^yr
	
`PARITY	 EXPONENT	 ARI7NMETIC LOGIC	 ^j UL 
LATCH
^^{{ ^^ A
-
DUREsS (^	 ^	 ARf,7NM6"^IG	 '^J	
.
R G, i , n) n	 rC1jCC1^ 	 (	 Aw	 u&JIT	 UNIT	 MTI -.^USAGE.r,
	
/f rr
	 (AVU^	 Av RE^i	 /' R6GrisTERS:i	 ^E^EcT/
	
(MUR);^
/ /f6)i
	
, / G uro^Js / 33 6.t sM2CRoPRoGRAM ^
	 A a t	 AREKD'ONLY MEMc,l 	 3	 -tl
1014 R9M)1 'f	 MuX	 M U X yj^I EVER i	 MULTIPLEXER (Yl,^ LF N H °c" _°.	 a LiLriniE cE'R' (^/I)
ClNTAOt UNIT	 '	 u v a	 a r	 -	 ^, :F;-7.
	u\	 K H H E €
b r r 1 rV)
	 aia	 (Y	 r'	 ' p	 VI j r_	 J .! - J •. K ra	 o o	 d	 F<z Q	 of	 L. L,	 r` o o	 OL	 A^/• f^<
	
1 
U w N` .w ^o.	 o a	 f	 Iii f°r^+NOo
r
^^.3o f	 ¢ a f ^? qa
^^^	 F...I t ^t tt^rl^ti.
w
F^ .$ rc
CENTRAL PRocFsslNG ELEMENT C F-)
DIAGRAM
y
...
tea-
,	
1	 ^ rII l -. 	1 - {r^
-	
1
F.9
.TNSTR_UCTroN REGISTER
g3:RLoo	 QrA .o i QIRI-o 2
F/F	 FIr	 F/F
INSTRUCTIou R EGJS TER	 TA)STRUCT1ou REGISTER
	 TNSTRUCTIom REGMSTER
=R oo -Is	
.=R
	 (i(.)	 =R 3t- 7	 ire)
M R
,^-^ ^
Mu T iPL-EXGR	 Mu
-
Cr-r PCFx rQ
-7 4ff
N Q N	 5i H
r
i
^^

rF
Q S R O '07 SN/FT REG/SrER SR >,$_
Gvuvi T DECODi< Z) $^ SR>
3) 'SF ^SR>
S R = o
SttIFT__RFGISTFR	 s R^`
f^ 75^19^	 8
E
{f
I	 sH^Fr
_
RFGisrcR
	
MUMPLSXER (I/,)__ _ 1
7 1 1sI	 ($^ 1
t	
_T t r	 t
O N lu
n O
a[	 w4x w `	 ViZ °x x	 x p
F, Nre Y-S
k
SHIFT R t(;IsrtR
I
Pt
C. NKF wou We
I
mcm F (2 R
ImbIRI:c r ADDRESS A o a F A „ V P P P
X rA Rl^ O —A^ R
kD
D
R A1> T E 6 1 A A A
T T
Y
P.
G C I E E
b I	 L	 3	 'F	 54a 4	 g	 foil	 11	 11	 I ,f (S t(6	 17	 i 4	 I q	 ;Zo Al	 Zi i3
`	 13 i T M mEmomic FuNCU-c-N
o X=AP,+m P 2uDIAEcr ADDRESS PARITY E A5 t- ^^]	 o D D
1 - It X=ARfMa_A TivDfREcT	 flI)DRESS	 POINTER T"O Pi R4M
IZ_ XXA CPA R COPJTR OL 	 PARITY L-8.
-t:	 -b-133	 o-OD
13 )C iAFwRD HALFicoRb DATA u7dRD
14 X FuI-wRD FULLwoRD DATA	 wokb
i5 X71^8t,WR7 1^ouet.E - uxRD -bATA W ORD	 5
tb XMEMRED MF.MoAY DATA REAb	 I
17 X H I.T PT FLoATtNG hoiNT TAISTRUcT1003	 I
—
XRI EVEM R 1	 FIE L D 	 EVEN
19 XR2EVEr0 R2	 FIELD	 EVE tJ
20 X PR=. V PRIVILEGE	 =NSTRUC.TION
-ti _ 7t3 SPOCS SPARE 8: 'S
.J
A'
I	 A
MuR nulj
R BRANCH A-DDRFSS j(!oA) srA#j r MUR AUURE55 / R W M u R MU R f3RM CH
E R AUDR9 1;s
-DA -rA Cou08reON
T  CoNST^NT (b) A Ir StLEcj3) SFLEGT}^ (6)
0 ! 2 3 4 S
	
7 $ 9 10 11 Iz 1 .3 Jµ 1 16 17 I fl 19 2O ^^ 22 23 z4 z5 z. 27 28 29 3c 31
E
mem M" twit PkR Mot PRR M11R M
5R E e G R ) o	 PRR I-	 MAR o	 L M9R ALU "A" ALU"B" 	ALU FUNCTMN
SELECT q '
'c
A SELEc.T A SFLEcT "6	 A 5E1-Ec T INPUT	 IuPuT 	CONTR OL(3) E A D	 ) (j) U	 (z) (^)	 ^^► 	 (b)
4
yo	 4 i	 'l i. `f3 " 45 44 47 4? 49 50 V
L _L	 ._ _	 L _.1.. l
4 2- '55 5 4 SS 5'(.  57 S8 61 60 (.1 	 bib 3ji 33 34 35 36 37 3 8 39
F.
LR EALU EAU EXPoNEAi"r SENSE R4mAR M 2R Mr$4, P MT$CELLANEouS
°
^^A^
"g " ALU FuucTioN ^ SELECT S>`L6c SELEcT CouTRO^ AR CourRo^ # 1A
D
NPUT
2)
IN	 T
(3^ CONTROL	 ^)
_ I	 L_L_	 .
WA ^'1' ()
_ _l^.r l_ _.L
(z1
_ 1
tZl
__ 1 ___
(^]
_ L wl
't E
l..wL.
(„I 6S 64 47 b1r 0 7o 71 72 73 7 q 7S 74 71 78 71 7v 81 9 z 93 8'F SS 8L 87 88 $9 90 91 4 2 9 3 14 qs,
R X x
M -	 xSA^Roo-ro XM URA330 _5 U u XMURA )(MUM XBRCND
A R w o- 2 o-z 0
R
-.I.. _ _ I __.__1......_1
A t 2 3 4 5 6 7 8 4 10 11 12 13 11 IS- 16 17 18 14 20 21 22 2 -1124 2S 26 27 Z8 24 30 3a
_
X^RS0
-2
x
M
R
R
x X X x
M	 RR	 H	 RR	 rR	 1.	 F	 sI r 1
37 38 39
X
FXRR^R	 o-z
R
D
40 41 42 43!44
X
AA(XMts_
R
D	 L__
45
 46 47
x	 x
MQ qM XMQRS
R	 R	 a-r
a
D _- _l _-_
48 41 50 Si
_	 x	 x-
XAUDA^' XADDB^S' U
o- 2
	0- 2
 U DM c
^._ I	
-	 11
52 53 54 55 5ro 57 58 59
XA^DF/l1
o-3
60 61 (02. 10337- 33 34 3-5 1 11-
X E E xEgDBS' EX F_ R R 5A A O-t A A XEADFN XvuATr 4 XMR% XIR$ XMrSc p KMI$cA
DD D
o-3 0-3
S
o-^ 0 -2 R o- s
o M E ......l.^.1.4^_.^.!_._^t
F	
f} R TWO 9--r 1-c	 G 1 c uN i T
PgRIrsit
	
Q PRR
X ADD t,	 Geu&JtATE
ARtrtfmCric LoGic UuiT
(A LO
$-7451$1
	 t1	 CARRY SAVE-
-4- 7 1 9 It I,
	ADD-ER "A" TuPUT MULTI PLEXER (M)
	 ADDER "B" rA1 PUT MliLT1 PIEXE R (E/,)
74$153	 (3	 3 z)
N	 ^^	
K	
O N	 `^' p	 Jo
or
t
T
4PRR"	 9	 t N o^ ;. tt o'^ ^^
coN.YO i	 E	 ''	 3 O 3
FRS PRR	 ¢ 	 pro O^ C 0. f
	
3e	 4r
^y
	
N^
	
Q
+;	 I
POW
i
Q E R oo - o -► --=-.^
X^'ouEwT RE61STE R	 (ER)
741 4
XEADboo- 07
EXPONENT A its
{
E'XP,	 AIDIOER "A" rAPUT'	 MU)(	 ('f/1) E%P, ADDER "Q" t&/,^IN?UT MUX
(B) ;
J
r
r
^	 ;'^	 ; N
,t	 7	 t^
?
W
Q (^ Ub
	 W
,Q
N	
U
O
Q
wr	 ^n
t	
r	
s	 o
^^
*
^
ov w z0 O ^
0
N ^i^ YNYt cif-10
.	
FXPoN 01— -ARITtiM ETic 	 UM i T
r	 (	 c.YM U K
RAM
mx4
1	 ?^	 t w TI 	MUR ToGG1,ES C-33)
RAM
se	 ^	 TeX 
MUR ouTp T
RAM
1 bX'l
PAR IT Y
C146 c K
(33)
RX8 ( R^Ut = o(FP) XX X 13
^ ^ R z = o(FP) xxxx
6330
-9 RAM's I _X o o X x X X
1--- - -- — — _
-
J 
PR¢Ms
^_ _^^ R1u ► = o(FP)XXxX
Q	 = o o lcxxx
MgR^_j ^= x x x x x X
k A-DDRESS SELECT MU)( DATA MULTIPLCY. E K Osh)
_ t^} C33)
-4	 1 14 1	 F--l- r-
hJ
ul
T v E 1
Z Q	 0	 ••
zlt-
a F^^.Nrt `/—//r 1%4UL.TIPLE- USAGE	 REGISTER S CMUR)
ADDRESS FUNCTION
0 - 15
16 - 23
MULTI-USAGE REGISTERS (16)
FLOATING POINT REGISTERS
(4 -- 64 BIT REGISTERS)
24 PROGRAM COUNTER
25 INSTRUCTION ADDRESS REGISTER
26 - 31 ! SPARE (6)
32 - 47 TEMPORARY REGISTERS (16)
48 - 63 CONSTANTS (16)
q PJZR q rn AR 4 MqR
. PRODUCT REMAINDER REG_ MEMoRY ADDRESS REG, MULr+PLY/quot mr REG.
PRR) 7	 i	 'F 33) MARS 33) M R (3^)
' ^PAR rY PqR IT`( ATO GENERh O
MQR- MULTIPLEKER
{
411MAR MU LTIPLO(ER	 ?/;I
1741ri 7063 ct
PR R
PRR g/^ ,— +	 i t_MULTlftEXER.._
?	 I S I 3 3
^/
Q^ aC	 Qf 4[ Qiy Q d^^
QQ'	 Q' N
I
O
Qr C'I	 Ej^ (} Q'
+ od	 oo1	 +
d A A A , A	 A A
x x O x x x x
M
. Fol -ire 4-1 3
PRR -MAR - MQR
	
REG ISTE RS
.
 I	 I	 -	
] . . . . ................. '1
	17
Table 4-1a
a) Standard Instruction Set
NAME bINE110NIC TYPE CODE
Add AR RR 11A
-	
Add A RX 5A
Add Halfword AH RX 4A
Add Logical ALE RR lE
Add Lobical AL RX 5E
AND NR' RR 14
AND N RX 54
AND NI • SI 34
AND NC SS D4
Branch and Link BALE RR 05
-	 Branch ar , Link BAL RX 45
Branch on Condition BCR RE 07
Branch on Condition BC RX 47
Branch on Count BCTR RR 06
Branch on Count BCT R`{ 46
Branch on Index Hihh BXF•I RS 86
Branch on Index Low or Equal BXLE IIS 87
Compare CR RR 19
Compare C RX 59
Compare Halfword CH RX 49
Compare Lobical CLR RR 15
Compare Logical CL RX 55
Compare Logical CLC	 • SS DS
Compare Logical CLI SI 95
I
Convert to Binary CVB RX 4F
Convert to Decimal CVD Ex 4E
Divide DR RR 1D
Divide D ' RX SD
Exclusive OR XR RR 17
Exclusive OR X RX 57
Exclusive OR XI SI 97
Exclusive OR XC SS D7'
Execute EX RY 44
Halt I/O HIO SI 9E
Insert Character IC RX 43
Load LA RR __ _ 18
Load L	 ! RX 58
Load Address LA RX 41
Load and Test LTR RR 12
Load Complement LCIR RR 13 :_
Load Halfword LH! RX 48
Load Multiple L:tI RS 95
Load Negative LNR RR 11
Load Positive LPR_ RR 10'
Load_PSW LPSW SI 82'
1•foveIIVI SI 92
Move INIVC SS 'M
Move Numerics 11V\ SS D1
'love with Offset 11%10 SS F1
Move Zones Vin, SS 1	 3'	 w
fNAME .MNEMONIC TYPE CODE
Multiply 1IR RR 1C
Multiply 1i RX 5C
Multiply HalfNvord MH RAY 4C
OR OR RR 16
I	
OR O RX 56
OR OI SI 964	
OR OC SS D6
E	 Pack PACK SS F2
Set Program Mask SPIM RR 04
k	 Set System Mask SS1I SI SO
Shift. Left Double SLDA RS SF
Shift Left Single SLA RS 8B'
Shift Left Double Logical SLDL RS PAD
Shift Left Single Logical SLL RS 59
Shift Right Double SRDA RS SE'
Shift Right Single SILA, " RS SA
Shift RI-ht Double Logical SRDL RS SC
Shift Right Single Logical SRL RS 58
Start 1/0 SIO SI 9C
Store ST . RX 50
Store Character STC RX 42
Store Halfword STH RY 4O
Store Multiple STM RS 90
Subtract SR RR 1B
Subtract S RX 5B
Subtract Halfword Sli RX 4B
Subtract Logical SLR RR iF'
Subtract Logical SL' FIX 5F
Supervisor Call SVC RR OA
Test and Set TS SI 93
Test Channel TCH SI 9F
Test I/O• TIO SI 9D
Test tinder Mask TM Si_ 91
Translate TP, SS DC
Translate and Test TRT SS DD
Unpack UNPK SS FT
b)	 I'toatina Point Instructions
NAME IMINENIONIC' ` TYPL•' CODE
Add Normalized (Short) AE RX 7A
Compare (Short) CE RX 79
Divide (Short) Dt R.Y 7D
Load (Short) LE' RX 78
Multiply (Short) IME RX 7C
Store (Long) STD RX 60
i	 Store (Short) STE RX 70,
Subtract Normalized (Short) SE RX 7B 
Table 4 =1c
C) Added ARMS Instructions
_ -
	
Sv 
.1 R7. (RR)
Bits 8-11 of the general register specified by the R field replace bits 8-11 of the,
current PSW.
Bits 0-7 and 12-31 of the register specified by the R3 field are ignored. The
contents of the register specified by the R1 field remain unchanged.
The instruction permits the setting of the halt mask in either the problem or
supervisor state.
Condition Code: The code remains unchanged.
Program. Interruptions: None.
Programming Note
-Bit 11 of the general register may have been loaded from the PSW by BRANCH
AND LINK. Bit 11 of the PSW is the halt mast:.
Program Progress Alert
PPA	 ERR)
The instruction allows coordination of the CPE and CCE by informing the CCE of a
convenient roll-back point and allowing the CCE to halt the CPE.
Bits 8-11 of the current PSW are set to onus, enabling the halt CPE interrupt.
Bit positions 0-7 and 12-e3 of the current PSW remain unchanged. Subsequently,
the current PSW is stored in location 136. The available line for the CPE is used
to inform the CCE of this -instruction. If the CPE is not halted, normal instruction;
sequencing proceeds with the updated instruction address. The instruction is valid
in both problem and supervisor state.
Condition Code; The condition code remains unchanged.
Program Interruptions: None.
i
I,
,j	 k -V7
TABLE 4-2. CPE COMPONENT COUNT
Function Gates
Flip-
Flop
RAM
bits
ROM `
bits
Fail Rate*
Equiv
Gates
Simplex
Coverage
1, Voter/Switch 289 0 - - 289 1.0
2. Memory Data Reg (MR) 650 33 848 1.0
3. Proc Bus Output MUX 164 0 164 1.0
4. Product-Remainder Reg 1,319 33 1,517 1.0
and MUX (PRR)
5. Memory Addr Reg and 893 33 1,-091 1.0
MUX (MAR)
6	 Multiply-Quotient Reg 488 33 686 1.0
(MQR)
7.	 Multiple Usage 865 38 1,584 556 2,747 0.95
Registers (MUR)
8. IAROM 286 16 6,144 1,150 0.9 -
9. MROM 799 0 98,304 13,087 0.9;
10	 Instruction Register t51 51 857 0
(IR)
11	 Arithmetic Logic 1, 456 0 1,456 0
Unit (ALU)
12. Exponent ALU (EALU) 438 0 438 0
13. Memory Interface 42 14 126 0
Control
14.	 Shift Register 191 8 239 0
15. Program Status Word 231 24 375 0
16i	 Misc Control Logi.p and 737 6 773 0
Sys Interface
17.	 Scanout and Panel (1,424) Not
Functions Applicable
9,399 1	 289 25,843 1	 0.7751 1,5841 105, 004
-a
Table 4-3
PERMANENT.' MEMORY ASSIGNMENTS
Address Length Purpose	 1
1
0 0000 0000 _ double word Initial program loading PSW
$ 0000 1000 double word Initial program loading CCW1
16 0001 0000 double word Initial program loading CCW2
24 0001 1000 double word External old PSW
32 0010 __ 0000 double word. Supervisor call old PSW
40 0010'' 1000 double word Program old PSW
48 0011 0000 double word Machine check old PSW
56 0011 1000 double word Input/output old PSW
64 0100 0000 double word Channel status word
72 0100 1000 word Channel address word
76 0100 1100 word Unused	 j
80 0101 0000 word Timer
84 0101 0100 word Unused	 j
88 0101 1000 double word External new PSW
96 0110 0000 double word Supervisor call new PSW .
104 OIlo 1000 double word Program new PSW
112 0111 0000 double word Machine check new PSW
120 0111 1000 double word Input/output new PSW
128 1000 0000 double word Stop CPE old PSW
136 1000 1000 double word Start CPE new PSW
144 1001 0000 double word Initialize Memory new PSW
152 1001 1000 word Channel Instruction word
-C
N
s-
Table 4-4
PROGRAM INTERRUPT CODE ASSICNMEWS,
is
Interruption Code	 __- _	 __.__	 ___ _ _	 -Program Interruption
1 00000001 Operation'
2 00000010 Privileged operation
i	 3 00000011 Execute
4 00000100 Protection
t 5 00000101 Addressing
6 00000110 Specification
7 00000111 Data
8 00001000 Fixed.-point overflow
9 00001001 Fixed-point divide
10 00001010 Unused
11 00001011 Unused
12 00001100 Exponent overflow
13 00001101 Exponent underflow
14 00001110 Significance
15 00001111 Floating-point divide
-C
w
C,
TABLE 4-5. INSTRUCTION REGISTER LOAD CONTROL
t	 t+l
RR
XIRSO XIRS1 XIRS2 IRL00 MAR30 Format IRL00 IRLO1 IRL02 Function
MRO-15 ♦ IR0-15
0 0 1 0 0 1 1 IRL02
MR16-31- IR16-31
MR16-31 - IRO-15
0 0 1 0 1 1 1111,01 IRL02
X	 -' IR16-31
MRO-15	 IR16-310 0 1 1 X 1 1 1
MR16-31— IR32-47
IR16-31 -' IRO-15	 EXIT FROM0 1 , 0 1 IRLOl IRL02 0 RR INSTRUCTIONIR32-47 - IR16-31
IR32-47 — IRO-15 	 EXIT FROM0 1 0 0 IRL02 0 0 RH INSTRUCTIONX -► 	 IR16- 31
IRO-15 -► IRO-15	 USE WITH0 1 1 1RL00 IRL02 0 SS FORMAT
X32-47 -' IR1G-31
XADD24-31 - IR08-15
1 0 0 IRL00 IRL01 IRL02
1 1 1 0 0 0 EXIT FROM ABRANCH OR EXECUTE
0 0 0 IR.L00 IRL01 IRL02 Quiescent State
t
X = Don't Care
A
XIRSO XIRSl XIRS2 Code Name Definition
0 0 0 Quiescent State
0 0 1 XIRFMR LOAD IR from MR
0 1 0 XIRSHFT IR Shift for Instruction Exit
0 1 1 XIRFIR IR 32-47 -+ IR 16-31
1 0 0 XIRFADD LOAD IR from ADDER
1 0 1 UNUSED
0 UNUSED
1 XIROFF EXIT from Branch or Execute
r7
Table 4-6
MUR	 CONSTANTS LOCATIONS
SYMBOL LOCATION VALUE
KO 48 OOFFFFFF
K1 49 FFOOFFFF
K2 50 FFFFOOFF
51 FFFFFF00
K
4
52 OOFFFFFF
53 FFOFFFFF
'	 K6
t
54 FFFFOFFF
Y-("`j
55 FFFFFFOF
K8 56 FOFFFFFF
o
57 FFFOFFFF
KK
"10 58 FFFFFOFF
_ :L, 59 FFFFFFF O
K12
60 OOOOFFFF
-K15x13
61 - 63 SPARESi
^f
4	 ^;
CPE INTERFACE
CPE - MEMORY
1. Processor Buss (11) CPE to Memory -TPMB
2. Memory Buss (11x4)=(44) Memory to CPE -TMPB___
3. Memory Request (1) CPE to Memory -TCPREQ_
4. Memory Request Acknowledge (4) Memory to CPE -TMRESP
5. Data Available (4) Memory to CPE -TDAVAL
CPE - CCE
1. CPE Stream Assignment (12) CCE to CPE -TSASN
2. Power Control (1) CCE to CPE -TPWRON
3. Clock)Sync (2) CCE to CPE -TCLK, TSYNC
4. CPE Fault (1) CPE to CCE -T,CPFLT
5. Start CPE Interrupt (1) CCE to CPE -TSTART
6. Stop CPE Interrupt (1) CCE to CPE -TSTOP
7. Initialize Memory Interrupt (1) CCE to CPE -TINITM
8. Initialize Memory Control (2) CCE to CPE -TPGCTL_
9. CPE Available/Rollback Pace (1) CPE to CCE -TRBPAC .
10.; Panic Halt Interrupt (1) CCE toCPE -TPANICH
	
a
11. External Interrupt (1) CCE to CPE -TEXTIN_	 r
12. External Interrupt Acknowledge (1) CPE to CCE -TEXIAK
CPE - IOP
1. IOP Memory Request Inhibits (1/IOP) IOP to CPE -TIOINH
2. CPE Memory Request Inhibit (1) CPE to IOPs -TCPINH
3. Initiate I/O Instruction (1) CPE to IOP -TIIOI
4. 1/0 Instruction Accepted (1/IOPi IOP to CPE -TIOIAK
5. I/O Interrupt (2/IOP) IOP to CPE -TIOINT_
6. I/O Condition Code (2/IOP) IOP to CPE -TIOPCC_
7. I/O Interrupt Acknowledge (2) CPE to IOP -TINTAK_
CPE =- MAINTENANCE PANEL/ELECTRONICS,
1. Fault Entry Switches (6) Panel to all SFLTIN
20 Scanout Source Select (8) Panel to all SSOC	 e
3 Scanout Buss (66) All to Electronics TSBLTS_
4-34
LA
4. Scanout Enable (1 - tw)	 Electronics to all 	 TSOMS_
5. Master Clear (1 - tw)	 Electronics to all 	 -TCLR
6. Panel Data, Address (54)	 Panel/Electronics to CPE	 SPADR -, SPDAT
7. Panel Function Select (4)	 Panel to CPE, CCE	 SPANF
8. Panel Function Initiate	 Electronics to CPE	 -TPFINT - TPMURQ-	 i
r (2 - tw)
9. Breakpoint, Single Com- 	 Electronics to CPE	 TBPTACT, TSCMACT,
mand Activate, Step	 TCMSTEP
(3 - tw)
10. Breakpoint Reached	 CPE to Electronics	 -T-BKPT-
(1 - tw)
_	 TE: All lines are single-ended unless marked tw (twisted pair).NO
I
CPE - MEMORY
1. Processor Buss (11) - The CPE sends a buss to all memories. 	 The buss is
utilized to send memory address, memory data and controls to the memories.
{	 2. Memory Busses (11/CPE) - Each memory sends the CPE (and IOP) 4. busses each
4 containing 11 lines.	 The busses carry memory data.	 The CPE votes on this data
processor busses.
3. Memory Access Request (1) - The CPE sends a Memory Access Request to all
memories, the memory which is selected by the page being transmitted on the 	 j
t
Output Buss will respoLd.
4. Memory Request Acknowledge (1/MB) - Each memory responds to the CPE via 	 ^
i this line acknowledging that the memory request has been accepted and that the
j requesting CPE should transfer the remaining address and data (if a write) across
{ the busses.
5.} Data Available (1/MB) - Each memory sends the CPE the Data Available signal
when memory data is available on the Buss.
CPE - CCE
a,
1. CPE Stream Assignment (12) - The CCE sends the CPE a group of 12 lines which
specifies the stream assignment of the CPEs at the present time. 	 The stream	 M
1 assignment specifies which CPEs are processing in the simplex, duplex, or TMR
i
mode. The CPE uses the lines to activate the appropriate ports into the voter
switch on its memory to processor busses.
:'4
y :,
4-35
2. Power Lines (1) — The CCE sends the CPE a Power On Signal to signify if a CPE
is on or off line.
3. Clock, Sync (2) — The CCE sends the CPE the system clock at the highest
frequency required in the system, plus a sync signal at 1/2 this- frequency.
4. CPE Fault (1) — The CPE sends the CCE a signal indicating a fault condition has
been detected.
5. Start CPE Interrupt (1) ^ The CCE sends the CPE an initialize signal which causes
the CPE to fetch a new PSW and start processing. This insures synchronization
of the CPEs during a Duplex or TMR mode of processing.
6. Stop CPE Interrupt (1) — The CCE sends the CPE a line which causes the CPE to
complete the instruction in progress and store the old PSW in a specified memory
location dedicated to this interrupt. Then the CPE sends the CCE the "CPE
Available" signal and then waits in the "fetch" cycle for an interrupt from the CCE.
7. Initialize Memory Interrupt (1) — The CCE sends the CPE a signal which requests
initialization of a new memory. The CPE fetches a new PSW from the designated
memory location for this interrupt and then proceeds processing to initialize
memory via this program.
8. Initialize Memory Control (2) - The CCE sends the CPE a 2-bit code to designate
which memory to initialize. These lines are used in conjunction with the Initialize
Memory Interrupt.
9. CPE Available (1) — The CPE sends the CCE a line signalling that the CPE is
quiescent and is waiting in the initial state of the "Fetch" cycle, or that the Pro-
gram Progress Alert instruction being executed is signalling a system roll-back
point.
10. Panic Halt Interrupt (1) — The CCE sends all CPEs a Panic Halt Interrupt which
causes the CPE to terminate the operations in progress and stop.
11. External Interrupt (1) — The CCE routes the external interrupt to the appropriate
CPE for execution.
12. External Interrupt Acknowledge (1) - The CPE sends an external interrupt
acknowledge line to the CCE to indicate- acceptance of the external interrupt for
processing.
CPE — IOP
1. IOP Memory Request Inhibit (1/IOP) — Each IOP sends the CPE a signal which
}	 represents that a memory cycle by the IOP is being requested and the CPE should
inhibit any memory request until this line is low. ; The fact that an IOP shares the
4-36
input and output busses with a CPE necessitates this communication line between
the sharing IOP and CPE. The CPE must look at all IOP request inhibit lines
when in a duplex or TMR mode of operation.
2. CPE Memory Request Inhibit (1) — The CPE sends a signal to each IOP in the sys-
tem indicating that this CPE has requested a memory cycle and the memory has
granted the request. In other words, the CPE is using the input buss and possibly
the output buss while the signal is true. The IOP has a higher memory request
priority than the CPE, so this signal must not be activated (high) until the memory
has granted the request.
3. Initiate I/O Instruction (1) — The CPE sends the IOP a signal telling the addressed
IOP that an I/O instruction is to be processed. The CPE must store the channel
number, device number and subchannel number into a designated memory location,
from which the signalled IOP can interrogate to determine what action is to be
taken. It is the responsibility of the program to know when the I/O instruction can
store in the designated memory location.
4. I/O Instruction Accepted (1/IOP) — Each IOP sends the CPE a signal which denotes
the previously sent I/O instruction is completed or has progressed to the point to
assure initialization of the requested function. The CPE must wait for the I/O
instruction complete signal before completing the I/O instruction and setting the
condition codes.
5. I/O Interrupt (2/IOP) — The IOP sends CPE an interrupt line for each channel
which designates one of many conditions that may exist in the IOP which must be
signalled the system. The IOP stores the interrupt information in a memory
location (64) to be interrogated by the interrupt program. The CPE processes
the interrupt if the I/O interrupt mask is off.
6. I/O Condition Code (2/IOP) — Each IOP sends the CPE two lines which represent
the IOP condition, following the execution of an I/O instruction, which is to be
loaded into the CPE condition code indicators. These lines are interrogated by
the CPE while the I/O instruction accepted line is high.
7. I/O Interrupt Acknowledge (2)-- The CPE acknowledges the 2 IOP channel's
interrupts via these lines.
CPE -- MAINTENANCE PANEL/ELECTRONICS
1. Fault Entry Switches (6) - The fault entry switches allow the insertion of
switchable faults into any-6 desired points in any modules for fault tolerance
studies.
- 4-37
2. Scanout Source Select (8) — The scanout source select switches allow selection
of up to 16 different scanout sources independently for each of the two 33 bit
scanouts on the maintenance panel.
3 Scanout Buss (66) — The tri-state scanout buss multiplexes inputs from scanout
sources in each module into the maintenance panel scanouts.
4. Scanout Enable (1) — The maintenance electronics decodes the scanout module
select switch output to provide an enable to the scanout multiplexers in the
module selected.
5. Master Clear (1) — A master clear is provided to all modules when the master
clear pushbutton on the maintenance panel is activated.
6. Panel Data, Address (54) — The Panel Data and Address Lines allow loading key
CPE registers. from the maintenance panel under microprogram control.
7. Panel Function Select (4) — The output of the panel function select switch is decoded
within each CPE to allow activation. of one of up to 16 panel functions for loading
memory and key CPE registers.
8. Panel Function Initiate (2) — Each CPE receives separate panel function initiate
lines allowing individual execution of activated panel functions for diagnosis and/or
fault insertion. Panel switching allows initiation of activated functions in•from
1 to 4 CPES simultaneously. One line provides a synchronized output, the other
a direct output from the pushbuttons antibounce circuit for MUR operations.
9. Breakpoint, Single Command Activate, Step (3) — Panel switches allow activation
of breakpoint and single command modes of operation within the- ARMS CPE. The
Breakpoint/Single Command Step switch allows stepping the program beyond the
breakpoint in the breakpoint mode or stepping it ahead one instruction in the
single command mode.
10. Breakpoint Reached (L) — When a CPE stops at a breakpoint, this line signals
this condition to the maintenance panel indicator.
5. MEMORY
The memory interface contains all necessary logic for interfacing
between the commercial core memory and the AIMS data bus structure
and CCE module. This logic consists of:	 1
a) memory timing and control logic
b) bus access . request decoder and . memory response_ generator
c) input voter switch
d) address register
e) data register
f) memory input Hamming - parity code logic
g) memory output Hamming - parity code logic
h) fault control logic
i) output multiplexer
Memory 'Timin g and Control Logic. The memory timing and control
logic controls the sequence of events in other portions of memory inter-
face logic and provides necessary initiation and control signals to the
core memory. This logic sequences read and write modes in response to
access requests from CPE or IOP modules accepted by the bus access
request decoder,and to the state of the read/write signals transmitted
on the processor buses simultaneously with the access requests
by the CPE or IOP modules.
The states taken on by the memory timing and control logic are shown in
Figure 5-2, while Figure 5-3 shows corresponding memory access control
logic states within the CPE. Figure 5-4 shows write cycle timing at the
interface while Figure 5-5 shows read cycle timing. Figure 5-6 illustrates
the memory interface timing and control logic path and Figure 5-7 does the
Bus Access Request Decoder and Memory Response Generator. The
bus access request decoder and memory response generator, as shown
t	 in Figure 5*8,consists of a page address comparitor, request priority
ordering logic and voter/switch and output multiplexer control logic and
holding registers. The page address comparitor determines if any bus
access requests are directed to this memory by comparing the page
addresses transmitted on the processor buses simultaneously
with the access requests by the CPE or IOP modules with the page address
assignment currently being received from the CCE module. When the
addresses agree, and the memory is not busy as determined from the
state of the memory timing and control logic, the highest priority request
is granted and the memory timing and control logic initiates a new memory
cycle. The request priority ordering logic always gives a new access
request from an IOP priority over a new access request from a CPE.
However if a CPE access request is already being sent: the IOP will not
be granted access until the CPE's access has been completed. Logic to
order priority between competing CPE access ,requests in a multiple.stream
version of ARMS is also provided. The voter/switch control logic causes
the voter/switch, by means of a holding register, to input on the processor
buses corresponding to the CPE's or IOP's whose access requests have	 j
been granted. The holding register's contents are updated each time a 	 1
new access request is granted. The output multiplexer control logic causes
the output multiplexer, by means of a holding register, to output on a
single memory bus according to the following algorithm:
a) if only one access request is granted (simplex mode) the
memory outputs on the memory bus paired with the
processor bus whose access was granted,
b) if two or three access requests were granted (duplex or
TMR modes) the memory outputs on the memory bus paired
with either the lowest, middle, or highest numbered
processor bus depending upon the memory output bus
assignment currently; being received from the CCE module.
5.2
b) continued
This requires multiple memories assigned the same
	 1
page.address but different output bus assignments by the
CCE to respond to duplex or TMR processor requests on
different buses.
4
	
	
Input Voter/Switch. The input voter/switch is capable of operating
in three modes:
a) the voter/switch passes data from the selected bus
in the simplex mode. No fault detection is possible
from the voter/switch in this mode.
b) the voter/switch compares data bit-by-bit logically ORing
selected data in the duplex mode. A fault signal is issued
for both selected buses upon disagreement in any of the
bit positions unless all of the bits from one of the selected
inputs are identically "0
c) the voter/switch votes on selected data bit-by-bit outputting
the majority decision in the TMR mode. A fault signal
is issued for the disagreeing bus(es) upon disagreement
in any of the bit positions.
The 'voter/ switch is 11. bits wide and is capable of selecting between
data from 4 processor ,
 buses. Figure .0-0
-
 illustrates one
bit of the memory's voter switch. The voter switch used in the CPE and IOP which
is not capable of fault detection- is also shown for comparison.	
9
i
Address Register. The address register contains 13 bits (12 data,
1 parity) and is capable of addressing 4096 words in the core memory 	
8
module.
S-3y
l	 1	 l
Data Register. The data register contains 33 bits (32 data, 1 parity)
and buffers data transferred through the voter/switch during write cycles.
Memory Input Hamming - Parity Code Logic. The memory input Hamming
parity code logicAs shown in Figure 5= 10, performs the following functions:
a) it performs a 13 bit parity check on the address
register output detecting odd numbers of errors.
b) It performs a 33 bit parity check on the data register
output detecting odd numbers of errors.
c) it generates a 6 bit Hamming code over the 32 data bits
at the output of the data register.
d) it generates an overall parity bit over the 32 data bits
at the ouOut of the. data register plus the 6 Hamming
code bits generated in item c). The parity bit is a "1"
when all other bits are "0". The 6 Hamming code bits
plus the overall parity bit are stored with the 32 data bits .
to provide single error detection and multiple error
correction within the memory module.
Memory Output Hamming Parity Code Logic. The memory output
Hamming parity code logic,also shown in Figure 5-10, performs the following
functions
a) it performs a 38 bit Hamming check on the data output
from the core memory. This logic outputs a non-zero
svndrome when one or two Hammin g code errors are
c) it provides Hamming single bit error correction by
inverting one of the 32 data bits outputted from the
core memory according to the syndrome output of the
Hamming check of item a) if and only if the parity check
of item b) also indicates an error.
d) it indicates a multiple fault if either the Hamming checker
of item a) outputs a non-zero syndrome or the parity
checker of item b) indicates a fault but not when both
indicate faults. These conditions signify two and three
detectable (but not correctable) bit faults respectively.
An all "0" output indication from the core memory also
indicates a multiple fault except during memory initiali-
zation after a master clear interrupt.
e) it generates a parity bit over the 32 bit output of the
Hamming correction logic of item c).
Fault Control Logic. The fault control logic as shown in Figure-11
performs the following functions;
a) it inhibits a memory write cycle due to fault indications
from the address and data register parity check logic or
from the voter/switch logic if the latter faults are not
maskable through majority voting.
b)
	
	 it forces the output multiplexer output identically to "0"
on a read cycle due to fault indications from the address
and data register parity check logic, from 'the multiple
fault detection circuits of the memory output Hamming-
parity check logic, or from the voter/switch logic if the
c) it provides a fault interrupt to the CCE module due to
fault indications from the address and data parity check
logic, from the multiple fault-detection circuits of the
memory output Hamming-parity check logic, or from the
voter/switch. Except in the case of the Hamming check
fault indication, the IOP(s) or CPE(s) accessing the memory
at the time the error is detected are indicated to the CCE.
Output Multiplexer. The output multiplexer multiplexes the 33 bit output
of the Hamming single bit error correction logic and its associated parity
bit onto the memory bus selected by the output multiplexer holding register
of the memory response generator, eleven bits at a time, unless inhibited
from doing so by the fault control logic.
Data Bus Formats Between Memory, CPE, and IOP. Data transfers
between memory, CPE, and IOP modules occur on 4 processor buses.
and 4 memory buses: Each bus contains 11 data lines. Thus address
transfer requires 2 clock times, and data transfer 3. Address and data
transfer formats are shown in Figure 5-12. Refer to Figure 5-4 and 5-5 for
timing of these transfers.
Component Count
a
Table 5-1 shows the number of gates and flip-flops required by each part
of the memory interface. The final design and complexity level of the
memory interface is extremely close to that assumed for the reliability
analysis contained in Reference 2.
i
	 5-6
rLutKaM oNTin FAcC ywr1l.
I	 Poa1tYC0I4k164tC1A L
	 Wc.o OCn.
CoRQ ME MoIRY
	 I	 O uTpor	 NEMwtY
UNIT	 ^K	 aoscs
^` ^	 ^	 KaMMwb-^. _
^Yy
pa IZ.I 
Moq 6 x 31'
	
	
L^QRr.ttOti
	
..__	
iC^r\ML
A`
+	 t7	 PI^QfT	 IMMMMIN G-/
crfEc^cE2 -PARITY
fwcnuE2	 FhuLT
CYN74oL
C.00r1 t.
A po^T iS RE`s	 DATA RT-Cr137601-
J;
Z!	
i
tf^ LAIIJf^ Af ^^
VC—
F,.Wtr of
SWITC 	
TIMINb Q^	 P1► G6 Aao4	 PR^.itVoTE2
/	 CoNTROt.	 1 Clarf'AAE	 R6SPoG^
	 -M	 trAinM ASr^.W LOv/ t
ftT-1
onrw aoo^a.	 RAM► 	 P41oa►vr PoaE
^Qoc#ts.Q
	
Tom 10 ^^-+^
	 ttG
CLFAIL ft
	
iltwlJT INTSRaaP7	Alal' iuM/••t
F ► S^a.,R-I
	
g Rm5 MEMuRY M. OOVL,,^-7	
^.
e
	ME«.atf 
_	 _.
	
nvw ►cn'!4E	 .^
START	 A1 A2/ 
AI
A
G
A1[401	 NpZ
6	 MiM^RY
d^T
I	 AVAuAq^$
F
OC"'kWA PAIL,
ftj
$.{!r ^-t
	
W c.xE
	 W t/Are
	
/dtr	 DTi
1
	
R) /RPJ 	DATA AVA1	 3/
 HAMAtIA*
!!!/ AOR • pAiA	 /	 A G/EClI
r a^a ^►,^4^
--- AVAILA@f&e FW2 w124'*E
--^ AVAILnntt Fu n- 2e^0
art	 3
MEA0194 tc-CESS CoM TIXC1t- LOO-IC (c.?E)
NWR t MR^2} _ ^tNMN lC^I.1N)
	
^I9M p^Mih^}^LNwN t^oGNN}	 ^^	 2. y^RGTf
111 • A^rGQ T at Amin-,e ! ^Q
	
eAO0► 	 A o^q/.	 /^
	
.L.//
`	 ^wy Whirl	 ^c.7YN wrwN	 A/^wnttl` CP/MM	 ^/L^NA9us..AYO`6
.y.a TO ADp^ 	 iMw f► cp/N
	^^wb7ia^^	 TNiwG' q^eJ
	
E^J.Abat_^R^ 	 y^^F	 1^ ^`..
i	 (Rol+ V X QONMRA) . SyNG
1
E
1
 PZ z
A 2 • REA j	 DATA AVn14_	
z 
	
^^
r
	
010A	 DtoB_	 p oc	 ox	 n Z`	 OTC` .	 a-rcEAIA9lf
	 ^`yA9•E
	
Or/ErwdaE
on rw !N	 b"rA lA-t
	
^^	 /	 A	 OATR ^^'^ o
pZ . I Ew D	 Re ►M OTC. 3v(oic
A REwp
^	 Al . ws tE
	
P#O	 p¢/	 ^^^ 	Q^ 2y^	 waive	 90
	
p	 /E^lnsat •t !	 / ENwR:
	
LOokTAO J-t A	 : 04YA00T 3	 •^Tw' WIT C
i
At
1
t
u	 ^s 2 Y!
V
ARMS 111CA,1012Y 1NZ'6aF AC,E -VMI /G - W21TE CYG4 C C1'E^
0
.^^,
ry ,
n
i
1
CPINNr /OIiNM
J
F IyEM REQ>
f ►BEMRESY • oa wa#7i -^ 	 ^F SAMt *AQ
i
w^IJ NFA4
F
CFO NN
^• PMS OAT/ f -^^	 AI	 A2
&ATA AVAfL. ^.	 ...
n ►0 DAta pT1	 pzZ
	 Dc;
LLULK
MRA
r tf
D?c t
F.b.,,,^ s-s
gRmSMEM0R'( I-/T64FACt TimiAfC- — REao C.YcLE (v?S)
F 44% S-^
/hEMoet( tNTE2F1rcC TIAAIVCG A/JD toN7,e*L L0-G1(,
Vq^IJ ecAaae_
	 _	
Ano2 tct^
Gt/i4^L
MEM AVAIL Fe
ILEq^ ADDR.6.S5
—	 nuo4c
	
SC^,u;tr^ct2
>"T4eAq
VALID wRITERF
ED
	ASSICq/M
MFH "Sp
11cM AVA1l Fit 
	
T^S Jt/^^/I tjt 7
wKIT.E
Aoua csS kFtFt L.uPIEZs^...	 -	 7d cnE /oP
OVT MuX
	
RED Q	 c.MTeu(
S9n2T 2¢^O 5 .. Na^E	 S QV4 0.1c
^j	 .uzr^r	 t
VQ ^	 A^S^6NMQY7
•
Ci'^	 _	 MtM AVAA.-
^	 Fs4 QEno^ ^
 P-
%.od17l!
	 R(.J IMITIA99F
^lAt► + wlt/TF tt ^arvc'	 SGQ 4,,L-'N462(2(w Tu	
nnafTr C06CK	 VA7n. racy
..	 CdLC Mf=M01b(	 FA#L .T- illill	 _	 GOM1'YlJ1.
_. -_...
	
To uV^ruT MukSS.	 ____
/apotc^IC
Cud
^	 P21Yr<l pry	
A
Ass14iJ D^1n	
Goa PARlTO2'
lCtAO
	
7 715 1AI Nlgfr
i
v+
r
4 _
	 _
N
Fps ►1. e s-7
C P e mf m o2( 14 Zc-2 rA co SEJO UEMc62
/oP U5«ir Rusl
CI'E S7i2eRM
Kus i (si+si) -	 Aooaess
wt (c/LV/^il^t?AM	 SE uE.^-E2
Q ^n. w R6y^FSa	 C pE RL^6ss rtbi 3^s T ro ^^+
/I/I USINC-^IUS{
	
^	 ^fi^2T  64TE ,9aaa A. .wTO 4urb
D q 
CPa irQEnM
	
wall	 o L) T Aw K 
c. N PLO%-
nssl. uv3cc^w	 FF	 StnQT	 --^
s osy (:i'vy)	 W	 S^YVENra%2
L?E pb.^n h17lrQFACC 9^'GY	 Yl a4 I —	 -
--T5 EgIAAt FoiL. U QIQcSP^^iSt y `—	 ^/pT¢R/ 	 _ _
SWITCFI	 FF	 Mot 04T.w /4 vw'&-r4L ,
SA51 -	 STAN(	 IPFAO	 TO Mi LA.* PAv[.QAM
Srys Y '	 2rno^	 2	 SEqun*Jc62
	
lOn)
ENA4 E kFE/L	 Mc1 CoelTa,.L,REAa
	
—
:''	 CAE QF4S A V4 L.^a9uE
Yo Mr,A.i'2.64AM
041A AVAIL
sn$I
onTA AoAICYs^sy	 D	 _
• I O P 5-6 fW =A&CAL 5 4111-.12
N
w -
^IDl11	
- ^^	
_	
_	
,,...._.......aua..r. t.....-..^._..a.	 .._.._^. ..^ ........,..u.. _.^,... .......e .a.._i..._..^__....^................u_,....n. ......... ................^........^.u......^...`u.__....._..-._,......w
a	 _M	 ct655 ^k N65 Dl' ci	 A1UiT	 E .^ yF	 .t.'^T. CEM U IZ ^/ ^.3 TEL F -4 C E : $J^ A	 c	 - ^	 _ C- I E	 A'1 E	 Y IZ.... ^'^.__.......__ ^• E •V,`?	 ' 	
-=-..,...—
p44^ 'ss►c.
k	 FROM ¢cE 
A	 SNtEwmA ssr.*J
t	
A ^ p	
^ /^ SS^F ^!!JF^T
•	 l'Rka^YrAsswM	 DEcout2
Bus 4#/
	
I}Us 0. -
P46E
^noe	 8
^^ o e 0TY	 5 A	 ^a Ep+va^(
1 ^P^ c!E R6rt^s1	 kut:OwI-
	
a•^^.^
OAl 40-SA (
	 StCiAM	 kE lr	 gus '	 _	 REi—	 To
_	 5fic
	 _	
ouiP^T
•	
.	
ASflf- JAI ErT	
LaK.	
Mud[
IVA► f
7
•.
	
MEM+0.Y
i Fnu4-1 PEI,
A— 	 o	 3w^Mv	 DvU	 u	 v'i TYP i Moo p c^Fow^ tE
A= i3	 loo
/JSSiGNM6.w^
K,.K^Wnssrw^
	
Ofic^oE2	 =	
_
P44-6 4001Z
 y
^.P inE e
•w eYii
i o u T C u T;,
r
•	 A 4L Cr.MMAJAU45	 •
2 ATAlIM E
	 ^
L-0	 CPS., lop V076(z ^WITCH W/o Faw.-+r n ►_rixzj&otJ (iul ps/9rT)
I.Y	 S^ . M4E4AVVrI►%#T Q r	 ..--
AEMoIeY /.v,rtl2FiacF NA IAIIA1& --/e AItiYY cvnE LO&OC,
n E N1 uuTpv 1 ,
MEM•vTPv1 31
c42E
DATA
171,
MEMORY
FieliACR / Ty'
^
DA TA 	 Dap
Ty LuZDVT
Tok'E6 . uvT
x s
v-rsa ^ swnwl i l
HI NI SYw J) I > Yw 02aMI
^Ec•	 re. /Z-
lie
_ P `, ogrq pna^Yy _
) ^^/6LPPAA[YE4U
NANn i^L
^^ sAat.2
}InMhtx
ADO q
{
QEh^ /Nd^T^^cE	 i
O} .t f/A^tNI 3^  D^n^fyFAtits
P4 Of fY
WQIT^
1—o
Cgt^cC
Fw -
j
o.rtr.^-
/ U NIGfs Pw a.TYq 1T
17A 	IT wRat* ^aa.rL
',
GNEClu2
v1
1
i
S-/!
MEM(,rty /A/TEoZfACE FAVl.7 con/-r/ZO	 t_oFrG
PA^ rinf. r/S*► Fnw.`r
AccyM,,& A'[IuIJ FFs
sur(.Effj TMR MouE
' V15W FAULT uvT#/
fri of Alo m -66ao
DAl& r,	 s snae 6 Fl Ep c u 4 tr 2 rYNGGw7E FFS
u
tnR ITY craac 71Ate GA7 IC ^^
T. SMNi SY.v
S-ra E.A^lARl4
MEM^Y
E^lGu0E2- _ _Fnu l T
Pa alTy cflreic
FA•'-r
rnfn,cnTl..J
F ^ 2.SMN}^ S^NtEn^
FAULT cooaS
6
	
x	 L o P
o	 ©a	 c`^^
	
4V1 c^s s Mu^T^O^g ^/
/IG,acf c if* A4MIN^
10	 >tty Pnl2aTyFAVI T
-
CAS
>
Accfif ad
-
_
pQaansfS
h NY 2 V/C^
k. FAULTS -	 /rwN191TwrZoTE A-1.0 Ov7P%oT
'r
k	 u
F
A
PE ^O E-^ MrMo2`( lw t 2r/^G% wolf) 1=G2M/^TS
	
— -	
'_"•`^
	C?E >Tr1KnN	 re 91 e O
	
/ITf^c.^MF.^1	 „,ersll^ o O
	
^ tv r Te z I
	
Nr.« /kcsss Rrb .1
pR1012cT`f CoOf TES TI RE^^I
Ai
S4;T taBl'tE	
Il3GF_ AOOaE5S	 ( ADpa-E55
	
}
ADO(LESS
He ►r	 WORD
RA
Az	 ADp265S	 a
}
r
Di/ol
TABLE 5-1. MEMORY COMPONENT COUNT (Excluding Commercial Core Plane)
Function Gates Flip-Flops
Fail Rate
Equity
Gates
1. Voter Switch/Output MUX 504 0 504
2. Addr and Data Reg 52 33 250
3... Hamra jxmg-Parity Logic 994 0 994
4. Access, Timing and Control 414 31 600
5.	 Fault Control 51 8 99
2015 72 2447
I
MEMORY INTERFACE
MEMORY - CPEs- IOPs
1. Processor Busses (11) x4=(44) CPE to Memory -TPMB _
2. Memory Busses	 (11) x4=(44) Memory to CPE and IOP -TMPB _ _
3. Memory Access Request (8) CPE, IOP to Memory -TCPRER_
4. Memory Request Aclmowledge (4) Memory to CPE or IOP -TMRESP
5. Data Available (4) Memory to CPE or IOP -TDAVAL
MEMORY - CCE
1`. Page Assignment (2 bits) CCE to Memory-
20 Output Buss Assignment (2) CCE to Memory
3 Clear Memory, Interrupt (1) CCE to Memory
4 C1ock.Sync (2) CCE to Memory
5. Power Protect Inhibit (1) CCE to Memory
6. Memory Fault Interrupt (4) Memory to CCE
0	 No fault CPE1 failure
4	 IOP1 failure 9 CPE2 failure
5	 IOP2 failure* 10 CPE3 failure
6	 IOP3 failure* 11 CPO4 failure
7	 ICP4 failure* 15 Memory Internal
not used in the breadboard configuration
-TP AGE
TCLRNM_
TCLK, TSYNC
TPWRHLT
-TMFLT
MEMORY - MATi]R'ErTANCE PANEL/ELECTRONICS
1. Fault Entry Switches (6)
2. Scanout Source Select (2)
3., Scanout Buss (66)
4. Scanout Enable (1/Memory)
Panel to Memory	 SFLTIN
Panel to Memory
	
SSOC_, _ _
Memory to Electronics	 TSBUS_ _
Electronics to Memory 	 TSAO _
5. Master Clear (1/Memory) Electronics to Memory	 --TCLR
MEMORY - INTERFACE - CORE MEMORY
1. Address Input (12) Memory Interface to Core Memory -TMADR
2. Data Input (39) Memory Interface to Core Memory -TMDLN
3. Data Output (39) Core Memory to Memory Interface -TMDTA	 _	 r:
4. Read/Write Level (1) Memory Interface to Core Memory -TRWL
5. Initiate Cycle (1) Memory Interface to Core Memory -TRP
rEMRY INTERFACE
MEMORY - CPE - IOP
1. Processor Busses (11/CPE) - Each CPE (IOP combination)
sends the memory an eleven (11) line buss. 	 Control lines, address
and data is multiplexed across the buss to accomplish memory read
and write operations.
2. Memory Busses (11/CPE;) - 	 Each memory sends the CPEs and IOPs 4 busses
each containing 11 lines.	 The busses carry memory data. 	 The CPEs
and IOPs vote on the output busses in the Duplex and TMR modes.
3. Memory Access Request (1/CPE and IOP) - Each CPE or IOP signals the
memory for access by.the memory access request line.	 The memory access
request line will remain high until the memory signals acceptance of
the request, (Memory Request Aclm owledcr
^+. Memory Request Acknowledge (1/M B) - The memory sends the requesting
CPE or IOP a signal acknowledging that the memory request has been
accepted	 and the requesting unit should transfer the remaining
address and data (if a write) across the buss.
5.	 Data Available (1/M B) - The memory send the requesting (read) CPE
or IOP a signal stipulating that the memory data is now selected on
the appropriate output buss.
MEMORY - CCE
1. Page Assignment (2/Memory) - The CCE sends each memory a two (2)-bit
code specifying the page assignment for that memory,
2. Output Buss Assignment (2) - 'The CCE sends each memory an encoded 2-bit
line specifying which memory bus to use to output data on
during Duplex or TMR modes.
3. Clear Memory Interrupt_(I) - The CCE sends, each memory an interrupt line
which causes the memory to output all 110" on the memory bus
during the execution of a software routine that cycles through and clears
all locations. This is required when initializing essential memories.
MEMORY CCE (Cont.)
	
4.	 Clock Sync (2) - The CCE sends the memory the system clock at the
highest frequency required in the system and a sync signal at z this
frequency.
E 	 -C	 5. Power Protect Inhibit (1) - The CCE sends the memory a Power Protect
Inhibit Signal, This line specifies that the power is going out of
I	 tolerance or that system reconfiguration is , about to occur and the
fmemory should be shut down.
	
6.	 Memory Fault Interrupt (4fMemovr) - Each memory sends the CCE a 4 bit
encoded fault line specifying what type of fault has occurred.
0	 No fault	 8	 CPE 1 failure
4	 IOP 1 failure 	 9	 CPE 2 failure
5	 IOP 2 failure*	 10	 CPE 3 failure
C	 6	 IOP 3 failure*	 11	 CPE 4 failure
7	 IOP 4 failure*.	 15	 Memory internal failure
not used in the breadboard configuration
MEMORY - MA7STTE[VANCE PANELAMECTRONICS
1. Fault Entry Switches (6)	 - The fault entry switches allow the insertion
of switchable faults into any 6 desired points in any modules for fault
tolerance studies.
2. Scanout Source Select (2) -	 The scanout source select switches allow-
selection of 2 different memory scanout sources independently for each
of the two 33-bit scanouts on the maintenance panel.
3 scanout Buss (66) -	 The tri-state scanout bus multiplexes inputs from
scanout sources in each module into the maintenance panel scanouts.
4. Scanout_Enable (1/Memory) -
	
The maintenance electronic decodes the
scanout module select switch output to provide an enable to the scanout
multiplexers in the memory selected.
5. Master Clear (1/Memory) - A master clear is provided to all modules when
the master clear pushbutton on the maintenance panel is activated.
MEMORY INTERFACE - CORE MEMORY
1. Address Input (12) -	 The Address Input lines control 	 the location in the
core memory to be accessed for read o.r • *,write.
2. Data In-out (39) - ThE Data Input lines transmit data to the core memory
during write cycles.'
3. Data Output (39) -	 The Data Output lines transmit data from the core
memory during read cycles.
4. Read/GTrite Level (1) , - This signal determines if a memory cycle will
be a read cycle or a write cycle.
5. .Initiate Cycle (1) -	 This pulse causes the core memory m::dule to
initiate a read or write cycle according to the state of the read/write
a	 a
level.	 Once the cycle is initiated the core memory module provides its
own timing.
-	 a
4
i
i
^3
r
6. INPUT/OUTPUT PROCESSOR (IOP)
The ARMS IOP consists of 4 sections: 1) TTY channel logic, 2) TTY controller logic,
3)' DMS channel logic, and 4) common IOP containing logic for servicing both channels
and for interfacing with the rest of the ARMS computer. The first two sections are
unique to the breadboard. A flight version of ARMS would have one or more DMS
channels. Figure 6-1 is a block diagram of the IOP module. The ARMS IOP is func-
tionally similar to 2 IBM system 360 selector channels with each operating in a burst
mode during data transfer. Ref 1 describes the 360 I/O specification and operation.
The DMS channel is 16 bits wide. The TTY channel is 8 bits wide with the controller
converting this to a serial stream at the TTY interface. The IOP can operate concur-
rently with the CPE once a channel has been started by the CPE. The CPE software
initiates IOP action by use of the Initiate I/O Instruction line during Start I/O, Test
I/O, Halt I/O, or Test Channel instructions. Information pertaining to these instruc-
tions is stored in the Channel Instruction Word (byte address 1521 0) in main memory
when the CPE executes the instruction and is fetched by the IOP when the Initiate I/O
Instruction line is raised. The C1W format is shown in Figure 6-2. In the case of the
DMS the CIU address replaces the device address in the figure.
Each TOP channel requires additional locations in memory to specify data address loca-
tions, word counts, and control and status flags. The contents of these words are
used only by the channel and are not transferred to or from the I/O devices except for
certain command and status flags. These formats are shown in Figures 6-3 and 6-4.
Their memory byte address assignments are listed in Table . 4-3 in the CPE module
section of this report. - The 32-bit Channel Address Word (CAW) points to the byte
location in memory of the first Channel Command Word (CCW). Each CCW consists
of 64 bits and specifies which command the IOP will execute (Read, Read Backward,
Write, Control, Sense, and Transfer in Channel), the starting address in main memory
from which data will be read or written, the number of bytes or bus words to be
transferred under this CCWs control, and flags modifying the r- .mmand (chain data,
chain command, skip, program controlled interruption). The CCW for the DMS
Channel also specifies DIU and channel addresses within the DMS. Once the IOP pro-
gram is started the IOP sends its condition code to the CPE and signals it to proceed	 r
by means of its I/O Instruction Accepted liner
6-1
L...	 _	
_	 t
Upon completion of an I/O command or in response to an error or to a device interrupt
f the IOP requests permission to store a channel status word (CSW) in memory by rais-
lug its I/O interrupt line for the appropriate channel to the CPE. If the CPE program
is finished with the data in the previous CSW and its PSW system mask bit is set equal
to one it raises its I/O Interrupt Acknowledge line allowing the IOP to store the new
[
	
	 CSW in memory byte addresses 64-71. The CSW format is shown in Figure 6-5. The
command address field contains the last CCW address +8 bytes, the Device (or CIU/
DIU) and channel status fields contain status information as of the time of the interrupt
and the byte (or bus word) count field contains the residual byte or word count (if any)
from I/O operations.
	 -
The channel/device interface operates as follows: The channel and device (TTY or
DMS C IU) each may be in an available, busy, interrupt pending, or non-operational
state when an I/O request is received from the CPE due to a Start I/O instruction.
If the channel is available (or if an I/O interrupt is pending) it fetches a CAW and out-
puts the specified device address. If the device is in an available state and no faults
are noted the device responds by returning its internal device address to the channel
which then sends it the command code. The device then responds with status as to
whether or not it will execute the command. If the status is affirmative the device
remains connected, the channel fetches the first CCW from memory and executes it
in connection with the selected device returning an appropriate condition code as it
releases the CPE. If the status is negative, faults are noted, or either channel or
device is unavailable different condition codes are returned to the CPE telling the
CPE to either automatically request CSW storage or to obtain this by means of a
"TEST I/O" instruction. The latter condition occurs if the channel was already busy
at the time of the request.
The Halt I/O instruction terminates on-going I/O operation, placing the channel in an
interrupt pending state and allowing the CPE to override on-going IOP action. The 	 -
"TEST I/O" instruction allows the CPE program to obtain status and to clear pending
interrupt conditions selectively by I/O device. The "Test in Channel" instruction
allows CPE testing of channel status without disturbing on-going device operations.
All instructions cause an appropriate condition code return to the CPE as summarized
in Table 6-1.
sf	 .
6-L
Channel status bits returned in the CSW include 1) Program-Controlled Interruption
(allowing the channel to interrupt the CPE upon fetching this CCW), 2) Incorrect Data
Length transferred, 3) Program Check ( invalid address, command, or count fields
detected by IOP), 4) Channel Data Parity . Error, 5) CCW parity error, 6) Invalid
interface signals present, and 7) Input Data Overrun. Device status bits returned in
the CSW are 1) attention, 2) status modifier, 3) Device Busy, 4) Channel End (trans-
fer complete), 5) Device End, 6) Unit Check ( identified by available sense data from
the device) and 7) Unit Exception (unique to a given device). Status bit positions and
meanings are compatible with the IBM system 360 CSW. The operation of the four
sections comprising the IOP are described below.
DATA TERMINAL CONTROL UNIT
The Data Terminal Control Unit (DTCU) provides for serial to parallel conversion of
the TTY output, parallel to serial conversion at the TTY input, and for buffering and
parity checking at the channel/DTCU interface. It also provides for decoding and
encoding of ASCII data and tape unit control characters by means of PROMS and for
an optional direct binary mode bypassing the PROMS. This logic also converts the
specific command and status signals within the TTY unit to a form compatible with the
standard IBM 360 selector channel interface provided by the TTY channel section of
the IOP.
IOP CHANNEL LOGIC
The logic found in the two channel sections , of'the IOP are essentially identical except
for the differences due to the buss width of the 2 channels and the additional line
drivers and line receivers and at the DMS interface: As summarized in Figure 6-7
the channel logic consists of 1) discrete control logic for read memory forward and
backward, and write memory, 2) Read/write multiplexer and register logic for buffer-
ing and routing data both ways through the channel, 3) Priority routing logic for the
various memory access requests that the channel can make, 4) Holding Registers for y
holding and operating on the channel Instruction, Command, and Status words includ-
ing decoding the CCW op-code to obtain the proper IOP instruction, synchronized
counters for data words address, and byte (or bus word) counts, a Channel Command,
Word Address Counter, Command Word and Data Word address parity generation, (	
i
buffering and decoding of control flags (and of CIU and DIU address in the case of the
t
6-3
r:
:^	 V	 I	 I	 I __	 r- f
DMS channel) and buffering of device status bits for inclusion in the log-out of the CSW,
5) Device interface logic including logic for comparing device response to addresses
sent and device interface parity checks, and, 6) I/O Interrupt Request control logic,
7) channel status and control logic to sequence the registers mentioned and to generate
condition codes information and appropriate channel status bits for inclusion in the
CSW. Multiplexers to log out CSW bits and decoder for CPE instructions to the IOP
are found in the common IOP section.
COMMON IOP LOGIC
The remaining IOP logic is that common to both channels. Figure 6-8 summarizes
this logic which involves sequence control including the 1) decoding of I/O instructions
from the CPE, fetch control for the CIW, CAW, and CCW, encoding of IOP condition
codes, and generation of and response to interface control signals with the CPE and
CCE; 2) the voter/switch interface to the 4 memory buses including buffering and
parity checking of the data; 3) memory access control logic including priority control
between the 2 channels, and discrete sequencing logic driving PROM controlled selec-
tion of appropriate IOP/Memory output multiplexer sources; 4) IOP/Memory output
multiplexer selecting between 36 possible output sources within the 2 channels followed
by a buffer register, parity generation over this register and parity checking over the
Output Multiplexer Control PROM, and CCE controlled interfaces to each of the 4 proc-
essor to memory buses; 5) scanouts of key register and control points throughout the
IOP to the maintenance/status panel.
COMPONENT COUNT & RELIABILITY DISCUSSION
Component counts for the IOP logic (with the exception of scanout which would probably
not be included in a reliability calculation) are given in Table 6-2. The overall com-
plexity of the breadboarded IOP is approximately 14, 000 equivalent gates. An IOP
with only one DMS channel would require something under 8, 000 equivalent gates since
the common IOP logic would also be reduced somewhat if only one channel was imple-
mented. An IOP with two DMS channels would have a complexity of approximately
12,500 equivalent gates. For comparison the baseline IOP discussed in our architec-
ture study had a complexity of approximately 10, 000 equivalent gates for one channel
and a probability of successful operation over 5 years of 0.9997 in a TMR plus one
spare configuration.
4
Since it is intended that the IOP be operated in a TMR, configuration in a flight version
of ARMS with voting on all outputs 3 fault, tolerance add-ons in the breadboard ver s ion
of the IOP are limited to parity checks on key registers and interfaces and to IIBM
compatible status checks as discussed earlier in this section. Although this com-
bination of parity and likelihood coverage could be extended somewhat further it was
felt that the only way to insure a high probability of fault correction in real time was
through use of TMR, IOPs.
­UAM
un	 MEHaRtt ,-. IaP_6uS_,0 O
Y	 _	 _FROM rULETYPE
". rvjeM -A,AL
— - - - -
SVJii'i a_I TTY C f)t-TROL J" IT
^	 o(	 1 I	 H 1 Xr-+iT I
1;
z I GUffE}: 1
ofH I
I a`P 	 —--
rcttA.,^,E	 o
T3F CtiPt	 04git1
`
OAK
^ J \	 Cort'64	 AD pfc	 Vick
	
j_ BYTE
 1
^ADDR'	 COMMD	 ^,e JK 	
G HI n1
CONTROL STO;^1: CNTR tNTfZ 1 1 c.t4TR
CtJTR STARE CON7ROl
DATA
--- --^-
DATA
5Rtz
r -----j
i COOST coK I 1
1 ADDR toe 1 1_ i STORE co^n'Rot. 1
Mud( M it X MUX
cS7ATt3^
I ` STRT+3S1
^ Rur I
33	
I
REG 1
I
1 I I
IF
MUY 2EG 1 MUX 1
I
0l
1
^ 33
^
CµAN•Jg	 I J
	
:
1 I	 H	 - - - - - - — — — — — —	 •I	
't 1	 z'1
_	 I I j RED I1 M u X 1 gUFPER'
LCHA►i ►lEL O
'
-! - 
_ 
11	
-u l_ _	 - TT`C Co
►i ; RoL U4
To _TELETYPE
F	
. e
To ^M^	 IoP --.MEMORY But TERMI ^► fiL.
f	 ^;.:.	 _
.ARMS IOp BLOCK DIA L RANI _ 	- _-'
I	 I
OP CODE	 CHANNEL	 , DEVICEADDRESS	 ADDRESS
0	 7 3
	 15 16
	
23 24	 31
Figure 6 - 2	 CIW Format (Channel 1)
FLAGS DIU CHA\TNEL BUSADDRESS ADDRESS WORD COUNT (16 BITS)
0	 3 4	 7 S	 31
}	 DEVICE	 CHANNEL STATTY	 BYTE COUNT
:	 STATUS	 ( ^
32	 3,940	 4748	 63
P	 ,
Figure -;	 CS %V Format	
s

QMS	 C64 IF 4D,
-
-
-
- 6.1.2.0
• MeM IS•OP &EG Bus
1 - sr use OtMI. i
 WWI - ClGL71 " - ,^, jl R
f >vo O Nut
f
°
: -lf'
f
lto t li:^ a ^ ^ i -
1• CLL1	 + war. w+-^ u U1$ wN► Cie D2J^; of CNY 1	 L[r _ Cut0. Abh[^
.
la.,wxvo oria An^^ hW^ C SIao6
11 ^ s
_. A wde
1
T
I t EF4[ etF^R • sops t Q t^or	 4stii
- 1 8
NI IsUF ufiio) fAS..y
' t vCaGCI?
• - u^r[,....u• - •32 t2 12
fwa Mt PA A worn
U bf^ GWI `E[t 6 VHot wr
11 cz b • O 8
4E6 sreto$
STATUS
8
^ ^	 I
W.>t: r.. o 9 [+wry 1 11A M[
• cwla GGI GFA  - ^.^ sNiltFwcfi
-
1
'
1
i
-	 ' y ,
to
F aoi t!! ! 9 (!^^ 1
.
 . ' ' a^tr+cfr.^
`
•
_ a
swifts" WS ,tp	 ,^ s^I^HAM ft6 rp1
NJyF '^ f't!p'l MOW ypr^Npr `
NOX MtlK
t
1
.
'1N
 j,—
'Dana va • /s
	
1 rw
w
a
(it-sL1 sL^ ine
	
v
ale
	
I 
.
' v
«
a
W
-.o)
	
s
.
(S.
,n)
	
1-
I
r
e
	
Iv M
sa
	
_
	
^
	
;
T
L
V
 
e
e
v
a
.
.
	
1
	
Ir nwa
	
^
2
V
 A
"
IY
 m
x,
S
(01.0)
	
L!
	
•
 
^
a
	
^t 3
	
11
•
 1
	
Ca-es)
	
r
	
o
 «
.ten
	
{)
`
.
	
(OI_e) tali
	
en iD
	
o 'Ir11a
	
^
	
i
	
I
sa.• yn•
	
V
aw
i
	
O
 r'Ih
a
	
a
ptNMI
 
1
 
1
 
M
I
L -
'
N
	
^
	
_
	
1
	
1
0^j(j j
 A
1+ PA
G
IS
	
_
d
t C
tl_
L
) u
1 e
 7
a
.^
s rsa
 ►
 n
a
«
a
P
O
O
40(''A
-L)aa1v 
-pa
rv
.)
 Ili { 
m
v
"
*
(
	
n
 
w
e
e
	
-
	
.
Sim 1
n
o
 V
"o
 O
 n
v
4
1
')
•
M
M
.
d
 
^1N4) SS+/ iL
M 7 V a
	
O ngwa
(M
) we sa" fNaa -*-%
* O 
•rala
	
^:^
S`
t
^
	
V
II
	
t_..
	
,
'
 d
v
	
r^
.V
a
	
N
a1f^
	
`
^
N
ei j(
,
 rlia
	 M9.Vl^
t •a.M
 r+sa aNS
	
4
J /e
e
n
 M
sa
 a
^.p
s
	
(:e..y ti)
	
Vy
-
	
-
	
VA
" O
nsf
	
h
Y
A
e
2
.O
; e
 
I+
IN
a
yS
.
	
J'
	
of
rvM
^'
	
v
w
a
 0
x2
4
T
'
a 1124N
	
•w
.1 r
A
v
o
l
m
o
w
n
	
C
	
^
1 ov.w
,
 f^7a
	
1/!
	
.
.
	
J
	
W
 e
11
	
(ram
, h)
	
^
.
	
V
 v
	
gg
i s100% T7a
	
sn
e]
	
g'Ifv^lvet
	
v
a
vi
	
O
	
V
'
,
'
.
	
_
 
_
	
S
1
 •7
q
w
. w
ft* q,.es
v
1
N
 
e
n
•
t;
	
1
^
/1
w
L
S
 m
a
t
	
M
lu
w
 naa+•
	
,+
w
w
N
 e
d
	
A:
2 ee... n.» ..U
N
1
 O
v
+
r r"a'.j b
„
.
 
,
I
TABLE 6-1. I/O CONDITION CODES
Instr	 Halt	 Test	 Test
CC	 Start I/O	 I/O	 I/O	 Ch
0	 Channel Executing	 I/O	 Channel & Device
Requested Opr	 Interrupt	 Available
'r	 Pending
1	 CSW Ready for Storage
f
2	 Channel Busy
3	 Not Operational
TABLE 6-2. IOP COMPONENT COUNT
Function Gates Flip-Flops
ROM
bits
Fail Rate
Equiv Gates*
1. Data Terminal Controller 770 92 6,400 2,106
2.	 TTY Channel (Ch 1) 2,346 252 256' 3,874
3. Common IOP Logic 2,435 130 4,864 3,823
4. DMS Channel (Ch 0) 2,699 274 256 - - 4,359
Total 8,250 748 11,776 14,162
IOP INTERFACE
IOP - MEMORY
1. Processor Buss (11x4) IOP to Memory -TPMB
2. Memory Buss (11x4) = (44) Memory to IOP -TMPB
3. Memory Request (1) IOP to Memory -TIOREQ
4. Memory Request Acknowledge (4) Memory to IOP -TMRESP
5. Data Available (4) Memory to IOP -TDAVAL
IOP - CCE
1. IOP Stream Assignment(4) CCE to ION -TSASN
2. Clock Sync (2) CCE to IOP -TCLK, TSYNC
3. ! Panic Halt Interrupt (1) CCE to IOPs -TPANICH
4. IOP Available (1) IOPs to CCE -TRBPAC5
5. IOP Fault (1) IOPs to CCE -TIOFLT
IOP - MAINTENANCE PANEL/ELECTRONICS
1. Fault Entry Switches (6) Panel to all SSFLTIN
2. Scanout Source Select (8) Panel to all SSOC
3., Scanout Buss (66) All to Electronics TSBUS
4. Scanout Enable (1) Electronics to all TSOMS
.5. Master Clear (1) Electronics to all -TCLR
IOP - CPE
1.; IOP Memory aequast Inhibits (1/I0P) IOP to CPE -TIOINH
2.'1 CPE Memory Request Inhibit (1) 	 - CPE to IOPs -TCPINH
3. Initiate I/O Instruction (1) CPE to IOP
-TIIOI
4. 1/0 Instruction Accepted (1/IOP) IOP to CPE -'TIOIAK
5., I/O Interrupt (2/I0P) IOP to CPE - -TIOINT_
6. I/O Condition Code (2/IOP) IOP to CPE -TIOPCC_
7. 1/0 Interrupt Acknowledge (2) CPE to IOP -TINTAK
IOP - MEMORY
1. Processor Busses (44) - The IOP sends 4 busses to all memories. The buss is
utilized to send memory address, memory data and controls to the memories.
^r
-
6-12	 1
I	
I	 I	 I	 I	 -	 ' ''"I
c9
2. Memory Busses (44) -'-L4,ach memory sends the CPE ( and IOP) 4 busses each
containing 11 lines. The busses carrymemory data. The IOP votes on this data
in duplex and TMR modes.
3. Memory Access Request ( 4) Thie .10P sends one Memory Access Request for
each buss to all memories, the memorywhich is selected by the page being
transmitted on the Processor Buss will respond.
4. Memory Request Acknowledge ( 1/MB) - Each memory responds to the IOP via this
line acknowledging that the memory request has been accepted and that the
requesting IOP should transfer the remaining address and data ( if a write)
across the buss.
5. Data Available ( 1/MB) Each memory sends the CPE the Data Available signal
when memory data is available on the Buss.
IOP CCE
1. IOP Stream Assignment (4) - The CCE sends IOP 4 lines specifying the stream
assignments for voter switch and output bus control. Each bit specifies an IOP
in the stream.
2. Clock, Sync ( 2) - The CCE ,sends IOP the system clock at the highest frequency
used in the system and a sync signal at 1/2 this frequency.
3. Panic Halt Interrupt ( 1) - The CCE sends each IOP a Panic Halt Interrupt which
causes the IOP to terminate the operations initiated and stop.
r	 4. IOP Available ( 1) Each IOPs sends the CCE a signal which specifies that the IOP
has completed all outstanding operations and is quiescent.
5. IOP Fault ( 1) - Each IOP sends the CCE a line which specified that a fault con
r
	 dition has occurred in the IOP.
IOP MAINTENANCE PANEL /ELECTRONICSR
1. Fault Entry Switches ( 6) The fault entry switches allow the insertion of switchable
faults into any 6 desired points in the IOP for fault tolerance studies.}
;^	
a
6-13
2. Scanout Source Select (8) The scanout source select switches allow selection of
up to 16: different scanout sources independently for each of the two 33 bit scan-
outs on the maintenance panel.
3. Scanout Buss (66) - The tri-state scanout buss multiplexes inputs from scanout
sources in each module into the maintenance panel scanouts.
4. Scanout Enable (1) - The maintenance electronics decodes the scanout module
select switch output to provide an enable to the scanout multiplexers in the module
selected.	 t
s
5. Master Clear (1) - A master clear is provided to all modules when the master
clear pushbutton on the maintenance panel is activated.
IOP - CPE
1. IOP Memory Request Inhibit (1/I0P) - Each IOP sends the CPE a signal which
represents that a memory cycle by the IOP is being requested and the CPE should
inhibit any memory request until this line is low. The fact that an IOP shares
the input and output busses with a CPE necessitates this communication line
between the sharing IOP and CPE. The CPE must look at all IOP request
inhibit lines when in a duplex or TMR mode of operation.
2. CPE Memory Request Inhibit (1) - The CPE sends a signal to each IOP in the
system indicating that this CPE has requested a memory cycle and the memory
has granted the request. In other words, the CPE is using the input buss and
possibly the output buss while the signal is true. The IOP has a higher memory
request priority than the CPE, so this signal must not be activated (high) until the
memory has granted the request.
3. Initiate I/O Instruction (1) - The CPE sends the IOP a signal telling the addressed
IOP that an I/O instruction is to be processed. The CPE must store the channel
number, device number and subchannel number into a designated memory, location,
from which the signalled IOP can interrogate to determine what action is to be taken.
It is the responsibility of the program to know when the I/O instructions can store
in the designated memory location.
6-14
...W..._
4. I/O Instruction Accepted (1/IOP) - Each IOP sends the CPE a signal which
denotes the previously sent I/O instruction is completed or has progressed to the
point to assure initialization of the requested function. The CPE must wait for
the I/O instruction complete signal before completing the I/O instruction and
setting the condition codes.
5. I/O Interrupt (2/10P) - The IOP sends CPE an interrupt line for each channel
which designates one of many conditions that may exist in the IOP which must be
signalled to the systern. The IOP stores the interrupt information in a memory
location (64) to be interrogated by the interrupt program. The CPE processes the
interrupt if the I/O interrupt mask is off.
6. I/O Condition Code (2/IOP) - Each IOP sends the CPE two lines which represents
the IOP condition, following the execution of an I/O instruction, which is to be
loaded into the CPE condition code indicators. These lines are interrogated by
the CPE while the I/O instruction accepted line is high.
7. I/O Interrupt Acknowledge (2) - The CPE acknowledges the 2 IOP channels'
•	 interrupts via these lines.
1	 I 1 I ^^
7. MAINTENANCE STATUS PANEL AND ELECTRONICS DESCRIPTION
The maintenance/ status panel and electronics (MSPE) allow displaying and
controlling the ARMS breadboard's internal state, and inserting faults to test
and demonstrate ARMS fault tolerance logic. It provides the following capabilities:
a) loading the memory register in the CPE from thumbwheel switches.
From .this register other CPE registers and scratchpad memory can
F	 be loaded, and data may be written into main memory modules with
the function initiate button depending upon settings of the functioncontrol
switches. Parity for data and address switches is , generated by'the
maintenance electronics.
b) a breakpoint program halt and single-step capability.
c) "stuck at" and intermittant faults introduction by forcing IC pins to logical
"0" (and hence their outputs to logical "1") by means of panel switches
whose terminals may be temporarily connected to various appropriate
points in ARMS prior to a test or demonstration.
d) simulation of ground command loading of new module status assignments
into the CC E.{
e) display of important register contents in ARMS CPE, IOP, main memory,
and CCE modules through_a multiplexer along with direct display of key
points within these modules. Both binary and hexidecimal readouts are
provided.
f) Master clear, External Interrupt, and Single Clock controli
s
i
r
{	
iY	
a	 ,y
do
ste
t;
f
Figure 7-1 is a block diagram of the MSPE showing the interconnections between the
panel switches and displays and the electronics assembly. Figure 7-2 shows the
location of the various controls and displays on the panel. The controls operate as
follows:
HEX DISPLAY SOURCE SELECT Selects which binary display (32 msbs)_will also
be displayed hexidecimally.
FAULT INPUTS 1, ... , 6 - Each switch solidly (switch down) or momentarily (switch
up) grounds a fault line that is routed to each ARMS module through the interconnect
board. Within any module these lines can be connected as desired.
EXTERNAL INTERRUPT - Provides an external interrupt to the CPEs via the CCE.
STOP (LOAD CCE)/RUN - RUN (lighted) position allows normal operation. LOAD
position allows loading new status assignments into the CCE with the FUNCTION
INITIATE P/B as selected by the FUNCTION ACTIVATE DigiSwitches. Normal CCE
reconfiguration action is inhibited until this switch is returned to the RUN position.
MASTER CLEAR - This button clears all control registers in all ARMS modules.
SINGLE CLOCK ACTIVATE - ACTIVATE (lighted) position inhibits all normal ARMS{
clock signals.
SINGLE CLOCK P 
	
This button provides one 5.0 MHz clock pulse to all clock
lines whenever it is pushed.
FUNCTION INITIATE - Executes the function selected by the FUNCTION ACTIVATE
DigiSwitches.
xLE COMMAND ACTIVATE - ACTIVATE (lighted) position stops all CPE instruc
execution on the first microinstruction of the instruction fetch sequence allowing
ping through a CPE program one instruction at a time.
_	
'7 - 7
Er
BREAKPOINT ACTIVATE - ACTIVATE (lighted) position forces the CPE to stop on the
first microinstruction of the fetch cycle in which the Program Counter contents equals
the•breakpoint address selected by the ADDRESS ENTRY DigiSwitches.
SINGLE COMMAND/BREAKPOINT STEP. Each time this button is pushed the CPE
program will stop one instruction if the SINGLE COMMAND mode is activated or will
advance from the breakpoint it stopped on if BREAKPOINT mode is activated.
ADDRESS AND DATA ENTRY DIGISWITCHES - These switches allow entering byte
addresses and accompanying data to the CPE._ The 5 lsbs of the address switches
also allow loading module status assignments into the CCE.
FUNCTION ACTIVATE DIOISWITCHES - These switches select the module (lefthand
switch) and function (righthand-switch) to be controlled by the FUNCTION INITIATE
button, according to Table 7-1.
SCANOUT SOURCE SELECT DIGISWITCHES - These switches select the module
(lefthand switch) and function to be displayed on scanouts A (middle switch) and B
(right hand switch). Module select 4-3 selects CPEs 1-4, Module Select 4-7 selects
1Memories 1-4, Module select 8 and 9 select the CCE and IOP respectively.
a
i
+f
q	 7-3
NOW
	p	 FAUN FMTR'( to Aar.	 1SwITC .es 
^6j,	 -11	 ARMS Mlj,.-:.fi(^N^N^'E r 5TA-ros	 Al^l^(. r Ef.ECT2o.VIG$
(jtaictt. 1^ I A G-R/1M
1^ To ALL.
.Sc^NVuf 	 auT	 Ij MoUOaE
cowtilaL _ fi ► 	 SaaleCV-tCtr (to)
VEtao^
	
U^41TA1. SvJ.	 `4l
DATA, ADOR.
^RENTRY T
OettCo-t_ SI:/• (5^	 AwQ, DATA To cPE ccf
-	 FA2-TY	 CTy)
	
O	 GFNli.ZAT101^1	 .
t'UMCT. SS
	
,O CPC .FuNCIIu'J	 Cf•urtci sat.	 (tFMUIaAiraatl Ai g , SYNC	 d/ c^tyCcE r^
	
b 1n	 St6tT
tiN	
SATE
D141Tat sw l1^	 ' TIATF ^	 _
	
1 1 .
	
Ito bVI'MiluOr
	
rt,#Jo„r
MASTE[ ClEA1L
PJfi
	
(i)	 )	
+)
 ^yNTt^doYwtf^ 7o ccE
	 ,
SW6LE G^oCC Aid
	 To CZ.__
sw PQ. N)	 t a>
STo 1^ ^ Qv M Svl.	 .
(2^	 Ale
	
Tn Cr-E
SttsA ue.wr, swca^ cA•Pwc^w a5 ^ - - - - 	 1	 '
acn a,>^twr /	 Y1	 -	 s Y.uC , n o it	 s
SIMGcF' CMn	 8^'/ic Sr6^	 -_ - - -	 T. n ► t C.'fi
ALLdP R^ncl,Gu 	 - Ftio.•	 a.•2Ez sW/,I d^Llr=
	 __....{ I..ITF+r•=ncc_
gtN^RY 	 f
p ISRLAYS	 -	 ^ DRWFR.S
 SCANttvT yJ5(GG cEos)	 4L`f
t!	 (Ta 1 -5T/11^)
p	 t1E rlDE^rp;tt	 ICG)is 1 Mux
(1Y1^	 ;T6`L- j
ItEx 015ptl4v	 EICt.TRaNI[.5
SwBC^, SyJ•	 C,ocic. Wwlc-PiLltCtt
p	 ^	 CY)
3	
Pl^NE(
a
AR
	
MA 'iNTA ENccISTAT05 PANEL LA'fovT
HEX WOW Sooacd SeIEGT
131NwRY Ols^^^AY "h"
_	 _	
hEX11)^.M/t^- q^sltAY
g^NARY QISI^LA`r' ^(^^.
ISREAMmair REACNEO-t-1GHT'
ScANPVT SoU"ll SXUGCT sw1.lc"ILS
',	 puwCTwtJ hGTIVATF swlTtNtS
OAT^ ISwT&I 5WITCwtifis
S/kDo".5s Eurzy
SvJ17CNf.S
0000;46-®e0000 o®e ,0000,soo 000 0066 0
v
N 
OZ
f { 3 A^ 1
Qaoo_ vo o` oogoao Ot^Q	 Copo^go' 00 0-00 o	 jj
•	 i
9
i
t/312EAK)^►NT
AtT1YATE Sn1.
._	
.0 INGIE Coy► MA ►JQ^_
st
QREAKPo^NT STEP
SIN44E CoMM
	 ^AIJO C—rfofflESiJ•	
J
JJpu wcT lo ^t i n11'r^ h7E Old	
9
SIw4tE C6oCK eia
StNkt-E CLOCK Acrl-#4rE swirco/
MASrdQ Cc fFwrs J-J4
STOP(Ls40 CcE)/Ru#J Swlfcu/
J	 FAv^T lwlf?r od Svil cr/ ^1
vt	 -
NorE = ic.rt4wAL ,•vs^RS^Pt A.yo IAt t) q 'AvI}^ c q^^ ow TTr	 __
O A^^ E N G 5 $ I {^
y 3' g A B F~ I 6 4-,I
Modules To
Execute Function
Module Function
CPE CPE CPE CPESelect Select Function To Be
(Left) No. 4 No. 3 No. 2 No. 1 CCE (Right) Executed
No No No'. No Yes CCE SELECTED0
0 LOAD CPE STATUSL 1 Yes No
2 Yes No 1 LOAD MEMORY STATUS
3 1 Yes 2 LOAD IOP STATUS
4 Yes
1
No No Other NO-OP
CPE SELECTED5 I Yes
0 MUR READ6 Yes No
7 Yes 1 MUR WRITE
84. Yes No No, No .2 MEMORY READ
9 Yes 3 MEMORY WRITE
A Yes No 4 LOAD PSWO-31
B I Yes 5 LOAD PSW32-63
C Yes No No 6 READ PSWO-31
D Yes 7 READ PSW32-63
E Yes No 8 LOAD IR
F Yes 9 LOAD PRR
'r A , LOAD MAR
B LOAD MQR
C LOAD ROM ADDR. REG.
D INITIAL PROG. LOAD
E NO-OP
F
TABLE 7-1. FUNCTION ACTIVATE SWITCHES
I	 I	 I
I
MAINTENANCE PANEL/ ELECTRONICS INTERFACE
MAINTENANCE PANEL/ ELECTRONICS - ALL MODULES
1. Fault Entry Switches (6)Panel to all SFLTIN
2. Scanout Source Select (8)	 Panel to all SSOC
3.. Scanout Buss (66)	 All to Electronics TSBUS
4. Scanout Enable (1/module - tw) 	 Electronics to all TSOMS
5. Master Clear (17module - tw) 	 Electronics to all -TCLR
MAINTENANCE PANEL/ ELECTRONICS - CCE ONLY
1, Panel Control (12)*	 Electronics to CCE _.
2. Clock, Sync (2. - tw)	 CCE to Electronics TCLK, TSYNC
*,Not included in motherboard cabling.
_ MAINTENANCE PANEL/ ELECTRONICS - CPE ONLY
i
j
1. Panel Data, Address (54)	 Panel/ Electronics to CPE
	 SPADR	 ,. SPDAT
2. Panel Function Select (4)	 Panel to CPE, CCE SPANF
3. Panel Function Initiate. (2 /CPE - tw) Electronics to CPE -TPFINT - TPMURQ-
4 Breakpoint, Single Command 	 Electronics to CPE TBPTACT, TSCMACT,
Activate, Step 0 - tw) TCMSTEP
5. Breakpoint Reached (1/CPE - tw)
	
CPE to Electronics TBPTLED, - TBKPT -
NOTE: All lines are single-ended unless marked tw (twisted pair).
	 x
1
3MAINTENANCE PANEL/ ELECTRONICS INTERFACE
MAINTENANCE PANEL/ ELECTRONICS - ALL MODULES
1. Fault Entry Switches (6) The fault entry switches allow the insertion of
switchable faults into any 6 desired points in any modules for fault tolerance
studies.
2. Scanout Source Select (8) The scanout source select switches allow selection
of up to 16 different scanout sources independently for each of the two 33 bit
scanouts on the maintenance panel.
3. Scanout Buss (66) - The tri-state scanout buss multiplexes inputs from scanout
sources in each module into the maintenance panel scanouts.
4. Scanout Enable (1/module) - The maintenance electronics decodes the scanout
module select switch output to provide an enable to the scanout multiplexers in
the module selected.
5. Master Clear (1/module) A master clear is provided to all modules when the
master clear pushbutton on the maintenance panel is activated.
MAINTENANCE PANEL/ELECTRONICS-CCE ONL Y
1. Panel Control (12) - Panel control lines to the CCE include Panel Data (5),
Panel Function (2) and Load Initiate to allow loading new configuration
assignments to the CCE from the panel; a STOP/run line forcing ARMS to
stop for reconfiguration; single clock activate and initiate lines; and an
external interrupt line.	
4g
2. Clock, Sync (2) - The CCE sends the maintenance electronics the system
x	clock at the highest frequency used in the system and a sync signal at 1/2
this frequency.
MAINTENANCE PANEL/ ELECTRONICS - CPE ONLY
1. Panel Data, Address (54) - The Panel Data and Address Lines allow loading
memory and key CPE registers from the maintenance panel under microprogram
control.
2. Panel Function Select (4) The output of the panel function select switch is decoded
within each CPE to allow activation of one of up to 16 panel functions for loading
memory and key CPE registers.
3. Panel Function Initiate (2/CPE) - Each CPE receives separate panel function
initiate lines allowing individual execution of activated panel functions for diagnosis
and/or fault insertion. Panel switching allows initiation of activated functions in
from 1 to 4 CPES simultaneously. One line provides a synchronized output, the
other a direct output from the pushbuttons antibounce circuit for MUR operations.
4. Breakpoint, Single Command Activate, Step (3) - Panel switches allow activation
of breakpoint and single command modes of operation within the ARMS CPE. The
Breakpoint/Single Command,Step switch allows stepping the program beyond the
breakpoint in the breakpoint mode or stepping it ahead one instruction in the
single command mode.
5. Breakpoint Reached (1/CPE) - When a CPE stops at a breakpoint, this line signals
this condition to the maintenance panel indicator.
F
t
a
