Difference between revisions of "Incompatible Timesharing System"

From Computer History Wiki
Jump to: navigation, search
(Early artifacts: Sussman's 1967 listing.)
m (See also: Adopt an orphan)
 
(34 intermediate revisions by 2 users not shown)
Line 8: Line 8:
 
}}
 
}}
  
The '''Incompatible Timesharing System''' (usually '''ITS''') was an early [[time-sharing]] [[operating system]]; initially for the [[PDP-6]], and later for [[PDP-10]]'s. It was developed at MIT in the [[MIT Artificial Intelligence Laboratory|Artificial Intellegence Lab]], after [[Multics]] was done by [[Project MAC]]. It first became operational in July, 1967, after a very short design and implementation period, starting earlier that year.
+
[[Image:mit-mc.jpg|thumb|right|300px|The KL10 MC machine at MIT]]
  
[[Image:mit-mc.jpg|thumb|right|The KL10 MC machine at MIT]]
+
The '''Incompatible Timesharing System''' (usually '''ITS''') was an early [[time-sharing]] [[operating system]]; initially for the [[PDP-6]], and later for [[PDP-10]]'s. It was developed at MIT in the [[MIT Artificial Intelligence Laboratory|Artificial Intelligence Lab]], after [[Multics]] was done by [[Project MAC]]. It first became operational in July, 1967, after a very short design and implementation period, starting earlier that year.
  
The earliest versions ran on the PDP-6, using the [[base and bounds]] [[memory management]] [[hardware]] native to that machine. Later versions ran on [[KA10]]s which were modified with MIT-designed and built [[virtual memory|paging]] hardware (which that generation of PDP-10 did not have). It later ran on the [[KL10]] and [[KS10]] models as well, in both cases running custom [[microcode]] that emulated the operation of the MIT paging box.
+
The earliest versions ran on the PDP-6, using the [[base and bounds]] [[memory management]] [[hardware]] native to that machine. Later versions ran on [[KA10]]s which were modified with MIT-designed and built [[virtual memory|paging]] [[hardware]] (which that generation of PDP-10 [[Central Processing Unit|CPU]] did not have). It later ran on the [[KL10]] and [[KS10]] models as well, in both cases running custom [[microcode]] that emulated the operation of the MIT paging box.
  
ITS was one of the first OS's connected to the [[ARPANET]], and it was on an ITS system that the first versions of [[Emacs]], [[Zork]], [[MACLISP]], and [[Scheme]] were created.
+
ITS was one of the first OS's connected to the [[ARPANET]], and it was on an ITS system that the first versions of [[Emacs]], [[MACLISP]], [[Scheme]], and [[CLU]] were created, as well as notable games such as [[Zork]].
  
During much of its operational lifetime, ITS ran on only a handful of machines:
+
==Architecture and features==
 +
 
 +
''See also [[ITS Internals Manual‎]]''
 +
 
 +
ITS was broadly similar to many other operating systems of its era; each user had a [[terminal]], from which they controlled a [[tree]] of [[process]]es (called a 'job tree' in ITS; 'job' being the ITS term for a process). The top-level process connected to a terminal was normally a [[command processor]] - in ITS' case, the debugger [[DDT]], extended with the usual set of commands: list the [[file]]s in a [[directory]], etc. [[Application]]s (such as [[editor]]s) each had their own process.
 +
 
 +
A superior process has complete control of an inferior; it may halt it, read and write in its memory, kill it, etc. A process tree could be detached from its controlling terminal (e.g. if a [[modem]] was hung up), for which the ITS term was 'disowned'; the user could reconnect to the system and hook back up to their process tree. [[Daemon]]s (top-level processes which performed various housekeeping functions) were not attached to terminals.
 +
 
 +
The earliest versions of the system didn't even support [[swapping]] (it is not yet clear if an intermediate version did); paging was added as soon as the custom hardware to support it was done. Pages from other processes could be mapped into a process' [[address space]], as could pages from files. On machines which had [[front end]] [[PDP-11]]'s, their memory could be mapped into processes' address spaces, too.
 +
 
 +
Processes had full [[interrupt]] handling available (with interrupts coming from either hardware, or software, including other processes); the system also supported [[lock]]s, so that if a process were unexpectedly killed, all locks 'owned' by the process were automatically freed.
 +
 
 +
[[Input/output|I/O]] was all performed through 'channels', of which each job had up to 16. Channels could connect to a [[peripheral|device]] or a file; they operated in either input or output, and in units of either [[character]]s or [[word]]s (although an entire block of data could be transferred by a single [[system call]], if desired). All the usual operations were provided (open, close, delete, rename, etc). I/O operations could either be [[synchronous]] or [[asynchronous]] (completion of those notified by interrupts).
 +
 
 +
ITS had the unusual feature of supporting virtual devices, implemented with demand-created processes into which [[object code]] to implement the device was loaded from the [[file system]]. This was used, among other things, to make each machine's file system accessible from the others, using their ARPANET connections to carry the data. (This may have been the first example of a 'network file system' in any OS.)
 +
 
 +
The file system was not very adventurous: it only supported a single level of directories; but it did support [[symbolic link]]s. (File names had four parts: 'device: directory; fn1 fn2'.) It did have one novel capability (which [[TENEX]] also shared); version numbers: when file "FOO >" was opened for reading, if "FOO 22", "FOO 23" and "FOO 24" all existed, 'FOO 24' was opened; opening "FOO <" opened 'FOO 22'. For writing, opening "FOO >" created 'FOO 25'. Unusually, it did not provide any protection; any user could read or write any file in the system.
 +
 
 +
ITS also supported terminal-type-independent [[video terminal]] output; applications would give commands such as 'clear screen', which the system would convert into the appropriate strings for the user's particular terminal.
 +
 
 +
==Instances==
 +
 
 +
''See also [[ITS machine configurations]]''
 +
 
 +
[[Image:KnightTV.png|thumb|right|400px|Output from the PEEK program, showing a process tree and the usual daemons]]
 +
 
 +
During much of its operational lifetime, ITS ran on only a handful of machines (all at [[Technology Square‎]]):
  
 
* The AI Lab PDP-6, serial number 2.  (The Dynamic Modeling group also had a PDP-6, not much used.)
 
* The AI Lab PDP-6, serial number 2.  (The Dynamic Modeling group also had a PDP-6, not much used.)
Line 22: Line 48:
 
* One KL10: MC, serial number 1038.
 
* One KL10: MC, serial number 1038.
  
Due to failing hardware, the PDP-6 was shut down in the late 1970s, and physically removed in the early 1980s. The KA10s followed shortly after, but some were replaced with KS10s. By 1990 all MIT machines were shut down permanently.
+
The AI Lab's PDP-6 and KA10 were joined into a [[multi-processor]] system, with shared [[main memory]] and devices. Originally, the PDP-6 was the master, where ITS ran, but the two later swapped roles. Due to failing hardware, the PDP-6 was shut down in the late 1970s, and physically removed in the early 1980s. The KA10s followed shortly after, but some were replaced with KS10s. By 1990 all MIT machines were shut down permanently.
 
 
[[Image:KnightTV.png|thumb|right|Output from the PEEK program]]
 
[[Image:Knight-keyboard.png|thumb|right|The Knight keyboard was used with the MIT-AI PDP-10 and CADR [[LISP machine]]s; this is a rendition of the layout]]
 
  
In modern times, ITS runs on a KS10 at the [[Living Computers museum]]; it was previously MIT-AI.  The museum also has the KL10 MIT-MC in storage. ITS also runs on several software emulators.
+
In modern times, ITS runs on a KS10 at the [[Living Computer Museum]]; it was previously MIT-AI.  The museum also has the KL10 MIT-MC in storage. ITS also runs on several software emulators.
  
 
Some information on installing & images can be found [http://www.cosmic.com/u/mirian/its.html here].
 
Some information on installing & images can be found [http://www.cosmic.com/u/mirian/its.html here].
Line 33: Line 56:
 
==Milestones==
 
==Milestones==
  
* 1967 - First version for PDP-6
+
* 1966 - Moby memory acquired and TTY device added four more teletypes; preparing for timesharing?
 +
* 1967 - First version of ITS; ran on PDP-6 &mdash; ITS 1.0 3/19/67
 +
* 1968 - Two Data Disc drives added, too small to be useful
 
* 1969 - Ported to KA10
 
* 1969 - Ported to KA10
 
* 1969 - Second PDP-6 at Dynamic Modeling group
 
* 1969 - Second PDP-6 at Dynamic Modeling group
Line 53: Line 78:
 
==Notable contributions==
 
==Notable contributions==
  
The Artificial Intelligence PDP-6 and PDP-10 were host to many influential programs: [[TECO]] (adopted form the RLE [[PDP-1]]), [[Logo]] (coming from [[BBN]]), Mac Hack VI, [[MACLISP]], [[Scheme]], [[EMACS]], and was used to bootstrap the [[LISP machine]] hardware and software.
+
The Artificial Intelligence PDP-6 and PDP-10 were host to many influential programs: [[TECO]] (adopted from the one on RLE [[PDP-1]]), [[Logo]] (coming from [[Bolt, Beranek, and Newman|BBN]]), Mac Hack VI, [[MACLISP]], [[Scheme]], [[Emacs editors|EMACS]]; it was also used to [[bootstrap]] the [[LISP machine]] hardware and software.
  
The Dynamic Modeling PDP-10 was used to develop [[Muddle]], [[Maze War|MAZE]], the first C compiler outside Bell Labs, [[CLU]], and [[Zork]].
+
The Dynamic Modeling PDP-10 was used to develop [[Muddle]], [[Maze War|MAZE]], the first [[C programming language|C]] [[compiler]] outside Bell Labs, [[CLU]], and [[Zork]].
  
The Mathlab PDP-10 was used to develop Macsyma, but was later supplanted by a dedicated Macsyma Consortium [[KL10]].
+
The Mathlab PDP-10 was used to develop [[Macsyma]], but was later supplanted by a dedicated Macsyma Consortium KL10.
  
 
==Early artifacts==
 
==Early artifacts==
  
The earliest ITS code on record is Gerald Sussman's printed listing of version 138 dating from 1967.
+
The earliest ITS code on record is Gerald Sussman's printed listing of [[ITS 138]] dating from 1967.  The title says "ITS 1.0 3/19/67", but it seems the date hasn't been updated.  The listing is being processed, with results put here: [http://github.com/PDP-6/ITS-138 http://github.com/PDP-6/ITS-138]
 +
 
 +
The next is ITS version 671 from early 1971.  It's a complete [[object code|binary]] core image, including Salvager and Exec [[DDT]].  It runs on Richard Cornwell's KA10 simulator with [[Systems Concepts DC-10]] disks.  Also on the same tape is the next earliest [[source code]] version, ITS 672.
  
The next is ITS version 671 from early 1971.  It's a complete [[object code|binary]] core image including Salvager and Exec DDT. It runs on Richard Cornwell's KA10 simulator with [[Systems Concepts DC-10]] disks.  Also on the same tape is the earliest source code version is ITS 672.
+
==Stories==
 +
 
 +
[[Image:MagicSwitch(Front).jpg|thumb|right|200px|The "magic switch" which had been attached to the MIT-AI PDP-10]]
 +
 
 +
ITS, and the [[hacker]] culture around it, produced innumerable stories:
 +
 
 +
===Magic/More magic switch===
 +
 
 +
The AI ITS machine had a mysterious experimental two-position switch attached to the machine at some point, labelled 'Magic' in one position, and 'More magic' in the other. It was only connected to [[ground]], but on several occasions it was observed that throwing the switch crashed the machine!
  
 
==See also==
 
==See also==
  
 +
* [[PCLSRing]]
 +
* [[ITS Internals Manual‎]]
 +
* [[ITS on-disk file system layout]]
 +
* [[Versions of important ITS software]]
 +
* [[Running ITS (the Incompatible Timesharing System) on the KL-10]] - a historical memo
 
* [[Systems Concepts DM-10]] - Paging box used on several KA10 ITS's
 
* [[Systems Concepts DM-10]] - Paging box used on several KA10 ITS's
 
* [[Systems Concepts DK-10]] - Datapoint kludge; AI lab KA10 terminal multiplexor
 
* [[Systems Concepts DK-10]] - Datapoint kludge; AI lab KA10 terminal multiplexor
 
* [[Systems Concepts DC-10]] - IBM 2314 disk control for the AI lab KA10
 
* [[Systems Concepts DC-10]] - IBM 2314 disk control for the AI lab KA10
 
* [[ITS DDT Guide]]
 
* [[ITS DDT Guide]]
* [[MIDAS]]
+
* [[MIDAS]] - the ITS [[macro]] [[assembler]], in which most code was written
* [[Technology Square‎]] - home of all the ITS machines
 
* [[WAITS]], another operating system similar in spirit
 
 
* [[Installing ITS on SIMH]]
 
* [[Installing ITS on SIMH]]
 
* [[Unix interoperability with PDP-10]]
 
* [[Unix interoperability with PDP-10]]
 +
* [[WAITS]], another operating system similar in spirit
 +
 +
==Further reading==
  
 +
* Steven Levy, ''Hackers: Heroes of the Computer Revolution'', Doubleday, Garden City, 1984 (original edition) - covers much else, but does provide a good non-technical historical overview of the environment and people who produced ITS
 +
 
==External links==
 
==External links==
  
 
* [http://github.com/PDP-10/its Source code and scripts for building ITS]
 
* [http://github.com/PDP-10/its Source code and scripts for building ITS]
** [https://github.com/PDP-10/its-vault/tree/master/files/ ITS files]
+
** [https://github.com/PDP-10/its/tree/master/doc ITS documentation] - curated
** [https://github.com/PDP-10/its/tree/master/src ITS source]
+
** [https://github.com/PDP-10/its/tree/master/src ITS source] - curated
** [https://github.com/PDP-10/its-vault/blob/master/files/sysdoc/its.histry SYSDOC; ITS HISTRY] - log of changes from ITS 946 to 1263
+
** [https://github.com/PDP-10/its-vault/tree/master/files/ ITS files] - un-curated; raw unsorted dump from CSAIL archives
** [https://github.com/PDP-10/its-vault/blob/master/files/_info_/its.primer An Introduction to ITS for the MACSYMA User] - good intro overview to ITS
+
<!-- ** [https://github.com/PDP-10/its-vault/blob/master/files/ ITS files] - goes to same place -->
 +
** [https://github.com/PDP-10/its-vault/blob/master/files/sysdoc/its.histry ITS HISTRY] - list of changes to ITS versions
 +
** [https://github.com/PDP-10/its/tree/master/doc/_info_/its.primer An Introduction to ITS for the MACSYMA User] - good intro overview to ITS
 +
** [https://github.com/PDP-10/its/tree/master/doc/info/intro.29 INFO;INTRO >] - a good starting place for online documentation
 +
* [http://github.com/PDP-6/ITS Source code for a very early ITS 1.0 running on a PDP-6]
 +
* [https://dspace.mit.edu/handle/1721.1/6194 ITS Status Report] - these cover very old versions of the system
 +
** [https://dspace.mit.edu/handle/1721.1/6085 ITS 1.4 Reference Manual]
 +
** [https://hack.org/mc/texts/its-reference-1.5.txt ITS 1.5 Reference Manual]
 +
*** [http://ana-3.lcs.mit.edu/~jnc/tech/pdp10/its/itsmanpg19.pdf The missing page 19]
 +
* [http://junk.nocrew.org/pipermail/its/ BUG-ITS] - archive of email messages (currently offline)
 +
** [https://github.com/PDP-10/its-vault/blob/master/files/sysdoc/its.bugs ITS BUGS] - another copy, all in several large archive files
 +
** [https://github.com/PDP-10/its-vault/blob/master/files/sysdoc/its.obugs0 ITS OBUGS0]
 +
** [https://github.com/PDP-10/its-vault/blob/master/files/sysdoc/its.obugs1 ITS OBUGS1]
 +
** [https://github.com/PDP-10/its-vault/blob/master/files/sysdoc/its.obugs2 ITS OBUGS2]
 +
* [https://wiki.livingcomputers.org/doku.php?id=its_topics ITS Topics] - ITS page at the [[Living Computer Museum]] DokuWiki
 
* [http://its.victor.se/wiki/ The Incompatible Timesharing System wiki]
 
* [http://its.victor.se/wiki/ The Incompatible Timesharing System wiki]
 
** [http://its.victor.se/wiki/setup Some notes on setting up an ITS system]
 
** [http://its.victor.se/wiki/setup Some notes on setting up an ITS system]
** [http://its.victor.se/mailman/listinfo/its-hackers_its.victor.se ITS mailing list]
+
** [http://its.victor.se/mailman/listinfo/its-hackers_its.victor.se ITS-hackers mailing list]
 +
* [https://github.com/larsbrinkhoff/its-manual/wiki ITS Manual] - a new 'Intro to ITS' manual
 +
** [https://github.com/larsbrinkhoff/its-manual/wiki/ITS-on-the-PiDP-10 ITS on the PiDP 10]
 +
** [https://github.com/PDP-10/its/blob/master/doc/networking.md Networking] - networking on ITS simulations
 
* [http://github.com/larsbrinkhoff/pdp10-its-disassembler Unix tools for working with ITS files]
 
* [http://github.com/larsbrinkhoff/pdp10-its-disassembler Unix tools for working with ITS files]
 
* [http://ana-3.lcs.mit.edu/~jnc/tech/pdp10/ITS_Hardware_Memo_2.pdf ITS Hardware Memo #2] - Specification for the MIT paging box
 
* [http://ana-3.lcs.mit.edu/~jnc/tech/pdp10/ITS_Hardware_Memo_2.pdf ITS Hardware Memo #2] - Specification for the MIT paging box
 +
* [https://github.com/PDP-10/its/issues/1232 The Magic Switch]
  
[[Category:PDP-10 Operating Systems]]
+
[[Category: PDP-10 Operating Systems]]
 
[[Category: Non-DEC Operating Systems]]
 
[[Category: Non-DEC Operating Systems]]

Latest revision as of 20:29, 8 February 2024


ITS
Type: Multi-tasking, multi-user, virtual memory
Creator: MIT AI Lab
Architecture: PDP-10
This Version: 1651
Date Released: July, 1967


The KL10 MC machine at MIT

The Incompatible Timesharing System (usually ITS) was an early time-sharing operating system; initially for the PDP-6, and later for PDP-10's. It was developed at MIT in the Artificial Intelligence Lab, after Multics was done by Project MAC. It first became operational in July, 1967, after a very short design and implementation period, starting earlier that year.

The earliest versions ran on the PDP-6, using the base and bounds memory management hardware native to that machine. Later versions ran on KA10s which were modified with MIT-designed and built paging hardware (which that generation of PDP-10 CPU did not have). It later ran on the KL10 and KS10 models as well, in both cases running custom microcode that emulated the operation of the MIT paging box.

ITS was one of the first OS's connected to the ARPANET, and it was on an ITS system that the first versions of Emacs, MACLISP, Scheme, and CLU were created, as well as notable games such as Zork.

Architecture and features

See also ITS Internals Manual‎

ITS was broadly similar to many other operating systems of its era; each user had a terminal, from which they controlled a tree of processes (called a 'job tree' in ITS; 'job' being the ITS term for a process). The top-level process connected to a terminal was normally a command processor - in ITS' case, the debugger DDT, extended with the usual set of commands: list the files in a directory, etc. Applications (such as editors) each had their own process.

A superior process has complete control of an inferior; it may halt it, read and write in its memory, kill it, etc. A process tree could be detached from its controlling terminal (e.g. if a modem was hung up), for which the ITS term was 'disowned'; the user could reconnect to the system and hook back up to their process tree. Daemons (top-level processes which performed various housekeeping functions) were not attached to terminals.

The earliest versions of the system didn't even support swapping (it is not yet clear if an intermediate version did); paging was added as soon as the custom hardware to support it was done. Pages from other processes could be mapped into a process' address space, as could pages from files. On machines which had front end PDP-11's, their memory could be mapped into processes' address spaces, too.

Processes had full interrupt handling available (with interrupts coming from either hardware, or software, including other processes); the system also supported locks, so that if a process were unexpectedly killed, all locks 'owned' by the process were automatically freed.

I/O was all performed through 'channels', of which each job had up to 16. Channels could connect to a device or a file; they operated in either input or output, and in units of either characters or words (although an entire block of data could be transferred by a single system call, if desired). All the usual operations were provided (open, close, delete, rename, etc). I/O operations could either be synchronous or asynchronous (completion of those notified by interrupts).

ITS had the unusual feature of supporting virtual devices, implemented with demand-created processes into which object code to implement the device was loaded from the file system. This was used, among other things, to make each machine's file system accessible from the others, using their ARPANET connections to carry the data. (This may have been the first example of a 'network file system' in any OS.)

The file system was not very adventurous: it only supported a single level of directories; but it did support symbolic links. (File names had four parts: 'device: directory; fn1 fn2'.) It did have one novel capability (which TENEX also shared); version numbers: when file "FOO >" was opened for reading, if "FOO 22", "FOO 23" and "FOO 24" all existed, 'FOO 24' was opened; opening "FOO <" opened 'FOO 22'. For writing, opening "FOO >" created 'FOO 25'. Unusually, it did not provide any protection; any user could read or write any file in the system.

ITS also supported terminal-type-independent video terminal output; applications would give commands such as 'clear screen', which the system would convert into the appropriate strings for the user's particular terminal.

Instances

See also ITS machine configurations

Output from the PEEK program, showing a process tree and the usual daemons

During much of its operational lifetime, ITS ran on only a handful of machines (all at Technology Square‎):

  • The AI Lab PDP-6, serial number 2. (The Dynamic Modeling group also had a PDP-6, not much used.)
  • Three KA10s: AI, DM, ML. Their serial numbers were 8, 144, and 198.
  • One KL10: MC, serial number 1038.

The AI Lab's PDP-6 and KA10 were joined into a multi-processor system, with shared main memory and devices. Originally, the PDP-6 was the master, where ITS ran, but the two later swapped roles. Due to failing hardware, the PDP-6 was shut down in the late 1970s, and physically removed in the early 1980s. The KA10s followed shortly after, but some were replaced with KS10s. By 1990 all MIT machines were shut down permanently.

In modern times, ITS runs on a KS10 at the Living Computer Museum; it was previously MIT-AI. The museum also has the KL10 MIT-MC in storage. ITS also runs on several software emulators.

Some information on installing & images can be found here.

Milestones

  • 1966 - Moby memory acquired and TTY device added four more teletypes; preparing for timesharing?
  • 1967 - First version of ITS; ran on PDP-6 — ITS 1.0 3/19/67
  • 1968 - Two Data Disc drives added, too small to be useful
  • 1969 - Ported to KA10
  • 1969 - Second PDP-6 at Dynamic Modeling group
  • 1970 - Second KA10 at Dynamic Modeling group
  • 1971 - Connected to ARPANET, version ~670
  • 1972 - Third KA10 at Mathlab group
  • 1975 - Ported to KL10, version 915
  • 1978 - PDP-6 support dropped, version 1115
  • 1984 - All KA10 machines shut down, first KS10 arrives
  • 1985 - Ported to KS10, version 1488, three more KS10s
  • 1986 - KS ITS distributed outside MIT (SI, FU, PM, DX)
  • 1988 - KL10 machine shut down
  • 1990 - All MIT KS10 machines shut down; last MIT version 1644
  • 1992 - First run on KS10 software simulator
  • 2001 - First simulator available on Internet
  • 2010 - First run on an FPGA PDP-10 implementation
  • 2017 - First run on KA10 software simulator

Notable contributions

The Artificial Intelligence PDP-6 and PDP-10 were host to many influential programs: TECO (adopted from the one on RLE PDP-1), Logo (coming from BBN), Mac Hack VI, MACLISP, Scheme, EMACS; it was also used to bootstrap the LISP machine hardware and software.

The Dynamic Modeling PDP-10 was used to develop Muddle, MAZE, the first C compiler outside Bell Labs, CLU, and Zork.

The Mathlab PDP-10 was used to develop Macsyma, but was later supplanted by a dedicated Macsyma Consortium KL10.

Early artifacts

The earliest ITS code on record is Gerald Sussman's printed listing of ITS 138 dating from 1967. The title says "ITS 1.0 3/19/67", but it seems the date hasn't been updated. The listing is being processed, with results put here: http://github.com/PDP-6/ITS-138

The next is ITS version 671 from early 1971. It's a complete binary core image, including Salvager and Exec DDT. It runs on Richard Cornwell's KA10 simulator with Systems Concepts DC-10 disks. Also on the same tape is the next earliest source code version, ITS 672.

Stories

The "magic switch" which had been attached to the MIT-AI PDP-10

ITS, and the hacker culture around it, produced innumerable stories:

Magic/More magic switch

The AI ITS machine had a mysterious experimental two-position switch attached to the machine at some point, labelled 'Magic' in one position, and 'More magic' in the other. It was only connected to ground, but on several occasions it was observed that throwing the switch crashed the machine!

See also

Further reading

  • Steven Levy, Hackers: Heroes of the Computer Revolution, Doubleday, Garden City, 1984 (original edition) - covers much else, but does provide a good non-technical historical overview of the environment and people who produced ITS

External links