A microprocessor-based input/output system for an interactive computer by Jones, Wayne Elmer
Retrospective Theses and Dissertations Iowa State University Capstones, Theses andDissertations
1975
A microprocessor-based input/output system for
an interactive computer
Wayne Elmer Jones
Iowa State University
Follow this and additional works at: https://lib.dr.iastate.edu/rtd
Part of the Electrical and Electronics Commons
This Dissertation is brought to you for free and open access by the Iowa State University Capstones, Theses and Dissertations at Iowa State University
Digital Repository. It has been accepted for inclusion in Retrospective Theses and Dissertations by an authorized administrator of Iowa State University
Digital Repository. For more information, please contact digirep@iastate.edu.
Recommended Citation
Jones, Wayne Elmer, "A microprocessor-based input/output system for an interactive computer " (1975). Retrospective Theses and
Dissertations. 5484.
https://lib.dr.iastate.edu/rtd/5484
( 
INFORMATION TO USERS 
This material was produced from a microfilm copy of the original document. While 
the most advanced technological means to photograph and reproduce this document 
have been used, the quality is heavily dependent upon the quality of the original 
submitted. 
The following explanation of techniques is provided to help you understand 
markings or patterns which may appear on this reproduction. 
1.The sign or "target" for pages apparently lacking from the document 
photographed is "Missing Page(s)". If it was possible to obtain the missing 
pag@(s) or section, they are spliced into the film along with adjacent pages. 
This may have necessitated cutting thru an image and duplicating adjacent 
pages to insure you complete continuity. 
2. When an image on the film is obliterated with a large round black mark, it 
is an indication that the photographer suspected that the copy may have 
moved during exposure and thus cause a blurred image. You will find a 
good image of the page in the adjacent frame. 
3. When a map, drawing or chart, etc., was part of the material being 
photographed the photographer followed a definite method in 
"'sectioning'" the matsriai. it is customary to begin photoing at the upper 
left hand corner of a large sheet and to continue photoing from left to 
right in equal sections with a small overlap. If necessary, sectioning is 
continued again — beginning below the first row and continuing on until 
complete. 
4. The majority of users indicate that the textual content is of greatest valus, 
however, a somewhat higher quality reproduction could be made from 
"photographs" if essential to the understanding of the dissertation. Silver 
prints of "photographs" may be ordered at additional cha^^s by writing 
the Order Department, giving the catalog number, title, author and 
specific pages you wish reproduced. 
5. PLEASE NOTE: Some pages may have indistinct print. Filmed as 
received. 
Xerox University Microfilms 
300 North Zeeb Road 
Ann Arbor, Michigan 48106 
1 
76-1849 
JONES; Wayne Elmer, 1948-
A MICROPROCESSOR-BASED INPUT/OUTPUT 
SYSTEM FOR AN INTERACTIVE COMPUTER. 
Iowa State University, Ph.D., 1975 
Engineering, electrical 
Xerox University iMiCrOfilme, Ann Arbor, Michigan 4810e 
THIS DISSERTATION HAS BEEN MICROFILMED EXACTLY AS RECEIVED. 
& microprocessor-based input/output 
system for an interactive computer 
by 
Wayne Elmer Jones 
A Dissertation Submitted to the 
Graduate Faculty in Partial Fulfillment of 
The Requirements for the Degree of 
DOCTOE OF PHILOSOPHY 
Major: Electrical Engineering 
Iowa State University 
Ames, Iowa 
1975 
Approved ; 
For the Major Department 
Signature was redacted for privacy.
Signature was redacted for privacy.
Signature was redacted for privacy.
ii 
TABLE OF CONTENTS 
Page 
INTRODUCTION 1 
REVIEW OF LITERATURE 8 
PROBLEM DEFINITION 11 
SYSTEM EVALUATION CRITERIA 13 
SYSTEM FUNCTION DEFINITION 16 
PROCESSOR FUNCTION ASSIGNMENTS 21 
I/O SUBSYSTEM COMMUNICATION REQUIREMENTS 28 
CLASSES OF TERMINAL TYPES SUPPORTED 38 
Class 1 38 
Class 2 113 
Class 3 ill 
Class 4 (12 
DETAILED PROCESSOR DESCRIPTIONS 4U 
Terminal Controller 44 
Channel Controller 47 
Control Interpreter 49 
Interface Processor 50 
I/O Supervisor 54 
Code converter 59 
I/o Memory 60 
CONCLUSIONS 67 
ACKNOWLEDGEMENTS 70 
LITERATURE CITED 71 
RELATED LITEBATUBE 
APPENDIX 
1 
INTRODUCTION 
The earliest computers consisted of a terminal and a 
processor. When a programmer wished to run a program, he 
loaded his program and data, ran the program, made any needed 
changes, and reran the program. The final two steps were 
repeated until the program operated correctly. This 
technique was excellent in terms of programmer efficiency 
because results were available very rapidly» 
However, several disadvantages were present in this type 
of configuration. The computer was idle while the programmer 
was making changes. Every programmer was required to learn 
the intricacies of operating the computer. Every programmer 
had to come to a cantralizsd location since there was usually 
only one terminal. 
To correct some of these inadequacies, batch processing 
was developed. The programmer now submitted his program to 
some type of operations staff which ran the program on the 
machine and returned the program and any output to the 
programmer. This type of ccufigaration improved the 
utilization of the computer and removed the burden of 
physically operating the computer from the programmer. 
However, elapsed time for a run increased causing programmer 
efficiency to suffer. The programmer often had forgotten the 
pattern of thought that lei him to make certain changes 
2 
before the results of those changes could be returned ta him. 
In an effort to speed the response time and increase 
efficiency, a modification o£ batch processing called 
multiprogramming was developed. This allowed multiple 
programs to run on the same machine simultaneously. This 
process was accomplished by letting each program run for a 
fixed interval of time and swapping programs at the end o f  
every such time slice. This concept decreased the elapsed 
time but Sid not provide a significant improvement over the 
standard batch processing technique because there were still 
too many people involved in the intermediate tasks. 
The next technique developed was called remote job 
entry. In this mode the programmer entered his program from 
a remote terminal and the results were returned to him either 
from a centralized output device or possibly from an output 
device at the remote job entry point. This technique did not 
provide much improvement over the earlier batch procassing 
methods because the elapsed time was not significantly 
decreased. 
As sn alternative it * as sssggssted that the ussr rscexvs 
a real-time response to his actions at a remote location. 
This technique is the basis of the interactive time-shared 
system. The system appears to interact with many users 
simultaneously by rapidly commutating the system's facilities 
among these users, each of whom is on-line at a remote 
3 
terminale 1,2 ]. 
A definition of a real-time response is na* required if 
the system is to be adequately specified. K real-time 
response implies that the user receives a response to his 
activity while the reasons for an operation are still fresh 
in his mind. Delays grôater than four seconds can be 
tolerated if they occur when a major break occurs in the 
user's thought pattern. Delays greater than two seconds 
should be avoided if the task requires a high level of 
concentration. The response speed needs to be proportional -
to the amount of detail involved in the operation. 
operations like keystrokes and cursor movements should appear 
instantaneous to the user. However, care must be exercised 
to see that rapid response does not push the user[3,4]. 
The implementation of an interactive time-shared 
computer has been the goal of several efforts. The original 
interactive systems were of a centralized design. The 
percentage of time the processor was doing useful work for 
the user was typically vary small. The processor spent most 
of its time doing bookkeeping tasks, program editing 
functions, time slicing activities and terminal control 
functions. The block diagram of a central processor 
eonfiguration is shown in figure 1. 
A similar situation arose in systems with a preprocessor 
type of configaration[5]. The preprocessor was used to 
I* 
manipulate the data stream and thus simplify the I/O handling 
requirements for the main processor. The preprocessor 
typically removed part of the overhead from the main unit, 
but usually not a significant amount. The block diagram of i 
preprocessor configuration is shown in figure 2. 
Another solution vas the SYMBOL system with its 
distributed architecture and hardware control sequence[6]. 
This technique allowed the central processor to perform only 
users' work; However, the implementation of the control 
functions in hardware made the machine very difficult to 
service or to adapt to new equipment. A second problem was 
that the terminal interface requirements could be met only 
with a specialized and expensive type of terminal. A final 
problem was the relatively primitive level of communication 
between the SYHBOL system and the terminal. The block 
diagram of the SYMBOL system is shown in figure 3. 
5 
r-
I 
I Memory 
r 
I 
-ITecainal 
I 
I 
I I 
r—irerninal 1| 
I I 
Central 
Pro=essor 
I 
I 
I 
-1 I 
I i 
I i 
I I 
^Terminal 
I 
I 
I 
—ITeroinaX 2| 
I 
3| 
I 
I I 
-ireralnal n| 
I I 
I I 
Fig. 1. Central Processor Configuration 
6 
I 
I (Terminal 0 
I 
Memory 
I 
I. 
Central 
Processor 
Preprocessor 
I 
r—irerminal 
I 
J 
I I 
————————irerminal 2| 
!. I 
I I 
L—{Terminal 3| 
I I 
r-— 1 
I I 
{Terminal n| 
i 1 
I J 
Fig. 2. Preprocessor Configuration 
7 
r-
I I 
I I 
I System | 
I Supervisor | 
I I 
I I 
I I 
r ITerainal 0| 
I Interface | 
j Processor | 
I I 
M 
e 
m 
o 
r 
y 
r — 1 
1 XCVR 0 1 
1 XCVR 1 1 
1 XCVR 2 1 
1 Channel 1 1 
1 XCVR 3 1 
1 Controller ] ————— 
— 1 
i * 
1 • 
1 # 
1 XCVR n i 
1 1 
I I 
—J 
I 
r—ITerminal 
I 
I I 
-llerminal 2 \  
I I 
Remainder 
of System 
I 
«.—jleriinal 
1 
I I 
(Terminal n| 
I I 
L —_j 
Fig. 3. SYMBOL System Configuration 
8 
REVIEW OF LITERATURE 
Nearly all previous work involving I/o structures in 
interactive systems has involved the use of a general purpose 
computer with software control. The HOLTICS system at the 
Massachusetts Institute of Technology is one example. It is 
implemented entirely in software on a General Electric 645 
computer system[7,8]. one major fault of this system is a 
restriction on the type of terminals that can be supported, 
i.e., HOLTICS supports only the IBM Model 2741 and the 
Teletype Model 37. 
A second interactive system is TH0R[9]. This system is 
implemented in software and utilizes a video display 
terminal. However, a special keyboard is required at the 
terminal to generate the control characters required by the 
system. During editing operations a portion of the user's 
text is displayed at the terminal. The user may edit the 
displayed text or request that a new portion oE his text be 
displayed. The system also supports Teletypes, but the 
control and editing procedures are less general and mora 
difficult to use than tbsge for the video terminais; 
Another interactive system is TALK[10]. It is 
implemented on a CDC 1700 computer. The system is capable of 
supporting Teletype devices and card reader/line printer 
pairs as I/O devices. However, on-line editing facilities 
are not provided. 
9 
An evaluation o£ commercially available interactive 
systems was undertaken by Ford Motor Company in 1970(11]. 
All of the systems utilized a software approach to I/O 
handling. Each system was evaluated in terns of command 
language and editing facilities. The user interface was 
defined as the major problem for nearly all of the evaluated 
systems. 
A major thrust in the area of interactive computing has 
been the development of test editors. One system, Q2D, it 
the oniversity of California in Berkeley is designed to 
support Teletypes and typewriters in a variety of editing 
operations[12]. Character editing operations are provided 
for intraline editing after the selected line has been 
accessed. 
An editing system at Brandeis Oniversity is line 
oriented. No character editing is provided[ 13]. This system 
provides support for Teletypes and typewriters. 
An editing system implemented by Bourne utilizes a set 
of codes for intraline eàiting[14]. f means keep the current 
character and # means delete the current chacastec. other 
editing functions are supported on a line basis. 
HYLBUB is the Stanford University computation Center's 
editing system[15]. It is a large and powerful software 
system with only one major restriction. It supports only the 
IBM Model 27U1 and Teletype Model 33 terminals. The system 
10 
does not contain provision for many of the functions of a 
video display, e.g., cursor movement. 
The STHBOL system represents a different approach to an 
interactive system[16,17,18,19,20,21]. Eacii processor within 
the system is utilized for a specific function and nearly all 
of the control is implemented in hardware. This system 
provides adequate support only for the SYMBOL terminal. 
Software can be used to support other I/O devices although 
not very efficiently. 
11 
PROBLEM DEFINITION 
All Of the previously described interactive systems are 
limited in the type of terminals that they are capable of 
supporting. Only one of the systems utilizes a video display 
and that display unit is special because of keyboard 
requirements. 
In an effort to alleviate this problem, the research 
described in this disseration involves the letarminatioa of 
the type of I/O structure required to support many types of 
terminals in an interactive environment. This work Includes 
the specification of command and editing functions for a 
variety of terminal types and the evalgation of various 
implementation methods for both control functions and data 
paths. Serviceability and understandability are also factors 
in such an evaluation because of the high cost of updating 
the I/o structure to support new terminals as they are 
introduced, 
A principal emphasis of this work has been the 
development of an I/O subsystem which optimizes performance 
with interactive terminals, i.e,, where average data rates 
are low and control functions are complex. Bhere the maximum 
data rate is an important factor, e.g., a bulk storage 
device, the subsystem does not represent the optimum I/O 
structure. 
12 
The availability of Microprocessors adds i new dimension 
to this work. If a microprocessor with supporting hardware 
can be utilized as a special purpose processor in a large 
computer system without impairing performance, both 
serviceability and understandability of the system are 
improved. With an element, i.e., the microprozessor, common 
to many of the special purpose processors in the system, 
knowledge concerning any one of the special processors is an 
aid in understanding the operation of the others. 
13 
SrSTEfl EVALUATION CRITERIA 
Dsing information from existing systems, i set of 
criteria has been developed to evaluate the input-output 
section of interactive computers. Such a system should: 
1. Interface directly to any asynchronous 
terminal type with a serial channel of up to 
9600 baud including those terminals consisting 
of an interface and multiple devices. 
2. Perform code conversion between the terminal 
character set and the system character set. 
3. Provide on-line editing facilities for any 
type of compatible terminal without 
unreasonable time delays for the user. 
tt. Provide terminal control functions as 
required, e.g., carriage return, clear, line 
feed. 
5. Provide detection and decoding facilities for 
system commands, e.g., run, initiate, load. 
6. Require minimal control from the rest of the 
computer system. 
7. Be interruptible so that it may be used with 
time slicing or virtual memory systems. 
8. Provide a means of "pushing a program down" 
on a terminal so that a supervisory program 
m 
can be run on the same terminal and the 
"pushed down" program later completed. 
9. Be simple to facilitate understanding and 
serviceability. 
10. Include enough flexibility to handle new 
types of terminals as they are developed. 
11. Be capable of being initialized without 
complex set-up procedures. 
Tho flexibility requirement virtually eliminates the 
idea of hardware control sequences except in cases where 
there is little likelihood of change, e.g., buffer 
manipulation. 
The criteria of rapid response, code conversion, and 
simple initialization preclude the use of pure software since 
execution time increases when software is used as the driver. 
The software must also be reloaded at initialization if a 
system failure caused the control program to be eodifiei. & 
solution is to use a combination of software and hardware in 
the form of read-only memory containing control code 
sequences for the processors. 
The serviceability criteria requires that the system be 
simple. However, the response speed requirement dictates 
that the system may need to respond to one terminal while it 
is handling another. One way that both of these criteria can 
be reasonably satisfied is with a distributed architecture. 
15 
With the concept of distributed architecture comes a new 
problem. Because each processor is constructed to perform a 
specific function, there may be little resemblance between it 
and the other processors in the system. Thus, serviceability 
must still be considered. A viable compromise would be to 
construct each processor from a standard part, e.g., a 
microprocessor, and surround it with the supporting hardware 
necessary to perform the required function. Each processor 
could then have a common element, but could still be 
customized to perform a specific task. 
16 
SYSTEM FONCTION DEFINITION 
Combining a distributed architecture in the I/o section 
with the preprocessor configuration of figure 3 results in an 
I/O subsystem capable of operating between a number of 
terminal types and a main computer system. Such a 
configuration is shown in figure 4. 
With this organization, the main computer need not 
possess any knowledge concerning the terminal being utilized, 
•hen the main computer requires I/O, the I/O subsystem is 
informed and the main computer proceeds to other work. Using 
the terminal identification provided by the main computer 
with the I/o request, the I/O subsystem accesses the proper 
terminal, executes the I/o task, and informs the main 
computer at the time the task is completed or suspended. 
This method of interconnection has two significant 
advantages. The main computer is involved in the I/O task 
only to the extent that it informs the I/O subsystem when an 
I/O task is pending and receives the I/o subsystem shutdown 
information when the task is halted. This allows the main 
computer to perform other work while I/O is in process on a 
terminal without time slicing activities. A second advantage 
is that the I/O subsystem can be utilized with any main 
computer system capable of supplying the necessary control 
information. Minor modifications will be required in the I/O 
subsystem to interface it with different types of main 
17 
computer systems. These modifications will be in the I/O 
subsystem/main computer interface, i.e., the control signals, 
the memory access signals, and possibly a data conversion if 
character sets differ. 
The SYMBOL computer was utilized as a vehicle for 
further investigation of the I/O subsystem because SYMBOL'S 
hardware I/O structure is a possible candidate for 
replacement by the subsystem. Availability of the SYMBOL 
system and general knowledge of tha SYMBOL I/O structure were 
also important considerations. The detailed descriptions 
included in the remainder of this paper are defined in terms 
that are applicable for the I/O subsystem as it would be 
utilized with the SYMBOL computer. However, the concepts 
described have a much broader application. 
To aid in the iapleaentatioa of this I/O subsystem, a 
definition of the functions required o£ the subsystem is 
needed. Such a description follows: 
1. Terminal control function, e.g.. generating 
carriage returns at the end of a line of text 
if the terminal dcssn-t, controlling data 
rates to prevent data loss, and synchronizing 
the terminal's asynchronous information to 
allow the system to manipulate it. 
2. Code conversion, i.e., the transformation 
between the symbolic code used by the terminal 
18 
and the symbolic code used by the system if 
they are not identical. 
Control command detection, i.e., system 
commands and editing commands must be detected 
in the data stream. 
Buffer manipulation, i.e., some type of 
buffer mechanism must be provided to smooth 
the data flow to the terminal and yet not 
present an eacessive load to the system. 
Data transfer, i.e., information must be 
moved between the terminals and their 
respective buffers. Information must also be 
moved between the buffers and main memory. 
I/O subsystem control, i.e., the total data 
path must be monitored to assure that 
transfers are accomplished as efficiently and 
rapidly as possible. 
Control command interpretation, i.e., system 
commands and editing commands must be 
interpreted to determine the proper response. 
Separate control command channel, i.e., a 
discrete channel for control commands must be 
provided to allow system commands to be 
received during output. 
Editing command execution, i.e., the receipt 
19 
of an editing command may necessitate an 
immediate update of the terminal display. 
10. System command transmission, i.e., the rest 
of the system must be informed of the receipt 
of a system command. 
11. Character echoing, i.e., the system must 
transmit any characters that are to be 
displayed back to the terminal because the 
system is interposed between the entry device 
and the display at the terminal in the full 
duplex mode of operation. Half duplex does 
not alio* enough flexibility for an 
interactive system. 
12. Pushdown operation, i.e., a supervisory 
routine can be run on a terminal and then 
return control to a user program in progress 
on the same terminal. 
20 
I 
L. 
Memory 
(lain 
Computer 
System 
I I 
-irerminal 0| 
I I 
I 1 
I I 
r—ITeriinal 1| 
I I 
J 
ITeriinal 
(Terminal 31 
# 
I I 
«- (Terminal n( 
I I 
Fig. 4. I/O Subsystem Configuration 
21 
PROCESSOR FUNCTION ASSIGNMENTS 
Accepting a distributed architecture as optimum leaves 
the problem of deciding where each of the previously defined 
functions should be performed. 
The terminal control functions must be performed on a 
dedicated basis if they are to be adequate. If an effort is 
made to perform yuch tasks on a time-shared basis the 
complexity rises markedly. For example, it is necessary to 
prevent transmission of a new character fr^rn the terminal 
before the previous one has been handled. However, if such 
control is time-shared, high speeds and careful design are 
required to ascertain that every terminal is checked for such 
an overwrite condition. An individual terminal control for 
each terminal is more straightforward and allows control to 
be tailored for the terminal desired. Because a variety of 
terminal types is to be supported, the first application of a 
microprogrammed microprocessor becomes apparent. Standard 
hardware and a variety of control sequences for a variety of 
terminals effectively solves the problem. The name Terminal 
Controller has been chosen to describe this element in the 
architecture. One will be required for each terminal 
connected to the system. 
The code transformation should take place in the 
Terminal Controller, since needless complexity can be 
avoided if the rest of the system handles only one character 
?2 
set, the code transformation must be done as close to the 
terminal as possible, i.e., in the Terminal Controller. An 
added advantage is that the Terminal Controller already 
requires an identification of the terminal type to determine 
the control requirements and this same identification cm be 
used to control the code transformation. 
Handling of control commands is the next function to be 
considered. These commands require detection at an early 
stage in the incoming data stream so that they nay be routed 
separately. Because every character undergoes a code 
transformation, the control commands can be detected at the 
same time by deriving additional information from the code 
transformation. This information can then be used to control 
the routing of the control commands. 
A final task that can be performed in the Terminal 
Controller is the job of echoing characters back to the 
terminal. If the character is not a part of a control 
command, it will need to be echoed and the most rapid 
response is obtained fay doing the job in the Terminal 
Controller, control commands may or may not need to be 
echoed and must be handled in a more complex manner. 
The buffer concept and the requirement that the control 
command channel be separate dictate that there must be three 
buffer areas for each terminal. Two, A and B, will he 
utilized as data buffers. A third, c, will be utilized as a 
23 
holding area for control commands. This can ba accomplished 
by locking out any new control commands until the previous 
one has been interpreted. This is not an unreasonable 
procedure because the user will need to know the result of 
the previous control command before another is entered. 
The data transfers between the Terminal Controllers and 
their respective buffers will be handled by the Channel 
Controller. The Channel Controller will scan the Terminal 
Controllers and transfer characters between the Terminal 
Controllers and the appropriate buffers as required to keep 
the terminals and the system operating. It will utilize the 
information provided by the Terminal Controllers concerning 
control commands to initiate transfers to the c buffer. 
To most effectively utilize the main memory, the data 
transfers between the buffers and the main memory will be 
performed on a burst basis to lessen the loading on the main 
memory. The processor which does this is called the 
Interface Processor. 
The logical location for editing command execution is 
the Interface Processor. Because it manages transfers 
between the buffers and virtual memory, it has access to a 
copy of the information available to the user. This 
information is needed during editing tasks so that the 
information presented at the terminal may be updated 
correctly. 
24 
The iatecpretation of control commands is a simple task 
if each command is transmitted from the terminal as a unique 
code. However, this is clumsy because the keystrokes 
required will typically have little in common with the 
operation requested. If multiple keystrokes are permitted to 
construct a control command, another problem arises. 
Experienced users may be capable of using an abbreviated set 
of keystrokes while a new user may want to use very explicit 
commands to accomplish the same function. This implies that 
a variety of commands, e.g., *1*, «LOADt, and "Control" X, 
may need to be converted to the same code for use within the 
system[22]. f represents the end of a message. 
To allow enough flexibility and still not cause 
unnecessary duplication of hardware, such a conversion nan be 
accomplished after the control command is placed in the c 
buffer. Thus, only a single processor, the Control 
Interpreter, is needed to handle all the terminals in the 
system. The only restriction is that the same sequence can 
not have different meanings for different terminals. This 
restriction applies only after the cods transformation is 
completed. 
The I/O supervisor is required to control the operations 
of the other processors in the system. Its tasks include: 
1. communicating with all the processors in the 
I/O subsystem to provide operating 
instructions. 
25 
2. Ascertaining when i processor in the I/O 
subsystem is done with its assigned task so 
that buffers and terminals may be reassigned 
to provide more work for that processor if any 
is available. 
3. Communicating with the rest of the system to 
see what I/O tasks are ready to be performed. 
U. Informing the rest of the system of system 
commands that have beai received and 
interpreted. 
The I/O supervisor also has a responsibility to see that 
no information is lost when a program is made inactive on a 
terminal so that a supervisory routine may be executed. It 
must transfer all pertinent information to a safe location in 
the main memory. Then, upon request of the supervisory 
routine, the I/o supervisor must restore the terminal to its 
original status by retrieving the data from the main memory 
and continuing the original operation. 
The code transformation problem can be handled by an 
array of read-only memories, each programmed for a specfic 
type of device. The memory will be time-shared.among the 
Terminal Controllers and thus will be able to scan 
Controllers at a rate equivalent to the cycle time of the 
memory array. 
26 
The input-output memory will be of the read/write 
variety and will contain the three buffers and a set of 
control words for each terminal. These control words will 
contain the information needed for the system to perform I/o 
tasks on the terminal. 
A read-only memory containing control sequences will be 
attached to each processor. Provision for new terminals as 
they are introduced will require expansion of the control 
memory to provide additional control sequencss. The 
Interface Processor and the Control Interpreter will require 
the most control memory modification if additional terminal 
types are supported. The Terminal Controller will require 
minor modifications and a new code transformation table will 
need to be added if the terminal's character set is 
different. 
The block diagram of the I/O subsystem is shown in 
figure 5. 
27 
Control 
Interpreter 
Memory 
—f 
I 
I/o 
Supervisor 
I 
I 
I 
Computer 
System 
r -
I 
Code 
Con ve rtar 
Channel 
Controller 
1 
Interface 
Processor 
I 
Main 
Memory 
I r 1 
I 1 I I 
p—— I TC 0 |—I Terminal 0| 
L J I I 
I 
— I TC 1 I 
I 
I I 
• jrerainal 1| 
I I 
I 
I —1 I I 
—I TC 2 (Terminal 2| 
I I 
I L J 
I 
I 
I 
I r 1 
r~  1 I I 
— I TC 3 I—(Terminal 3| 
I I 
I 
9 
I 
I I 
— I rc n I—irerninal n| 
Fig. 5. I/O Subsystem Block Diagram 
28 
I/O SOBSTSTEH COHHUMICATION REQOIREMENTS 
To provide a communication path between the various 
processors, a twenty-seven line control bus will be required. 
This bus is allocated as follows: 
1. Five lines for the terminal number. These 
will be used to specify a terminal number for 
the various start and stop signals transmitted 
by the I/O Supervisor. 
2. One line for the Terminal Controller start 
signal (TCSTBT) from tha I/O Supervisor. This 
line in combination with the terminal number 
lines will start the selected Terminal 
Controller. 
3. One line for the Terminal Controllar gait 
signal (TCQOIT) from the I/O Supervisor. This 
line in combination with the terminal number 
lines will stop the selected Terminal 
CoatïollsE. 
îi. One line for the Interface Processor start 
signal (IPSTRT) frca tha 1/3 Supervisor. This 
line in combination with the terminal number 
lines will start the Interface Processor on 
the selected terminal's task. 
5. One line for the Interface Processor quit 
29 
signal (IPQOIT) from the I/O Supervisor. This 
line will cause the Interface Processor to 
shut down, i.e., to suspend work on th@ 
current task. 
6. Three lines for the Interface Processor to 
transmit shutdown information to the I/O 
Supervisor. 
7. One line for the Channel Controller start 
signal (CCGO) from the I/O Supervisor. This 
line will cause the Channel Controller to 
begin scanning the Terminal Controllers. 
8. One line for the Channel Controller quit 
signal (CCQOIT) from the I/O Supervisor. This 
line will cause the Channel Controller to stop 
scanning the Terminal Controllers. 
9. Eight lines for tha Channel Controller to 
transmit shutdown information to the I/O 
Supervisor. Three lines will be used to 
define the type of shutdown and five lines 
will be used to transmit the terminal number. 
A CCGO signal will be required from the I/O 
Supervisor after a shutdown before the Channel 
Controller will resume scanning the Terminal 
Controllers. 
10. One line for the Control Interpreter start 
30 
signal (CISTBT) from the I/O Supervisor. This 
line in combination with the terminal number 
lines will start the control interpreter on 
the selected terminal's task. 
11. One line for the Control Interpreter quit 
signal (CIQOIT) from the I/o Supervisor. This 
line will cause the Control Interpreter to 
shut down. 
12. Three lines for the Control Interpreter to 
transmit shutdown information to the I/O 
Supervisor. 
Because all of these lines are driven by only one 
output, the bus will not require wired-OB connections. An 
advantage to this bus configuration is that most of the 
processors need to monitor only selected lines of the bus and 
need not be concerned with the other lines. The only 
decoding required sill be lone by the I/o Supervisor to 
process shutdown information. 
The shutdown information for the Channel Controller will 
be transmitted to the i/o Supervisor as one of tha fallowing 
codes. A terminal number, which is transmitted with the 
shutdown information, provides the terminal identification to 
the I/O Supervisor. 
CCBFE This shutdown signals the I/O Supervisor that 
31 
the Channel Controller has stopped scanning 
because it has completed the processing 
required on the specified terminal and is 
ready for more work on that terminal. This 
shutdown also signals the I/O Supervisor that 
a buffer is empty during an editing task. 
CCEOB This shutdown signals the I/O Supervisor that 
the Channel Controller has stopped scanning 
because it has completed the processing 
required on the specified terminal* Execution 
was stopped because an "end of record" 
character was encountered during processing. 
This shutdown also signals the I/O Supervisor 
that an editing task has been completed and 
the system is ready for more input from the 
specified terminal. 
CCCC This shutdown signals the I/O Supervisor that 
the Channel Controller has encountered the end 
of a control coaaand and has stored the 
coBsand in the C buffer of the specified 
terminal. 
CCSTAT This shutdown signals the I/O Supervisor that 
the Channel Controller has stopped scanning 
because it has completed a status update on 
the specified terminal. 
32 
CCEBR This shutdown signals the I/O Supervisor that 
the Channel Controller has stopped scanning 
because it has detected an error on the 
specified terminal. An error coda and the 
location of the error have been stored in the 
I/O Memory to facilitate diagnosis. 
CCTCQT This shutdown signals the I/O Supervisor that 
the channel Controller has stopped scanning 
because it has detected that the Terminal 
Controller on the specified terminal has shut 
down in response to a TCQUIT signal. 
CCQT This shutdown signals the I/O Supervisor that 
the Channel Controller has stopped scanning in 
response to a quit signal from the I /O  
Supervisor. The terminal number is ignored 
when this shutdswn is received by the I/o 
Supervisor. 
The shutdown information for the Interface Processor 
will be transmitted to the I/O Supervisor as one of the 
following codes: 
IPBFE This shutdown signals the I/O Supervisor that 
the Interface Processor has completed the 
processing required on its assigned job and is 
ready for more work. This shutdown also 
33 
signals the I/O Supervisor that a buffer is 
full during an editing task. 
IPEOR This shutdown signals the I/O Supervisor that 
the Interface Processor has completed the 
processing required on its assigned job and is 
ready for more work. Execution was stopped 
because an "end of record" character was 
encountered during processing. This shutdown 
also signals the I/O Supervisor that an 
editing task has been completed and the system 
is ready for more input from the terminal as 
. soon as a CCEOR shutdown is received from the 
Channel Controller for the terminal of 
interest. 
IPPO This shutdown signals the I/O Supervisor that 
the Interface Processor is shutting down 
because it has encountered a page fault in the 
main memory and may be reassigned until the 
needed page is available. 
IP2RR This shutdovû sigaals the I/O Supecvisoc that 
the Interface Processor is shutting down 
because it has detected an error condition. 
An error code and the location of the error 
have been stored in the I/O Memory to 
facilitate diagnosis. 
3U 
IPQT This shutdown signals the I/O Supervisor that 
the Interface Processor is shutting down in 
response to a quit signal from the I/O 
Supervisor. 
The shutdown information for the Control Interpreter 
will be transmitted to the I/O Supervisor as one of the 
following codes: 
CIED This shutdown signals the I/O Supervisor that 
the Control Interpreter has completed the 
processing required on its assigned job and 
has detected an editing command. 
CISC This shutdown signals the I/O Supervisor that 
the Control Interpreter has completed the 
processing required on its assigned job and 
has detected a system command. 
CIEBB This shutdown signals the I/O Supervisor that 
the Control Interpreter is shutting down 
because it has detected an error condition. 
Àû error code arid the location of the error 
have been stored in the I/O Memory to 
facilitate diagnosis. 
CIQT This shutdown signals the I/o Supervisor that 
the Control interpreter is shutting down in 
response to a quit signal from the 1/3 
Supervisor. 
35 
The communication path between the I/O Supervisor and 
the rest of the computer system requires eight lines for 
information and five lines fci the terminal number. The 
allocation is as follows: 
1. One line for the I/O subsystem start signal 
(lOSTBT) from the computer system. This line 
in combination with the terminal number lines 
will instruct the I/O Supervisor to initiate 
processing on the selected terminal's task. 
2. One line for the I/O subsystem quit signal 
(lOQOIT) from the computer system. This line 
in combination with the terminal number lines 
will instruct the I/O Supervisor to halt 
processing on the selected terminal's task. 
3. One line for the I/o subsystem save signal 
(lOSAVE) from the computer system. This line 
in coBbination with the terminal number lines 
will instruct the I/O Supervisor to halt 
processing on the selected terminal's task and 
store status information for the terminal in 
the main memory to allow restoration of the 
terminal's status at a later time. 
4. One line for the I/O subsystem restore signal 
(lOREST) from the computer system. This line 
in combination with the terminal number lines 
36 
will instruct I/O Supervisor to retrieve the 
status information for the selected terminal 
from the main memory and resume processing on 
the selected terminal's task, 
5. Four lines for the I/O Supervisor to transmit 
shutdown information to the computer system. 
These lines in combination with the terminal 
number lines will specify the type of shutdown 
generated for a particular terminal. 
6. Five lines for the terminal number. These 
lines will be used to specify a terminal 
number for the communication path. 
All of the above lines must be conditioned to meet the 
logic level requirements of the computer system. Provision 
must be made in the I/O Supervisor to generate any status 
signals that may be required by the computer system during 
these information eschanges. 
The shutdown information for the I/O subsystem will be 
transmitted to the computer system as one of the following 
codes. À terminal number is transmitted with the shutdown 
information to provide terminal identification to the 
computer system. 
lONOB The I/O task assigned by the computer system 
on the specified terminal has been completed 
satisfactorily. 
37 
lOEBB The I/O task assigned by the computer system 
on the specified terminal has been terminated 
because of an error. An error code and the 
location of the error have been stored in the 
main memory to facilitate diagnosis. 
lOPO The I/O task assigned by the computer system 
on the specified terminal has generated a page 
fault in the main memory. Processing will be 
suspended as soon as the buffer capacity is 
exceeded. 
lOQT The I/o task assigned by the computer system 
on the specified terminal has been terminated 
in response to a gait signal from the computer 
system. 
lose A system command has been detected by the I/O 
subsystem on the specified terminal and has 
been stored in the main memory pending further 
action by the computer system. 
38 
CLASSES OF TERMINAL TYPES SOPPOPTED 
The proposed I/o subsystem can support four broad 
classes of terminal types: 
Class_1 
Class 1 is composed of devices such as card readers and 
line printers. Although these types of devices do not land 
themselves to interactive operation, they are still important 
to the user who desires to manipulate large lata blocks on an 
interactive system without long I/O periods as would be 
required for keyboard entry or typewriter output. Status 
display is not provided for Class 1 terminals because there 
is no reasonable place for the presentation of such 
information. The system will support the use of simple 
editing and system commands. These will need to be provided 
as an input to the system where they will be interpreted as 
control commands and routed accordingly. The system commands 
which will be supported are: 
•INITf Initiate activity on the terminal. 
•CLEARt Clear the terminal's work area. 
"LOAD* Load a program into the terminal's work area. 
sRUN* Sun the program in the terminal's work area, 
mCANODTt Cancel the current output task on tha terminal. 
aPAOSEt Halt processing on the terminal's work. 
«CONTINS Continue processing on the terminal's work, 
"Fm? Initiate a special function call for terminal. 
•TERHt Terminate activity on the terminal. 
where 'm' represents any integer between 0 and 15. These 
commands are all expressed in the long form. A short form 
39 
consisting of a one or tiro letter sequence will alao be 
supported. The third form that will be supporke3 is a single 
character representation, e.g., a maltipunch will symbolize a 
LOAD command. 
The system will support editing for Class 1 terminals 
only on a line basis. Each line is considered an autonomous 
unite A line may be a fixed number of characters or may be 
delimited by a carriage return. This decision is a function 
of a flag set by two of the editing commands as defined 
below. The line editing commands which will be supported 
are: 
#CEf A line will be delimited by a carriage return, 
•L=n4 A line will be considered as *n* characters. 
"+nf Move the pointer forward «n* lines. 
#-nf Move the pointer backward *n* lines. 
•OLn^ Delete *n* lines following the pointer. 
#Dn4 Display *n' lines following the pointer. 
mSFxxxx* Search forward for *xxxx'. 
•SBxxxxt Search backward for *xxxx'. 
Enter overwrite aode. 
•In4 Enter insert mode. 
where «x« represents any character other than ««' or 't* and 
*n* represents any integer between 0 and 999. The 
alphanumeric field for search operations may ba up to eight 
characters in length. Tie alphanamaric field Eollowiag ,IN* 
will be padded with blanks on the right to correspond to a 
fixed line length if a line is defined as a fixed number of 
characters. If #IN* is not used, an overwrite will be 
performed. The 'insert* mode is exited whenever an editing 
command is encountered in the data stream from the terminal. 
40 
If *0* is 0 the system will interpret *n' as "to the 
beginning" or "to the end." If 'n* is omitted the system 
will assign «n» a value of 1. 
Glas§_2 
Class 2 is composed of devices such as typewriters and 
Teletypes. Although more convenient than a Class 1 device 
for interactive activity, the Class 2 device's slower 
operating speed is a hindrance to optimum interactive 
performance. 
In addition to the system commands for Class 1 devices. 
Class 2 terminals provide the user with the terminal's status 
upon request. Entering mSTAT* at the terminal will cause the 
system to respond with the terminal's current status in the 
system. An example of a single character representation for 
Class 2 devices is "Control" X for a LOAD command. 
The system will support editing commands for Class 2 
terminals on a line or character basis. A line will be 
defined as for Class 1 devices. The line editing commands 
will be identical to those for Class 1 terminals. To allow 
the use of character editing, the system will cesponi to any 
line editing request by displaying the lins selected by the 
current pointer position. The pointer will be positioned at 
the first character of the line. 
To initiate the charazter editing mode the user will 
enter mCH*. The character editing commands which will be 
41 
supported are: 
"+nf Move pointer forward 'n* characters, 
•-nt Move pointer backward 'n* characters. 
«DLnt Delete 'n* characters following the pointer. 
"Dnf Display «n* characters following the pointer. 
"SFxxxxf Search forward for "xxxx*. 
•SBxzxxf Search backward for *xxxx*. 
"OVf Enter overwrite mode, 
#INf Enter insert mode. 
where *x' represents any character other than or 'and 
•n* represents any integer between 0 and 999. The 
alphanumeric field for search operations may bs up to eight 
characters in length. If the alphanumeric field following 
"INf causes the line to exceed the maximum length allowable, 
the system will generate a new line and pad it with blanks as 
necessary. If #IN+ is not used, an overwrite will be 
performed. The 'insert* mode is exited wheaavsr an editing 
command is encountered in the data stream from the terminal. 
It 'n' is C the system will interpret 'n* as "to the 
beginning" or "to the end." If *n* is omitted the system 
will assign *n« a value of 1, 
To return to the line editing mode the user will eater 
#LNf. The system will respond by displaying the line 
selected bv the current oointer oosition. The oointer will 
# fc- & g* — - - — 
be positioned at the first character of the line. 
Gi&ss_3 
Class 3 is composed of devices with a video display. 
These devices comprise the most useful type for interactive 
42 
operation because of their high speads and convenient 
display. Most video terminals have some type of cursor to 
inform the user where the next character will appear on the 
screen. 
Class 3 terminals utilize the same system command set as 
Class 2 devices. However, the extra keys on many Class 3 
devices provide a concise method of generating system 
commands from one keystroke[ 23,24,25]. 
The system will support editing commands Cor class 3 
terminals in the same manner as utilized for Class 2 devices. 
The following single keystrokes will also be supported: 
Eove cursor left one character. 
Move cursor right one character. 
t Move cursor up one line. 
i Move cursor down one line. 
'HOME' Move cursor to upper left corner of iisplay. 
•DELLIME' Delete line selected by cursor. 
'DELCHAP.' Delete character selected by cursor. 
'INSLINE* Insert line at cursor location. 
'IBSCHAR' Insert character at cursor location. 
If the user moves the cursor to a location containing 
information and dees not select 'IWSCHAH' or 'INSLINE', an 
overwrite will be performed. 
Class 4 is composed of a terminal interface and a number 
of I/O devices. If the I/O request specifies that the 
default device be used, the terminal interface must provide a 
default device identification when requested by the Terminal 
Controller to permit proper handling of data by the I/O 
*3 
subsystem. If the I/O request contains a specific device 
number, the I/o subsystem can be configured without 
interrogation of the terminal interface, in this way aay of 
the preceding terminal classes can be used in combination 
with a terminal interface to construct a more complex 
terminal. 
au 
DETAILED PROCESSOR DESCRIPTIONS 
isiaiaaL-Sostrsiist 
Each Terminal Controller will consist, in part, of a 
microprocessor driven by a read-only control memory. To  
supplement the microprocessor, five high speed registers will 
be required with the following characteristics: 
IIBEG A twelve bit register to store data produced 
by the code conversion during IBPOT. 
lOBEG A twelve bit register to store data ready for 
the Channel Controller during INPOT. 
OIREG An eight bit register to store data 
transmitted from the Channel Controller during 
OUTPUT. 
OOREG A twelve bit register to store data produced 
by the code conversion during OUTPOr. 
TMNID An eight bit register containing the terminal 
type identification. 
The microprocessor utilized in the Terminal Controller 
is required to process one character every millisecond if the 
terminal is operating at 9600 baud. A four bit 
microprocessor with a 2 microsecond instruction cycle time is 
adequate for this mode of operation. Available 
microprocessors having this type of specification include the 
Intel UOUO. Because the data registers are twelve bits in 
45 
many cases, the width of the data path through the 
microprocessor is not critical. 
The data registers are necessary to buffer data since 
different portions of the subsystem operate at different 
rates. The low order eight bits in the data registers will 
be used to represent the data with the remainder reserved as 
indicators for escape symbols, carriage returns, and control 
commands. 
A counter will be maintained in the Terminal Controller 
to determine if a carriage return should be inserted since 
the end of the line has been reached at the terminal. Since 
speed is not essential for this operation, the counter can ba 
kept in one of the microprocessor's registers. If the 
counter is equal to zero, the Terminal controller will 
generate a carriage return for the subsystem and for the 
terminal in addition to its normal work. 
k number of flags will be required to indicate that the 
registers are valid, that characters should be echoed, that a 
: has been received from the terminal, that the terminal is 
in an I/O mode, that control commands can be accepted, and 
that the terminal is active. These may be either within the 
microprocessor or external depending on the capabilities of 
the microprocessor utilized. 
Another element in the Terminal Controller is a buffer 
register for storing data as it is generate! by the terminal. 
46 
This is necessary because under certain conditions some 
terminals continue to produce data after they have been 
instructed to stop sending information. This data would be 
lost if buffering was not provided. Each Terminal Controller 
will also contain the hardware necessary for asynchronous 
serial I/o, i.e., a Universal Asynchronous Receiver 
Transmitter or DART. A frequency divider will be required to 
generate a variety of baud rates. The proper baud rate will 
be determined by the contents of the THHID register. 
The Terminal Controller will be connected to the control 
bus to monitor the TCSTBT, TCQQIT, and terminal number lines. 
In the event that a TCQDIT is received from the I/O 
Supervisor, the Terminal Controller will instruct the 
terminal to stop sending information. After waiting 
sufficient time to insure that the terminal has stopped 
transmitting data, the Terminal Controller will transmit the 
information needed to restart itself to the Channel 
Controller with instructions to store the information in the 
Terminal Controller's control word. When this task is 
completed, a CCTCQ7 will be seat to the I/o Supervissc by the 
Channel Controller. When a TCSTRT signal is received by the 
Terminal Controller, the Channel Controller will retrieve the 
information stored in the Terminal Controller's control word 
and transmit it to the Terminal Controller so that the job 
may be started or resumed as the case may be. 
47 
The organization of the Terminal Controller is shown in 
figure 9. 
The Channel Controller will consist, in part, of a 
microprocessor driven by a read-only control memory. To 
supplement the microprocessor, two high speed registers will 
be required with the following characteristics: 
CCHHD k sisty-four bit register to store the 
Channel Controller's control word for the 
selected terminal. 
CCDATA &n eight bit register to hold the data being 
transferred between the Channel Controller and 
the I/O memory. 
The microprocessor utilized in the Channel Controller 
will have a minimum of 35 microseconds to process each 
character. An eight bit microprocessor with a 1 microsecond 
instruction cycle time ca» provide this data rate if care is 
exercised in the control program. Since it is very unlikely 
that all 32 terminals will be operating at 9600 baud 
simultaneously for extended periods of time, a microprocessor 
with a 2 microsecond instruction cycle time is adequate for 
this application most of the time. Available microprocessors 
having this type of specification include the Intel 8080. A 
faster microprocessor would allow more latitude in control 
48 
program construction and permit the Channel Controller to 
handle the worst case data rate without slowing the I/O 
subsystem. 
The control word for the Channel Controller will contain 
the location of the next character position in the I/O memory 
and information describing the selected terminal's task. 
After each data transfer the control word is updated and 
written back into the I/O memory. 
The Channel Controller will communicate with the 
Terminal Controllers over the channel control bus. This bus 
will consist of twelve bidirectional data lines, five address 
lines for selecting the appropriate Terminal Controller, a 
line activated by the selected Terminal controller to 
indicate that a transfer c&n be accomplished, and a control 
line from the Channel Controller to enable the selected 
Terminal Controller's registers. 
The selection of the Terminal Controller will be handled 
by a scanner implemented in hardware. Each Terminal 
Controller will be interrogated twice during each scan cycle, 
once for the XnPuT mode and once for the GUTPuT mode. 
Whenever the Channel Controller transmits a shutdown 
code to the I/O Supervisor, the I/O Supervisor must respond 
with a CCGG signal before the Channel Controller will resume 
scanning the Terminal Controllers. This method is needed to 
prevent a second Channel Controller shutdown while the first 
49 
is being processed by the I/o Supervisor. 
The organization o f  the Channel controller is shown in 
figure 10. 
COB&coi_I&te&Ereter 
The Control Interpreter will consist, in part, of a 
microprocessor driven by a read-only control memory. To 
supplement the microprocessor, two high speed registers will 
be required with the following characteristics: 
CIHBD A sixty-four bit register to store the 
Control Interpreter's control word for the 
selected terminal. The terminal type 
identification will be stored in this control 
word. 
CIDATA A sixty-four bit register to store the 
portion of the C buffer being processed. 
The microprocessor utilized in the Control Interpreter 
has no data rate problems. However, since the subsystem 
should respond to a control request rapidly, an eight bit 
unit with a 2 microsecond instruction cycle time is required. 
Available microprocessors having this type of specification 
include the Intel 8080. A four bit microprocessor is an 
alternative, but the search time for a table entry would 
increase. 
50 
The Control Interpreter will also require a read-only 
memory containing a table of the supported control commands 
for each type of terminal. There will be sufficient space in 
the Control Interpreter control word to store the interpreted 
version of the control commands for use by the I/O 
Supervisor. 
The organization of the Control Interpreter is shown in 
figure 11. 
Interface processor 
The Interface Processor will consist, in part, of a 
microprocessor driven by a read-only control memory. To 
supplement the microprocessor, nine high speed registers will 
be required with the following characteristics: 
IPDAT& A sixty-four bit register for temporary 
storage of data being transferred to or from 
the buffers in the I/o memory. 
IPDATB A sixty-four bit register for temporary 
storage of data being transferred to ac from 
the main memory. 
BOFADO A sixteen bit register containing the current 
buffer location in the I/o memory. 
TnHID An eight bit register containing the terminal 
type identification. 
DPSTRT A thirty-two bit register containing the 
51 
start location for the terminal display. 
OPEND A thirty-two bit register containing the end 
location for the terminal display. 
LHSTRT A thirty-two bit register containing the 
start location for the current line within the 
display. 
LMEHC A thirty-two bit register containing the end 
location for the current line within the 
display» 
PNTADD A thirty-two bit register containing the 
current pointer location. 
The microprocessor utilized in the Interface Processor 
will have a minimum of 2 milliseconds to handle a 64 
character buffer. Providing this data rate while performing 
the necessary processing requires an instruction cycle time 
of 100 nanoseconds or less since a significant portion of the 
2 milliseconds may be consumed by a page fault in th@ main 
memory. Available microprocessors having this type of 
specification include the Intel 3000 series. 
The standard I/O functions involve transfarring data 
between IPDAT& and IPOATB while updating the address 
registers as required. The editing functions require more 
complex processing. In an effort to standardize this 
processing, a set of editing functions has been defined for 
the Interface processor: 
52 
1. Move the pointer forward *n* characters or to 
the end of the current line if fewer than *n* 
characters follow the current pointer position 
in the line. 
2. Move the pointer forward to the beginning of 
the following line and then forward foe 'n* 
lines or tp the end of the string if fewer 
than *n* lines follow the current line. 
3. Move the pointer forward to the beginning of 
the following line and then forward for « n* 
characters or to the end of the line if there 
are fewer than *n* characters in the line. 
n. Search forward for a specified pattern or to 
the end of the current line if the pattern 
does not occur following the current pointer 
position in the line. 
5. Search forward for a specified pattern or to 
the end of the string if the pattern does not 
occur following the current pointer position 
in the string. 
6. Move the pointer backward *n* characters or 
to the beginning of the current line if fewer 
than 'n« characters precede the current 
pointer position in the line. 
7. Move the pointer backward to the beginning of 
53 
the carrent line and then backward for *n* 
lines or to the beginning of the string if 
fewer than *n* lines precede the current line. 
8. Hove the pointer backward to the beginning of 
the preceding line and then forward for *n* 
characters or to the end of the line if there 
are fewer than 'n* characters in the line. 
9. Search backward for a specified pattern or to 
the beginning of the current line if the 
pattern does not occur preceding the current 
pointer position in the line. 
10. Search backward for a specified pattern or to 
the beginning of the string if the pattern 
does not occur preceding the current pointer 
position in the string. 
11. Insert the incoming data into the existing 
string at the current pointer position. 
12. Overwrite the existing string with the 
incGsing data beginning at the current pointer 
position. 
13. Delete *n* characters following the current 
pointer position or to the end of the line if 
fewer than 'n® characters follow the current 
pointer position in the line. 
14. Delete the current line and *n* following 
5U 
lines or the reminder of the string if fever 
than »n* lines fallow the current line. 
15. Display *n* characters following the current 
pointer position or to the end of the line if 
fewer than *n* characters follow the current 
pointer position. 
16. Display the current line and *n' following 
lines or the remainder of the string if fewer 
than 'n* lines follow the current line. 
Utilization of these standard functions decreases the size 
of the control memory because each terminal type's control 
program can now be written as a series of linkages to these 
standard functions. 
The organization of the Interface Processor is shown in 
figure 12. 
l/£L5ll£misor 
The I/O Supervisor will consist, in part, of a 
microprocessor driven by a read-only control memory. To 
supplement the microprocessor, five high speed registers will 
be required with the following characteristics: 
lODATA A sixty-four bit register for temporary 
storage of control words as they are being 
updated and for data transfers during 'save* 
and 'restore* operations. 
55 
lOAOD A sixteen bit register containing the 
location being processed in the 1/3 Memory 
during 'save' and 'restore* operations. 
SAVADD A thirty-two bit register containing the 
location in the main memory for 'save* and 
'restore' operations. 
CNBBEG A fourteen bit register for temporary storage 
of shutdown information from the other 
processors in the I/O subsystem. 
COHBEG A thirteen bit register for use in 
communicating with the main computer system. 
The microprocessor utilized in the I/O Supervisor must 
respond to processor shutdowns with significant processing 
tasks of its own. An instruction cycle time of 2 
microseconds is required to perform the work in a reasonable 
length of time. Long delays in the I/O Supervisor decrease 
the time available to the Channel controller and the 
Interface Processor for the performance of their tasks. 
Available microprocessors having this type of specification 
include the Intel 8080. 
The control sequence required for the I/O Supervisor can 
best be expressed by a flow table for each of the general I/O 
processes. When the I/O Supervisor receives an I/O request, 
the I/O state for the specified terminal is set to 0 and 
processing is begun. 
56 
If the I/O request is for INPOT, the flow table in 
figure 6 is utilized. The specified Terminal Controller is 
started and the Channel Controller begins to fill the A 
buffer. CCF is used in the flow table to indicate that the 
Channel Controller is filling the buffer. Because the B 
buffer is empty, E is entered in the flow table. When the k 
buffer is full, the Channel controller stops scanning and 
transmits a CCBFE shutdown to the I/O Superviser. The I/O 
Supervisor sets the I/O state to 1, adds the tsrai&al t3 the 
Interface Processor queue to transfer the A buffer to the 
main memory, assigns the B buffer to the Channel Controller 
for the specified terminal. and transmits a CCSO to the 
I/o BUFFER BOFFES SH0TD09NS 
STATE A B CCBFE CCE09 IPBFE IPEOR 
0 CCF E 1 6 X X 
1 IPO CCF 2 7 3 X 
2 IPU P A X ti X 
3 E CCF 4 8 X X 
4 CCF IPO 5 9 0 X 
5 P IPU X X 6 X 
6 IPO E X X X QOIT 
7 IPO F X X 6 X 
8 E IPO X X X aoiT 
9 F IPO X X 6 X 
Fig. 6. INPOT Flow Table 
57 
Channel Controller, This is denoted in the fl3w table by 
IPO for the A buffer and CCF for the B buffer. F in a buffer 
column indicates that the specified buffer is full. Kn *x* 
in the shutdown portion of the table indicates that the 
specfied shutdown can not occur. 
If the I/O request is for OOTPDT, the flow table in 
figure 7 is utilized. Two new symbols appear in this flow 
table: IPP meaning the Interface Processor is filling the 
buffer; and CCU meaning the Channel Controller is 
transferring data out of the buffer. 
I/o BUFFER BUFFER SHUTDOWNS 
STATE A B IPBFE IPEOR CCBFE C:EOR 
0 IPF E 1 7 X X 
1 CCU IPF 3 8 2 X 
2 E IPF H 6 X X 
3 CCU F X X U X 
U IP? CCU 5 9 0 X 
5 F CCU X X 1 X 
6 E CCU X X X QUIT 
7 ecu E X X X QUIT 
8 CCU F X X 6 X 
9 F CCU X X 7 X 
Fig. 7. OUTPUT or EDITING Flow Table 
58 
The third type of I/O processing involves control 
command interpretation and editing command execution. 
Control command interpretation is handled using the flow 
table in figure 8. A new symbol appears in this flow table; 
CIU meaning the control Interpreter is operating on the C 
buffer. When the C buffer is filled for a terminal, the 
Channel Controller's control word is modified to prevent the 
A and B buffers from being filled again since the buffers may 
be required for editing command execution. Bhen the Control 
Interpreter shutdown is CISC the Channel Controller is again 
allowed to fill the A and B buffers. When the Control 
Interpreter shutdown is CIED a check is performed to verify 
that the terminal mode is INPUT and that the I/O state is 
less than 6. If these conditions are met, the A and B 
buffers are emptied and the editing command is executed using 
the flow table in figure 7. 
COSTSOL BOFPES SHUTDOWNS 
STATE C CCCC CIED CISC IPEOR 
A CCP B X X X 
B CIO X C A * 
C CCP D X X A 
D P X X X B 
Fig. 8. CONTBOL Flow Table 
59 
TO maintain information on what types of work are ready 
to be performed three queues will be used in the I/o 
SaperTlsor[26]. The I/O queue will contain all terminals in 
I/o modes. The IP queue will contain all terminals needing 
service by the Interface Processor. The CI queue will 
contain all terminals needing service by the Control 
Interpreter. Whenever the Interface Processor or the Control 
Interpreter completes a task, the I/o Supervisor looks in the 
appropriate queue to find a different task. 
Another responsibility of the I/O Supervisor is analysis 
of available information to determine the terminal type 
identification and updating of the subsystem control words to 
reflect that in£oroation[ 27]. 
The organization of the I/O Supervisor is shown in 
figure 13. 
Code Converter 
The Code Converter consists of an array of read-only 
memory programmed to provide the necessary code conversion. 
Each terminal type will require 512 words of twelve bits. 
The code conversion will be controlled by a scanner which 
will look at the code converter registers in each Terminal 
controller and see if a transformation can be executed. If 
possible, the array will be accessed by the scanner using the 
data in the Terminal controller's OIBEG or buffer register as 
an address and the returned data stored in the Terminal 
60 
Controller's OOREG or IIREG. In this manner the code 
conversion can be performed very rapidly because the 
microprocessor in the Terminal Controller is not involved. 
The organization of the Code Converter is shown in 
figure 14. 
1/9. 
The I/O Memory will be organized in words of 8 
characters or 6U bits. If the three low order bits o£ an 
address are all zeroes, the memory will consider the address 
to refer to a word and read or write 64 bits of information. 
If the three low order bits of an address are not all zeroes, 
the memory will consider the address to refer„to a character 
and read or write only 8 bits of information. The memory 
will consider only the eight low order lines of the data path 
to be significant in this case. 
The organization of the I/O Memory is shown in figure 
15. 
61 
Control Bus 
c 
o 
n 
t 
r 
0 
1 
R 
0 
H 
Channel 
Controller 
I 
I 1 
I lOREG I 
1^ j 
I 
I I 
-——I OIREG I 
I I 
I 
Microprocessor 
Coîe 
-Converter 
Address 
Code 
-Converter 
Data 
I IIBEG I 
Code 
—Converter 
Data 
I I 
! OOBEG ! 
I I 
jFrequency| 
I Divider { 
I I 
I THNID I 
Code 
-converter 
Address 
< ! 
( I 
I Buffer I 
! Pegister î 
I I 
I I 
I 
Code 
—-Convert s J 
Address 
\ I 
I 0 I 
A 
n 
r 1 
i I 
!—TsralBîl 
i 
I 
Fig. 9. Terminal Controller Block Diagram 
62 
I/O 
MEM 
C 
C 
D 
A 
T 
A 
Control ROM 
J 
Terminal 
Controller 
Scanner 
—rco 
—TCI 
—rc2 
—TC3 
—TC4 
—rc5 
—TC6 
• rc3i  
I 
Conrrox bus 
Fig. 10. Channel controller Block Diagram 
63 
I / O  
HER 
C 
I 
* 
B 
D 
Control BOM 
Microprocessor 
T 
a 
b 
1 
e 
R 
0 
M 
Control Bus 
Fig. 11. Control Interpreter Block Diagram 
64 
MEM 
I 
P 
D 
A 
T 
A 
Main 
I 
P 
D 
A 
T 
B 
Main 
T 
M 
N 
I 
D 
I BOPADD I 
r 
I 
Control ROM 
r 
I 
MicroprocessDr 
-f-
I I I I 
I  I I  I I  I I  I I I  
i 0 | | 0 | | L | | L | | P |  
I P î l P I J H l î H î j H î  
| S | | E | | S | | E | | T |  
| T i i N | | T | | N | | A |  
2 ; I I ; R 1 ; B I ; D i 
I  ? I  I  I  I  T  I  I  I  I  D  I  
I 
L. 
I I 
J L. 
i  i  I I I  
MEM 
Control Bus 
Fig. 12. Interface Processor Block Diagram 
65 
I 
0 
A 
D 
D 
5 
6 
V 
A 
0 
D 
Control ROM 
Microprocessor 
— 1  
c 
0 
H 
B 
E 
G 
J 
CNBREG 
I 
Control Bus Computer 
System 
Fig. 13. I/O Supervisor Block Diagram 
66 
Code 
Converter-
Address 
Code 
Converter-
Data 
Terminal 
Controller 
Scanner 
Code 
Conversion 
Table 
Fig. 1U. Code Converter Block Diagram 
I/O 
Memory-
Access 
Memory 
Control 
Hardware 
I  
I  
Re ad/• rite |
Beaory { 
Array j 
I  
Fig. 15. I/O Memory Block Diagram 
67 
CONCLUSIONS 
The proposed I/O subsystem satisfies nearly all of the 
criteria set forth in an early chapter of this paper. 
Thirty-two terminals operating at 9600 baud produce a 
maximum of 28,000 characters per second. This rate forces 
the Channel Controller to perform a character transfer every 
35 microseconds and the Interface Processor to handle a 64 
character buffer every 2 Billiseconds. Although both of 
these speeds are within the range of current technology, 
extra consideration needs to be devoted to the microprocessor 
in the Channel Controller. Further information on this 
problem appears in the Appendix. The 35 microsecond minimum 
is not typical since it is unlikely that all 32 terminals 
will be operating at 9600 baud for extended periods of time. 
If àû âVêïâyê Of 70 aicroseconds Càn bè dllôttsà for each 
character transfer, a slower but more easily implemented 
Channel Controller results through the use of a slower but 
simpler microprocessor. 
On-line editing facilities are provided with acceptable 
response speeds. The above character rates ars aasisaas and 
editing operations typically do not require high speed 
exchanges between the system and the terminal. Thus, the 
response times should not be degraded because of long editing 
execution times. 
68 
By placirojig tbha terminal control functions in the 
Terminal Contr»-oLleec, the rest of the I/O subsystem is not 
involved with * terminal operation and thus can be utilized for 
other purposes 3, itie detection and decoding facilities for 
system comnanclrjs aHlov the user to control the system with 
commands that i ace easily understood. The code conversion 
problem is con'iVer^ed to an addressing operation on a 
read-only me«o:«ty. 
The capak:oiLi*ty to interrupt an I/O operation, run a 
supervisory px«rogirM« on the terminal, and then complete the 
I/O operation i pconfides a convenient means of communication 
between the and the terminal even during I/O tasks, 
programs may 2)^ slacked more than one deep on a terminal 
simply by h&vi\ing ;a second supervisory routine push down the 
first one, etcc, 
Simplicitzy l:s another feature of the subsystem. With 
only registers^ ex ternal to the microprocessors, the operation 
of each processsoc is straightforward. The flexibility is 
also enhanced tbis type of design- Since the control 
sequences are provided by read-only control memories, 
initializatlonm âs only a matter of setting up the standard 
control words acid starting the I/o subsystem. 
This projtjict. is completed to the estent that the 
subsystem is fSiirnic^tlonally specified. Detailed design was not 
included in thite e ffort because the microprocessor field is a 
69 
rapidly evolving tecbnslagy and the newest products offer 
magnitudes of improvement in performance over the 
capabilities of the earlier types. Only recently have 
devices become available that possess the performance 
characteristics required for this I/O subsystem. 
This I/o subsystem as specified can operate with any 
main computer system capable of supplying control information 
and data to the subsystem and accepting data from the 
subsystem. The code conversion tables and the control 
memories for the I/O Supervisor and the Interface Processor 
will need to be modified to meet the specifications of the 
main computer system, but the general subsystem will remain 
unchanged. 
Further work in this area should include consideration 
of the scheduling algorithms needed for optimum performance, 
particularly with regard to editing commands and the 
Interface Processor. Another important consideration is the 
serviceability aspect. With many dedicated processors in the 
subsystem, complex diagnostic programs must be used to verify 
correct performance. Sines tiaing plays an important cole, 
this testing must be done dynamically. As an exhaustive test 
would be impossible, a compromise procedure must be developed 
that will run in a reasonable length of time and still verify 
that the subsystem operates as intended. 
70 
ACKNOWLEDGEMENTS 
The author wishes to thank Professor T. A. Smay anl 
Professor B. J. Zingg foe their suggestions, encouragement, 
and patience throughout this project. 
71 
LTTERATCRE CITED 
1. Bell, c. Gordon and Gold, Michael M. "An Introduction 
to the Structure of Time-shared Computers." In &dv&ases 
in_In£QrmatlQn_§ïstêms Science, pp. 161-272. Edited by 
Julius T. Tou. New York: Plenum Press, 1972. 
2. Bull, G. M. and PacJchao, S. F. G. Time-sharing 
Systems. London: McGrav Hill Book Company Limited, 
Ï971. 
3. Martin, James. 
Englevood Cliffs, N.J.: Prentice-Hall, Inc., 1973. 
4. Miller, Robert B. "Response Time in Man-computer 
Conversational Transactions»" f^çceedincfs of the 1968 
Fall Joint computer Conference. Washington, D.:.: 
Thompson Book Company, 1968. 
5. Mills, David L. "Preprocessors in a Data communication 
Computer Environment." Proceedings of the ACM Symposiu» 
Systems. Hew York: Association for computing 
Machinery, 1969. 
6. Smith, W. P.; Bice, Bex; Chesley, Gilman D.; et al. 
"SYMBOL: A Large Experimental system Exploring Major 
Hardware Replacement of Software." £E2£Sââilia§-2f-iàâ 
222 J-5Ema-a2iai-£2aEat S£-C21£SEea$6S- nont va la , n. J. : 
APIPS Press, 1971. 
7. Saltzer, J. H. and Ossanna, J. F. "Remote Terminal 
Character stream Processing in HOLTICS," EE2£,SaâiQ2S_2£ 
Montvale, 
N.J.: APIPS Press, 1970. 
8. Saltzer, J. H. and Ossanna, J. P. "Technical and Human 
Engineering Problêss in Connecting Terminais to a 
Time-sharing System.% 
Joint Computer Conference. Montvale, N.J.: APIPS 
Press, 1970. 
9. McCarthy, John; Brian, Dow; Feldman, Gary; and Alien, 
John. "THOS--A Display»*based Tiae=sharing System." 
çonf^yence. Washington, D.C.: Thompson Book Company, 
1967. 
72 
10. Kingslake, R. "TALK-An Interactive System for a Small 
computer." Software--Practice and Experience 1 (October 
1971); 391-401. 
11. Borman, P. R. and Grimm, E. H. III. "An Analysis of 
Selected Interactive Systems." Interactive Computing. 
Berkshire, England: I8F0TECH Information Limited, 1972. 
12. Deutsch, L. Peter and Lampson, Butler w, "An Online 
Editor." CommuQicattpnf of th^.ACH 10 (December 1967); 
793-9, 803. 
13. Benjamin, Arthur J. "An Extensible Editor for a Small 
Machine with Disk storage." Communications of the,ACM 
15 (August 1972); 742-7. 
14. Bourne, S. R. "A Design for a Text Editor." 
52£ti[a£S^LàÇU£ê.àall£XELÊ£isacê 1 (January 1971); 
73-81. 
15. Fajman, Roger and Borgolt, John. "HTLBUR: An 
Interactive Text Editing and Remote Job Entry System." 
£fiJiaimi£aii2ûS-2£-ihs-A£H 16 («ay 1973); 314-22. 
16. Jônês, Wayne E. -The Role of the Interface Processor 
in the SYMBOL IIR Computer System." Special Report 
NSF-OCA-GJ33097-CL7304, Cyclone Computer Laboratory. 
Iowa State University. Ames, Iowa, 1973. 
17. "SInBCL 25 Chââûêl Côùtcôllêr Floe Charts." 
Unpublished document. Fairchild semiconductor Research 
and Development Laboratory. Palo Alto, Calif., 1970. 
18. "SYMBOL 2R Interface Processor Flow charts." 
onpublished document. Fairchild Semiconductor Research 
and Development Laboratory. Palo Alto, Calif., 1970. 
19. "SYMBOL 2R Job Control Flow Charts." Onpublished 
document: Fairchild Semiconductor Research and 
Development Laboratory. Palo Alto, calif., 1970. 
20. "SYMBOL 2R Job Controller Specification." Unpublished 
document. Fairchild Semiconductor Research and 
Development Laboratory. Palo Alto, calif., 1969. 
21. "SYMBOL 2R Memory Specifications—SP028E." Unpublished 
document. Fairchild Semiconductor Research and 
Development Laboratory. Palo Alto, Calif., 1970. 
73 
22. Wasserman, Anthony I. "The Design of * Idiot Proof 
Interactive Programs." £lossââiû3§-fi£-tàS-1221-llati2flU 
£oa£iilâ£.ÇsaÉSISn2S.âIlâ-EXB2SlU2B* Montvala, N.J.: 
AflPS Press, 1973. 
23. Hayman, E. "Design Criteria for CRT Alphanumeric 
Displays." 1969_I&te&&atio&al_5imE2Si!im_2n_aa|i:Qacki!ie 
Systems. New York: Institute of Electrical and 
Electronics Engineers, 1969. 
24. McLaughlin, Richard A. "Alphanumeric Display Terminal 
Survey." Datamation 19 (November 1973); 71-92. 
25. Mclaughlin, Richard A. "Fast Interactive Hardcopy 
Terminals." Datamation 19 (October 1973): 77-80. 
26. Gotterer, Malcolm H. "On the Development of a 
Supervisory Seguencing Routine." On Line D%t% 
Processing. New York: Institute of Electrical anJ 
Electronics Engineers, 1963. 
27. Ossanna, Joseph F. "Identifying Terminals in 
Terminal-oriented Systems." Second Symposium oq 
Systems, me* York: Association for Computing 
Machinery, 1971. 
7U 
RELATED LITERATUBE 
Barrett, E. E. "Memory Considerations for an on-lina 
Processor." Oa_Liae_Data_Er2cessiag. New York: 
Institute of Electrical and Electronics Engineers, 1963. 
Black, V. Wayne. &DL_I&t[2aysti2&_&2_0n%ilae_&omEat2[s. 
London; Gordon and Breach, Science Publishers, Ltd., 
1971. 
Boies, S. J. "User Behavior on an Interactive Computer 
System." IBM gystgms Journal 13 (January 1974): 2-18. 
Bratman, Harvey; Martin, Hiram S.; and Perstaia, Ellen 
Clark. "Program Composition and Editing with an On-line 
D is play. " ÊE2SiiâiBâ§»2£.t he^ 1968^Fa,l 1. Jo 
Conference. Washington, B.C.: Thompson Book company, 
1968. 
Chu, B. i. "A Study of Asynchronous Time Division 
Multiplexing for Time-sharing Computer Systems." 
ftaS22ailia&_2C_&hâ_12&9_Eàii_Joiat_C2mBUtër_C2aE2E2BSe. 
Montvale, N.J.: APIPS Press, 1969. 
Fein, Louis. "Assessing Computing Systems." On_Lia8_Data 
Processing. New York; Institute of Electrical and 
Electronics Engineers, 1963. 
Fitzsissons, Thcsas ?« -aSCII Extension ani Expansion and 
Their Impact on Data." SSS2al-SïIfi2siajS-Oii.£robigms.in 
1 às-ûBÈ iaiiiti2a-2L.aâÈa-£2aasiai£all2ns_âï§£ sag. Ne* 
York: Association for Computing Machinery, 1971. 
Fraser, A* G. "On the Interface Between Computers and Data 
Communication systems." Communications.of the.&çp 15 
• (July 1972): 566-73, 
Groner, Gabriel F, "Display Terminals Can Help People to 
ase Computers." £ï2Stiâiïia2^t-ltts-I223.aàt 
«^2!!l£ÛS£.£2&£â£SfiSâ.ft&â.£l£SSl£i2&* Montvale, H.J.: 
AFIPS Press, 1973. 
Hansen, Wilfred J. "Oser Engineering Principles for 
Interactive Systems," ProceediRgs_Qf the 1971 Fall 
Joint computer Conference. Montvale, N.J.: AFIPS 
Press, 1971. 
Meadow, Charles T. g&azB&Ebi« New York: 
John Wiley and Sons, Inc., 1970. 
75 
Parnas, David L. "On the Ose of Transition Diagrams in the 
Design of a User Interface for an Interactive Computer 
System. «• £iLagêââiaa3-2f oafâssBSê » 
New York, N.Y.: Association for Computing Machinery, 
1969. 
Bice, David E. and van Dam, Andries. "An Introduction to 
Information Structures and Paging Considerations for 
On-line Text Editing Systems." In àiïàSSâS-ifi 
In£flriatioa_Sy.stems,Science, pp. 93-158. Edited by 
Julius T. Tou. Mev York: Plenum Press, 1972. 
Bosenbium, Stanley R. "Progress in Control Procedure 
Standardization. « Ssg2ââ.S£l£2§ilà£.S&.££2bJLâJ!§.lB.£&S 
GEllmizatio&_o^6al&_S2mm&lS&ki2am_âlStsms. Mev York: 
Association for Computing Machinery, 1971. 
Ross, H. McGregor. "The British Standard Data Code and How 
to Exploit It." Computer Journal 13 (August 1970); 
223-9. 
Teperman, A. and Katzenelson, J. "A format Editor." 
52£tiat£2Z££â2yiSâ-ânâ-£xBSEj5û£S 2 (July 1972): 
219-30. 
Van Dam, Andries and Rice, David E. "On-line Text Editing: 
A Survey." Surveys 3 (September 1971): 
93-11*. 
eilkes, nary Allen. "Scroll Editing: An on-line Algorithm 
for Manipulating Long Character Strings." IEEE 
Transactions on ComDut^^s 19 (November 1970)7 "1009-15. 
Williams, Robin, "A Survey of Data Structures for Computer 
Graphics Systems." Computing pqpyevs 3 (March 1971): 
1 - 2 1 .  
76 
APPENDIX 
The performance characteristics of the 1/0 subsystem are 
affected by the response speed of all of the processors 
within the subsystem. However, the most critical performancs 
specifications are in the Channel Controller. More than 100 
instructions can be executed for each character in the 
Terminal Controllers and the interface Processor without 
degrading the response time of the system. In the Channel 
Controller only about 10 instructions can be executed for 
each character if all 32 terminals are operating at their 
maximum rates. Maximum rates can occur only during standard 
I/o operations, i.e., without control commands. Vhen control 
commands appear in the data stream from a terminal, that 
terminal's average data rate decreases since the user is 
utilizing much of the time deciding which operation to 
perform. The worst case for the Channel Controller is during 
the INPUT mode because checks must be performed on the high 
order bits from the Terminal Controller to determine the 
proper routing of characters. During the ODTPUT mode these 
checks are unnecessary because all chacacters are transferrei 
to the Terminal Controller. 
To justify the feasibility of a microprocessor-based 
Channel Controller, a control seguence for an Intel 8060 
microprocessor was constructed to perform the worst case 
operation described above. The control seguence is shown in 
77 
figure 16* The execution time for the sequence shown is 73 
microseconds with a 2 microsecond instruction cycle time. 
Execution 
Time (us) Label Mnemonic Operand Description 
5 TOP; OQT HOLD Wait for scanner to 
release HOLD line. 
5 IN GETCH Fetch control word from 
I/O Memory and load 
selected byte of CCWRD 
into accumulator. 
3.  5  CPI COH Check INPOT flag (bit 8) 
and CONTROL flag 
(bit 7 ) .  
5  JNC CONCN Branch to control routine 
if bit 7 and bit 8 are 
not both 1 * .  
5  IN CINFO Fetch t high orler bits 
from rc  lOREG. 
3.  5  CPI 00 H Check that the bits are 
all ' 0 ' =  
5  JNZ BE6CN Branch to control routine 
if any bits are not '0*. 
5 IN FCHAR Fetch character from 
from TC lOREG. 
3.  5  CPI OEM Check if end of records 
5 JZ EOR Branch to shutdown 
routine if end of 
record. 
5 OOT SCHAB Load CCDATA with 
character and transfer 
to I/O Memory. 
5 IN BOFAO Fetch buffer address 
from CCWRD. 
2.  ,5  INB k  Increment buffer address. 
5 OOT STCRW Store buffer address in 
CCWRD and return control 
word to I/O Memory. 
5 JC BFE Branch to shutdown 
routine if buffer full. 
5 JHP TOP Return to top of program. 
73us 
fig. 16. Channel Controller Standard INPOT Control Program 
