The Compatible Time-Sharing System (CTSS) was the first general purpose
time-sharing
In computing, time-sharing is the Concurrency (computer science), concurrent sharing of a computing resource among many tasks or users by giving each Process (computing), task or User (computing), user a small slice of CPU time, processing time. ...
operating system
An operating system (OS) is system software that manages computer hardware and software resources, and provides common daemon (computing), services for computer programs.
Time-sharing operating systems scheduler (computing), schedule tasks for ...
. Compatible Time Sharing referred to time sharing which was compatible with
batch processing; it could offer both time sharing and batch processing concurrently.
CTSS was developed at the
MIT Computation Center ("Comp Center"). CTSS was first demonstrated on MIT's modified
IBM 709 in November 1961. The hardware was replaced with a modified
IBM 7090
The IBM 7090 is a second-generation Transistor computer, transistorized version of the earlier IBM 709 vacuum tube mainframe computer that was designed for "large-scale scientific and technological applications". The 7090 is the fourth member o ...
in 1962 and later a modified
IBM 7094 called the "blue machine" to distinguish it from the Project MAC CTSS IBM 7094. Routine service to MIT Comp Center users began in the summer of 1963 and was operated there until 1968.
A second deployment of CTSS on a separate IBM 7094 that was received in October 1963 (the "red machine") was used early on in
Project MAC until 1969 when the red machine was moved to the Information Processing Center and operated until July 20, 1973. CTSS ran on only those two machines; however, there were remote CTSS users outside of MIT including ones in California, South America, the
University of Edinburgh
The University of Edinburgh (, ; abbreviated as ''Edin.'' in Post-nominal letters, post-nominals) is a Public university, public research university based in Edinburgh, Scotland. Founded by the City of Edinburgh Council, town council under th ...
and the
University of Oxford
The University of Oxford is a collegiate university, collegiate research university in Oxford, England. There is evidence of teaching as early as 1096, making it the oldest university in the English-speaking world and the List of oldest un ...
.
History
John Backus said in the 1954 summer session at
MIT that "By time sharing, a big computer could be used as several small ones; there would need to be a reading station for each user".
[ The first known description of computer time-sharing.] Computers at that time, like
IBM 704, were not powerful enough to implement such system, but at the end of 1958, MIT's Computation Center nevertheless added a typewriter input to its 704 with the intent that a programmer or operator could "obtain additional answers from the machine on a time-sharing basis with other programs using the machine simultaneously".
In June 1959,
Christopher Strachey published a paper "Time Sharing in Large Fast Computers" at the
UNESCO Information Processing Conference in Paris, where he envisaged a programmer
debugging a program at a console (like a
teletype) connected to the computer, while another program was running in the computer at the same time.
[ Describe the system and its commands] Debugging programs was an important problem at that time, because with batch processing, it then often took a day from submitting a changed code, to getting the results.
John McCarthy wrote a memo about that at MIT, after which a preliminary study committee and a working committee were established at MIT, to develop time sharing. The committees envisaged many users using the computer at the same time, decided the details of implementing such system at MIT, and started the development of the system.
Experimental Time Sharing System
By July, 1961 a few time sharing commands had become operational on the Computation Center's IBM 709, and in November 1961,
Fernando J. Corbató demonstrated at MIT what was called the ''Experimental Time-Sharing System''. On May 3, 1962, F. J. Corbató, M. M. Daggett and R. C. Daley published a paper about that system at the
Spring Joint Computer Conference.
"
jor portions of
he CTSS system were largely prepared by Mrs. Marjorie M. Daggett, Mr. Robert Daley, Mr. Robert Creasy, Mrs. Jessica Hellwig, Mr. Richard Orenstein, and Professor F. J. Corbató".
[Corbató, p. vii]
The system used an
IBM 7090
The IBM 7090 is a second-generation Transistor computer, transistorized version of the earlier IBM 709 vacuum tube mainframe computer that was designed for "large-scale scientific and technological applications". The 7090 is the fourth member o ...
, modified by
Herbert M. Teager, with added 3
Flexowriters for user consoles, and maybe a
timer. Each of the 3 users had two
tape units, one for the user's file directory, and one for dumping the core (program in memory). There was also one tape unit for the system commands, there were no disk drives. The
memory
Memory is the faculty of the mind by which data or information is encoded, stored, and retrieved when needed. It is the retention of information over time for the purpose of influencing future action. If past events could not be remembe ...
was 27 k words (36-bit words) for users, and 5 k words for the supervisor (operating system). The input from the consoles was written to the buffers in the supervisor, by
interrupt
In digital computers, an interrupt (sometimes referred to as a trap) is a request for the processor to ''interrupt'' currently executing code (when permitted), so that the event can be processed in a timely manner. If the request is accepted ...
s, and when a
return character was received, the control was given to the supervisor, which dumped the running code to the tape and decided what to run next. The console commands implemented at the time were ''login, logout, input, edit, fap, mad, madtrn, load, use, start, skippm, listf, printf, xdump'' and ''xundump''.
This became the initial version of the Compatible Time-Sharing System. This was apparently the first ever public demonstration of
time-sharing
In computing, time-sharing is the Concurrency (computer science), concurrent sharing of a computing resource among many tasks or users by giving each Process (computing), task or User (computing), user a small slice of CPU time, processing time. ...
; there are other claims, but they refer to special-purpose systems, or with no known papers published. The "compatibility" of CTSS was with background jobs run on the same computer, which generally used more of the compute resources than the time-sharing functions.
Applications
DOTSYS and BRAILLEMBOSS
The first version of the DOTSYS
braille
Braille ( , ) is a Tactile alphabet, tactile writing system used by blindness, blind or visually impaired people. It can be read either on embossed paper or by using refreshable braille displays that connect to computers and smartphone device ...
translation software ran on CTSS and could output to a BRAILLEMBOSS braille page printer. DOTSYS on CTSS was first demonstrated on August 18, 1966, as part of a feasibility study where teletypesetter tape, in the form of news, was converted to Grade 2 Braille. The following month the feasibility of converting textbook information on teletypesetter tape to error-free Grade 2 Braille was successfully demonstrated. As MIT CTSS was an academic system, a research vehicle and not a system for commercial computing, two years later a version of DOTSYS stripped of CTSS dependencies for software portability was used on an IBM 709 at the
American Printing House for the Blind to print the first braille edition of a book produced from teletypesetter input, only a few weeks after the ink-print version. The following year, on CTSS, a demonstration of printing mathematical tables in braille was shown. A short FORTRAN II program was written to produce a conversion table from inches to millimeters in braille via the BRAILLEMBOSS braille page printer.
Intrex

The Intrex Retrieval System ran on CTSS. Intrex was an experimental, pilot-model machine-oriented bibliographic storage and retrieval system with a database that stored a catalog of roughly 15,000 journal articles. It was used to develop and test concepts for library automation. A deployment of three BRISC
CRT consoles for testing at the MIT Engineering Library showed that it was preferred over two other systems, ARDS and DATEL.
Features
* The original
ELIZA ran on CTSS.
* CTSS was the first computer system to implement
password login.
* CTSS had one of the first computerized text editing and formatting utilities, called
TYPSET and RUNOFF (the successors of MEMO, MODIFY and DITTO).
* CTSS had one of the first inter-user messaging implementations, pioneering
electronic mail.
[ Tom Van Vleck's memoir o]
The History of Electronic Mail
* CTSS had one of the first
instant messaging systems similar to
write.
* MIT Computation Center staff member
Louis Pouzin created for CTSS a command called
RUNCOM, which executed a list of commands contained in a file.
RUNCOM also provided for parameter substitution.
He later created a design for the
Multics shell
Shell may refer to:
Architecture and design
* Shell (structure), a thin structure
** Concrete shell, a thin shell of concrete, usually with no interior columns or exterior buttresses
Science Biology
* Seashell, a hard outer layer of a marine ani ...
that was implemented by
Glenda Schroeder which in turn inspired Unix
shell scripts.
* CTSS had an implementation of the text editor
QED, the predecessor of
ed,
vi, and
vim, with regular expressions added by
Ken Thompson.
Implementation
Kernel
CTSS used a modified IBM 7090 mainframe computer that had two 32,768 (32K) 36-bit-
word banks of
core memory instead of the default configuration which provides only one.
One bank was reserved for the time-sharing supervisory program, the other for user programs. CTSS had a protected-mode kernel; the supervisor's functions in the A-core (memory bank A) could be called only by software interrupts, as in modern operating systems. Causing memory-protection interrupts were used for software interrupts.
Processor allocation
scheduling with a quantum time unit 200 ms, was controlled by a
multilevel feedback queue.
It also had some special memory-management hardware,
a clock interrupt, and the ability to trap certain instructions.
Supervisor subroutines
* RDFLXA – Read an input line from console
* WRFLX – Write an output line to console
* DEAD – Put the user into dead status, with no program in memory
* DORMNT – Put the user into dormant status, with program in memory
* GETMEM – Get the size of the memory allocation
* SETMEM – Set the size of the memory allocation
* TSSFIL – Get access to the CTSS system files on the disk
* USRFIL – Change back to user's own directory
* GETBRK – Get the instruction location counter at quit
Programming languages
CTSS at first had only an assembler,
FAP, and a compiler, MAD. Also,
Fortran II code could be translated into MAD code by using MADTRN. Later half of the system was written in MAD. Later there were other programming languages including
COMIT II,
LISP 1.5 and a version of
ALGOL.
File system
Each user had their own
directory, and there were also shared directories for groups of people with the same "problem number". Each
file had two names, the second indicating its type as did the
extension in later systems. At first, each file could have one of four modes: temporary, permanent, read-only class 1, and read-only class 2. Read-only class 1 allowed the user to change the mode of the file. Files could also be symbolically linked between directories. A directory listing by ''listf'':
10 FILES 20 TRACKS USED
DATE NAME MODE NO. TRACKS
5/20/63 MAIN MAD P 15
5/17/63 DPFA SYMTB P 1
5/17/63 DPFA BSS P 1
5/17/63 DPFA FAP P 2
Peripherals
Input-output hardware was mostly standard IBM
peripherals. These included six data channels connecting to:
* Printers,
punched card
A punched card (also punch card or punched-card) is a stiff paper-based medium used to store digital information via the presence or absence of holes in predefined positions. Developed over the 18th to 20th centuries, punched cards were widel ...
readers and punches
*
IBM 729 tape drives, an
IBM 1301 disk storage, later upgraded to an
IBM 1302, with 38 million word capacity
* An
IBM 7320 drum memory with 186K words that could load a 32K-word memory bank in one second (later upgraded to 0.25 seconds)
* Two custom high-speed vector graphics displays
* An
IBM 7750 transmission control unit capable of supporting up to 112
teleprinter terminals, including
IBM 1050 Selectrics and
Model 35s. Some of the terminals were located remotely, and the system could be accessed using the public
Telex and TWX networks.
Influences
CTSS was described in a paper presented at the 1962
Spring Joint Computer Conference, and greatly influenced the design of other early time-sharing systems.
Maurice Wilkes witnessed CTSS and the design of the
Titan Supervisor was inspired by that.
Dennis Ritchie wrote in 1977 that UNIX could be seen as a "modern implementation" of CTSS.
Multics, which was also developed by Project MAC, was started in the 1960s as a successor to CTSS – and in turn inspired the development of Unix in 1969. One of the technical terms inherited by these systems from CTSS is ''
daemon''.
Incompatible Timesharing System (ITS), another early, revolutionary, and influential MIT time-sharing system, was produced by people who disagreed with the direction taken by CTSS, and later, Multics; the name was a
parody
A parody is a creative work designed to imitate, comment on, and/or mock its subject by means of satire, satirical or irony, ironic imitation. Often its subject is an Originality, original work or some aspect of it (theme/content, author, style, e ...
of "CTSS", as later the name "Unix" was a parody of "Multics".
CTSS and ITS file systems have a number of design elements in common. Both have an M.F.D. (master file directory) and one or more U.F.D. (user file directories). Neither of them have nested directories (sub-directories). Both have file names consisting of two names which are a maximum of six-characters long. Both support linked files.
See also
*
PLATO (computer system)
*
Timeline of operating systems
*
Time-sharing system evolution
References
Further reading
*
*
*
*
*
External links
Oral history interview with John McCarthy Charles Babbage Institute, University of Minnesota. Discusses computer developments at MIT including time sharing.
Oral history interview with Fernando J. Corbató Charles Babbage Institute, University of Minnesota. Discusses many computer developments at MIT including CTSS.
Oral history interview with Robert M. Fano Charles Babbage Institute, University of Minnesota. Discusses computer developments at MIT including CTSS.
personal memoir of
Tom Van Vleck, a system programmer on CTSS
CTSS Sourceversion MIT8C0 in Paul Pierce's collection.
– Includes a
license-free simulator, cross assembler and linker that can be used to build and run CTSS.
Richard Cornwell's CTSS sources and binaries which run on
SIMH. Includes
license-freebr>
toolsCIO: 40 years of Multics, 1969-2009: Interview with CTSS and Multics developer Fernando J. Corbato.
*
Jerome Saltzer'
CTSS bookshelfvia
CSAIL.
{{Time-sharing operating systems
1960s software
1970s software
Discontinued operating systems
Massachusetts Institute of Technology software
Time-sharing operating systems