An investigation of program exchange methods for multiprogramming environment. by Hatch, Ross R.
Calhoun: The NPS Institutional Archive
Theses and Dissertations Thesis Collection
1964
An investigation of program exchange methods for
multiprogramming environment.
Hatch, Ross R.







This document has been approved for public




AN INVESTIGATION OF PROGRAM




AN INVESTIGATION OF PROGRAM




Lieutenant, United States Navy-
Submitted in partial fulfillment of











AN INVESTIGATION OF PROGRAM




This work is accepted as fulfilling





United States Naval Postgraduate School

ABSTRACT
An investigation of program exchange techniques and methods of
evaluating such procedures is conducted. Basic hardware and system
parameters vitally affecting program exchange are discussed. The basic
program exchange methods covered are 1) the Complete Program Exchange
2) the Block or Page Exchange and 3) the Completely Integrated System
Exchange. The investigation is conducted using heuristic analysis,
and a simulation study is conducted on selected methods. The combined
analysis not only evaluates present methods but provides a guide for
evaluating and selecting an Exchange technique for any system configura-
tion . A complete multiprogramming system simulator and a specific
technique for status preservation are presented as Appendices .
The author wishes to express his appreciation to Mr. Jules I.
Schwartz and the members of the ARPA Time-Sharing Project, System
Development Corporation, Santa Monica, California for their assistance
and to Professor Mitchell L. Cotton for his invaluable advice and en-







3.0 The Executive Control Routine 6
4.0 Program Exchange 9
4.1 General Considerations 9
4.2 Exchange Techniques and System Capacity 10
4.3 Space Allocation 13
4.4 External Storage Devices 16
404.1 Magnetic Drums 17
4.4.2 Magnetic Discs 17
4.4.3 Magnetic Tapes 21
4.4.4 Cartridge Units 22
4.4„5 Woven Screen 22
4.4.6 Comparison of Storage Devices 23
4.5 Memory Protection 23
4.6 Relocation 29
5.0 Complete Program Exchanges 32
5 . 1 Storage Compacting 32
5.2 Preservation of Environment 33
5.3 Basic Complete Program Exchange 34
5.4 Two Level Storage 35




5.6 Complete Program Exchange with Space
Allocation 37
5.6.1 Hardware Constraints 38
5.6.2 Hardware Determined Methods 38
5.6.3 Space-Sharing Exchanges 40
6.0 The Block Exchange 42
6.1 The Page Exchange Method 43
6 . 2 Pageturning Algorithms 48
6.2.1 Two Level Checking 49
6.2.2 Adaptive Algorithms 49
6.2.3 The Decay Algorithm 50
6,,2o4 Probability Allocation 51
6.3 The Pseudo Block Exchange 52
7.0 The Completely Hardware Oriented Exchange 55
7.1 The CDC 6600 55
7.1.1 The Central Processor 56
7.1.2 The Peripheral and Control Processors 58
7.1.3 The Central Memory 59
7.2 The Exchange Jump 60
7.3 Executive Control 62
7.4 Critique of The Hardware Oriented Method 62
8.0 Simulation 64




8.1.1 The Basic Simulated System
Configuration 67
8.1.2 Exchange Method 1 67
8.1.3 Exchange Method 2 69
8.1.4 Exchange Method 3 69
8.2 Simulator Output 71
8.3 Simulation With Type 1 Inputs 72
8.3.1 Analysis of Results 7 3
8.4 Simulation With Type 2 Inputs 74




I. SIM - A Multiprogramming System Simulator 102
II. Program SIM 108






1. A Basic Space Sharing Scheme 12
2. Basic Space Allocation Methods 14
3. Comparison Graph of Access Time vs Capacity for
External Storage Devices 18
4. Table of Representative External Storage Devices 19
5. High Speed Transfer Channel Configurations 39
6. ATLAS Block Address Format 46
7. The Pseudo Block Exchange 53
8. The CDC 6600 System 57
9. The Exchange Jump Instruction 61
10. SIM Load and Quit Operations 66
11. SIM Exchange Methods 1 and 2 68
12. SIM Exchange Method 3 70
13. SIM Job Input Table 73
14. Simulation Results - Mixed Jobs - Exchange Method 1 76
15. Simulation Results - Mixed Jobs - Exchange Method 2 77
16. Simulation Results - Mixed Jobs - Exchange Method 3 78
17. Simulation Results - Mixed Jobs - Exchange Method 2
with Single Cell Resolution 79
18. Simulation Results - Mixed Jobs - Exchange Method 3
with Expanded 64K Core 80
19. Simulation Results - Single Job, with Increasing Mean
Size, Ten to Fifty Users - Exchange Method 1 81
20. Simulation Results - Single Job, with Increasing Mean




21. Simulation Results - Single Job, with Increasing Mean





















Maximum number of operating user stations permitted in the
system
Maximum number of users that can receive service during a
given cycle
System response or cycle time
Exchange time
Quantum





Recent technological advances in high speed logic, digital data
transmission, random access mass storage devices and related fields
have freed the system designer from many former constraints . The
resulting complex large scale systems will be able to operate in a
practical and efficient manner only through the use of a technique
such as multiprogramming. The term, multiprogramming, is applicable
primarily to the computer with a single processing unit and is defined
as the execution of several programs by the transferring of control
among them in a controlled fashion, but where one and only one program
is in control at any one time . (9)
Multiprogramming, by definition, includes the concept of pro-
viding simultaneous service to several on-line users. However, the
majority of the work in the field is involved with concurrent type operations;
the interleaving of various type programs to improve overall efficiency.
A common example of this is the combination of the compute limited and
the I/O limited program to permit each element of the system (i.e. the
central processor and each peripheral device) to use a greater portion
of the operating cycle. The goal of this type of operation is the fulltime
use of every system element.
An area which is now receiving attention, and deserves much
more, is that of time-sharing, or the furnishing of service to several
on-line users. Bright and Chedleur have suggested the term "multiple
break in operation" to more aptly describe this type of operation which

concentrates on user service. (3) Due to inherent reaction time delays
in man-machine communications, several on-line users can obtain vir-
tually simultaneous service. The system can offer assistance simultane-
ously to several programmers for on-line debugging and program modifica-
tion in the program formulation phase; provide a control system for war
game simulation and data retrieval; and perform various command and
control functions Short bursts of service are thus provided to several
on-line users, while the batch jobs, serving as a system background,
are only slightly degraded. This paper will approach multiprogramming
in this service context. Accordingly, time-sharing, which has been
used in various ways in the literature, will be defined as the essentially
simultaneous use of a central processor by several on-line users.
The introduction of multiple simultaneous users into a system
immediately creates severe control problems. A comprehensive Executive
Control Routine (ECR) is required to exercise positive control over the
system. The characteristics of this routine and effectiveness of its
control will exert a dominant influence on the overall system efficiency.
One of the most difficult problems faced by the Executive Control
Routine is program exchange. To permit several simultaneous users in
the system, an efficient method must be devised to exchange programs
while retaining all status information and program environment. This
information must be readily available for use when restoring a previously
terminated program. As control is passed from one program to another,
the loading cycle must include the resetting of the environment and

status. This paper will investigate and analyze the various aspects
of the Exchange problem and outline the general hardware and software
requirements. Particular characteristics will be noted and a general
analytic procedure to evaluate various exchange methods developed.
A System Simulator will be used where applicable to test the effectiveness
of various exchange techniques on overall system performance. The final
result will not only furnish a summary of exchange methods available,
but provide a general analytic technique using both heuristic and
simulation methods to evaluate future exchange methods.

2 . Background
Several widely diverse interest groups can benefit from a time-
sharing system. Each, individually, would impose slightly differing
timing and control problems, but these could be accommodated relatively
easily in a general system. The technical knowledge of each group will
vary widely, and the system must retain the capability of serving the
most experienced and well trained user while providing service to the
neophyte. The following paragraphs will describe several areas where
time-sharing could be utilized to good advantage. Some are current
problems that are presently handled by other means, while others are
uses that would become economically feasible through the use of an
approach such as time-sharing.
The programmer's debugging problem is too time consuming to
permit individual use of a large computer Time-sharing, however,
provides virtually instantaneous computer reaction time and allows
others to operate while the programmer is interpreting results. The
excessive turn-around time experienced in closed shop batch job
operation is thus avoided, or at least, considerably reduced. Another
desirable feature oriented toward the engineer/programmer is the ability
to make repeated runs
,
changing parameters on the basis of preceding
runs without closed shop delays. This is easily accomplished under
time-sharing.
Real time operations fall into the purview of the time-sharing
system. In control and monitoring applications, where the demands

for service are normally absolute, the system can easily become
saturated, and extreme care must be taken when including this type of
activity in an operating system.
On-line data retrieval appears to be the most promising of the
future applications of time-sharing. A user will have access, from a
remote station, to a large data base. This will not only allow faster
handling of tasks that were formerly done manually, but encourage the
use of data retrieval to enable more informed decisions to be made.
The ability to provide such a service to a multitude of users makes it
economically feasible for all. Banking uses and airline reservation
systems fall into this general system.

3. The Executive Control Routine
All multiprogramming and multiprocessing systems from the
basic stack job processor to the most complex on-line system depend
on an Executive Control Routine for their effectiveness. The increasing
interest in multiprogramming systems has been reflected in the greater
emphasis being placed on the general subject of control routines The
primary requirements of the Executive Control Routine are reliability and
effectiveness. The user must be able to assume that the system program
is error free and virtually fool proof, and that long periods of service can
be expected. This implies that the Executive has the capability of
recovering from both object program and machine errors.
Though terminology may differ, the Executive Control Routine con-
sists of five basic parts. The Interrupt Handler passes control to various
parts of the Executive and establishes the initial flow. The Scheduler
determines what programs are to be run, in what order, and for how
long. The Dispatcher handles all I/O transfers, and the Sequencer
establishes the normal flow through the entire Executive. The Exchange
Routine uses the information from the Scheduler as inputs to allocate
internal and external storage and initiate program transfers through the
Dispatcher. Other functions of the Executive include Rollback and
Recovery, interpretive packages and, if provided, debugging routines.
The Executive must, in general terms, perform as an efficient and
capable executive or supervisor, and the broad requirements can be
determined without difficulty. It is when specific portions are subjected

to detailed investigation that the difficulties become more apparent
The constraints and problems created by a specific system or approach
will vitally affect the system in question, and all facets must be
carefully considered.
To provide a general idea of how the Executive functions , the
sequence of operation of a typical time-sharing system will be described.
All object programs are initially stored in a high speed random access
store
,
placed there by a load command to the Program Exchange Routine
.
At the start of a basic cycle, the Scheduler determines the queue, and
the Exchange Routine brings the required program into core at f or preferably
before, its actual active quantum. If a storage conflict occurs, the
previous programs are transferred to the external store as required. At
the completion of a program's active period, whether through an early
termination or the normal end of a quantum, the program environment
(i.e. statue of all operational registers, etc.) is saved and, dependent
upon the system load, the program is either saved in core or transferred
to the external store awaiting its next turn. A basic concept that will
be followed throughout this paper is that no user will be transferred
from core unless a storage conflict exists. The specific conflicts will
be determined by the exchange method as will procedures to reduce
both the probability and the effect of such conflicts
.
This paper is primarily concerned with the Program Exchange
portion of the Executive Routine, and it will be assumed that the
remainder of the Executive performs its basic functions in a normal

manner. If any deviations are required by a particular exchange
method, they will be noted.

4 . Program Exchange
As long as the compute speeds greatly exceed I/O rates , as they
do at present, the program exchange phase will remain a critical opera-
tion. When the Scheduler determines a request is to be honored, the
Exchange Routine determines what jobs, if any, need to be dumped to
provide the required core space, where to load the new program, and
saves all required information, sets memory protection limits when
applicable and handles relocation if provided in the system. The
Exchanger also handles space allocation and maintenance in both core
and in external storage devices
.
4.1 General Considerations
The effectiveness of the exchange technique will be determined
to a great extent by the hardware configuration of the system. Memory
protection is of vital importance, and it should be emphasized that
without this feature the integrity of even the Executive Routine cannot
be guaranteed. Relocatibility is both a hardware and a software feature.
Lack of this capability seriously hampers the system in that dynamic
space allocation is virtually impossible and space is essentially
allocated by the compiler.
Although several of the exchange algorithms to be discussed are
hardware limited, some can be used to overcome hardware deficiencies
and improve the system. The system itself determines to a great extent
the type of swapping used, and core utilization must be carefully weighed
against overhead time required. In the analysis of the exchange algorithms

the emphasis will be placed on hardware requirements, overhead and
core utilization with the aim of providing the user with the most effi-
cient service. The basic approaches will be handled first, and then
various combinations investigated to find the most effective methods of
solving the swap problem
.
The normal exchange methods can be divided into two basic groups
,
those that swap entire programs, and those that handle blocks or "pages",
the blocks or "pages" being defined as data blocks less than program
size in length. Each method has its particular advantages and, although
complete program swaps have been favored in the past, the increase in
the number of users in a time-sharing system coupled with the reaction
time required and the increasing size of programs calls for a critical
re-evaluation of both methods . Many of the problems are common to
several techniques and will be discussed in detail when they first occur
and only mentioned in subsequent methods
.
4.2 Exchange Techniques and System Capacity
The reaction time of the system is one of the basic parameters of
a time-sharing system. The decision as to reaction time will vitally
effect both the user and the system. A selection of too small a reaction
time (t
f
) will seriously decrease the number of active users serviced
during a cycle while too long a period will result in disgruntled users.
Although the users are receiving better service than could be expected
in a closed shop operation, personal observation has shown that the
addition of even a few seconds delay will tend to cause general
10

discontent among users. A second basic system parameter is the quantum
time or the time alloted to a specific user during a given cycle. The
determination of quanta is treated in detail by Lt. W„ G. Wilder (31) .
The Executive Control Routine establishes an operating queue and passes
control to the proper programs. The only delay in the passing of control
is the non-availability of the program in core. Due to the length of
transfer times relative to compute times, the basic exchange time (t )
s
will normally exceed the quantum and will become the limiting factor in
the number of users serviced. In the normal passing of control, the
program in core is dumped, the required program loaded and run for the
quantum. Thus (2t_ + q) is required for each user and the maximum
number of active users per cycle is given by:
nmax = Vd-^)/ (2ts+ q)
This is based on the complete swap approach when, due to hardware
limitations and/or program size, only one program can exist in the core
at any one time. These constraints will be discussed more fully in the
following sections
.
If programs are relocatable, the two users may exist in core
nmax=tr
(1
- * > f 2ts
and q may be as great as 2t with no degradation of service. The process
























A BASIC SPACE SHARING SCHEME
FIGURE 1
It would appear that n can be further increased by allowing more
max
users' in core and more simultaneous transfers, and this is true However,
this requires multiple high speed I/O channels, and this, in itself, pre-
sents new problems
.
The analysis of particular methods of program exchange is intended
to both delineate the capabilities and limitations of the individual pro-
cedures and also to demonstrate a general approach to the exchange
problem. As new hardware developments permit new techniques for
program exchange , these can be analyzed in a similar manner and
evaluated against the same standards . Before treating individual methods
of exchange, a discussion of generalized techniques such as space
allocation, memory protection, relocation and random access storage
mediums will provide a general background and permit certain vital




The preceding discussion of the effect of exchange methods on
system performance also raised the problem of space sharing or space
allocation. The examples used, considered extreme cases, whereas
this section will treat the general allocation problem. Space allocation
methods and program exchange techniques are closely interwoven, and
the complete specification of one virtually determines the other. Because
of this interdependence, space allocation is of vital importance in both
the complete program and the block exchange concepts. The allocation
scheme may range in complexity from the basic, one user approach,
to full packing and even to the interleaving of instructions found in
languages such as LISP and IPL. The basic ideas presented will be
applied in various exchange methods, and the specific analysis will
show the details involved and enumerate the hardware requirements
that are imposed.
The graphic representation if Fig. 2 will be used to illustrate
the dynamic changes in core storage during a typical interval of each
of the basic allocation types. Due to the multiprogramming emphasis
intended, it will be assumed that the Executive remains in core, and
the allocation methods will be concerned only with the remaining core
.
The basic single user allocation depicted in Fig. 2a. This is
the type normally used in a system control program such as the Fortran
Monitor and results in low core utilization factors, typically 0.10.








...... — , . , ___
(
3* j\





1* 1 f l f *l f
-
t5

























. ^n .—— --..„«.^» ,
_
,.,-~
















Lv*.~J Unused core * Run for Quantum
t- Load f- finished |- Dump




available core to the next user. The effect of this approach will be
more fully explored in the analysis of the basic complete program
exchange method
.
The dense, complex packing shown in Fig. 2b is used to best
advantage in the system where memory is initially loaded, and then all
programs run to completion before any exchanges are made . This type
of multiprogramming system, typified by the Ferranti FP6000, concen-
trates on utilization efficiency and is not concerned with on-line users
.
The complexity of packing for each load can lead to complications and
delays if the load is frequently changed. This method does not seem
suited to any great extent to the time-sharing system with its constantly
changing load and the requirements for exchanges every quantum. The
problems created by time-sharing can be seen in Fig. 2c, where, although
some packing is attained, the overhead for the space sharing allocation
plus the occasional dead time reduces the system efficiency.
Fig. 2d is similar to the ideal block allocation case previously
mentioned. The average core utilization factor lies between case a and b,
and, as the programs approach the block size in length, the higher factor
of b is approached. The method requires either large memories, short
programs or program modification, but avoids many of the disadvantages
of the other methods . For maximum system efficiency, the exchange
time, t , should be completely overlapped by the minimum q. This
requires that for Fig. 1, q=2ts , while Fig. 2d requires a q=t
s ;
the
methods do, however, require one and two high speed transfer channels
15

respectively The constraints imposed by this requirement will be
discussed in the development of the complete program exchange.
4.4 External Storage Devices
When a program exchange is made, the program being removed
must, obviously, be placed in some external storage device. The
types of external storage available to the system will vitally affect
the exchange method selected and the efficiency of the exchange
phase of the control routine. Transfer rates and access times vary
greatly not only between types, but among classes of specific types.
A brief description of various external storage devices will establish a
background for future decisions and delineate possible problem areas.
The ideal storage device is the magnetic core memory which
provides an extremely high speed, random access storage device.
Cost factors, however, render this impractical for the storage of
large amounts of data . The widely varying loads to be expected in a
multiple on-line user environment require the capability of storing the
programs of all active users. The amount of external storage available
for program exchange will establish one of the basic limits on the number
of users allowed into the system at a given time . This limit is the
maximum number of stations in use, and not the lower valued number
of active users in a given cycle. While disc and drum storage, both
random access devices, are the most applicable to the multiprogramming
exchange problem, the magnetic tape system is included, due both to its
flexibility and its low cost. These, along with some of the less common
16

storage devices, will be described in the following paragraphs. A
summary of representative storage devices is presented in the graph
of Figure 3 and the Table of Figure 4
,
4.4.1. Magnetic drums
Magnetic drums provide an extremely fast random access capability
at a lower cost than core. The magnetic tracks on the circumference of
the drum may be read by either fixed or movable read/write heads . The
circular track implies a maximum rotational delay of one drum rotation
and an average time of half this amount. The movable head drum requires
proportionally fewer heads and has a lower cost per character than the
fixed head type. Positioning time, however, is increased from zero in
the fixed head system to typical values of 50 to 300 msec, for various
movable head systems. The cost vs. access time relationship can
more easily be seen in Fig. 3 and Fig. 4.
4.4.2 Magnetic discs
Discs files are a natural step from the drum approach. Several
discs mounted on a common shaft provide a lower cost per character
than found in the drum devices . The time required to position mechani-
cally the read/write heads plus an increased rotational delay makes the
typical disc considerably slower than the drum. Various schemes for
positioning the access arms are used, but all must solve difficult, but
basically mechanical, problems. Of major importance among these
problems are increasing the speed and accuracy of positioning and








































































































































° 2 O 2










o 1 1 O 1






































































> r>. 6 S? 5 ^t^ «=; o
























































































































































ia ° o n vh
r-H O CD CD




















the heads . Complex mechanisms have been developed to handle the
positioning, floating heads maintained by air cushions to protect the
discs and positive measures provided to ensure separation in the event
of power failures. The problems, however, are not completely solved,
and movable head discs remain chiefly as large capacity storage devices
with the disadvantage of excessively large access times. In the early
discs devices the arms moved in unison, while newer units permit
individual movement. A typical late model is the Data Products Discs
being installed in the Q-32 Time-Sharing System, in which the access
arms are mechanically independent, although, at present, only one
arm may be positioned at a time. Careful allocation may decrease the
effective access time, although the apparent mean will not decrease.
In the Data Products unit, the access arm consists of eight heads;
four above and four below which read or write in a simultaneous serial-
parallel mode. The rotational delay encountered in the drum is also
present in the disc storage unit. The movable head disc does provide
an excellent random access storage for large data bases that would
saturate the practical drum system.
A recent development in mass storage devices is the fixed head
disc which may be thought of as a three dimensional drum storage
surface. Access times are comparable to fixed head drums, in the
order of 20 milliseconds. Due to the large number of characters handled
through the basic control unit, the cost per unit character is comparative
with high speed drums of a lower capacity. In the commercial unit,
20

the Burroughs B472, the transfer rate is quite slow, 100K characters
per second. This results in transfer times almost an order of magnitude
higher than those commonly available in drums. Undoubtedly, serial-
parallel transfers would increase the transfer rate, but this would also
increase the cost to the point where it equalled at least that of high
speed drums . The fixed head disc should be thought of as the logical




The lowest cost device with the greatest capacity is still magnetic
tape. The chief disadvantage, which proves to be decisive in most
cases, is the lack of random access. Records are available only
sequentially, and intolerable delays will result if an appreciable tape
searching is required. The high density tape is capable of speed in the
vicinity of 62. 5K characters/sec. If the tape does not require positioning,
access times are in the order of five to thirty milliseconds, which is
comparable to other types. However, unless only two programs are active
repeatedly, searches are required and access time in the range of tens of
seconds encountered. This would obviously degrade a system to the
point of almost uselessness. Tape does still provide an excellent
storage for programs that are not active but need to be retained in the
system. An example of this is the handling of disc overflows, where
programs selected by some aging criteria are transferred to tape when
active users require more disc capacity than is available. Tape,
21

therefore, appears useful primarily as a backup, or secondary, store
and should be considered as a primary store only if the other types
of more effective storage are not available, and/or severely reduced
system performance is acceptable in light of the cost reductions.
4.4.4 Cartridge units
A promising storage device is the cartridge unit with replaceable
sections which present a combination of the random access disc and
the large volume characteristics of tape. Large delays are encountered
when non-loaded cartridges are required, but this appears to be a method
of handling disc overflows that should not be overlooked. Rather than
transfer selected programs to tape as space is required, cartridges would
be switched and retained for future use. There are problems in implementa-
tion, but the approach deserves consideration and careful observation to
allow inclusion into the multiprogramming system when performance
warrants it. If positioning times can be reduced
,
this device will be
able to compete with discs in the large volume storage area
.
4.4.5 Woven screen
The woven screen memory concept now under development is the
multiprogramming storage device of the future and would solve many
of the program exchange problems . A large capacity high speed random
access storage device would be available at a relatively reasonable
cost estimated at only about three or four times that of a high speed
drum. It appears that the reduction in swap time, if any is required
at all, will provide a sufficient time saving to justify the use of such
22

a storage device in terms of the great increase in the number of active
users permitted.
4.4.6 Comparison of storage devices
The characteristics of representative units of the various storage
device types are shown in Figure 4. The woven screen memory is
included only as a forecast and will not enter into future discussions.
It should be noted that the transfer rates of discs are only two to four
times that of drums, while the access times are at least one order of
magnitude greater. If schemes can be found to reduce the effective
access time, discs could compete favorably with drums. The ability
to issue a "look ahead" command followed by reading provides one
scheme and will be fully explored. The higher cost per character of a
drum requires that the size required be carefully determined. Fig. 3
provides a graphic presentation of the primary areas to which each
storage device applies in terms of cost, typical sizes, and access
time. These several descriptions provide an idea of the advantages
both practical and economic which accrue from the proper combination
of external random access storage devices The basic characteristics
described will be applied in any determination of the optimum exchange
methods
.
4 . 5 Memory Protection
Any practical multiprogramming system should provide a memory
protection capability, During active periods, a minimum of two users,
the Executive and one object program, must coexist in memory. If the
23

system is to function in a reliable fashion,, the status of the Executive
must be preserved unaltered. Further, to provide satisfactory service
to the users, they should be protected from each other.
Two basic degrees of protection are readily apparent. The first,
malfunction protection, is absolute in nature, encompassing both hard-
ware failures and interprogram interference and appears virtually im-
possible. A comprehensive automatic recovery program such as the
IBM FIX used in the Q -32 can overcome many hardware failures but
requires extensive overhead and adds immensely to system complexity.
This section will be concerned only with the second type of protection,
interprogram protection, and the methods of attaining protection in an
effective but flexible mannner.
Before deciding on a method, the degree of protection must be
established. The Executive Routine must have access to all areas,
whereas object programs should be either read or write protected or
both, and illegal entries (jumps) should be prevented. Although it does
not concern the Exchange problem, the I/O Dispatcher must prohibit
write operations in forbidden (Executive) or inas signed areas of both
external storage and core
.
The memory protection method and its effectiveness are very
important parts in determining the overall system performance . An
uncontrolled program can not only damage itself, but other users and
the Executive routine which renders the system inoperative. In as
much as the memory protection provided affects the program exchange
24

method used, it also exerts an influence on the number of users per-
mitted. This section will describe several memory protection schemes
in detail. Later sections will demonstrate the influence of memory
protection on various exchange methods.
Due to the high frequency of core references in any program,
protection should be implemented by hardware rather than software.
The following list of characteristics is a modification of a list proposed
by E.A. Codd (4) and represents the primary areas with which a memory
protection scheme should concern itself.
1
.
Resolution - The smallest block which can be protected.
Flexibility in determining block size should also be considered.
2. Adjacency - Can non-adjacent areas be simultaneously
protected? What are the limits on this multiple protection feature?
3= Types of protection - Are data handling and operational
violations handled differently? What combination of read and/or write
protection is afforded?
4. Performance - What penalty, if any, is paid for protection in
total system performance?
5. Treatment of potential violations - How are violations handled?
To provide a useful service to the user as well as a safeguard to
the system, potential violations should be trapped and an interrupt jump
to an error routine initiated. The user should be informed, as specifically
as is compatable with allowable overhead constraints, of the nature of
the violation. This general treatment of handling violations will suffice
25
I
for this section,, and attention will be devoted to studying the ways
various memory protection schemes are implemented and how effectively
they perform.
The Bounds Register approach is one of the most useful protection
schemes. It is controlled by the Executive which sets limit registers to
bound the area available to an object program. Hardware comparison is
made to these registers automatically and simultaneously for each
instruction requiring memory access. This technique is used on both
the IBM Stretch and 7090, the CDC 6600, and the RCA 601. The RCA
601 also utilizes the lower limit register in conjunction with object
program addresses to provide relocation on loading. This method is
extremely flexible in both size and location, and multiple bounds
registers may provide protection to several non-adjacent areas. Another
addition to the hardware permits selection of protection of the area either
inside or outside of the bounded area. The disadvantages are the large
amount of logic circuitry required and the timing problems involved in
comparison
.
A modified bounds register is used in the IBM 7040. In this
approach, the lower boundary of protection is loaded into a 9 bit register,
which is then compared against the higher order bits of the effective
address to determine if the number is equal or unequal. Another register
defines how many of the higher order bits will be compared. The value
in this count register determines whether the protected area enclosed,
starting from the base address, is 1 K, 2 K, up to 64 K. An additional
26

feature is the option of specifying the legality of the unequal or equal
condition. One choice, the illegal inequality, protects the area outside
the defined area. Conversely, the equality being illegal protects the
area inside the boundary. Less hardware is required by this method than
in the complete boundary register method, and timing considerations are
not as stringent. Due to the bit setting nature of the approach, the size
of the protected areas is is 2 K increments.
The mask register method of protection is similar to limit register
approach. The mask register has one bit for each memory block, and the
setting of any bit establishes a protected area. Fewer hardware complexi-
ties and timing problems areise, as the method requires only one bit per
block. The Executive can maintain a table of memory areas, or they can
be carried with the object programs, and each change it controls will
be preceded by a resetting of the protection mask. The system provides
for any combination of blocks desired, but the size of the blocks is an
inflexible hardware parameter
.
The Ferranti Leo III uses a mask type of protection but applies it
to each individual storage location in the form of a tag. When a program
is entered into the memory, a tag identification is set on all locations
available to the program. Object programs may use only those locations
tagged for its use . Certain areas available to several programs are
given special tags . This method is effective in the environment where
several programs are placed in core and remain there until completion.
Non-adjacent areas are protected, and any size protected area is
27

selectable. However, the method becomes consuming for applications
where frequent exchanges are encountered and is generally unsuitable
for time-sharing applications.
The Q-32 uses a mask type of protection scheme. Each of the four
logically separate 16K memory banks has a control flip-flop to establish
a protected area. The primary disadvantage is the coarse, 16K resolution.
This will be improved by a modification to provide mask registers for each
block. Protection will be available in contiguous increments of 2K with
no non-adjacency provisions.
The next major approach is hardware lockout. In the Atlas applica-
tion, object programs operate in a different mode than the Executive and
cannot generate addresses addressing a restricted portion of memory. If,
due to hardware errors, illegal addresses occur, interrupt transfers to
the error routine are made
.
Fixed or "read only" memories provide a rigid protection which
requires little overhead or parallel logic. Deposited capacitors or
inductive arrays are pre-set and cannot easily be altered. Compactness
and low power requirements enable high switching speeds to be attained.
This provides an excellent storage for the Executive but cannot even be
considered for interprogram protection. Due to the difficulty in changing
the storage, it is of doubtful value for even the Executive.
The last program protection method is a software approach. This
is used in some debugging routines when no other methods are available
,
but it is so time consuming as to preclude its use in most other areas.
28

The most practical protection scheme from the Program Exchange
viewpoint is a modified mask approach. The requirements for protection
of blocks of under IK in size cannot be justified in the practical case.
The hardware costs .. overhead impose , and circuit complexity far out-
weigh any increase in capability. The masks would be re-set each time
control is shifted. The containment of the program in control provides
the desired protection,, and no further non-adjacency requirement is
apparent. This is by no means a complete solution, but adequately
defines a practical method which satisfies the general requirements of
memory protection for the purposes of Program Exchange methods.
4.6 Relocation
The term relocatability can be defined as the independence of
the object program from the constraint of occupying a specific area in
memory. Relocatability provides a technique for improving the efficiency
of program exchange schemes over the basic run and reload method. Core
space allocation , which helps provide the desired improvement, is
realizable only with relocatability . In most multiprogramming systems
neither the system nor the program will know what area the object program
will occupy at run time nor should they be required to. Indeed, due to
exchanges, a program may occupy several areas during its execution.
Combinations of hardware and software are best suited to providing the
desired relocatability.
The most common method of program relocation uses a base register
or pseudo base register. At first inspection, compilation to a base
29

address of zero with modification in accordance with a base register at
load time seems to solve the problem simply and effectively. In principle,
it does, but, upon closer investigation, problem areas are revealed.
The various instructions treat the address portion in a great variety of
ways, and no general modification scheme is apparent. Hence, each
instruction must be inspected and then modified in the proper way using
the base register. If a "relocation" bit, which signals the addition of
the base register
,
is provided, much of the hardware complexity is
avoided. This bit can be either part of the instruction itself or entered in
the header of the binary record used to control the load.
Another approach is a basic system scheme which, incidently,
provides relocation. This is page turning, developed to a great extent
in the Atlas system. Pages of a fixed size (512 words in the Atlas) are
transferred, and a page address register containing the most significant
bits of the core address of the page loaded is associated with each page
read into memory. Hardware comparisons of the required page address
and the available page addresses are made to determine if the referenced
page is located in core. If not loaded, an interrupt is generated and the
page loaded as soon as possible. The hardware utilized for paging also
provides memory protection. The program relocation problem is auto-
matically handled through the page address register, and memory alloca-
tion is simplified. The paging concept will be treated in greater detail
when studied as a basic program exchange technique.
30

While no particular scheme is favored, it will be assumed that
relocatability is provided by a specific exchange method when required
31

5. Complete Program Exchanges
As a basic exchange method, the complete program approach has
the chief advantage of simplicity. Programs are handled in a natural
fashion, in their entirety, and no undue overhead is created. The entire
program is available at all times during the quantum, and closed sub-
routines can be utilized to reduce program size. No unusual demands
are placed on the compiler as, at worst, only relocatibility bits are
required. In contrast to the "page" approach, there are no inefficient
pauses while pages are checked and required pages called, nor is a
large overhead required to keep track of the pages and their status .
Space allocation, memory protection and relocatability provide the most
efficient type of operation. The most serious disadvantage is the
presence in valuable high speed core of large strings of coding which,
although they cannot possibly be operated on in one quantum, must be
transferred in and out of core during each active period. Several large
users can effectively thwart space allocation and make the value of
memory protection and relocatability marginal. A relatively small core
and a large Executive Routine which must remain in core at all times
impose a limit on maximum program size. This can become a major
system constraint in an environment characterized by large programs
.
5 . 1 Storage Compacting
Prior to handling specific methods , two fundamental problems
inherent in all program exchanges will be discussed. These are drum
compacting and preservation procedures. A running measure of the
32

external storage must be maintained to handle new arrivals. However,
due to a previous user becoming inactive, the available storage may
well consist of broken blocks. The basic question is then, when to
compact or compress the storage. Attempts could be made to insert a
new user in available areas or immediately upon ascertaining that suffi-
cient total space exists , the storage could be compacted and the new
user placed at the end of the active programs,. Inasmuch as the system
envisioned would be open ended as far as users are concerned, it appears
little would be gained by attempting insertion. The inspection of all open
areas to determine if the size is sufficient would be time consuming , and
subsequent arrivals would most probably necessitate compacting in any
case. The general compacting philosophy will call for compacting when-
ever it is determined that a new user can be accommodated into the system
,
and insufficient room exists after the last active program on the external
storage device.
5.2 Preservation of Environment
The second problem concerns the preservation and storage of the
program environment, the information concerning the state of the object
programs such as operational registers, I/O control words, etc,. This
information must be preserved for each program exchanged and prior to
restarting all information restored. The actual operations are to be handled
by the Executive, but the storage location is not as simply handled. If
storage is to be maintained in the Executive, the table capacity must
provide for the maximum number of users. If the system is large,
33

valuable core space will be lost to preservation tables using this method.
The alternative is adding storage to each program which carries the
required information. This increase can be implemented most effectively
by the system at load time, although the compiler could add the required
space. The first method permits the Executive to be re-setting the opera-
tional registers while the program is being reloaded, but appears to be
very wasteful of core, especially in large systems. The time required to
load several registers will, however, be relatively small (20 or fewer
major cycles) . In view of this and the more effective use of core per-
mitted, this method of status preservation is recommended. The general
concept has been used in both the SDC TSS-2 and CDC 6600. A proposed
preservation routine for the CDC 1604-160 Satellite System is presented
in Appendix III
.
5.3 Basic Complete Program Exchange
The fundamental complete exchange method is the run and then
dump and reload procedure. Its lack of sophistication provides its
greatest virtue, simplicity. No space allocation is implied, and, with
only the Executive requiring protection and no relocatability required
,
the hardware problems are simplified. Users are loaded on the external
storage, typically a drum, as they arrive, and the capacity of the drum
determines the maximum physically allowable number of users . As only
one object program is permitted in core, the maximum number of users
for a given reaction time can be obtained from
34

which is the worst case form previously developed. Lack of concurrency
of t
s
and q seriously degrades the system performance. In addition,
during the period 2t for each user, the central processor is idle,
seriously reducing the computing efficiency. In a system where the
number of active users per cycle, a function of both the number of on-line
station, N , and the job mix, is low, this type of exchange is valid.
If the smaller n is acceptable, the simplicity of the approach recom-
max
mends it. This approach will serve as the basis for other complete pro-
gram exchange methods and attention will be devoted to various means
of improving the efficiency and overcoming the disadvantages
.
5.4 Two Level Storage
The use of drum or fixed head discs seems natural in the basic
case due to the transfer times, and an increase in system capability
can be achieved by addition of a movable head disc with its large
volume storage, albeit slower access times „ In the most common usage,
the disc replaces tape storage and speeds system operation but has no
effect on the exchange problem. The disc, though, can serve as an
effective secondlevel storage device. Although the actual scheduling
will not be covered, the disc could handle large programs such as com-
pilers
,
whose long run time and few man-machine delays permit a
reduction in response time. To prevent the introduction of several
compile type jobs from degrading the system due to several repeated
slow disc accesses, a reduced service interval could be used for
disc programs. If only one disc program was allowed per cycle with
35

all programs on the disc receiving service from a round robin queue,
system response would suffer only slightly and virtually no delay would
be noticed. Using this approach, the compute limited jobs would receive
service while not overloading the system drums This type of treatment
could also be applied to slow background or batch type jobs. A limit
should be placed on even this service , as the primary function of the
disc is to overcome tape deficiencies. The secondary object program
storage should not be permitted to curtail this to any great extent. The
overhead involved can be justified in view of the increased service
offered by the system and the increased storage made available on
the drum for generaly smaller, fast reaction time programs.
5.5 The Disc "Look Ahead"
In a drum and movable head disc system, the largest delay
encountered is in positioning the disc heads. Reduction of effective
access time increases the efficiency of the concept. Means do exist
through "look ahead" features to reduce this time. Discs are available
which permit the issuing of position commands only, and the transfer
operation is ordered only after the heads are positioned. Considerable
time could be saved if the positioning could occur concurrently with the
running of another program. Then, when the present q was completed,
the next program would be ready for loading. In current units this
approach has the serious disadvantage of precluding the simultaneous
use of the disc, which was basically to replace tapes, by an object
program. The increase in system capability offered by use of the "look
36

ahead" must be carefully weighed against the lack of disc reference
for short periods. The true effect on object programs involves the
theory of program structure which is beyond the scope of this paper,
but the handling by use of a WAIT command is a method. The WAIT
reply, however, can cause one or more programs to loose their entire
useful quantum, and, due to their remaining active until serviced,
probability considerations show that the situation is likely to deteriorate
with no one receiving good service . For this reason, the method is not
recommended for general usage. The alternative is the hardware capa-
bility of independently positionable movable heads or fixed heads.
Either of these add considerable cost to the system but provide a
powerful capability. If the economic considerations warrant it, one
of these features should be included.
5.6 Complete Program Exchange with Space Allocation
The three previous techniques, while providing increasingly
better service,, are still constrained by the
"max = trO-W 2ts+«
equation. Space allocation or space sharing of core provides the most
practical method of improving this user factor „ The concurrency of
exchange and run operations permits the reduction of effective swap
time, and permits either more users or better service to the same
number of users , As previously developed, this method requires the




Concurrency of exchange and run modes will focus attention
on the high speed channels, and some introductory material is in
order. The subject of high speed transfer channels presents some
interesting paradoxes. High speed is generally construed to mean at
a speed comparable to one memory cycle . Due to the read/write nature
of memory references, it can be seen that two high speed channels can-
not operate simultaneously in a given core unit„ The slowing down of
the channels and inter-leaving of operations does not improve speed,
but only ensures that each job will require 2t , and that they will be
completed at about the same time. An alternative is the use of multiple
logically independent memory banks. A separate high speed line can
be provided for each bank and a simple stepping mechanism used in
the memory control unit to allow large programs to utilize several banks
.
The method also facilitates memory protection, especially at the block
level. Fig. 5a and 5b depict the basic configurations. While the second
has a higher cost due to both the more complex control unit and the mul-
tiple high speed lines, its advantages are attractive.
5.6.2 Hardware determined methods
The extent to which space allocation is implemented depends upon
the number of simultaneous transfer operations permitted, a hardware
determined parameter. If the three operations - run, load and save -
procede concurrently, a smaller effective exchange time results if the





' single ^L central
large f memory \ pro-
*l control/






































at least as long as the time to transfer onp third of memory is pre-
supposed. If only one transfer operation is provided the acceptable
mean program size increases to one half the available memory, and
the minimum quantum becomes the time to transfer the entire core.
The quantum constraints are introduced to reconcile the general timing
problem. If very short quanta are allowed, it is impossible to complete
the exchange concurrently with the run operation , and little improvement
,
if any, can be realized regardless of the exchange method. The quantum
must be as long as the time required to perform the complete exchange of
programs of mean size.
5.6.3 Space-sharing exchanges
The use of space-sharing in the full program concept does not
assure increased effectiveness since the allocation algorithm increases
the overhead. If the mean system program size is a large fraction of the
total available core , transfers will be required at almost every quanta
.
The method will then proceed similarly to the basic run and reload method,
but will require the extra overhead to check for space-sharing possibilities
A similar condition can result if many users are present in the system and
the size of the available core is small. If the mean program size is
greater than the average allowed per user, the system becomes saturated
and little is gained from attempted space-allocation. The latter problem
can be oyercome if concurrent transfers are permitted but should be
carefully considered if this concurrent capability is not provided.
40

The use of space allocation in conjunction with both the disc
and drum storage provides the maximum complete program exchange
efficiency. This maximum efficiency requires several conditions be
satisified. First, the mean program size for drum users must be less
than half the available core memory. Second, hardware must exist to
provide at least one level of concurrency of exchange and run modes.
The previously mentioned requirement of relocatability must be met,
and memory protection of some sort is advisable. The disc would be
used to store a limited number of large programs , scheduled in a
slower manner than the drum users . Failure to satisy any of these
requirements will detract from the method, and a thorough study should




6. The Block Exchange
The block exchange technique provides several extremely useful
features to the time-sharing system. Block exchanges permit many
users to reside in core concurrently and dependent on the program mix,
several of the transfers required by the complete program approach are
avoided. This reduces the average exchange time, t , and as shown
previously, increases the upper limit on the number of active users
permitted. If additional blocks are required, the exchange time is,
at worst, no greater than that required for the entire program to be trans-
ferred. The penalty paid is in increased overhead which must be care-
fully controlled. Use of the proper algorithm minimizes "page" turnings,
or the number of times a block is dumped and then reloaded. A further
advantage of the block exchange method is that the programmer is
virtually freed from the constraint of particular machine memory size.
Programs written on a general Symbolic Language can be compiled with
any applicable compiler without regard to memory size* Due to the
relatively small size of the blocks, space allocation is more easily
implemented than in the complete program exchange methods,,
The block concept greatly increases the complexity of the compiler,
as the blocks must be assembled and references to other blocks treated
in a distinctive manner. Some systems use hardware design to simplify
these problems, and those without the hardware capability must rely on
the time consuming software methods. One of the most obvious ways
to simplify the compiler is the liberal use of open subroutines which
42

reduce the number of program jumps. This greatly increases program
size but, as this is no problem in the block method, it can be accepted.
If references are made to blocks not in core, pauses, which degrade the
particular program and decrease system reaction time result. In most
applications, complex checking routines are also required to first
determine whether or not a reference is in the same block, and,
secondly, if it is in another block, to determine if the required block
is in core and where. If this is not the case, the location of the block
on the external store must be determined, and the block loaded. This
latter, three phase problem, basically the excessive time and space
required for maintenance and checking, is one of the most serious dis-
advantages of the block exchange. A second major disadvantage is the
difficulty of access to large data bases. Successive references to
widely scattered data entries generate numerous block calls which
result in losses in efficiency.
6 . 1 The Page Exchange Method
One of the earliest uses of the block exchange method was in
the Ferranti Atlas system /17 , 18/\ The implementation in this case
is extremely hardware oriented, and the discussion of the concept
has value not solely as a particular method but further as an example
of the capabilities that can be achieved by hardware design. It is in-
dicative of the features that will be further developed in the next
generation of large scale systems, and less sophisticated systems
will attempt to obtain the same advantages through software. The
43

system solution to the space allocation problem will also be discussed.
Although a complete explanation of the entire system will not be
attempted, sufficient detail will be included to provide a background
for the exchange method
.
The storage hierarchy of the Atlas is rather unusual, and the
exchange method derives much of its power from this storage approach.
The primary storage consists of normal ferrite core, a high speed drum
(2 msec/block) and an unusual storage termed the fixed store. The
fixed store contains several thousand words of fast (300 ns) storage
and consists of a woven wire mesh with small ferrite plugs inserted
into the spaces. The presence or absence of a plug determines the
state of the store. The fixed store holds complicated functions which
permit both a simplification of the arithmetic unit and inclusion into
the instruction code of complex instructions such as vector operations
and polynomial evaluation. The core is divided into stacks of 4096
words, each with an independent access to the central processing unit.
The stacks are interleaved in pairs, odd and even, and instructions
drawn from the store in pairs . Transfers between drum and core are
direct, in 512 word blocks, and, once initiated, proceed autonomously.
From an exchange viewpoint, the most valuable feature in the
Atlas structure is the one level store concept. The core and drum are
considered as a single large memory (maximum size 10 words) and can
be addressed as such. In the following discussion some difference
between Atlas terminology and normal usage requires clarification.
44

The Atlas system defines a block as 512 words of information and a 512
word memory unit as a "page" in core and a sector on the drum. Further,
the term address refers to the identifier of a required piece of information
and does not necessarily provide its location. The 20 bit address (Fig.
6) consists of 11 bits providing the block address and 8 bits providing
the location of the word within the block. Each page of core has asso-
ciated with it a 12 bit page address register, 11 bits of which identify
the block contained When a storage reference is made, a parallel com-
parison of the page address registers is made, and non-equivalence
indicates the block is not in core memory. A suitable interrupt is then
generated, and the Executive, termed the Supervisor in the Atlas system,
initiates the required transfer. This frequent, complex checking requires
involved system tables which are maintained in a subsidiary store acces-
sible only by the Executive. The block directory contains an entry for
each block in the one level store consisting of the block number, n, and
the location of the page or sector occupied by that block. Each object
program is assigned a distinct area, and a separate program directory
defines the areas occupied by each program. The number of blocks re-
quired is one of the job input parameters
.
During some operations such as drum or tape transfers, a page
cannot be moved or accessed by an object program. To protect such
pages a lockout bit is provided in the page address register. Reference
to a protected page causes an interrupt to be generated, and the Executive

























with a flexible memory protection technique and allows protection to
be shifted easily as the controlling program is changed.
The Executive insures that the core always contains an empty
page. When a non-equivalence interrupt is received , the Executive
locates the required sector using the block directory and initiates a
transfer to the empty page location. While this transfer is proceeding,
another page is selected for transfer to the drum to fulfill the empty
page requirement. The selection of the page to be transferred is made
by an adaptive type program which predicts, learning through its errors,
the page that will not be required for the longest time. Various types
of adaptive programs to accomplish this selection are described in
Section 6.2. When the initial transfer to core has been completed, an
interrupt transfers control to the Executive which updates the block
directory and program address register. The transfer from core to pro-
vide the empty page is then initiated, and, upon completion, the block
directory is updated and the location of the empty page noted
.
These storage and exchange techniques combined with other
interesting hardware features provide the Atlas with an excellent multi-
programming capability. Representative drum times show access and
transfer times of 6 and 2 milliseconds respectively . Due to the one
level store and the reference by block address and then by location
within the block, relocatability is not required as it is provided
implicitly by the storage method. The program directory reduces the
number of entries in the block directory that need to be checked for each
47

non-equivalence interrupt to determine the block location and, hence,
effectively reduces overhead. The one level store and allocation scheme
provides a definite advantage to the programmer in that program can be
written without regard to the machine on which they will be run, especially
as far as size is concerned. An interesting effect of the adaptive page
selection routine applies to large multipurpose programs. If, for a
specific application, only a few blocks are needed, they will exist in
core with a high probability, and the unused portions will remain on the
drum and not require exchange time. The system efficiency would be
improved if the transfers to and from core could proceed concurrently.
But the interleaving of the logically separate memory units, rather than
the sequential treatment, precludes this, even if the additional high
speed channel were available.
6 . 2 Pageturning Algorithms
The use of adaptive learning programs to select pages for replace-
ment in core is based on the fundamental assumption that a good correla-
tion exists between the previous activity of a particular page and its
future usage. The determination is not a trivial problem and depends
on a study of the program structure of the system in question . The arri-
val times and, hence, usage of core space of programs that require a
short, one or two, quantum, burst of service followed by a long latent
period awaiting human response are extremely difficult to predict „ As
service periods increase, however, prediction becomes feasible. Any
so called page turning algorithm will increase overhead due to the
48

time required to record data and make computations . The probable
effect must be carefully determined to ascertain that the overhead is
justified.
6.2.1 Two level checking
In a short service environment, a two level page check would
probably be satisfactory. First, a check could be made to determine if
any pages in core are for users who are not active during the present
cycle or, secondarily, have already received service during the cycle.
If any such pages are encountered, as many as required could be exchanged
In the event that all pages belong to the remaining active users for the
cycle, an arbitrary exchange of a random page would require less over-
head and probably be as effective as any other determination.
6.2.2 Adaptive algorithms
As soon as any user or users require service for several successive
quanta, an adaptive page selection algorithm becomes worthwhile. The
algorithm attempts to minimize the turnings per unit time
,
or the number
of times a page is required to be reloaded after being transferred out
of memory. As pointed out previously, a poor choice, will, at worst,
result in an exchange time equal to the complete program exchange time,
t
, plus the overhead, while better methods improve computer efficiency
and system performance. The number of page turnings will be the basic
parameter rather than page accesses which are more difficult to determine
and less indicative of problems in system performance. An algorithm is
required that not only considers the transfers of a given page, but has
49

some method of weighting and decaying so that a page heavily used
during a previous period does not receive undue priority in the future.
6.2.3 The decay algorithm
J. W. Weil and J. W. Harriman have suggested methods of compu-
ting a figure of merit for each page which is adjusted when the page is
transferred into core and updated for other transfers while it is in core.
The overhead required to update all figures of merit for each page turning
would be prohibitive., and a second parameter providing an indication of
the last update would be helpful. With this parameter set when a page
is turned out to the drum, no further action is required until the page is
returned to core
.
The basic algorithm proposed by J„ Wo Weil uses the following
equation to compute figure of merit:
F° = F . e-h-hW + t*
mi mi
g
Fm i = new Figure of Merit
ti = last time Fmwas updated
t = present time
a= decay factor
Tf = 1 if page turned in
= if page in core
<* = new page emphasis factor
The time parameter could use the real time clock, but a greater sensitivity
will result if the unit of t is a page turning, and t reduces in effect to a




= Fmf for Pa9es in core
-(n-ni)0>




The values of F * and n. are stored either in a table in the page
itself or in the status and environment storage for the program . When a




J. W. Harriman uses accesses to a "page" to update it rather than
page turnings. This requires hardware sensing of an access different
from a preceding access (regardless of whether the new page is in core)
.
The individual accesses are used for the n and n, of the previous equa-
tions. The variation requires a greater hardware capability, including
the ability to differentiate between instruction and data accesses but
results in an extremely fast adaptation and an efficient paging algorithm.
6.2.4 Probability allocation
Probability allocation provides another method of increasing system
efficiency by reducing the exchanges required. It has its greatest value
when the system requirements can be defined to some extent. A typical
example presented by B . N. Riskin deals with a data processing and
multiprogramming system. The programs to be operated are known, and
all possible combinations in a cycle can be tabulated along with asso-
ciated probabilities. The process then evolves into one in which storage
is allocated to a particular table or proqram in such a manner that other
possible users occur with a lower probability. The fact that some pro-
grams or program parts must coexist for a cycle is also considered in
space allocation. In a general time-sharing system where the program




6 3 The Pseudo Block Exchange
The pseudo block exchange method loads programs in their entirety,
as in the complete exchange method, but uses a block type approach for
transferring programs from core. When there is insufficient space in core
for the next user, only that portion of core required by this next user is
transferred to the external storage. If there are only a few active users
of widely varying sizes, a considerable saving in exchange time can be
realized. This method was developed originally for the MIT Time-
Sharing System in an effort to overcome the problems of slow speed
transfers in a core and disc only system. Although other systems utilize
high speed drums to store active programs , the method is deserving of
general consideration.
The overhead required to keep track of the location of various
program blocks appears imposing at first, but reduces to a simple two
entry table for each user. The first entry would provide the complete
program length, and the second, a measure of the portion in core or on
the external device. The program will exist as it did upon completion
of its last quantum, partially in core and partially in the external store.
Fig. 7 depicts the actual variation in the stores with the status depicted
only during running quanta with exchange phases not depicted. It is
conceivable that, at any given instant, parts of several programs, in
addition to the complete program being run, would exist in core.
To simplify transfers, exchanges will usually be handled by












2q 3q 4q 5q 6q
CORE








2 2 2' 2' 2' 2 1
1
1





* indicates program operating during quantum, q.
1 indicate successive states of a program(l l 1 1"
)




in the usual sense, but provides a useful composite of the two general
techniques . It could well serve as an interim exchange method until
larger core and external stores could be integrated into the system
54

7 . The Completely Hardware Oriented Exchange
The final program exchange technique is quite different from both
the basic block and the complete program approaches and was not even
considered in the same general class. This technique is a completely
hardware oriented system and the problems and potential of this approach
are just now being realized.
7.1 The CDC 6600
The recently developed CDC 6600 incorporates several of the most
advanced techniques of both multiprocessing and multiprogramming. The
methods utilized show how many of the complex multiprogramming problems
may be efficiently handled by hardware design and point out trends in
hardware system design. The multiprocessing capability is provided by
ten peripheral and control processors and a central processor. Multi-
programming is handled both in the central processor and in the peripheral
processor arithmetic unit, with the peripheral processors themselves
acting in both cases as on-line users. The peripheral processors each
have a small 4 K independent memory and are used to handle all I/O
transfers and to perform simple arithmetic operations . Programs requiring
complex or high speed operations use the central processor on a time
shared basis. The central processor operates on peripheral requests
only and is not assigned to a specific program.
Before studying in detail the exchange method utilized, a brief
description of the three major units would be of value. The characteristics
of the central processor, the peripheral and control processors and the
55

central memory, in reality, determine the basic exchange method. Fig. 8
provides a basic block diagram of the 6600 system.
7.1.1 The central processor
The central processor relies on minimization of memory references
to achieve a high speed. Programs to be run are stored in the central
memory and initiated by an exchange jump instruction from a peripheral
processor. The peripheral processors also establish upper and lower
bounds to provide memory protection and specify the error exit to eli-
minate Executive overhead for illegal references. Multiple arithmetic
and instruction registers are used to minimize storage references and
increase the overall speed. In addition, multiple banks of memory
permit concurrent referencing. The actual processor has ten different
arithmetic units, each designed for a specific operation such as Boolean,
multiply, etc. . Non-dependent instruction strings are sensed and may
proceed concurrently, while a reservation system maintains the required
program order. Programs are formulated in the normal manner, and the
32 instruction registers are updated frequently enough to maintain the
program flow without pausing for memory accesses. Branch or jump
instructions cancel the remaining instruction registers and they are
reloaded. Central processor references to the central memory are made
relative to the lower bound set by the peripheral processor exchange jump







Hardware features cause the programming of the central processor
to vary from conventional methods when examined at the machine language
level. An example is the effect of multiple registers. The central pro-
cessor has 8 operand registers, X O through X 7, and 8 address registers,
A O through A 7; X 1 to X 5 read operands , while X 6 and X 7 write to
central memory. The action is initiated simply by a change in the cor-
responding A register. A O and X O are used as scratch or buffer areas.
7.1.2 The peripheral and control processors
The peripheral and control processors are independent units each
with a separate 4 K, 12 bit word memory. The instruction set includes
access to the other two major units, I/O and logical operations,, fixed
point addition and subtraction and indirect addressing. The ten pro-
cessors use conventional programming techniques
,
but the instructions
are executed on a single multiplexed arithmetic unit. The instructions
are stored in a ten position barrel which can be thought of as a fixed
form queue. As each position reaches the arithmetic control unit or
"slot", all or part of the instruction is executed. If the system is
considered in the time sharing context, each processor is basically
an on line user receiving a fixed quantum (100 ns) of service. A con-
currency technique permits memory references to be serviced and made
ready for service while the instruction is moving through the barrel
awaiting its next quantum
.
All data transfers are conducted through the peripheral processors
with an initial transfer to the peripheral memory and a subsequent
58

transfer to either the external devices or the central memory. Transfers
to and from the central memory are conducted through read/write pyra-
mids . The pyramids assemble and disassemble 60 bit words in 12 bit
segments per stage. A position for 60, 48, 36 , 24 and 12 bits is avail-
able in each pyramid so that four transfers can be proceeding in each
direction simultaneously. The actual transfers from the pyramid to the
applicable memory are handled through the "slot". Fig. 8 demonstrates
the basic flow in the time sharing of the peripheral arithmetic unit.
Communications between any peripheral units and/or external devices
are handled on 12 bidirectional I/O channels with a maximum transfer
rate of 10 words (12 bits) per second.
7.1.3 The central memory
The central memory consits of 131K words (60 bits) organized in
32 logically separate interleaved banks. Consecutive addresses go
into different banks permitting the rapid loading of the 32 instruction
registers in the central processor . The address and data control
6
mechanism permits a transfer rate of 10x10 words per second. A novel
control technique is used to handle all references. A clearing house
called the "stunt box" receives all requests, and, under a priority
system, passes the addresses on to all banks. The applicable bank
accepts the request if not in use and notifies the "stunt box" which
then initiates the transfer to the data distributor. If the bank referenced
is in use, the request is stored in a hopper. Addresses are sent from
the hopper, central processor and the peripheral processors in that
59

priority and repeated until accepted. Division of four banks use a common
line to the data distributor which serves as the transfer point
.
7.2 The Exchange Jump
An exchange jump instruction provided in the peripheral processor
repretoire initiates program operation on the central processor. The
instruction first generates an interrupt and transfers the program starting
address in the central memory to the central processor via the accumulator
of the peripheral processor. When the interrupt is sensed, the program
status and environment are set in the central processor's registers and
the information from the previous program saved. A subsequent exchange
jump instruction referencing the block stored returns the interrupted
program to the central processor for further service. The format of the
exchange blocks and a description of the registers involved is given
in Fig. 9. Once the status is set, the instructions are loaded into the
32 instruction registers and execution commenced. All central processor
memory references are made relative to the reference address
,
one of the
status registers, permitting easy relocation. The upper boundary of
memory protection is established by the sum of the reference address
and the field or program length. The program address register P is an
index relative to the reference address, and the P = word is used for
program exit condition storage. An exit feature permits programmer






















A - Address registers
3 = Increment register:
X = Operand registers
THE EXCHANGE
JUMP INSTRUCTION
F 1 sure 9

7 . 3 Executive Control
The 6600 provides an outstanding example of a hardware imple-
mented Executive routine. The functions required by the Executive, as
previously described in Section 3, are all handled to provide a virtual
two level time-sharing system which utilizes an unusual exchange tech-
nique. No actual transfer of programs is made, and the exchange jump
instruction only saves and loads program status and environment infor-
mation and switches control among programs. Similarly, the multiplexed
arithmetic unit for the peripheral processors uses the ten independent
memories, and the barrel and "slot" provides a method of switching
operational control . A lower bound register and a computed upper
bound memory protection scheme is used with relocation for the central
processor provided by the reference address or lower bound register.
7 . 4 Critique of the Hardware Oriented Method
The only major fault is to be found is the lack of flexibility and
general system complexity. Due to the hardware nature of the system
Executive, all procedures are fixed, and no capability of adaptation to
special users needs is apparent. To obtain the maximum benefit of the
powerful techniques available, the programmer's job is made considerably
more difficult , although this could be remedied by a comprehensive com-
piler and system control, or "Monitor", program. Another weakness
seems to be the relatively small memory. If the ten peripherals are
presumed active, an average program length of only 13. 2K is permitted.
The effect of this constraint is, of course, dependent upon the job mix.
62

On the whole, the system does provide an impressive portent of future
generation multiprogramming systems , and the methods used undoubtedly




The use of a system simulation program provides another tech-
nique for analyzing Exchange methods. Further, it permits investigation
of the effect of varying certain basic parameters on various Exchange
algorithms . A time-sharing system is a stochastic system and is
amenable to the Monte Carlo method of analysis. The arrival of users
and job characteristics can be treated in a probablistic sense and used
to supply inputs to the system. The manner in which the various Exchange
algorithms service these users can be used as a good approximation of
actual performance in an operating system. Simulation provides a
valuable secondary result in system planning The coding required to
simulate an Exchange algorithm approximates very closely the actual
coding to be used in an operating system. Thus a measure of the com-
plexity of the procedure is obtained, and, more importantly, the over-
head attributed to the various methods can be closely approximated,
Inasmuch as the overhead is a critical factor in the comparison of
Exchange techniques , accurate determination of overhead time is
invaluable
.
The general development of the system simulator, Program SIM,
is covered in detail in Appendices I and II . This chapter will treat the
Exchange portion of SIM specifically and will present and analyze the
results of several simulation runs using different Exchange algorithms
.
The changing of either the Exchange technique or any of the system
parameters permits many diverse systems to be investigated. The
64

system parameters include core, drum and disc storage capacity,
number of users allowed and mean program size as well as the other
job parameters. A computer with a three microsecond cycle time is
assumed and transfer times computed on this basis.
8.1 Simulator Exchange Routines
The Exchange portion of SIM is divided into three major parts
corresponding to the three basic system functions handled by the
Exchange routine. These are the LOAD, QUIT and EXCHANGE operations
LOAD and QUIT bring the binary program from permanent storage , such
as tape, to the external storage device used to handle operating programs
and remove a completed program from this external store, respectively.
Bounds are placed on the capacity of the external store, and NOLOAD
conditions may arise due to lack of space. Figure 10 provides a flow
diagram of the LOAD and QUIT routines . To permit completed programs
to be saved if desired, upon receipt of a QUIT command the program is
transferred from core to the external store before actual termination of
the users service. Regardless of the Exchange algorithm used, the
LOAD and QUIT operations are the same . The rearrangement or com-
pacting of the external store was discussed in Chapter 5 and is not
considered in SIM. It is felt that this is somewhat of a Dispatcher
problem and would only degrade service slightly and have no effect on
the comparison of Exchange or Scheduling algorithms.
Rather than a general treatment of all the Exchange methods


















































This approach was followed to provide a better demonstration of the use
to which the simulator could be put. Also, with the basic hardware
capabilities fixed, the effectiveness of the various Exchange methods
under differing operating conditions could be studied. The effect on
performance of varying single system parameters was also investigated.
8.1.1 The basic simulated system configuration
The system investigated utilized a drum for the external storage
device and did not permit concurrent transfers. An average access time
of 15 milliseconds was used for all read and write transfer operations,
and, as previously mentioned, a cycle time of three microseconds was
used. Relocatability was provided and memory protection limited to 2K
blocks except in special cases where the departure from this is noted.
The normal core size was 32K, but this is a variable input parameter.
8.1.2 Exchange Method 1
The first Exchange Algorithm is the basic complete program exchange
discussed in Section 5.3o The flow chart of Method 1 is provided in
Figure 11a. As mentioned earlier, no program is transferred from core
unless another user desires service. A check is first made to see if
the program is in core and, if so, no transfer is required. If another
user is in core, the normal dump, load and run sequence is implemented.
The only memory protection required is the protection of the Executive
Control Routine , and no relocatability is required
.
Basic runs were made with 10, 20, 30, 40 and 50 users with a

















































Df core, co be
times - 1:











widely mixed operating environment representing a typical computer
center operation. The presentation and analysis of the data will be
deferred until the latter part of this chapter to permit inclusion of all
types and to allow comparisons to be made.
8.1.3 Exchange Method 2
Exchange Method 2 , the flow chart of which is provided in
Figure lib, is a very rudimentary space allocation scheme. Programs
are fitted into core one after another until core is full . At that time no
selective dumping is attempted, and all programs in core are transferred
to the external store and the build up restarted with the next user. Due
to the requirement of checking memory bounds and preserving program
environment of all programs transferred , the overhead is somewhat higher
than for Method 1
.
Runs corresponding to those of Method 1 were made . In addition
separate runs were conducted using the mixed job input on a system
with single cell resolution in memory protection and on another with
protection limited to 2K blocks
.
8.1.4 Exchange Method 3
The third and final Exchange algorithm, Method 3, is a complex
space allocation type. Figure 12 provides a flow chart of the method.
Core is filled sequentially until insufficient room exists for the next
program. Several conditions are then tested with the aim of finding the
smallest program that can be transferred to provide room, this minimizing
transfer time . Memory protection is provided in 2K blocks . If no single
69

ye; is prorram^N no




















































program can be transferred to allow the next user into core, including
the combination of the last program sequentially plus the unused portion
of core, the entire core is transferred. While various combinations of
programs could be tested, the overhead required leads to a point of
diminishing returns , and no combinations other than those using the
unused portion of core were tested.
Again basic runs corresponding to those of Method 1 were made
.




To evaluate the performance of the Exchange algorithms tested,
certain basic quantities were recorded for each run. The first of these
is Exchange Time which consists of the summation of access times,
actual transfer times and Exchange overhead. The second value recorded
is Exchange Overhead which consists of specific overhead and all access
times . Total Entries is the number of times the Exchanger was entered
and an Exchange decision required. In Methods 2 and 3 Core Fits and
Core Transfers are also recorded. Core Fits indicates the number of
times programs were able to be inserted without transfer and Core Trans-
fer, the number of times the complete core was transferred. The differ-
ence between the sum of these two and the Total Entries in Method 2
indicates the number of times the program required was already in core.
Method 3 also records the number of Single Fits , or times a single
program was transferred to make room for the new user. The second
71

line of output is generally self-explanatory. Number of Users is the
number of stations in operation. Users Serviced provides a count of
the number of users loaded into the system during the run. Jobs
Generated actually provides an indication of jobs completed as fifty
jobs are originally generated to start the run, and any number greater
than this indicates jobs completed. Average Job Size is the average size
of all jobs exchanged. No Loads and Load Wait Time are determined by
drum size. No Loads is the number of times a LOAD request was received,
but no room existed on the drum, and Load Wait Time is the average time
a user waited to be loaded after receiving a No Load
.
8 . 3 Simulation with Type 1 Inputs
The first series of runs conducted operated with a typical job mix
that could be expected in a time-sharing type system. A mean arrival
time of 300 seconds and a mean load time of one second were assumed.
The other job characteristics are shown in Figure 13. The presence of
several small, highly dynamic jobs with a background of larger compute
limited jobs typifies a normal computation center loading.
72

Job Active I/O Repeats Mean Job
Type Time Time Size Probability
1 3.0 1.0 9.0 2000 0.150
2 1.0 3„0 15.0 4000 0.200
3 3.0 1.0 9.0 6000 0.200
4 2.0 2.0 30.0 8000 0.150
5 2.0 1.0 30.0 12000 0.100
6 1.0 2.0 15 ,0 16000 0.050
7 2.0 1.0 12.0 20000 0.050
8 2.0 2.0 15.0 24000 0.050
9 2.0 1.0 15.0 28000 0.020
10 1.0 1.0 15„0 32000 0.030
SIM JOB INPUT TABLE
FIGURE 13
A total of five different runs were made using this job mix as input.
Each run consists of five individual one hour operating periods with 10,
20, 30, 40 and 50 users permitted respectively. The first three runs
consisted of the three basic methods with a 32K core. Run 4 used Exchange
Method 2 but assumed a single cell resolution for memory protection and
transfers. Run 5 used Exchange Method 3 but allowed a 64K memory.
8.3.1 Analysis of results
The runs prove conclusively that as the mean core available per
user becomes less than approximately thirty per cent of the mean job
size, little advantage can be gained in the system under study, from
more sophisticated space allocation Exchange techniques „ When a
large number of users are active, complete core transfers are required
virtually every cycle, and the system behavior approaches that of the




The data from these runs is shown in Figures 14-18. The value
of the single cell memory protection in this system appears to be
marginal. The increased cost and timing problems created far outweigh
the slight increase in performance. In comparing Figures 15 and 17
(block and single cell respectively) only a 1% increase in Total Entries
and a 2.5% decrease in Exchange Time for the single cell configuration
can be noted. Although increasing core (Figure 18) greatly increases
exchange efficiency for the ten user system, by the time thirty users
are allowed „the performance is only slightly improved over the 32K
core Method 1 results (Figure 14).
8.4 Simulation with Type 2 Inputs
The second basic set of runs used a single job type, and, as the
number of users was held constant, the mean program size was increased
from 4K to 44K which resulted in average program size of approximately
32K. After each size increasing phase, the mean was reset to 4K, the
number of users incremented and the run repeated. This set again
emphasizes the relation between mean job size and mean size available
per user with respect to Exchange method performance.
8.4.1 Analysis of results
The results are presented in Figures 19-21 which are further
separated into a- e runs, each with a fixed number of users. As in the
preceding simulation, with a mixed load, comparisons should not be
made entirely on the basis of Exchange Time, but rather should concen-
trate on Total Entries which is a measure of the actual number of
74

computation quanta allowed during the operating period. The results
using the Type 2 inputs are as expected Matching Figures 19, 20
and 21 shows that the advantages of a particular method tend to dis-
appear as the mean program size increases. As the number of users
increases this crossover point occurs at a smaller mean size.
The simulation conducted shows the practical value of such a
system design technique . Simulation provides valuable practical
information on the relative value of hardware features such as memory
and drum size and memory protection. Additionally, assistance is





EXCHANGE METHOD ONE WITH A MIXED LOAD, TEN TO FIFTY USERS IN





1322. 3Ui4 493.616 16262.0
1390.910 493.693 16166.0
1399.685 492.853 16237.0













10.0 22.0 64.0 9753.9 .0 .0
20.0 26.0 58. 8515.5 .0 .0
30.0 34.0 5U.0 ^303. 3 .0 .0










LXCHANGt METHOD' TWO WITH A HUE) LOAD, TEN TO FIFTY USERS IN
A SIMULATED ONE HCUR OPERATING PERIOD
EXCHANGE EXCHANGE TOTAL CORC CORE
TIME OVERHEAD LNTUES FITS TRANSFERS
1360.385 U59.226 15534.0 8953.0 6096.0
13U0.65M 490.540 16133.0 10730.0 5337.0
lUOo.911 486.366 :60D0.0 10260.0 5674.0
1418.415 489.6 09 16110.0 10147.0 5897.0
1L07.225 U89.117 -6054. C 10179.0. 58U7.0
NUM.8 ER USERS JOBS A'ERAGE HI
OF USERS SERVICED GENERATED JOb SIZE LO^DS
10.0 22.0 64.0 9615. 4 .0
20.0 2 6.0 59.0 8511.9 .0
30. C 34.0 "54.0 9307.2 .0
1*0.0 42.0 52.0 935 1.6 .0













EXCHANGE METHOD THREE WITH A MIXED LOAD, TEN TO FIFTY USERS
i
N






Mr GE EXCHANGE TOIAL CORE SINGLE COREHME OVERHEAD ENTRIES FITS TRANSFERS TRANSFERS
1372.354 464.120 156D1.0 5717.0 5084.0 3525.0
131+0. 0U6 497.935 16126.0 5448.0 5926.0 3930.0
1410.962 496.451 ^5935.0 5667.0 4986.0 4118.0
1419.361 501.357 16031.0 5318.0 5599.0 4191.0













ICO 22.0 64.0 Q766.9
.0
.
20.0 26.0 58.0 8505.5 .0 .0
30.0 34.0 54.0 9307.0
.0
.
40.0 42.0 52 .0 9334. C .0 .0
50.0 44.0 52.0 92^3.4 337 .0 592 . 1





EXCHANGE METHOD TWO WITH A MIXED LOAD, TEN TC FIFTY USERS IN


















































64 .0 96 4.9 .0 .0
20.0 26.0 59.0 85 2 0.2 .0 .0
30. 34.0 5^.0 93C3. 1 .0 .0
40.0 42.0 52 .0 95' .0 .
50. 47.0 53.0 9245.0 337 .0 1339.3





EXCHANGE METHOD THREE WITH A MIXED LOAD, TEN. TO FIFTY USERS
IN: A SIMULATED D\E HOUR OPERATING PERIOD
EXCHANGE EXCHANGE TOTAL CORE SINGLE CORE
TIME OVERHEAD ENRIES FITS TRANSFERS TRANSFERS
372.293 305.584 19217.0 3051.0 4128.0 67o.O
1291.921 472.299 16424.0 5813.0 5146.0 1156.0
1401.732 U80.6U I60i>9.0 7405.0 4369.0 1600.0
1411.124 483. 247 :6U4.0 7402.0 4935.0 1455.0













10.0 26.0 67.0 96 5 0.2 .0 .0
20.0 27.0 59.0 8686.4 .0 .6
30.0 34.0
*
54.0 9424.7 .0 .0
40.0 42.0 52 .C 9444.0 .0 .0
50.0 45.0 53.0 92 60.6 336 .0 65^-.6





EXCHANGE METHOD ONE WITH A SING-E JOB TYPE OF VARYING MEAN




16 1 .576 6+ .93 5 2422.0
19?.. 165 63.007 2256.0
2U5.67U 62.724 2384.0
534.136 71 .281 2512.0
379.6 16 73.2 37 • 2445.0
375.5 02 62.6 53 2264.0
456. 47U 65.746 2349.0
1+73,802 63 .974 2351.0
481 .338 63.396 253 1.0
485.550 67.666 2304.
NUMBER USERS JOBS AVERAGE N3 LOAD
OF USERS SERVICED GENERATED JCB SIZE L04DS MIT TIME
10.
c
20.0 70.0 :827.4 .0 .0
ICO 19.0 67.0 7595.4 .0 .0
10.0 19.0 67.0 11 304.5 .0 .0
10.0 19.0 68.0 149,^5.2 .0 .0
10.0 17.0 65.0 187U6.3 .0 .0
10.0 17.0 64.0 22U00.4 .0 .0
10.0 16.0 65. C 25562.2 .0 .0
ICO 15.0 63. C 28203.8 .0 .0
10.0 14.0 . 61 .0 29830.4 .0 .0
10.0 14.0 59.0 30665. 1 .0 .0




EXCHANGE METHOD ONE WITH A SINCE
SIZE IN A REPRESENTATIVE FITTE5N




232.802 133. 122 4300.0
301 .232 1 16 .654 38 5 7.0
35°. 469 1 OS .531 3524.0
402. 198 95 . 3 1 6 3188.0
UU0.303 83.521 292 5.0
474.734 81 .695 2707.0
493.241 75 .799 2513.0
507.090 73. 15^ 24 26.0
51 1 .546 71 .909 2585.0
513. 104 71 .240 23 63.0
514.778 73.875 2351.0
NUMeER USERS JOBS AVERAGE ND LOAD
OF USERS SERVICED GENERATED JOB SIZE LOADS WAIT TIME
20.0 27.0 66.0 599 9.9 .0 .0
20.0 23.0 62.0 R020.4 .0 .0
20.0 23.0 58.0 120 7 5.7 .0 .0
20. 23.0 56.0 16098.9 .0 .0
20.0 21.0 55.0 20202.5 .0 .0
20.0 21.0 54.0 24390.5 43 .0 210.7
20.0 19.0 5^.0 27924.4 96 .0 112.8
20.0 19.0 55.0 3008 1 .4 114.0 93. 1
20. 18.0 55.0 5099 7.
1
139.0 94. 6
20.0 17.0 55.0 3 1 4 U 2 . 7 147.0 117.2





EXCHANGE METHOD ONE WITH A SING.E JOft TYPE OF VARYIMG MEAN
SIZE IN A REPRESENTATIVE FIFTEEN MINUTE OPERATING PERIOD
EXCHANGE EXCHANGE TOTAL
TIME OVERHEAD ENTRIES
233.347 1 29 . 8 1
9
'4290.0
301 .29C 1 15 .926 3833.0
356.711 10+ .799 3467.0
395.431 93.401 3092.0
436.477 85 .865 2877.0
461j .479 83 .086 2654.0
492.543 75 .86 1 2515.0
505.710 72.578 2407.0
513.506 71 .514 2572.0
516.207 71 .332 2566.0
515.611 73.967 2354.0
NUMPFR USERS JOBS AVERAGE NO LOAD
F USERS SERVICED GENERATE D J08 SIZE LOADS WAIT TIM
30.0 33.0 58.0 4042.3 .0 .0
30.0 33.0 56.0 8105.3 .0 .0
30.0 3 1 . 55.0 1218 5.0 .0 .0
30.0 30.0 55.0 16391.0 65.0 102. 3
30.0 25.0 5 5.0 20403.9 95.0 94.8
30.0 22.0 55.0 2^335.2 i 2^ . 133.3
30.0 20.0 55.0 278 5 3.4 143.0 85.3
30.0 19.0 Sd .0 50262.4 149.0 95.
S
30.0 18.0 55.0. 313 5 2.4 153.0 77.9
30.0 17.0 55.0 31620.6 159.0 85. 1
30.0 17.0 55.0 317^9.8 15B.0 85.2




EXCHANGE METHOD ONE WITH A S!NG_E JOB TYPE OF VARYIMG MEAN




299.691J 1 14 .802 5 796.0
351.521 102 .U30 3389.0
398.057 95.796 3105.0
435.497 86.075 28 51.0
1+67.572 83.391 2661*.
493.50? 75 .U05 2500.0
510.568 72.699 21+11.0
515. U12 71 .605 • 375.0
515. 614 71 .210 2 .
517.516 71 .210 21 .2.0
NUMBER USERS JOBS AVERAGE NT LOAD
OF USERS SERVICED GENERATED JOB SIZE LOAUS WAIT TIM
40.0 41 .0 56.0 40 66.3 .0 .0
40.0 4 1.0 53.0 8163.3 .0 .0
40.0 56.0 5 3.0 12326.7 53.0 91.2
40.0 30.0 55.0 16443.3 83.0 189. 2
40.0 2 5.0 55.0 2 578.5 107.0 8 5. 6
40.0 22.0 55.0 2441 7.8 1 3D . 105.8
40.0 19.0 55.0 26
1
14.9 145.0 91.6
40.0 18.0 55.0 30538.9 152.0 89. 9
40.0 18.0 55.0 31413.5 155.0 73.2









EXCHANGE METHOD ONE WITH A SINCE JOB TYPE OF VARYING MEAN
SIZE IN A REPRESENTATIVE FIFTEEN MINUTE OPERATING PERIOD
EXCHANGE EXCHANGE
ENTRIESTIME OVERHEAD
231. 889 129 .030 4264.0
296.426 1 lu. 195 3776.0
355. 98U 103.494 3424.0
398.5 16 9U. .040 31 13.0
430.978 85 . 167 2854.0
469.230 79.722 2 64 2.0
488.011 75 .4 36 2501.0
502.65a 72.487 2404.
C
507.696 71 .089 2358.0
513.374 7D .967 2354.0
513. 167 73.633 2343.0
NUMBER USERS JOBS AVERAGE NO LOAD
OF USERS SERVICED GENERATED JOB SIZE L04DS WAIT TIME
50.0 49.0 52.0 k 4 . 8 .0 .0
50.0 < 48.0 51 .0 80 8 9.0 .0 .0
50.0 34.0 52.0 12365.5 67.0 75.7
50. 29.0 54.0 1641 1.6 93.0 5 5.3
50.0 26.0 56.0 20286.4 1 15.0 30. 4
50.0 22.0 56 .0 2U766.2 138.0 7 5.3
50.0 21 .0 56. C 27733.9 147 .0 60.9
50.0 20.0 5 ft n 30094.4 1 53 . 126.7
50.0 20.0 57.0 3113 6.9 1 60 . 116.4













.A SINGLE JOB TYPE QF VARYING MEAN
FIFTEEN MINUTE OPERATING PERIUD
EXCHANGE EXCHANGE TOTAL CORE CORE
TIME OVERHEAT ENT* IES FITS TRANSFERS
1 .38 9 .82U 155 5.0 21.0 3.
15.97 3 6.179 16^4.0 1 33.0 64.0
181.895 56. 100 2 32 6.0 932.0 8 5 9.0
207.739 62.247 2135.0 7 u 3 . 974.0
33U.220 71 .073 251 2.0 206.0 21 36.0
579.672 70.001 2445.0 1 .0 2 308.0
376.92b 6 2.4 24 2254.0 1 .0 2059.0
436.443 66.533 2 34 9 . 1.0. 2195.0
475.790 68.771 235 1 .0 1 .0 2267.0
4B 1.326 - 68. 191+ 2 331.0 1.0 2248.0
485.540 67,465 2 33 4.0 1.0 2224.0
NUMBER USERS JOBS AVERAGE NO LO,AD
OF USERS SERVICE!) GENERATED JC3 SIZE LOADS WAIT TIME
10.0 21.
C
71 .0 39P6.3 .0 .0
10.0 2C.0 70.0 7752.0 .0
10.0 19.0 69.0 11278.0 .0 .0
10. 19.0 68.0 1502 5.2 .0 .0
10.0 17.0 65.0 18746.3 .0 .0
10.0 17.0 64.0 22U00.4 .0 .0
10.0 16.0 65.0 25562.2 .0 .0
10.0 15.0 63.0 28203.8 .0 .0
10.0 14.0 61 .0 2 9850.4 .0 .0
ICO 14.0 59.0 306 6 3 .
1
.0 .0









A 5 INGLE JOB TYPE I
FI FTEEN MINUTE OPI
)F VARYING MEAN
BATING PERIOD
EXCHANGE EXCHANGE TOTAL CORE CORE
TIME OVERHEAD LNR IES FITS TRANSFERS
212.699 111.891 U 35 9.0 3172.0 581 .0
306.357 115.3 58 38^ 1.0 2603.0 1 191 .0
360.251 105.201 3 43 0.0 1784.0 1667.0
40U.974 9 6.4 49 319 1 .0 929.0 2242.0
LUO. 197 B8. 133 2 92 5.0 101.0 2804.0
474.529 81.192 2 73 7 . 1.0 2 686.0
493.050 75.609 2 51 3.0 1.0 2492.0
506.696 72.941 24? 5.0 1 .0 2404.0
511 .36 6 71.7 28 233 5.0 1 .0 2364.0
512.925 7 1.061 2 36 3 . C 1.0 2342.0
511.600 70.697 2 35 1 . 1 .0 2330.0
NUMBER UScRS JO S AVERAGE ND LOAD
OF USERS SERVICED GENERATED JOB SIZE LOADS WAIT TIME
20.0 27.0 69.0 4001.3 .0 .0
20.0 23.0 61 .0 3033.4 .0 .0
20.0 23.0 53.0 12057.1 .0 .0
20.0 23.0 56.0 16095.7 .0 .0
20.0 21.0 5 5.0 20202.5 .0 .0
20.0 2 1.0 54.0 2U390.5 43.0 210.6
20.0 19.0 54.0 27924.1 96.0 1 12.7
20.0 19.0 55.0 300° 1 .5 114.0 93. 1
20. 13.0 55.0 5099 7.1 1 39 . 94.6
20.0 17.0 55.0 3 1 4 b 2 . 7 147.0 117.2





EXCHANGE MBTHOD TWO WITH A SINGLE JC5 TYPE.OF V\RYING MEAN
SIZE IN A REPRESENTATIVE FIFTEEN MINUTE OPERATING PERIOD
EXCHANGE EXCHANGE Tor AL CORE CORE
TIME OVERHEAD ENTRIES FITS TRANSFERS
232.012 1 2 3 . 8 8 U 4 22 2.0 3403.0 648.0
503.781 1 14.0o6 379 2.0 2539.0 1 197.0
356.559 103.408 3422.0 1719.0 1674.0
598. 150 93.538 309 6.0 870. 2206.0
M36.305 86.662 2 87 7.0 40.0 2817.0
U6U.278 79.887 2654.0 1.0 2633.0
4 92. 55
2
75.672 2 51 5.0 1 .0 2494.0
505.527 72.396 2437.0 1 .0 2 386.0
513.327 71.335 2 37 2 . 1 .0 2 351 .0
516. 108 71.153 2 35 6.0 1.0 2345.0
515.433 70.789 2 35 4.0 1 .0 2333.0
NUMBER USERS JOtS AVERAG- NO LOAD
OF USERS SERVICED GENE '"ATE D JOB SIZE LO\DS WAIT TIME
30.0 3 U . 5°.0 1*036.9 .0 .0
30.0 3 3.0 56.0 80 9 8.2 .0 .0
30.0 31.0 5 5.0 121 c 4.7 .0 .0
50. 30.0 55.0 1 6394.5 67.0 104. 1
30.0 25.0. 55.0 20403.9 95.0 94.8
30.0 22.0 55.0 2U3 3 5 •
2
124.0 133. 3
30.0 20.0 53.0 27853.
U
140 .0 55.3
30.0 ': 9 . 55.0 30262. 149.0 93.8
30.0 1 8 . 55.0 313 5 2.
4
153.0 77.9
30.0 17.0 55.0 31620.6 1 59 . 84. 6






LXCHANGC METHOD TWO WITH A SINGLE JOB TYPE' OF VARYING MEAN
SIZE IN A REPRESENTATIVE FIFTEEN MINUTE OPERATING PERIOD
EXCHANGE EXCHANGE Tor AL CORE CORF
TIME OVERHEAD ENT* IES FITS TRANSFERS
253.634 124. 188 4251 .0 3403.0 657.0
303.307 1 13.U57 377 1 .0 2512.0 1203.0
355.432 102.2611 3 53 5.0 1705.0 1651 .0
397.59 6 95. 140 3032.0 908.0 2154.0
435.319 8 5.3 72 2 83 1 .0 33.0 2 798.0
U67.371 80.191 2 65 4.0 1 .0 2643.0
495.313 75.217 2 5DO.0 1 .0 2479.0
510.385 72.517 241 1.0 1 .0 2390.0
515. 137 71.426 2375.0 : .o 2354.0
515. U35 71.051 2 35 2.0 , "i 2341 .0
517.330 71.031 2352.0 . . 2341 .0
NUMBER USERS JO? ; S AVERAGE NO LOAD
OF USERS SERVICED GENERATE D JOB SIZE LOADS WAIT TIME
40.0 l, O f\ 56.0 4059.2 .0 .0
40. 4 1 1 6 53.0 8161.2 .0 .0
40.0 56.0 5^.0 123? 7.
9
58 .0 95.5
40.0 30.0 55.0 16446.9 79.0 192.8
40.0 25.0 55 .0 20578.5 107 .0 85. 6
40.0 22.0 55.0 2U4 1 7.8 1 50 .0 105. 7
40.0 19.0 55.0 281 14.9 145 .0 91.6
40.0 18.0 55 .0 50558.9 152.0 89.9
• 40.0 18.0 55.0 314 13.5 155.0 73.2
40.0 17.0 55.0 51635.2 1 60 .0 80.0





EXCHANGE METHOD TWO WITH A SINGLE JOB TYPE HE VARYING MEAN





















































































NUMBER USERS JOBS AVERAGE NO LOAD
OF USERS SERVICED GENERATED JOB SIZE LOADS WAIT TIME
50.0 49.0 52.0 4042.8 .0 .0
50.0 48.0 51 .0 8090. C .0 .0
50.0 34.0 52.0 12367.1 66 .0 76.3
50.0 29.0 54.0 16U16.5 92. C 53.9
50.0 26.0 56.0 202 8 6.4 1 15.0 ZQ.h
50.0 22.0 56.0 24766.2 133 .0 75.3
50.0 21 .0 56.0 27733.9 147.0 60.5
50.0 20.0 56.0 30094.4 1 53 . 126.7
50.0 20.0 57.0 3113 6.9 163 .0 1 16.4
50.0 19.0 57.0 51594.6 169.0 157.5





EXCHANGE METHOD THREE v I H
S IZE IN A REPRESENTAl I VE





EXCHANGE EXCHANGE Tor AL CORE SINGLE CORE
TIME OVERHEAD FNR IES FITS TRANSFERS TRANSFERS
1 .947 1 .107 1 35 5 . 17.0 12.0 3.0
102.98 8 U . 7 8 1 2 02 6.0 13.0 1323.0 4.0
162.069 50.781 215 1 .0 7 .0 1657.0 .4.0
21 1 .856 5 5.0 38 2U2 2.0 r • t -f -/ -f p. 19.0
335. U27 71.561 251 2.0 i .0 2 1 3 7 . 2 1.0
351 .099 66.335 25: 1 .0 1 .0 16SC.0 468.0
375.737 65.171 2422.0 1 .0 1 100.0 950.0
4 4 . 6 1 5 67.4 13 233 8.0 1 .0 515.0 1691 .0
43d. 21
3
6 3.651 240 0.0 1.0 17»*2.0 3^7.0
U77.895 67.858 2 33 8.0 1.0 2228.0 1 .0
433.472 67.390 22)6.0 1 .0 2213.0 1 .0
NUMPER USERS J03S AVERAGE ND LOAD
OF USERS SERVICED GENERATED JOB SIZE LO^DS WAIT TIME
10.0 21.0 71 .0 3986.3 .0 .0
10.0 20.0 70.0 7680.3 .0 .0
10.0 19.0 69.0 1 1300.4 .0 .
10.0 19.0 69.0 15111.6 .0 .0
10.0 "7.C 65.0 187^6.3 .0 .0
10. 17.0 64.0 226 6 3.6 . o • .0
10.0 16.0 65.0 2 5522.8 .0 .
10.0 15.0 62.0 28207. 3 .0 .0
10.0 1 5.0 64 .0 29902.8 .0 .0
10.0 14.0 61 .0 306 9 2.2 .0 .0





EXCHANGE METHOD THREE WITH
SIZE IN A REPRESENTATIVE
\ SINGIE JOE* TYPE DF VARYING MEAN
FIFTEEN MINUTE OPERATING PERIOD
EXCHANGE EXCHANGE TOrAL CORE SINGLE CORE
TIME OVERHEAD ;"NR IES FITS TRANSFERS TRANSFERS
16i.586 9 2.9 74 483 3.0 41 .0 1 365.0 6.0
282.873 108.381 393 5.0 609.0 24 34.0 202.0
5U0.393 100.6149 362 3.0 50.0 321 1 .0 24.0
3 90.401 9U .354 325 8.0 10.0 3074.0 9.0
1*38,390 88. 356 2 9:> 6.0 2.0 2898.0 2.0
1*74.827 81 .788 27D7.0 ",.0 2 606.O .0
a 9 5 . 3 2 2 75.880 2 51 3.0 1 .0 2492.0 .0
SOo.950 73. 193 2425.0 1 .0 2404.0 .0
SI 1 .594 71.957 2335. 1.0 2364.0 .0
513.148 71 .283 2363.0 1 .0 2342.0 .0
514.814 70.910 235 1 . 1 .0 2 3 30.0 .0
NUMBER USERS JOBS AVERAGE NO LOAD
OF USERS SERVICED GENERATE
D
JOB SIZE LO-MJS WAIT TIME
2 0.0 2 7.0 70.0 3909.4 /> .0
20.0 25.0 62.0 80 10.1 !c .0
20.0 23.0 58.0 12083.1 .0 .0
20.0 2 3.0 57.0 16093.0 .0
20.0 21 .0 55 .0 20191.0 .0 .0
20.0 21.
C
54.0 2U390.5 43.0 210.7
20.0 19.0 54. C 27924.4 96.0 112.3
20. 19.0 55.0 30081 .5 114.0 93. 1
20.0 18.0 55.0 3C997.1 139.0 94.6
20.0 17.0 55.0 3141:2.7 147.0 117.2





EXCHANGE MtTHOf) THREE WITH A SINGLE JOB TYPO OF VARYING MEAN
SIZE IN A REPRESENTA1 I VE FIFTEEN MINUTE OPERATING PERIOD
EXCHANGE EXCHANGE Tor AL CORE SINGLE CORE
TIME OVERHEAD LN TRIES FITS TRANSFERS TRANSFERS
188.246 105.432 4 57 4.0 169.0 1 878.0 31 .0
209.623 110. 6 57 387 8.0 663.0 2401 .0 220.0
345.436 101 .575 349 5.0 158.0 3016.0 73.0
388.954 92.375 315 5.0 7.0 3018.0 6.0
436.574 8 6.9 62 2877.0 1 .0 28d6.0 .0
464.570 80.177 2 65 4 . 1 .0 2635.0 .0
492.628 75.9^6 2 51 5.0 1 .0 2494.0 .0
50:;. 773 72.645 2 40 7.0 i .0 2306.0 .0
515.547 71 .554 2 37 2.0 1 .0 2351.0 .0
5 It. 32
5
71 .370 2 35 6.0 1 .0 2345.0 .0
515.646 71.002 2354.0 1 .0 2333.0' .0
NUMPER USERS JO. S AVERAGE NO LOAD
OF USERS SERVICED GENERATED JOB SIZE Loaos WAIT TIME
50.0 3^.0 59. C 4028.
U
.0 .
30.0 33.0 56. C 80 9 0.6 .0 .
30.0 : 1.0 56.0 1216 7.9 .0 .0
30.0 30.0 55.0 16386.6 65 .0 78.8
30.0 25.0 55.0 20403.9 95.0 ' 94.3
30.0 2 2.0 55.0 2^33 5.2 12'4 .0 133.4
30.0 20.0 55.0 27853.4 1 40 . 85. 3
30.0 19.0 55.0 302 6 2.4 147.0 93.8
30.0 18.0 55.0 31332.4 155.0 77.9
30.0 17.0 55.0 31620.6 1 57 .0 85. 1





EXCHANGE METHOD THREE WITH
SIZE IN A REPRESENTA1 I VE
A SINGLE JOB
FIFTEEN MINU
















































285 1 . ,
2 66 4 .
2 500..0
241 1 . ,
2 375. ,


























2 341 .0 .0
2341 .0 .0
NUMBER USERS JO s AVERAGE NO LOAD
OF USERS SERVICED GENERATED JOB SIZE LCWOS WAIT TIME
40. 43.0 56.0 4054.6 .0 .0
40.0 4 1 .0 54. C 8 1 U . 5 .0 .0
4 0. 36.0 5 3.0 123?. 2. 2 53 .0 91. 1
uo.o 30.0 55.0 164^0.9 32 .0 186. 3
40.0 25.0 55 .0 20578.5 107.0 8 5. 6
40.0 9") r\ 55.0 24U] 7.3 130.0 105.3
40.0 19.0 55.0 221 14.<j 145 .0 91.6
40.
C
18.0 '55.0 30 53 3.9 152.0 89. 9
40.0 18.0 55.0 31413.5 155.0 73.2
40.0 17.0 55.0 316 3 5. 2 163 .0 80.0





EXCHANGE METHOD THREE WITH
S IZE IN A REPRESENTAI IVE
A SINGLE JOE TYPE I) F VARYING MEAN
FIFTEEN MINUTE OPERATING PERIOD
EXCHANGE EXCHANGE TOF AL CORE SINGLE CORE
TIME OVERHEAD ENT* IES FITS TRANSFERS TRANSFERS
207.026 115.545 4U67.0 159.0 1840.0 27.0
287. 59
3
110.489 3 89 1 .0 129.0 32 71 .0 42.0
34 7.09 8 101.358 ?5D 1 .0 4.0 3324.0 1 .0
388. 159 92.655 31) 1 .0 27.0 2977.0 26.0
U31 .074 86.263 2 85 4 . 1 .0 2833.0 .0
469.324 7 9.816 2642.0 1.0 2621 .0 .0
488.092 75.516 25D 1 .0 1 .0 2 4 80.0 .0
502.717 72.550 243 4.0 1.0 2383.0 .0
507.745 71 . 139 2 35 8.0 1 .0 25^7.0 .0
515.316 71.005 2 35U.0 1 .0 2333.0 .0
513.202 70.668 234 3.0 1.0 2322.0 .0
NUMBER USERS JOBS AVERAGE N1 LOAD
OF USERS SERVICED GENERATED JOB SIZE LOADS WAIT TIME
50.0 49.0 55.0 U 4 . 9 .0 .0
5C.0 48.0 51 .0 ~7.4 .0 .0
50.0 3 5.0 52.0 12316.5 67. C 84.0
50.0 29.0 54.0 161) •"9. 8 96 .0 52. 5
50.0 26.0 56.0 2 02 5.4 1 15.0 80.4
50. 22.0 56.0 2.47 66.2 1 33 . 75.4
50.0 21.0 56.0 277 3 3.9 147.0 60.
9
50.0 20.0 56.0 30094.4 1 58 . 126.7
50.0 20. C 57.0 31136.9 160 .0 1 16.5
50.0 . 19.0 57.0 515 9 4.6 169.0 157.6





This investigation provides a set of guidelines for the develop-
ment of an Exchange technique for any system configuration. A general
Exchange method can first be developed using heuristic analysis. Once
the general approach applicable to the gross system has been determined
a simulation, such as the type conducted on the sample system, will
provide valuable information on the selection of the specific method
and point out worthwhile areas of hardware improvement.
The investigation also points out the sensitivity of the Exchange
techniques in general to small variations in the system configurations.
It is impossible to define an optimal general Exchange method, as ex-
changes are dependent on both hardware limitations and operating en-
vironment., There are, however, six major parameters which, if defined,
allow a general method to be selected . Minor parameters will modify
the method slightly, but the approach provides a point of departure
for the system designer The parameters are:
1) Mean Program Size - This is expressed in relation to the core
available to operating programs and can be roughly quantized into three
primary levels of interest; small - less than one-third core, medium -
approximately on-half available core and large - greater than half the
available core.
2) Core Size - This is actual core available to operating programs
,
or the full core less than area required for the Executive . This can also




3) External Store - This is the type of external store available to
the system. Typically, it consists of drum and/or disc, although any
type of storage device such as tape or cartridge units is possible.
4) Number of Simultaneous Transfer Channels - This is the number
of channels available for transfers and includes any necessary logical
separation of memory to provide concurrent transfers
.
5) Number of Stations - This is the maximum number of stations
permitted to be in operation regardless of the type of service being
received at a specific instant
.
6) Program Type - This is a definition of the expected job mix and
is defined in terms of compute or I/O limited jobs or jobs with large
periods of man-machine communication
.
Multiprogramming is a technique that will receive greater attention
in the future, and the potential of such systems is virtually unlimited.
This is best shown by a simple example. Imagine a system capable
of handling one hundred stations at a time, and users who require only
four hours of station operating time per day. In addition, the time-
sharing period of only eight hours per working day would be required
to provide half the rental cost of the system. An $8,000,000 system
could be provided at a cost to the on-line users of $6.00 per hour. An
increased number of stations or a longer operating period for time-sharing
could reduce the cost still further . This hourly rate makes the power of
such a system available to the myriad of small users who otherwise
could not afford such a capability.
97

The full benefits of such a system cannot be realized without
the best possible program exchange techniques „ Although the hard-
ware features will improve, the exchange method will still be required
to do everything possible to compensate for the inherent slowness of
transfer operations as compared to computation. In the next generation
of systems, as in the present, the ability of a time-sharing system to
meet its goal of more service to more users will be critically dependent




1 . Auerbach Corporation
;
Philadelphia, Pennsylvania. The
I' tent of the Opcon System Design; Master Control Philosophy,
by L. J. Glodatien and B. H. Bragen. 19 July 1962. Technical
Report 1069-TR-6.
2. Bauer, W. F. and W. L. Frank. DODDAC-An Integrated System
for Data Processing, Interrogation and Display. Proceedings
of the Eastern Joint Computer Conference 1961 . The Macmillan
Company 1961
.
3. Bright, H. S. and B. F. Cheydleur. On the Reduction of
Turnaround Time . Proceedings-Fall Joint Computer Conference
1962, Spartan Books , 1962 .
4. Codd , E. F. Multiprogramming. Advances in Computers 1962
Academic Press . 1963=
5. Control Data Corporation. Programming Manual for Control
Data Satellite Computer System. Pub. No. 187,
6. Control Data Corporation. Control Data 6600 Computer System
Reference Manual. Pub. No. 450.
7. Corbato, F„ J„ , M. Merwin-Daggett and R. C. Daley. An
Experimental Time-Sharing System. Proceedings -Spring Joint
Computer Conference 1962. Spartan Books , 1962.
8. Coyle, R. S. and J. K. Stewart. Design of a Real Time
Programming System. Computers and Automation , September
1963.
9. Critchlow, A. J. Generalized Multiprocessing and Multi-
programming Systems . Proceedings - Fall Joint Computer
Conference 1963. Spartan Books 1963.
10. Ferranti Electronics . The FP6000 Computer System.
11. Frank, W. L.
,
W„ H. Gardner and G„ L. Stock. Programming
On-Line Systems , Datamation, May-June 1963: 29-34, 28-32.
12. Fredkin, E. The Time-Sharing of Computers. Computers and
Automation. November 1963: 12-20.
13. Gordon, G„ A General Purpose Simulation Program. Proceedings




14, Hogg, R, L. and D
. C . Glover , Control System Programming
Remote Computing and Data Display. U.S. Naval Postgraduate
School M.S. Thesis 1963
15
.
Hogg, R. L, and D. C, Glover, Program Control System for a
Satellite Mode Computer Complex. Digital Control Laboratory,
U.S. Naval Postgraduate School . 21 December 1962 „
Report TR-DCL-62-11/13.
16 o Kelly, Jo E. , Jr. Techniques for Storage Allocation Algorithms.
Communications of the ACM„ October 1961: 449-45 3.
17. Kilburn, T. , R, B. Payne and D. J. Howarth. The Atlas Super-
visor
.
Proceedings of the Eastern Joint Computer Conference,
1961, The Macmillan Company 1961.
18. Kilburn, T„, D. J. Howarth, R. B Payne and F. H. Sumner.
The Manchester University Atlas Operating System. The
Computer Journal , October 1961: 3-10.
19. Lewis, J. W. Time Sharing on Leo III. The Computer Journal,
April 1963: 24-28.
20. Maher, R.J, Problems of Storage Allocation in a Multi-
processor Multiprogrammed System. Communications of the
ACM. October 1961: 421-422.
21. Markowitz, H. M. , B „ Hauser and H. W. Kau . Simscript -
A simulation Programming Language. Prentice-Hall, 1963.
22. McKenney, J. L. Simultaneous Multiprogramming of Electronic
Computers. University of California, Los Angeles Doctoral
Dissertation. February 1961.
23. Mills, M. R. Operational Experience of Time Sharing and
Parallel Processing The Computer Journal, April 1963: 28-36.
24. Riskin,B.N. Core Allocation Based on Probability
.
Communications of the ACM, October 1961: 454-459.
25. Ryle, B. L. Multiple Programming Data Processing.
Communications of the ACM , February 1961: 99-101.
26. Shafritz, A. B. , A. E. Miller and K. Rose. Mulrilevel
Programming for a Real-Time System. Proceedings of the




27. Smith, R, D. Multiprogramming the RCA 601 . Preprints of
Papers Presented at the 16th National Meeting, Association
For Computing Machinery .^61.
28. Statland , N, and J R, Hillegass. Random Access Storage
Devices o Datamation, December 1963
.
29. System Development Corporation, Command Research Laboratory
User's Guide, 7 November 1963. Report TM-1354 volumes
1-5
30. Weil, J, W, A Heuristic for Page Turning In a Multiprogrammed
Computer, Communications of the ACM , September, 1962:
480-481
.
31. Wilder^ W. G, An Investigation of the Scheduling Aspects of
Multiprogramming, U, So Naval Postgraduate School M.S.
Thesis 1964.
32 . Williams, R. J. , J, P„ Anderson, S. A. Hoffman and J„ Shifman.
D825- A Multiple-Computer System for Command and Control.
Proceedings-Fall Joint. Computer Conference 1962. Spartan
Books, 1962
.
33. Yarborough, L„ D. Some Thoughts on Parallel Processing,,




SIM -A MULTIPROGRAMMING SYSTEM SIMULATOR
Simulation has become a valuable analytic method that can be
applied in diverse situations. The type of simulation of interest is the
Monte Carlo Method which is defined in the McGraw Hill Encyclopedia
of Science and Technology
,
as "A technique for estimating the solution,
x, of a numerical mathematical problem by means of an artifical sampling
experiment „ . . „ „ " The method aptly fits the multiprogramming system
problem and can produce worthwhile results The required probability
distributions associated with users can be determined by general data
gathering and observation The use of various algorithms in the Execu-
tive routine and several hardware configurations in a simulated system
subjected to a typical loading will produce the data to obtain a measure
of effectiveness for the various hardware and software configurations,,
The time and expense required to actually evaluate each of the com-
binations in an operating system are prohibitive and the use of simulation
techniques provides the only realistic approach
„
Program SIM was developed as a general multiprogramming
system simulator with the emphasis on the time-sharing type of
environment o Due to the specific nature of the authors' theses,
primary attention was given to the Scheduler and Exchanger. The
normal performance of other specific areas of the Executive routine is
assumed and these portions treated in a block method. A prime example
of this is the Dispatcher. While it is a critical area of a multiprogramming
102

system no specific characteristics were assumed When a user has an
Input or Output the program assumes a waiting status until, due to the
incrementing of the simulator clock, the action is deemed complete.
The availability of the required I/O equipment at all tiroes is assumed.
A time-sharing system is characterized by frequent man-machine com-
munication and buffered I/O is usually impossible due to the step by
step nature of the system.„ However, simultaneous I/O by all users,
at least to their reactive typewriters, roust be permitted. The gross
Dispatcher treatment provides all this and only avoids the complica-
tions of particular operations » If this area is studied in the future the
Dispatcher portion could easily be made more detailed and added to the
system simulator,.
The job load on the simulated system is created by a job
generation subroutine (SET) . Each job is characterized by six variables,
which define any job entering the system. Arrival time, the first para-
meter, is assumed to be exponentially distributed on the basis of
queuing theory concepts and actual observation at System Development
Corporation „ A variable parameter is the mean arrival time expressed
in seconds. The value of arrival time was determined by taking the
natural logarithm of a uniformly distributed random number. The
second parameter is Load time and represents the time required to
transfer the binary program from its permanent storage to the temporary
storage having access to the central memory, The next three parameters
Active time, I/O time and Repeats define the actual program operating
103

characteristics,. A program once loaded into the system is assumed
to have an active period followed by an I/O period, during which ro
service is required from the central processor,, This cycle is repeated
until the job is completed or there are no further repeats required
.
Due to the nature of SIM, differences in I/O such as tape transfers,
searches or outputs to reactive devices are not recognized and the I/O
operatiors are grouped together , The sixth parameter. Size, completes
the job description. Program size is limited to a maximum length of
one hundred cells less than the full core available for operating pro-
grams. The last five parameters are determined using a Gaussian
Random number generator and the mean values received as input, A
uniform random number generater is used to generate any of ten possible
job types o The probability of each type job is received as an input
.
As soon as the job is completed, that, is the number of repeats remaining
is less than zero, a new job is generated for that station.„ An example
of the input to SIM is shown at the end of the program contained in
Figure I~l
.
It is possible to obtain a wide variety of output parameters from
the simulator as it has access to all of the internal system parameters
concerning the operation of the system in question . These parameters
may be gathered on a minute, average, total or maximum basis and
thereby present a picture of the system's operation in almost any




For the purpose of comparison, the output parameters of one
run, using a certain hardware and software configuration, may be
saved and then presented with the results of another run with changes
to the hardware and/or software configuration,. The output of the simu-
lator may be in a tabular format or modified to a graphical type format,
which ever is deemed best for comparison purposes,.
The program operation is cyclic in nature, First, the initial jobs
are generated and the program constants read in and/or initialized for the
run* The main body of the simulator is then entered and the actual run
commenced. The clock is checked against arrival times of all allowed
users (maximum 50) and an equality or greater than condition sets the
action, entries of the status table (STAT(X,Y)) . The Scheduler then deter-
mines which requests for service shall be honored and the order in which
they shall be honored, i.e.
,
queue information „ The Scheduler also
determines, from the number requesting service, the amount of time
each user is allowed per cycle. The cycle begins with the formation
of the queue and ends with termination of the last user°s quantum
.
The Scheduler then passes control to the Exchanger „ For further specific
information concerning the operation of the Scheduler section of the
simulator see Lt. W„ G, Wtlder's thesis.
The Exchanger determines the action required by the next user
in the queue and then LOADS, QUITS or TRANSFERS the users program.
The actual transfer algorithm is variable and the methods used are










2nd- T set up queue
pass i '
in















Va load ? Jg






























exact method, the required transfers are determined and the effective
transfer times (TELOAD and TEDUMP) and exchange overhead calculated
and added to the clock. In the LOAD and QUIT operations the size of
the external store, such as a drum, is considered and no load or storage
full conditions are possible.
At the completion of a cycle all users in an I/O status are handled
by decrementing the remaining time by the elapsed cycle time. Users
completing I/O are checked for repeats. If repeats are necessary the
program is reset to the active mode and if no repeats are required the
program is terminated by a QUIT command in the next cycle
.
To avoid long idle periods a scheme is used to advance the clock
to the next active clock time if there are no users desiring service.
The smallest I/O time remaining (SMALLA) and the nearest arrival time
(SMALLB) are determined and the smaller of these two added to the
clock and a new cycle commenced
.
A maximum clock parameter read in terminates the run and the
capability for recycling is provided. All new parameters may be read
in or the original parameters may be modified for successive runs.
A flow diagram of SIM is contained in Figure 1-2 and a copy of
the actual program is contained in Appendix II
.
Due to fact that the thesis topics of Lt. W. Go Wilder and
Lt. R. R. Hatch are both in the multiprogramming area and a generalized
multiprogramming simulator could be used in each case, this simulator





IT! h- • „ ^
2T X —O —< ro h-
fO MiO •» » X
*- xoo : l * x j
— fO<X
—O X CO •
13 ~ ••c^r- ^2: j- « xO V. UJUJ « V.*-. »
_j ,—
•~" ^o>xLuxa:<r-
c~i c <<j3-«-»s:< uj > *•
*- LU Oil »LU»-«5: 2D —1 LU
- »2 >— lui^-c<oi— x >£ c£ 2:
o h- > -uj2;xr- x ci —
—*">-
:-: x<n:-. x «x~xo xujx —
•3-o<o uu »iuzx*i »zr »u^ w- » ^




—< *-00 LUGJ UL'jX ••UJ—i< JlilOC «-UJ )—
<~>t-~-C s=C OJjxIxi-jwmoxc. z
oo</)0
- o~i <r< »-c\'o:<t^(_)Xt-->Lr>>- O





-j '-J >X a"<o »>i— on _£©*—C <:--' >orj-_)£DOf>- •.xxoop'k-
—^-> x <r ^zi xinj-xd<o: 2:
»• •*-«<j t/>a _ii_><cx,xk"! cj — lulj _•co
-




—.^ luO xj:d -a,oi\— c^x 1— 2:
-<^9 >~ ^- (-) -J"-1 lupoxjsizzicmuoxz < <o^:-— <t< ut-r-JL *.?_-<_:_' » p>-X U <xinijj—c 2"cu >-<2TC0UJ>—XH-2UJ -eg —
.
o
~-ot-oa: — oi-x -xx<r;rxx x— v- <— o
""* 2: -x->— -•_ q iDoxiL<z«iiijyir) x • cc00 :d—o. •» * r:-^ "icuriiD'iiD ou »x a. o a.
am— ->o v~ o^r> n- x^ _i\ — x«-cnj
3>_<— •• »o a xu'-ui:





c?«——'5: arc u-ioire— co ~s:m occ cm h—». oilcm
-•—'--Ci * <_l _l< »U »UJD P._J - .XI\LUI-Mr-
—•::r -J -02 uj_j ca:Q:-xo£QaxxojLuc:<
-a. —in --cQtuooa: < <luluu_ j-<t— <ujtij3- -
--ex-Jo -
-oo<oc:'— x —<>i— u. cxxo -tux—ox ••—Ou;mh<X2 i— l— Gi<uJLjujuj<r_jcujc.„>N-, (->-';• o • 110 'Xcr:<_> *-.a—<xs >_>5:a:is:c« *-xu_—r-o ,_,
"-•"•-Oujs — 3?-v.>r-<Q-,<:x'Xico—
->i-c:j-Xoou_u. —
S^^rz* •,5~-£Tw2 ~ xx\Xf\ja:< l-xr-> -i-xoljj -cox -cm-
<UOco
-Cicy .O • —roj-v.
-X1I4- -XXCXJJ- X5TOXCNJ .— .00s— -arouoo. o \ .. ->s.<-o c< «.xm to
-x-oxr-o *m .0



















»— or^-cr> o oo>— rvjjj'in'O cnco & fcn«e (*


























































r— uj i-hq: X
m a: xuj <
J3" <— ^J</7 a.
•— Q -13 e
•> c:xxz O
o a- ccr< - 3£
• r— u> i: a. a
o XQa£l—
o —» <i/>OQ




«~ + o {_) »n-)b-i
o o 1/11UQ «.X J- COTLL CM
«-"l— o x -a: a.
-co o <Q>0
in LUZ • 1 a £00>< 1
— *— OUJr •h •» •.i/^t/5 M
C\! •• <_J «-» in XO »*- I—
I
CO <M o:q_ ii
-o J* C£C?C\I »
-a- »- UJ II k m Q -C5T
r~ •» >—».— in XOQXl-
m in <Ot- j- <Ot^O
• r— r— «. UJ V. s: ->>•
o »» o II K-H--o U_ <CO00
t-UJJ-UJ II N-UJ —-<LUOUJ •OoOZCCUJ
~- M f—
— II
-J _i ii _jx—x mxxujujct:x<xo - - *iux
< < OO XX XU. ZHOOUJZUJZiriO^MflZ
•— >- XOUJ— 0>—iQ.O'—CXO'—<iX—• ZD— —
I- O II OOOO: II ZI-hl-Ol-|-2^0i<IKZKQCaO2h. —
—




i— cm j- in >o uj
























^ • • oo oo
£0 r—r— CC ooOOOO 1 1 t—
4
O— oo
-> •JT- II II U_ inn o • •
j- o *o - «.-~-~ »» •oo
II ••— II >— r— i—il—
l
UJ *-l- oOOO II — II II - I— ii ijuo II II
Z • II -J-J-5—i-3-> < -JoO II II
—0*: — _w a: 21 on
:«£ ii u^oi-j-^q:h UJ lT)_JOo>>
CO>—O 00 2< 2 jot>ao




• • • o oo • »o • •OOOO • OO II oo »oo
—
-o »oo • • II II O II II oO II • II II II O II «oo X II O II 2TXO II
ii _io ii i—o ii n oo iocs: no
^Oll h-l-OI—O II idXXIOillSLUJ




























O II UJ CM II IT)
II 1— -J — <C\J
a oo z> C<
-J«— UJ o c<o 1-^
> ll 13 UJ I-Q.K- »—
*
azzai X a:



























^ cc j- LU
O LJ < _l
—
.
lu 2 > O— CO
J" 3 O »J- <
r<0. 0_l UJ O •> — J-
*. _)
_j o u->— a:
OrO _J < . < l .-J- <2M 2. < x a: —lu— »- > 1
—1 » X 00 < LU 1—>—. J" .-•
a. s:n 1- — cc sc%: > •»<:'- 00 —>
v- 2: 00 ujr>o <-* O LU O^ < CC II •- CM c*r
o »— cc 2:^ » a: z 00 00 o —"-* az a lu
LU O LU I— Sir- C 3 _l_l LU«— ^r-i_ n oO
:*: >- 00 oi-co o • 00 s « lu •>— cm 3
00 o r> >-o • _i 2: o 11 11 — — ocolu j*
—
< 2: z o>o < o a: o z —— o i— 11 <mo — 00 u_
II ID II in II LU2UM o LU O 3 •— ro O CO o£«— <LU.— O-OSO O
<cm<cm<3 11 u_—* e: t— t— 1— a •. » •—_)>- ojluoco 11 — •— 11 n m— in
CC CC CC.-Z.SL II < CM 1- q: *-•— CM < CM>OUJZLL+ | LLLL CC +
<0<0<—'I—XQ -J II O > MOO ——CM II O > Oll«>MOQQaOCO LU 3 t-i
Q. I— Q. I— Q. I—O< r- 3 \-\— -J I— r- i^ OiQi II r-r- >-< J" r- II C£ < I—< >-l«-"0< I— h- CQ Z »-«
cc cc ccto-'s:, o lu or lu u zzsuj c: luujuj— zlu 11 —i—lu 2: II
<c<o<aoo<!b lu zo < zo < luluzztc o: oz»u.oc:qu.wq:oo 33 x
>0>0>OU~—'O C£ *-0 LU >-<0 CO C;o»——O < 0m«huZhmm200 Z. Z. •—
o
i— CM rOLO 2:
CM CM CMCM O <— CM NO O <— CM .3- UJ
















o m •» N-




C\J J- _i «.
o *: •» <ii r-
^~ u r- s:o co
•ft u O 000 Jt
C\J o _J J- _i j-
o • o l J* » —
«£. r— o —
»
00 -—
o OL1 1 i£ * 1 -3- -jn
CO —
«
~- oo LU O «. J- ~
J- 1— *: o<— _J— O o~ —.^O •> k—i-~
k m <; o o * o— _J —1-— LOO • r^- —lO
o> J- z o Oifl ">- •» o •..3-0 >— »
J- •» i—
<
_J '-O 00 o—:r> •—• 1— ~o JS <^-
• r>0 s: o + «— a: oo—;2 1 1 — —MO (— «—
CO J- or 1 ooo —2: » LU I a: •• £/ 1-00 o~ O0—
jr •» LU — • • •r-LUJ" i£ 00 i^ZCM— *~»zr < j-o Z— <
—
»













LU II O II
•»





LU-J II>• II LU— —*-oj&a:> «—
i
JJ— II LU II _J II LU














T^ / 1 ( i t ro
ciOa' O
—?• -^» -^ ^^ -^
-J
-*-r -^- --* *-j»
I-O-I
^ ^-€ ~~* -~* —
<
o«- t i-




LU Ot-hl- II Oi—1 + 1— Ol— < 1— U-«—l-d-OI— O—lt— _JoO_Jt-.^ooi~oo_J
LU—CiZUJ 11 — LU q: X> <<< z.-z.~—> >- ZOh< «—z—<z <—<z 2f—
<
;zu_<Oa:ujLLcx:o a: hm II LLI— t— t— LULULL II DUO o OZ>SIZ!u_ou_£:os:u.z.oou-ou_2:
<-i—i>o z: >-< »— ~zo < hHMW(/H/lOOMI-iOVIO 2 UUU(/)Oi-iJ—'OOLJOO'-'OOOO'—
'
O—i 00
O N"} o •— cv K>j3 IT) o iO C\!— ro j- 1K) O
=fco •3-J3- o oo OO o o - 00 00 O O



































J* 1— Q lv-1
*• —. i\ 2! fr
in CM CM <r C O
o o •o--" •• •H* "^ OUJ
j*< CD • 2TrO <—a J-3 x: o_j
—
_j -J «— •—- *. CM 1 21 <— »0£ <—
u
1
CD_I ._l + ecz o CM^— L.J 3 ;3 ZUJ UJ ->
_)< < o t— "Z^" z — -3"1C •—i • ~-"S X 00 l-H
—IS y z CO luo: —4 o UJ o .— I— 2! oq:«-> Oco
<CO CO t—
<
LU 02 1— • > i zrt- c_? <: —
-
•z»- 1
S + + o —3 + UJ h- — r— >—
(
«-»«-
.^-o + 2! t- f— UJ + UJ — *:
0Oi£ ^ < 1-3 ^O i—
i
1- 1 — 1— i— j-i—< ^ >-< < 1 0:*i —1 —0
1 o o o XU4 O II 3 X II —t o X ••< II o s: H II II o -JO<DOOO -J UJOi o~o O UJ——C < ujz:i——
.
OOO a: co —oo > O-l
UJ_)_jvO_IO 2: n _ij-o Z<— t—o Z^-COJ" II -JO UJ II OO'ulJO >OUJ
13—I'O^OrO CO «—r-OO Mfl CO — »ujnt CO —1- II *20^0 \— z • »» »0''v") O II 3
2!< II II — LUOO || ii 2: 1—4 UJk-HCO l-M uj<uj2!3 II 3--2:2: II U_ OUJZ








o UJ —«c?oo< UJ —H<t 1 UJ •-'— H- <SO a: s<:£<<o O —1-2:
oll-jo-io </) ii ujo_it-o CO II i-<o co II U.UI-MJO < «-tUJi— t— —jO Z u_>a X
u>-i;oau 3 zoi—jouoo 3 i—iCOUO 3 2i-h<C0I—UO UJ f->—COcOOO UJ HOU 1—
1





























o a:O OO CL
10 uj r^-o
» OO OO
o o < *-*-
m o in j_ •> •»
m r— o CX ooo
to •> «•—01— c\i«— cnj
•• o ••rouj m v_ •— o»—
o o o^z o oo «-—-- r^-
in—» •— >or— «—
(
mx c£ •..».
mrO o o •• * qq: •-. ooo
•» •» • —
O—
» X> UL 3C\J'-C> I
•c*- <— x *cmo a:o z—oo --
om—• i o <x ooj- >oo 2 „_____ _
o »^oc< — i— • z: <o—o a + o r>— -» »
•r-—zoina o»- ii o -— ooa -* z——
o
r— | »~UJ • »LU • O r—O - +1 H- •— t> CM C*




— • » -— ii o uj _jocm • o> s: oooooo—
_»0«-<~~Ct:'->— «-»—> I -J o«—O UJ O CC OH '————
.
ii _— —..—u-)<:~~iriu-iujij-!— "-j-o^ZiriLnujcnoujiKi o >—•— _j n _ji^ a — ~-:*:oo
UJ I— i— »rOt— jj »MD •• -cr: - it) »K1D •» »Z}(-> Q UZ- O -J O II u_ Ot-HX-
3C'—<<—• oOSTh-, ZmmZ««Oh ZTh-.1—2:0 UJ QK >- >-*-0—o II O C\J<<OII
—'ini— —«—o n m*omw—lu—— 11 —0—
—
~>-<«j x zluo o > 11 ^1 uj <— i-i— <-*
I—rOoOOOt— I— UJH-f-(— I— I— I—Ohh I— C£h- 1— I— I— t—O <-> UJI— t— II O II h-OO- 3 — OOoO_JO >—
> _->--< ii^-< ;2<<—<<q.2: 2<<s— 00 — •— s- p xcj> uj ——_-o
UOU.U.I-OMlLI-ODI-1-U.I-l-UJlUOOHkDU. U.LLO UJ l-kouJ-lO 3 OU.U_U._J X
<Qwmi/-,oi-hiiociJ^^hu^u;d.COU^i/)-;'-i O •——O 2 •— UJm 2:o 00 O 0«-"-"—n_i 1-4
— o
in
-O — OO OOO O OOO Z
LD in LO < OOrO in N-COO UJ














00 mm 1 TO
1 ro~o —uoujiiO— «-« • mr^s;
oz-o-- •- »M
»'-n«— 11 H-roV-




CvJCO 1^- in PO





















f- t 1 •—
f— O J± ui •»
r— J" -d- O CM i>£
» Jt <
—
UJ O p"» X 00
O f—
•
•» 3: j* •* ro
O •» CM O -3-0 O •- O
•— O St _J OJO 00 CM r- —1 « J-
»— CM a _l •— oj- 1— O un 1 O If) CO
(. f— 1— < — 00 2: CMX »— —Q 00 »—
O *— •a »— LU —
<
ClCC •* + _) m fi
O fk «— 00 o»- » 3 oc x> -> h-»- 2 O 1-
r— O J" cc JCMO C3f UJ e:o N —O «c -~- O K)
r— CM & UJ -——O UJ X >O0 in 1 2 OO 1—4 U") w—
«•» r— <— 00 -—^ cc h- + 3— UJ + >_J »— •—
— r— —
.
3 O •• - < O0Q z.~ OO o> -1 < k
vOl/) —
.
ro -3-00 > + x »—« OJOSOO> O
•»>-H 00 X 1 Q OJTJfr 2T iCCC —O Z>JQZJO 1-4 fl
000 II o—» < 0. 2 I—* »-oo <I 00 u> II •» 1 o>_i 1 >e S un




-3'JJQ a »-» OUJ^-^—
.
cc -* _JO0 ~» + UJO>— I—OJZ II UJ ^»
1 1 1 \ 1 |M« r-0< 3UJ c: 0— 1—3 22'— •— O «— k— O II 3 OH-OOZ II — 1— > II c h- SI
It <«- + >—
1
+ t zy •-> + zo 1 1 u. 1 00 II Q— MOZ 11 O 11 11 oa_i CC
^Oh-h-HC- 1a<2i<— 00 ^ wOOwQUI- —
«
iil II OinHZMCJQQ2J> >- UJ 1—
•




t— OC£UJ || —00 11 i-j>_i_j5:>o _i 1— >—





U— 1—i >—'OL)>-"M *~ •— 00 c^zzo'-2ozmi-<«j:u. UJ — k—
4
O2OO O O CM —00— OO 00
f— r- O 1r\j J* J- J-OCM J- LOf^- coo UJ































h- LO < •— O
x a: xi o
lu *-• a. t— LU
Z LL —O OO
U_ O Q «-— O O O O O
* Z fO Z h-LO Z lO f- s <— fO
LU O O O —•
—
O •—•—•— CM CM C>
> .— «— OX)- _,-.,_,__,_
< I— » LU OOO I— » * » •» •«
f— Q" < O to "-(CMO < O O O O O I
+ i z o ii vn-j z to Is- o <— to •-
I— Z'JJ >— U0 Z -».—— — r— i— i— CM CM «
xz i—
x
z tu •— o i—•— ••ii z — •— <— •— •—
lui— oo a: x » »-' <-* i o— o: *• •« •» •• -ZO >Z LUOOI— »t— CMh- LU o o o o o
I
>- OLL 1— Z O < i— •— L/t»— >— -3" O CO O CM ^~
LUOt-Z'V o LU V, ID Z II +-—+ LU — o»— O— OCM OOO o oXZXllzold Q z •— a: >-<LU—-LU Q >— cm«— CM»- CM«— C\J— CM CMO II LU II t- .LO I— — O Xi^XLU'— -» o-» o-~ o« o-~ o o
ZZZZU'-'- Z O »- U. OCIOJII Z < --CO —o —O — OJ i— —
II H- il I— >- I X > I MZU2ZJ X O O CT .O O
ujokuoho &- o t- lu r-—a— «-<o k- i oi oi o i oi ooX>X>ZZh- Z Z3- X •— LU_JLUf-> Z 0<»— OCDI— UfOt-^OQl— OLUh-LLh-
utuiiua-a: < n ->«- uj x—xzo < —a —o wo —o —o aZZZZ II LUO X C? II LL X 0OU.O02 X LL II OIL It CLL II OiM- II OLL II O II O
LL LL LL LL C? h-O C? ->0«— C C——>—'UZ O* wCO'-'COi-OOHOC'-COCJO
X
O O O OOOOO O OO OO OO OO o o z
J- M i/1 roiOC- C\J LO -=rr»- OO C0<— OfO CM CM LU
lo tn tn o<—~nmm »- «— •— <— •— r— cm cnjcnj cm o c





















• •> 2:O <
a O ." .--
•— m h- CM
* ry~i ro r—
—~ 1
—
1— ^ O Q-'
LU •> O •M O 1— a.
> '„' LO O O O
< CM PO vO z O CM Z
}»~ %*" 1
—









St O U"l O J- O < X O b
F— X <»*— OJ r<n O i~ Z CM
_j
•h o C£t— LU •» P0 1— P0 Q *—/ •» >
O z t— >Z>0 •— h 1
—
«— j_ 2: _i LU «— 00 OO f—
OJ 1—
4
LUZ 1—co<o -~ O —
.
CC oc 1 O x>
J" C£ 2.U LUZOOJ-O^O LU J O X > LU r— < OO LU LUQ 1
i
—
LU ~>- XO + O*'— y rO X 0C a H + * OCM UJ X
•h x o Kt-O C?>-0\LU - •—
4
r— 0: > 00 LU H ro z + LU k_
o t— • z>-^ ZOICDO f— LU-~ >o + a 1-* < «-»O—
. < F— 002: U-^C^XOO >:2JUJ ex 00 1 a. (—0— •—
•
s<: +
J- o + > + l- + LU>OiZfvO — X) ooo:lu + X LU LU XOCM
r— >—aros:>- 5 -UXO>>'~ 1 HO 1 >x^ a: —i DO LU LU • •» —1 00
•a. 00 Z + ^t-UILix>c?ooo<-~ X>ZUJSOOU > O • 00 O ZOw UJ _j>
-J o OKh>|- bCi^UW-O 3£iO 1 DQi^ZO >- Z— • z «^ — z 00
a "—I >COO II?2Zt- II O II 1 2: 11 ujq 52-JOoO 1 II 00 < LU M I— z UJ 00
> 1— Ot- K-^LJZl— II Q II LLX H-*XDZciZ II O II 1 11 HJO1 II 04 X X < < II
o 00 It OO II > II II LUlQU.<OI-2:3 II >GUJ II -JO u_ xo 11 OQh X z 112 1—
1
H> II II 2C<UJLLOa:iUj;5: 11 >-i.ZUDIX^OX c LU>^XO X M >00 —^ iw«2 1— 2i— ait— s:^3C>cx:ac?xo —•SX OO OiOO> CC 2Ulo:(- LU 0— hUQ k«4
»— < OC>>H<30ZO>E
—
<«- 1 .cjr~->200> —QU> ; II a. zo>
u_ t- >l-<U!>-ZZ>WCOlL5:u.>-U.ZLLC5;J2C z U.ZQOO su. O-JO X









o <DOOOOOOOO < O z
r— O—
1
rvfojtmor^-csj J* CO O u. r— UJ



























W^ * - 1 •*
ct PO 1/1 CM
O r— r-i^ O
X o G<J> O
< CM C\lO UJ LL CMy •» «»_J r«J > •*
-o Cc- J-O — — OU. CM
1
r— • r- LUoO ox> O
—
.
o :*:<— + C>"r>Ji- -UJO O
os: CM o CM *-" 1O — X CM
•O o + o + 00 + • o~- + uj
—
'C£ *» 1 _l < — 21 1— »CC —
.
wd «-~ ooo ->H- X 1 OiZ^. + —
»
C£Z ro it H-_l rOI— II O LUO O
z M II —>o ..—' cc II IIOOQ «k
UJ + —1 ^-> <tz —<—o II _J> l—
'
o ~- i>n -,s o —rsroz~'-UCO —
uu s: lu •*- it o UJS .%Jt^-CC 00OUJI—
II rsj D3-i «H ro 33 II —< II * « "II <MO<
—< C£i2~.— O ZCl — _.-.— II zrt—





< — z:cc:>— _j i£ 2—*-«c:c£<<<o> 2
</)U- o LLOQ<<IOO O QlKOCHI-hJOCDU.
2L'.*- _J i— 1_;2:,t^3:2:0 — 2: zr.zWWi/HJ^OU 1-'O
o CMN-i O < — j-lo r—
z: r— r— »— O .— t— r— O
oo O _J O OO O
















•• I +LU •»—
— — I









































































o 3:5: 5:2 003 <
ro <5 a Oj
o X + UJ o
o O r- c
o o X O o:




OO o aJO Cus:
•> •» o o 1— i-< 3
fc-4 I— ro o a o
_ m m ix o 13 + _i h-
(— r— r— • z UJ
< cm CM »— o «—
1
ClI— + o
t— » •» CO o s: o o CM
OO i— X o— * z o + > o m r—
LTl u-i 1—t • 1 r— o o o < •»
+ r— r— 1— CM «— Q- K-XCL o o 1
CM C\J 00 II II CO 00 U2 _l in •—
<
H- fc < II «QO — UJ + xoo 1— in —i
13 —
.
UJ J" CC -JO. ——.(—•< •»— | CC UJ •»
•JJ — cc li"> UJ «~2l-~ J"J—o— cc XU.+ + 0^
CC a o ^~ 00 H3S •> ~l— -J II II o ou-J o m
o •» u OO o CMO ID <o --—'<!- II o xi-Q **: aio
oc i >-* « •o »c\ 1 •OlTI )— K— <—• 1
—
l-l— uu >oo o •
c i — z OO ^•OlT t —o »<-n H «-^3 1— OOOOoO ^»J"J- i£ 1- II o a— CM ' !
II r-•UJUJ >—4 o <- lu»-> o«— 00 ii oo<< ii r- » •» o 00 ii -j CM UJO UJ
C\J3l^ II II II II OJ3I— II II iM < ii «=i —i t it «•—•*—. o II X O II 31- II 3
t— zo 00 .0.0 Z^ G. _J a._i«-— C—"— *-» -J O II O II H- Z« Z3CiMO »—
<




<i.DCI-*-J2D>- OJ SI D*-K 0<OH GC 3 OUJQOOHI- o. i-j:i->- 1—4
o£ «£.»-- s: 03DJ Z-DQ o 3Q<Q oiu-Kao: UJ . X Ui> 3.O 00 1 \— Z——2
OOOLL < _JQUJUJOCjU_CUJO z OUJI— OO—IUJI—OO o luujo:s_j<o z> OLL<0 X
oou— cc I— 1— h- 1— oo»-i— I—o < 1— 1— 00 2: ?_ i- 1- oo i: z: z 1— 1— OOOOO-JO o o»-3;o <—
o X < o
o o o — J" o ro in > o o z.
o a: in in in X in in o CM o o<© UJ


















X OO — OX O c£
LU Q.
\- —\ —
— X ixiX u t- o o —
o xxulu-ov-i— <x <? s:
X OLUU.LULULU»->C Oni >—
t— uj t— x s:q xu.uJci:Qia:<«j|— >uj i— —
OLULL CO< LU U_ SUJOJ LUUJX0002CWODQ CO < 00 fO
i— ciuj ccr >uj oil i:xx> i-i-LiJooo<2Qco<z>aijj (— in —
— Ol— ^<V-<X> XtUOX"—oc<o o<3 < m
<cj t— y- — o_2:2:oujc:cL_j<t— z>z: 3:3:0 Q • I
3: 1 22 —< oiui-z>>s;>s:>2Ci>-r3 11 11 11 11 11 11 11 n 11 11 11 11 coco lu o «
v. uo «-<>>.><OODC?Oll.cOLUZ <r<« n •— —<
•vvt— X>>- t->00<0<0< II II II II II II • II II II o ••HDUUOOCO II II II II II II II II ~-~ ——.*»-*«•»«-.-»-»»».-»->.—-.^ *-.-,-»,— -* ohuJXVNr-M-.«^~« -> 0— cMfO j-in<5Ncoc>0'- <\im -3- in -01s-coo »oz »—
«—OCLUClX »0»— CNIf^^ in -O N- CO Or-r-r-^- f— 1— r-^-»-^-t\JojC\J(\JC\JC\ICNJCSlC\JOJ<--/,Oi-i —
3u-ox 11 11 ci c£ 0: c< c£ c£ a: ci c< c£ c£ ci a£ c£ o: a: c£ c£ c£ o^ (^ c£ c^ u.
COLU<—1 t—H-M-1 *— _i_« ,-. .—. »—1 •—1»—1 1— ^-._.—1_>___,_>____>_____ 1—.LU LUQ.LU •—O
o 11 •——' 1— 1-^ 1— 1— >^ t—— 1— 1— 1— 1— i— )— 1— 1— 1— *— 1— »^ 1— »— 1— 1— 1— 1— 1—— .1— 1— ^— •—1 1— s: + 21-Z1|-U-LL>a^w3333333D33DDDD3D3ri3DD33DD2i2pDN X— DC - 10— 0£ I- 1- —HUJiLa<in<OOaOOOQOOOOCCODOODQOOODODOODOJl II OI->-hH«H«ZZ —
1
<C CC LU JS j£ I— 1— 1»- 1— I— I— I— I— t— H- 1— >—— I— •— h- >— h- h- I— I— I— H-— I— I— h- \— 1>- i— I-2|IZ-ZIImm3:cxcocoo<cboooococooooocooooocaoocoo6cozooct:cu_oa:Qioi x
<OCJ<<CQHf-t- h-h-t— I— >— I— I— t— I— I— I— I— H-H-l— I—— 1— l-^ k— 1— t— >— t— t-*- 1— Qi— f— o>-'0«— O'-'O-Cu i—
o
f-i- CO ^
in— — in lu






•. — >- —
.
r- u 3 o.
cm >- O lu
it — • 13
-3
— 2
— o — -» 00 I—








I— U- I! !i — O3 Z> -r-<- II _J 3C
C U —— I- o —
^ l_ .. »—. QT oo
n r> . o uj
i— h- oo-~ t— a. s:
~- ~ CMCnJO < > <
-
— p, ..__• r£ —
-» J" ir— * UJ CO O
N- — •— CM— 2 OoC O
*> •. it iim uj n«-i c^
— CO OOOO II O •» •» Q.
ii ,, —.— ^7 za:
—) —3 » -<—
i
• "JO
— — 00 00— I—
X
-3
-j __>_ oo • 00<
«. » » •.(_< c£ —'S! •
•—i i—i I— H- »» Q •» U">
— — *->-i— 2 «OZ C\J j}
I— (— »—.^.-. < tuooa: -O —
3 3 I— l—— •-• OQh o
a c iDi- oo 2-<xz o 2 i
i- i- cc^ oo ocmoc<:3 ro oc ~O t_(— O 3 0»— LU5.. * r— <— >— o —
I— I— OOh < 2«—> •» * • — < UJ •
— — i-i-o o <3<s:2 to * a o o—
^ ^ w«-K cC2 "OCoC CMCMO^O O _J CM + V.CVI
^ ^ ^^^. o oC0C3o02-— J- — U- i— o<—
» » ~- 2 uj 2x3acro » .-co i i -» »woj-
in j «o * •» • < zzuj<<- if)'—"-o>uj — •— o-——io
COOJtoOO- CM— CMcOj-lTt-—O— CM «0OSOZ0l|r-C"-.O *Ji»sl— • II 3<(_32
cu co u") j-i co co <x>u~>m co co ccin'/ic^oo 2: i— —• 3— >-<— .j-ll • 2 n 30— 2t_) u oc




— I— I— 1— I— t— I— K-# I— k— I— I— I— I— |— f— O OZDOOII II OttOZ *— >-»-CC20 II 2OC20C <—22222222222222222a UL OCUJS-SIS: CM< II C£M M-et^ II DCKTO DC OOqC3 —
mmw-hwmmmwi-ih-wi-i-wmOQ «-• a3i.i-S;22> — 2<sT 11 II 032I— -JH- 3*->— Q
DC OC DC DC DC DC DC QC DC DC DC DC DC DC CCOC DC I- 2 2 3—OCOOC—'OU-OC II —M_JZ DC LUO< UJ< 2LU2 X
Q.aacxOwO.CLQ.Q.CLQ.a-c_a.aD.o-oouj 3 wcuuo<u.CM<NM2a.o:<coooc3aijj <—
Q2
LUO— OO Q.
























uj cc i u i
CDO« v— •
<~3— 2J











•— L-iootv: cd »
— »OQ« —"XX'>0<X2 U-Csi z
-)OuTct:<r3 •»x •• cc
—— .— LUST «vO«— 00
i— zcx:> - » "»»CM • 3
OC UJ3Z<S1Z >v ^O IT) <




















Z Z 2C 2: 2. -jc —
13 ID 3 ID 3 ID -O
UJ«— •—
o<— d- m •>•>•>•> co I uo
<o+ —
oj • «o o w w «- w oq:
UJO— •> it < U-- UJ UJ UJ — a I*-
><—+-
-3" O CC O O O O ^C'-O •—O <-0~- «— O UJ <5 < < < -CCX i-i
• t— o j > e: k a e: -?o<
I— + -~O0 » O < UJ UJ UJ LU -OS
a."-< cm > > > > qcx
300:300—*kj*U_ <— .—S Z + Q-ZQ — Z It II < < < < Z< II
< uj zxdiSj » 11 o 11 020 zuj 00 n it 11 11 luz
CC ZZ2UJ<< i'^^J- +OO Oo: •»-•— UJV- II j* Q-» ~ « ^. ^ ^ oi"
uj hocozo^sn'-1 >-z-«ujZi->0(/) >— •—
—
ujujZ'— cm ro jt on -ouj ujo
2: 1—-*—. *^~~.^ 2: <UD<Z Q+ I -«>OODS< «• UJ •» • •» »3 II M »
UJ D^oOZZZH-t-hl- X^Oal-ZfiDIl ll ~ •— Z.~CC~} -3Z-3 -3 "3 ~3Z —•->
O CZZDQC l(t<«01 O ——• H •— Z-O I Hh — w_ «~ w w __ujoo«- —
arujujzzzz^zz 11 <3_j^i— _j 11 a. cucct—t— •—— _io: cii--a:uja: cc ccv-^>.cc <—
CQ GZSlSiZCSZZtcCCCCCCC II II JDZJ Zl— II Z—• o0 -ZJJZ 'Z ZSiZl^Z ZZ*-—ZO DwmCOOOOOO ZO<ZO<Zujoo uju_>-Ou_o<<uj ujujuj>-iuji— uj ujOoou»uj x
-J WQQOU!i!U.HU.U.MOOQUDUU^i-C>-l-'-<QO-U>UO e>>OI—0<0 OU^-U —
>
" O « LU UJ Q
O u~> CM O f—3-CC < *— O CL (nj O O Z
r-Oro»— O ^- *— t—#— oi OO v^UJ»-«CM •— UJ




5. CM s: J or,
t—
'
3 — 3 ~- —
»
O
z £ z s Sl T—3 3 3 3 O
«— * Z Z Z m
u. — 3 >c 3 3 C^O
(J <N * * * —OO •% «— ^-» — -~ •o-—3 »—
4
ro J- in O -





































































ZO I + I + I t ~
I— (—•——• -3 -> -5 -3,-5 2:Z2: i—-)»—2 2;2C t—2! I—O2—^- II —• || —«— «~.~.—. •— II —.1—1— -ZhQC























• O • •
— —O —0
•0 •O •00 O-O 0-0
ro ro rn
OC\l 0(M OCM
mo mo mo0—0 Or-
O
0—0
• • O • • • •000 OOO 000
CNJ CsJ CM
rO m m
00 1— CM ro zt>~ mo O
^- CMCM CM CM CM CM CM r—
•0
-O-O O -O-O OO r-sO
OOOO
• • • •
«— CMm-3"
j-o ^O j±
~ o o oOOOOOOOOOOOOOCMOOOCMOOOCM
• • • • • • ••• •* • c\jO •"" CMO ~~ fNiC"OOOOOOO OOON"lCMOON)CMOOmcM00OOOOOOOOOp • «CM »CM • »CM
mm r<"!mo croo o ^ooo »—ooc cmooom
o o o
















STATUS PRESERVATION IN THE 1604-160
SATELLITE ENVIRONMENT
The current 1604-160 Satellite System Control Programs do not
provide for executive directed program exchange during a job run.
Rather all switching between job input queries is performed by the
Monitor program during the interjob interval
.
While program exchange as a technique will be of limited effective-
ness until faster external storage devices are available (with present tapes,
the exchange time would be 16 seconds) , the status preservation technique
necessary is of value. The following analysis indicates the nature of the
status preservation problem associated with such an exchange and des-
cribes methods of resolution.
To provide the desired break-in capability, a priority approach
should be followed. Upon receipt of a satellite request, the batch job
would be halted, the environment preserved, and the program transferred.
The remote user would then be serviced to completion and the batch job
continued (Figure III— 1) . While the system provides little in the way of
exchange techniques , it does allow a detailed investigation of the
problems involved in environment preservation
.
The batch job can be interrupted at any time except when a transfer
to peripheral equipment is actually in progress. This problem was handled
previously by the use of a flag that could be set by the 1604 and sensed






































1 Cell 00 - Cell 0?
2 C ;ntrol Information and
.




5 Li stable Output Buffer
6 Punched Card Buffer
7 Stacked Job Buffer
8 Program Start Table
9 Monitor Control Cells
125

Glover in previous papers (14 and 15). Since then, an Interrupt Lock-
out select code has been provided in the hardware. It is recommended
that this select code be used during all transfer operations and no wait
loop will be required in the 160. The Lockout code will be selected
immediately before the transfer and deactivated immediately upon com-
pletion. To preserve maximum system sensitivity this code must be
selected and deselected on every pass through a repetitive loop. The
160 interrupt will then remain on the line until the 1604 is free to service
the request.
Upon sensing a monitor type job satellite request interrupt the
1604 will branch to the Exchange portion of Resident. It is this
Exchanger that will preserve the present environment and initialize the
Monitor Routine for the satellite job. As discussed in Section 5.2. the
environment could be stored either in internal tables or with the program
transferred to the external store. With only one user ever being exchanged
the storage in internal tables would be most practical. A storage area
could be provided immediately after Resident with only a slight change
in Resident programming.
The operation of the proposed Exchange routine is shown in the
flow chart of Figure III— 2 . To permit the restoring of the interrupted
job upon completion of the satellite job a SATJOB flag should be used.
Upon sensing a job termination the Monitor routine would check the
status of the SATJOB flag , if it were set , and hence a satellite job












































If the flag was not set, a normal batch job termination would be assumed
and the normal flow of Resident followed.
The double instruction per word format of the 1604 poses the
only difficult status problem. At present, it is impossible to sense
the status of the Interrupt Exit Flip Flop which provides the only indica-
tion of whether the interrupt occurred on an upper or lower instruction
Normally, programs exit from the Interrupt Processor through the
Interrupt Entry Location (Cell 07) and control is automatically returned
to the proper half word. In the proposed satellite system, however, a
new program would be injected into the system with new initial condi-
tions. If the absolute requirement of status preservation is to meet,
the status of this flip flop must be both preserved and be capable of
being restored. Programs can be written to determine this status but
they are time consuming. Once the status has been determined it can
be reset by artificially creating a divide overflow from the half word
desired. This causes an interrupt to be generated and with the suitable
flag checking in the Interrupt Processor, control can be passed to the
Exchanger with the Interrupt Exit Flip Flop properly set. A hardware
modification has been designed to both sense and reset this and its
implementation should be seriously considered if this type of operation
is to become common.
The transient portions of Resident can be stored in a IK area of
storage . While the following list is not complete it includes the main
areas that must be preserved. These areas are also shown in Figure III — 1
128

.1. Cell 00 - Cell 07. These contain the I/O transfer control
words and the interrupt exit. If cell 07 is preserved along with
the upper or lower status of the Interrupt Exit Flip Flop, restoring
these will provide reentry to the point at which the program was
interrupted
Due to the difference in Resident arrangements, the location of
the following areas is not a fixed quantity . The approximate length is
given after each area in octal notation.
2. Control Information and Monitor Tape Assignment Table (20)
3. Read Buffer (200)
4. Write Buffer (230)
5. Listable Output Buffer (20)
6. Punched Card Buffer (20)
7 . Stacked Job Buffer (30)
8. Program Start Table (40)
9. Monitor Control Cells (10)
These areas should be saved and then initialized prior to starting
a satellite job. Due to the fact that a batch job has probably been
interrupted a different output tape should be designated for the satellite
job. A careful determination should be made of the other areas that
require initial values to be reset
.
The actual saving and resetting should proceed in a logical fashion,
preserving those quantities that will be changed by the Exchanger first.
The tape to be used for the transfer can be either preset in the system
129

or brought in from the 160 as an input parameter.
Due to the nature of the FORTRAN compiler it would be advisable
to dump the entire core above Resident for all Exchanges . To reduce
transfer times, schemes to determine the portion of core actually in use
should be investigated for use in later systems. As a time saving step,
upon completion of any transfer the tape should be rewound immediately
so that it is at the load point ready for the next transfer operation.
This exchange technique will provide an invaluable start towards
a more sophisticated multiprogramming system. The question of environ
ment preservation is a vital one and its solution will apply to any type
of further system development. Availability of high speed transfer
mediums and/or the use of space allocation will still require the

















3 2768 002 07797 6
DUDLEY KNOX LIBRARY
IK
tw«uf(B
Iffll
';;: :
'-o •?;!:;; iiw'iT'
HE
ku;IHil
llfc*
i*kj
