home *** CD-ROM | disk | FTP | other *** search
/ ftp.pasteur.org/FAQ/ / ftp-pasteur-org-FAQ.zip / FAQ / dec-faq / pdp8 next >
Internet Message Format  |  2001-06-09  |  73KB

  1. Path: senator-bedfellow.mit.edu!bloom-beacon.mit.edu!nycmny1-snh1.gtei.net!cpk-news-hub1.bbnplanet.com!news.gtei.net!newsfeed.skycache.com!Cidera!netnews.com!feed2.onemain.com!feed1.onemain.com!uunet!dca.uu.net!news.uiowa.edu!not-for-mail
  2. From: jones@cs.uiowa.edu (Douglas W. Jones)
  3. Newsgroups: alt.sys.pdp8,alt.answers,news.answers
  4. Subject: PDP-8 Frequently Asked Questions (posted every other month)
  5. Followup-To: alt.sys.pdp8
  6. Date: 8 Jun 2001 08:08:08 GMT
  7. Organization: Computer Science, University of Iowa, Iowa City, Iowa, USA
  8. Lines: 1458
  9. Approved: news-answers-request@MIT.Edu
  10. Distribution: world
  11. Expires: 8 Aug 2001 08:08:08 GMT
  12. Message-ID: <9fqtpj$jde$1@flood.weeg.uiowa.edu>
  13. NNTP-Posting-Host: pyrite.cs.uiowa.edu
  14. X-Trace: flood.weeg.uiowa.edu 992017011 19886 128.255.28.3 (8 Jun 2001 16:16:51 GMT)
  15. X-Complaints-To: usenet@news.uiowa.edu
  16. NNTP-Posting-Date: 8 Jun 2001 16:16:51 GMT
  17. Summary: Answers to common questions about antique DEC PDP-8 computers.
  18.     Those posting to alt.sys.pdp8 should read this.
  19. Keywords: FAQ DEC PDP 8
  20. Xref: senator-bedfellow.mit.edu alt.sys.pdp8:6520 alt.answers:55886 news.answers:208795
  21.  
  22. Archive-name: dec-faq/pdp8
  23. Last-modified: Apr 8, 2001
  24.  
  25. Frequently Asked Questions about the DEC PDP-8 computer.
  26.  
  27.     By Douglas Jones, jones@cs.uiowa.edu
  28.     (with help from many folks)
  29.  
  30. Reasonably current versions of this file is available by anonymous FTP from:
  31.  
  32.     ftp://rtfm.mit.edu/pub/usenet/alt.sys.pdp8
  33.     ftp://ftp.uu.net/usenet/news.answers/dec-faq
  34.     ftp://src.doc.ic.ac.uk:/pub/usenet/news.answers/alt.sys.pdp8
  35.  
  36. Reasonably current automatic translations of this document to HTML format
  37. for the World Wide Web are available from:
  38.  
  39.     http://www.faqs.org/faqs/dec-faq/
  40.     http://www.cs.ruu.nl/wais/html/na-dir/dec-faq/.html
  41.  
  42. An obsolete version of this file is available on the Walnut Creek USENET
  43. FAQ CDROM; another version will be published as part of the FAQbook by
  44. Pamela Greene et al.
  45.  
  46. This posting conforms to RFC1153 USENET digest format (with exceptions due
  47. to the fact that it is not really a digest).
  48.  
  49.  
  50. Contents:
  51.  
  52.     What is a PDP?
  53.     What is a PDP-8?
  54.     What is the PDP-8 instruction set?
  55.     What does PDP-8 assembly language look like?
  56.     What character sets does the PDP-8 support?
  57.     What different PDP-8 models were made?
  58.     What about the LINC-8 and PDP-12?
  59.     Where can I get a PDP-8 today?
  60.     Where can I get PDP-8 documentation?
  61.     What operating systems were written for the PDP-8?
  62.     What programming languages were supported on the PDP-8?
  63.     Where can I get PDP-8 software?
  64.     Where can I get additional information?
  65.     What use is a PDP-8 today?
  66.     Who's Who?
  67.  
  68. ----------------------------------------------------------------------
  69.  
  70. Subject: What is a PDP?
  71.  
  72. In 1957, Ken Olson and Harlan Anderson founded Digital Equipment
  73. Corporation (DEC), capitalized at $100,000, and 70% owned by American
  74. Research and Development Corporation.  Olson and Anderson had designed
  75. major parts of the AN/FSQ-7, the TX-0 and the TX-2 computers at
  76. Lincoln Labs.  They wanted to call their company Digital Computer
  77. Corporation, but the venture capitalists insisted that they avoid the
  78. term Computer and hold off on building computers.
  79.  
  80. With facilities in an old woolen mill in Maynard Massachusetts, DEC's
  81. first product was a line of transistorized digital "systems modules"
  82. based on the modules used in building TX-2 at Lincoln Labs; these
  83. were plug-in circuit boards with a few logic gates per board.  Starting
  84. in 1960, DEC finally began to sell computers (the formal acceptance of
  85. the first PDP-1 by BBN is reported in Computers and Automation, April
  86. 1961, page 8B).  Soon after this, there were enough users that DECUS,
  87. the Digital Equipment Computer User's Society was founded.
  88.  
  89. DEC's first computer, the PDP-1, sold for only $120,000 at a time when
  90. other computers sold for over $1,000,000.  (A good photo of a PDP-1 is
  91. printed in Computers and Automation, Dec. 1961, page 27).  DEC quoted
  92. prices as low as $85,000 for minimal models.  The venture capitalist's
  93. insistance on avoiding the term computer was based on the stereotype
  94. that computers were big and expensive, needing a computer center and a
  95. large staff; by using the term Programmable Data Processor, or PDP, DEC
  96. avoided this stereotype.  For over a decade, all digital computers sold
  97. by DEC were called PDPs.  (In early DEC documentation, the plural form
  98. "PDPs" is used as a generic term for all DEC computers.)
  99.  
  100. In the early 1960's, DEC was the only manufacturer of large computers
  101. without a leasing plan.  IBM, Burroughs, CDC and other computer
  102. manufacturers leased most of their machines, and many machines were
  103. never offered for outright sale.  DEC's cash sales approach led to the
  104. growth of third party computer leasing companies such as DELOS, a
  105. spinoff of BB&N.
  106.  
  107. DEC built a number of different computers under the PDP label, with a
  108. huge range of price and performance.  The largest of these are fully
  109. worthy of large computer centers with big support staffs.  Some early
  110. DEC computers were not really built by DEC.  With the PDP-3 and LINC,
  111. for example, customers built the machines using DEC parts and
  112. facilities.  Here is the list of PDP computers:
  113.  
  114.     MODEL  DATE  PRICE    BITS NUMBER COMMENTS
  115.     =====  ====  ======== ==== ====== ========
  116.     PDP-1  1960  $120,000 18       50 DEC's first computer
  117.     PDP-2            NA   24        - Never built?  Prototype only?
  118.     PDP-3            NA   36          One built by a customer*, not by DEC.
  119.     PDP-4  1962   $60,000 18       45 Predecessor of the PDP-7.
  120.     PDP-5  1963   $27,000 12    1,000 The ancestor of the PDP-8.
  121.     PDP-6  1964  $300,000 36       23 A big computer; 23 built, most for MIT.
  122.     PDP-7  1965   $72,000 18      120 Widely used for real-time control.
  123.     PDP-8  1965   $18,500 12  ~50,000 The smallest and least expensive PDP.
  124.     PDP-9  1966   $35,000 18      445 An upgrade of the PDP-7.
  125.     PDP-10 1967  $110,000 36   **~700 A PDP-6 followup, great for timesharing.
  126.     PDP-11 1970   $10,800 16 >600,000 DEC's first and only 16 bit computer.
  127.     PDP-12 1969   $27,900 12      725 A PDP-8 relative.
  128.     PDP-13           NA             - Bad luck, there was no such machine.
  129.     PDP-14                        *** A ROM-based programmable controller.
  130.     PDP-15 1970   $16,500 18      790 A TTL upgrade of the PDP-9.
  131.     PDP-16 1972      NA   8/16      ? A register-transfer module system.
  132.  
  133. *  Scientific Engineering Institute of Waltham MA.  SEI was aledgedly
  134.      founded in 1956 by the CIA to study the effects of microwaves (radar)
  135.      on the human brain.  If so, the PDP-3 may have been used as an
  136.      instrumentation computer.  More info on the CIA connection and the
  137.      use of the PDP-3 would be nice!
  138. ** Includes DECsystem 20.
  139.  
  140. Corrections and additions to this list are welcome!  The prices given
  141. are for minimal systems in the year the machine was first introduced.
  142. Most of the production run numbers come from "Computer Engineering" by
  143. Bell, Mudge and McNamara, 1978, or from Computers and Automation's
  144. computer census figures published regularly throughout the 1960's.
  145. The bits column in the table indicates the word size.  Note that the
  146. DEC PDP-10 became the DECSYSTEM-20 as a result of marketing
  147. considerations, and DEC's VAX series of machines began as the Virtual
  148. Address eXtension of the never-produced PDP-11/78.
  149.  
  150. It is worth mentioning that it is widely (but somewhat incorrectly)
  151. accepted that the Data General Nova (see photo, Computers and
  152. Automation, Nov. 1968, page 48) grew out of the PDP-X, a 16-bit
  153. multi-register version of the PDP-8 designed by Edson DeCastro, Henry
  154. Burkhardt and Dick Soggee.  (DeCastro was one of DEC's key design
  155. engineers; his name appears on many of the blueprints for machines
  156. from the PDP-5 up through the PDP-8/L).
  157.  
  158. A prototype PDP-X was built at DEC; this and a competing 16-bit design
  159. were apparently submitted to Harold McFarland at Carnegie-Mellon
  160. University for evaluation; McFarland (and perhaps Gordon Bell, who was
  161. at C-MU at the time) evaluated the competing designs and rejected both
  162. in favor of what we now know as the PDP-11.  (I was at Carnegie-Mellon
  163. at the time, and McFarland gave a guest lecture in a class I attended
  164. telling part of this story.)  Some speculate, incorrectly, that Bell
  165. rejected the Nova design because the competing proposal used the
  166. register-transfer notation he had introduced in "Bell and Newell,
  167. Computer Structures -- Readings and Examples".  An alternate and equally
  168. unfounded story is that the reason DEC never produced a PDP-13 was
  169. because the number 13 had been assigned to what became the Nova.
  170.  
  171. In any case, when DeCastro, Burkhardt and Soggee founded Data General,
  172. Ken Olson at DEC was very angry, claiming for a long time that the
  173. Nova design was stolen.  Gordon Bell and others concluded that the
  174. Nova design was sufficiently original that a lawsuit was unwarranted,
  175. but the feud between DeCastro and Olson lasted until after Ken Olson
  176. left DEC.  It is more correct to say that the Nova is a reaction to the
  177. PDP-X than to say that it is based on the PDP-X.  I am indebted to
  178. Jim Campbell, retired VP at Data General, for some of the details of
  179. this story.
  180.  
  181. Today, all of the PDP machines are in DEC's corporate past, except the
  182. PDP-11 family, which survives as a line of microcomputers; DEC has
  183. promised to discontinue PDP-11 sales on Sept. 30, 1996.  Occasionally,
  184. some lab has built a machine out of DEC hardware and called it a PDP
  185. with a new number.  For example, the Australian Atomic Energy Commission
  186. once upgraded a PDP-7 by adding a PDP-15 on the side; they called the
  187. result a PDP-22.  There is also a story about the PDP-2 1/2, built by
  188. Ed Rawson of the American Science Institute out of surplus modules that
  189. were originally used in the prototype PDP-2.
  190.  
  191. In 1998, Compaq purchased DEC, and it is unclear how long DEC will retain
  192. any semblance of its original identity as a division of a larger company.
  193.  
  194. ------------------------------
  195.  
  196. Subject: What is a PDP-8?
  197.  
  198. The PDP-8 family of minicomputers were built by Digital Equipment
  199. Corporation between 1965 and 1990, although it is worth noting that the
  200. term minicomputer first came into prominence after the machine was
  201. introduced.  The first use of the term appears to have been made by
  202. the head of DEC's operations in England, John Leng.  He sent back a
  203. sales report that started: "Here is the latest minicomputer activity
  204. in the land of miniskirts as I drive around in my [Austin] Mini Minor."
  205. The term quickly became part of DEC's internal jargon and spread from
  206. there; the first computer explicitly sold as a minicomputer, though,
  207. was made by by Interdata (See the Interdata ad in Computers and
  208. Automation, May 1968, page 10).
  209.  
  210. The PDP-8 was largely upward compatible with the PDP-5, a machine that
  211. was unveiled on August 11, 1963 at WESCON, and the inspiration for that
  212. machine came from two earlier machines, the LINC and the CDC 160.  All
  213. of these machines were characterized by a 12 bit word with little or no
  214. hardware byte structure, typically 4K words of memory, and simple but
  215. powerful instruction sets.
  216.  
  217. Although some people consider the CDC 160 the first minicomputer, the
  218. PDP-8 was the definitive minicomputer.  By late 1973, the PDP-8 family
  219. was the best selling computer in the world, and it is likely that it was
  220. only displaced from this honor by the Apple II (which was displaced by
  221. the IBM PC).  Most models of the PDP-8 set new records as the least
  222. expensive computer on the market at the time of their introduction.
  223. The PDP-8 has been described as the model-T of the computer industry
  224. because it was the first computer to be mass produced at a cost that
  225. just about anyone could afford.
  226.  
  227. C. Gordon Bell has said that the basic idea of the PDP-8 was not really
  228. original with him.  He gives credit to Seymour Cray (of CDC and later
  229. Cray) for the idea of a single-accumulator 12 bit minicomputer.  Cray's
  230. CDC 160 family (see CACM, march 1961, photo on page 244, text on page
  231. 246) was such a machine, and in addition to the hundreds of CDC 160
  232. systems sold as stand-alone machines, a derivative 12 bit architecture
  233. was used for the I/O processors on Cray's first great supercomputer,
  234. the CDC 6600.
  235.  
  236. Note that Cray's 12 bit machines had 6 basic addressing modes with
  237. variable length instruction words and other features that were far from
  238. the simple elegance of the PDP-8.  Despite its many modes, the CDC 160
  239. architecture lacked the notion of current page addressing, it had no
  240. unconditional jump instruction, and the I/O instructions all blocked
  241. the CPU until I/O complete.  As a result, the PDP-8 is both far more
  242. flexible and it supports much tighter programming styles.
  243.  
  244. ------------------------------
  245.  
  246. Subject: What is the PDP-8 instruction set?
  247.  
  248. The PDP-8 word size is 12 bits, and the basic memory is 4K words.  The
  249. minimal CPU contained the following registers:
  250.  
  251.     PC - the program counter, 12 bits.
  252.     AC - the accumulator, 12 bits.
  253.     L  - the link, 1 bit, commonly prefixed to AC as <L,AC>.
  254.  
  255. It is worth noting that many operations such as procedure linkage and
  256. indexing, which are usually thought of as involving registers, are done
  257. with memory on the PDP-8 family.
  258.  
  259. Instruction words are organized as follows:
  260.      _ _ _ _ _ _ _ _ _ _ _ _
  261.     |_|_|_|_|_|_|_|_|_|_|_|_|
  262.     |     | | |             |
  263.     |  op |i|z|    addr     |
  264.  
  265.     op   - the opcode.
  266.     i    - the indirect bit (0 = direct, 1 = indirect).
  267.     z    - the page bit (0 = page zero, 1 = current page).
  268.     addr - the word in page.
  269.  
  270. The top 5 bits of the 12 bit program counter give the current page, and
  271. memory addressing is also complicated by the fact that absolute memory
  272. locations 8 through 15 are incremented prior to use when used as indirect
  273. addresses.  These locations are called auto-index registers (despite the
  274. fact that they are in memory); they allow the formulation of very tightly
  275. coded array operations.
  276.  
  277. The basic instructions are:
  278.  
  279.     000 - AND - and operand with AC.
  280.     001 - TAD - add operand to <L,AC> (a 13 bit value).
  281.     010 - ISZ - increment operand and skip if result is zero.
  282.     011 - DCA - deposit AC in memory and clear AC.
  283.     100 - JMS - jump to subroutine.
  284.     101 - JMP - jump.
  285.     110 - IOT - input/output transfer.
  286.     111 - OPR - microcoded operations.
  287.  
  288. The ISZ and other skip instructions conditionally skip the next
  289. instruction in sequence.  The ISZ is commonly used to increment a loop
  290. counter and skip if done, and it is also used as an general increment
  291. instruction, either followed by a no-op or in contexts where it is known
  292. that the result will never be zero.
  293.  
  294. The JMS instruction stores the return address in relative word zero of
  295. the subroutine, with execution starting with relative word one.
  296. Subroutine return is done with an indirect JMP through the return
  297. address.  Subroutines commonly increment their return addresses to index
  298. through inline parameter lists or to perform conditional skips over
  299. instructions following the call.
  300.  
  301. The IOT instruction has the following form:
  302.      _ _ _ _ _ _ _ _ _ _ _ _
  303.     |1|1|0|_|_|_|_|_|_|_|_|_|
  304.     |     |           |     |
  305.     |     |   device  | op  |
  306.  
  307. The IOT instruction specifies one of up to 8 operations on one of 64
  308. devices.  Typically (but not universally), each bit of the op field
  309. evokes an operation, and these can be microcoded in right to left
  310. order.  Prior to the PDP-8/E, there were severe restrictions on the
  311. interpretation of the op field that resulted from the fact that the
  312. operation was delivered as a sequence of IOP pulses, each on a separate
  313. line of the I/O bus.  Each line was typically used to evoke a different
  314. device function, so essentially, the operation 000 was always a no-op
  315. because it evoked no functions, and the code 111 evoked all three
  316. functions in series.
  317.  
  318. As an example of the use of IOT instructions, consider the console
  319. terminal interface.  On early PDP-8 systems, this was always assumed to
  320. be an ASR 33 teletype, complete with low-speed paper tape reader and
  321. punch.  It was addressed as devices 03 (the keyboard/reader) and 04
  322. (the teleprinter/punch):
  323.      _ _ _ _ _ _ _ _ _ _ _ _
  324.     |1|1|0|_|_|_|_|_|_|_|_|_|
  325.           |0 0 0 0 1 1|0 0 1  - KSF - keyboard skip if flag
  326.           |0 0 0 0 1 1|0 1 0  - KCC - keyboard clear flag
  327.           |0 0 0 0 1 1|1 0 0  - KRS - keyboard read static
  328.  
  329. The keyboard flag is set by the arrival of a character.  The KCC
  330. instruction clears both the flag and the accumulator.  KRS ors the 8 bit
  331. input data with the low order 8 bits of AC.  The commonly used KRB
  332. instruction is the or of KCC and KRS.  To await one byte of input, use
  333. KSF to poll the flag, then read the byte with KRB.
  334.      _ _ _ _ _ _ _ _ _ _ _ _
  335.     |1|1|0|_|_|_|_|_|_|_|_|_|
  336.           |0 0 0 1 0 0|0 0 1  - TSF - teleprinter skip if flag
  337.           |0 0 0 1 0 0|0 1 0  - TCF - teleprinter clear flag
  338.           |0 0 0 1 0 0|1 0 0  - TPC - teleprinter print static
  339.  
  340. The teleprinter flag is set by the completion of the TPC operation (as
  341. a result, on startup, many applications output a null in order to get
  342. things going).  TCF clears the flag, and TPC outputs the low order 8
  343. bits of the accumulator.  The commonly used TLS instruction is the or
  344. of TCF and TPC.  To output a character, first use TSF to poll the flag,
  345. then write the character with TLS.
  346.  
  347. IOT instructions may be used to initiate data break transfers from block
  348. devices such as disk or tape.  The term "data break" was, for years,
  349. DEC's preferred term for cycle-stealing direct-memory-access data
  350. transfers.
  351.  
  352. Some CPU functions are accessed only by IOT instructions.  For example,
  353. interrupt enable and disable are IOT instructions:
  354.      _ _ _ _ _ _ _ _ _ _ _ _
  355.     |1|1|0|_|_|_|_|_|_|_|_|_|
  356.           |0 0 0 0 0 0|0 0 1  - ION - interrupts turn on
  357.           |0 0 0 0 0 0|0 1 0  - IOF - interrupts turn off
  358.  
  359. An interrupt is requested when any device raised its flag.  The console
  360. master clear switch resets all flags and disables interrupts.  In
  361. effect, an interrupt is a JMS instruction to location zero, with the
  362. side effect of disabling interrupts.  The interrupt service routine
  363. is expected to test the device flags and perform the operations needed
  364. to reset them, and then return using ION immediately before the indirect
  365. return JMP.  The effect of ION is delayed so that interrupts are not
  366. enabled until after the JMP.
  367.  
  368. The instructions controlling the optional memory management unit are
  369. also IOT instructions.  This unit allows the program to address up to
  370. 32K of main memory by adding a 3 bit extension to the memory address.
  371. Two extensions are available, one for instruction fetch and direct
  372. addressing, the other for indirect addressing.
  373.  
  374. A wide variety of operations are available through the OPR microcoded
  375. instructions:
  376.          _ _ _ _ _ _ _ _ _ _ _ _
  377. Group 1 |1|1|1|0|_|_|_|_|_|_|_|_|
  378.              1                - CLA - clear AC
  379.                1              - CLL - clear the L bit
  380.                      1            - CMA - ones complement AC
  381.                        1          - CML - complement L bit
  382.                                1  - IAC - increment <L,AC>
  383.                          1 0 0    - RAR - rotate <L,AC> right
  384.                          0 1 0    - RAL - rotate <L,AC> left
  385.                      1 0 1    - RTR - rotate <L,AC> right twice
  386.                      0 1 1    - RTL - rotate <L,AC> left twice
  387.  
  388. In general, the above operations can be combined by oring the bit
  389. patterns for the desired operations into a single instruction.  If none
  390. of the bits are set, the result is the NOP instruction.  When these
  391. operations are combined, they operate top to bottom in the order shown
  392. above.  The exception to this is that IAC cannot be combined with the
  393. rotate operations on some models, and attempts to combine rotate
  394. operations have different effects from one model to another (for example,
  395. on the PDP-8/E, the rotate code 001 means swap 6 bit bytes in the
  396. accumulator, while previous models took this to mean something like
  397. "shift neither left nor right 2 bits").
  398.          _ _ _ _ _ _ _ _ _ _ _ _
  399. Group 2 |1|1|1|1|_|_|_|_|_|_|_|0|
  400.                    1     0        - SMA - skip on AC < 0  \
  401.                      1   0        - SZA - skip on AC = 0   > or group
  402.                        1 0        - SNL - skip on L /= 0  /
  403.                    0 0 0 1        - SKP - skip unconditionally
  404.                    1     1        - SPA - skip on AC >= 0 \
  405.                      1   1        - SNA - skip on AC /= 0  > and group
  406.                        1 1        - SZL - skip on L = 0   /
  407.                  1                - CLA - clear AC
  408.                            1      - OSR - or switches with AC
  409.                              1    - HLT - halt
  410.  
  411. The above operations may be combined by oring them together, except that
  412. there are two distinct incompatible groups of skip instructions.  When
  413. combined, SMA, SZA and SNL, skip if one or the other of the indicated
  414. conditions are true (logical or), while SPA, SNA and SZL skip if all of
  415. the indicated conditions are true (logical and).  When combined, these
  416. operate top to bottom in the order shown; thus, the accumulator may be
  417. tested and then cleared.  Setting the halt bit in a skip instruction is
  418. a crude but useful way to set a breakpoint for front-panel debugging.
  419. If none of the bits are set, the result is an alternative form of no-op.
  420.  
  421. A third group of operate microinstructions (with a 1 in the least
  422. significant bit) deals with the optional extended arithmetic element to
  423. allow such things as hardware multiply and divide, 24 bit shift
  424. operations, and normalize.  These operations involve an additional data
  425. register, MQ or multiplier quotient, and a small step count register.
  426. On the PDP-8/E and successors, MQ and the instructions for loading and
  427. storing it were always present, even when the EAE was absent, and the
  428. EAE was extended to provide a useful variety of 24 bit arithmetic
  429. operations.
  430.  
  431. ------------------------------
  432.  
  433. Subject: What does PDP-8 assembly language look like?
  434.  
  435. There are many different assemblers for the PDP-8, but most use a
  436. compatible basic syntax; here is an example:
  437.  
  438.     START,    CLA CLL        / Clear everything
  439.         TAD    X    / Load X
  440.         AND I    Y    / And with the value pointed to by Y
  441.         DCA    X    / Store in X
  442.         HLT        / Halt
  443.  
  444.     X,    1         / A variable
  445.     Y,    7         / A pointer
  446.  
  447. Note that labels are terminated by a comma, and comments are separated
  448. from the code by a slash.  There are no fixed fields or column
  449. restrictions.  The "CLA CLL" instruction on the first line is an example
  450. of the microcoding of two of the Group 1 operate instructions.  CLA
  451. alone has the code 7200 (octal), while CLL has the code 7100; combining
  452. these as "CLA CLL" produces 7300.  As a general rule, except when memory
  453. reference instructions are involved, the assembler simply ors together
  454. the values of all blank separated fields between the label and comment.
  455.     
  456. Indirection is indicated by the special symbol I in the operand field,
  457. as in the third line of the example.  The typical PDP-8 assembler has no
  458. explicit notation to distinguish between page zero and current page
  459. addresses.  Instead, the assembler is expected to note the page holding
  460. the operand and automatically generate the appropriate mode.  If the
  461. operand is neither in the current page nor page zero, some assemblers
  462. will raise an error, others will automatically generate an indirect
  463. pointer to the off-page operand; this should be avoided because it only
  464. works for directly addressed off-page operands, and only when the memory
  465. management unit is not being used to address a data field other than the
  466. current instruction field.
  467.  
  468. Note, in the final two lines of the example, that there is no "define
  469. constant" pseudo-operation.  Instead, where a constant is to be
  470. assembled into memory, the constant takes the place of the op-code field.
  471.  
  472. The PDP-8 has no immediate addressing mode, but most assemblers provide
  473. a notation to allow the programmer to ignore this lack:
  474.  
  475.         TAD    (3)    / add 3, from memory on the current page.
  476.         TAD    [5]    / add 5, from memory on page zero.
  477.         JMP I    (LAB)    / jump indirect through the address of LAB.
  478.  
  479. Assemblers that support this automatically fill the end of each page
  480. with constants defined in this way that have been accumulated during the
  481. assembly of that page.  Note that the variants "(3" and "[5" (with no
  482. closing parentheses) are usually allowed but the use of this sloppy form
  483. is discouraged.  Furthermore, the widely used PAL8 assembler interprets
  484. the unlikely operand "(3)+1" as being the same as "(3+1)".
  485.  
  486. Arithmetic is allowed in operand fields and constant definitions, with
  487. expressions evaluated in strict left-to-right order, as:
  488.  
  489.         TAD    X+1    / add the contents of the location after X.
  490.         TAD    (X-1)    / add the address of the location before X.
  491.  
  492. Other operators allowed include and (&), or (!), multiply (^) and divide
  493. (%), as well as a unary sign (+ or -).  Unfortunately, one of the most
  494. widely used assemblers, PAL8, has trouble when unary operators are mixed
  495. with multiplication or division.
  496.     
  497. Generally, only the first 6 characters of identifiers are significant
  498. and numeric constants are evaluated in octal.
  499.  
  500. Other assembly language features are illustrated below:
  501.  
  502.     / Comments may stand on lines by themselves
  503.                 / Blank lines are allowed
  504.  
  505.         *200        / Set the assembly origin to 200 (octal)
  506.  
  507.     NL0002=    CLA CLL CML RTL    / Define new opcode NL0002.
  508.  
  509.         NL0002        / Use new opcode (load 0002 in AC)
  510.         JMP    .-1    / Jump to the previous instruction
  511.  
  512.     X1=    10        / Define X1 (an auto-index register address)
  513.     LETA=    "A        / Define LETA as 000011000001 (ASCII A)
  514.  
  515.         TAD I    X1    / Use autoindex register 1
  516.  
  517.         IAC; RAL    / Multiple instructions on one line
  518.  
  519.         $        / End of assembly
  520.  
  521. The assembly file ends with a line containing a $ (dollar sign) not in
  522. a comment field.
  523.  
  524. The $, * and =  syntax used by most PDP-8 assemblers replaces functions
  525. performed by pseudo-operations on many other assemblers.  In addition,
  526. PAL8, the most widely used PDP-8 assembler supports the following
  527. pseudo-operations:
  528.  
  529.         DECIMAL        / Interpret numeric constants in base 10
  530.         OCTAL        / Interpret numeric constants in base 8
  531.         EJECT        / Force a page eject in the listing
  532.         XLIST        / Toggle listing
  533.         XLIST    N    / Turn on listing if N=0, off if N=1
  534.         PAGE          / Advance location counter to next page
  535.         PAGE     N    / Set location counter start of page N
  536.         FIELD    N    / Assemble into extended memory field N
  537.         TEXT    "STR"    / Pack STR into consecutive 6 bit bytes
  538.         ZBLOCK    N    / Allocate N words, initialized to zero
  539.         IFDEF    S <C>    / Assemble C if symbol S is defined
  540.         IFNDEF    S <C>    / Assemble C if symbol S is not defined
  541.         IFZERO    E <C>    / Assemble C if expression E is zero
  542.         IFNZRO    E <C>    / Assemble C if expression E is not zero
  543.         FIXMRI  OP= VAL    / Define OP as memory reference instruction
  544.  
  545. Conditonally assembled code must be enclosed in angle brackets.  The
  546. enclosed code may extend over multiple lines and, because different
  547. assemblers treat comments within conditionals differently, the closing
  548. bracket should not be in a comment and any brackets in comments should
  549. be balanced.
  550.  
  551. ------------------------------
  552.  
  553. Subject: What character sets does the PDP-8 support?
  554.  
  555. From the beginning, PDP-8 software has generally assumed that textual
  556. I/O would be in 7 bit ASCII.  Most early PDP-8 systems used teletypes
  557. as console terminals; as sold by DEC, these were configured for mark
  558. parity, so most older software assumes 7 bit ASCII, upper case only,
  559. with the 8th bit set to 1.  On output, lines are generally terminated
  560. with both CR and LF; on input, CR is typically (but not always) the
  561. line terminator and LF is typically ignored.  In addition, the tab
  562. character (HT) is generally allowed, but software support output of text
  563. containing tabs varies.
  564.  
  565. One difficulty with much PDP-8 software is that it bypasses the device
  566. handlers provided by the operating system and goes directly to the
  567. device.  This results in very irregular device support, so that, for
  568. example, control-S and control-Q work to start and stop output under
  569. OS/8, but the OS/8 PAL assembler ignores them when reporting errors.
  570.  
  571. Most of the better engineered PDP-8 software tends to fold upper and
  572. lower case on input, and it ignores the setting of the 8th bit.  Older
  573. PDP-8 software will generally fail when presented with lower case
  574. textual input (this includes essentially all OS/8 products prior to
  575. OS/278 V1).
  576.  
  577. Internally, PDP-8 programmers are free to use other character sets, but
  578. the "X notation provided by the assembler encourages use of 7 bit ASCII
  579. with the 8th bit set to 1, and the TEXT pseudo-operation encourages the
  580. 6 bit character set called "stripped ASCII".  To map from upper-case-only
  581. ASCII to stripped ASCII, each 8 bit character is anded with octal 77 and
  582. then packed 2 characters per word, left to right.  Many programs use a
  583. semi-standard scheme for packing mixed upper and lower case into 6 bit
  584. TEXT form; this uses ^ to flip from upper to lower case or lower to
  585. upper case, % to encode CR-LF pairs, and @ (octal 00) to mark end of
  586. string.  Note that this scheme makes no provision for encoding the %,
  587. ^ and @ characters, nor does it allow control characters other than the
  588. CR-LF pair.
  589.  
  590. The P?S/8 operating system supports a similar 6 bit text file format,
  591. where upper and lower case are folded together, tabs are stored as _
  592. (underline), end-of-line is represented by 00, padded with any
  593. nonzero filler to a word boundary, and end of file is 0000.
  594.  
  595. Files under the widely used OS/8 system consist of sequences of 256 word
  596. blocks.  When used for text, each block holds 384 bytes, packed 3 bytes
  597. per pair of words as follows:
  598.  
  599.         aaaaaaaa        ccccaaaaaaaa
  600.         bbbbbbbb        CCCCbbbbbbbb
  601.         ccccCCCC
  602.  
  603. Control Z is used as an end of file marker.  Because most of the PDP-8
  604. system software was originally developed for paper tape, binary object
  605. code is typically stored in paper-tape image form using the above packing
  606. scheme.
  607.  
  608. ------------------------------
  609.  
  610. Subject: What different PDP-8 models were made?
  611.  
  612. The total sales figure for the PDP-8 family is estimated at over 300,000
  613. machines.  Over 7000 of these were sold prior to 1970, and 30,000 were
  614. sold by 1976.  During the PDP-8 production run, a number of models were
  615. made, as listed in the following table.  Of these, the PDP-8/E is generally
  616. considered to be the definitive machine.  If the PDP-8 is considered to
  617. be the Model T of the computer industry, perhaps the PDP-8/E should be
  618. considered to be the industry's Model A.
  619.  
  620.     MODEL    DATES    SALES   COST    TECHNOLOGY    REMARKS
  621.  
  622.     PDP-5    63-67     116        Transistor
  623.     PDP-8    65-69     1450    $18,500    Transistor
  624.     LINC-8    66-69     142    $38,500    Transistor
  625.     PDP-8/S    66-70    1024    $10,000    Transistor    Very slow
  626.     PDP-8/I    68-71     3698    $12,800    TTL
  627.     PDP-8/L    68-71     3902     $8,500    TTL        Scaled down 8/I
  628.     PDP-12    69-73?    3500?    $27,900    TTL        Followup to LINC-8
  629.     PDP-8/E    70-78    >10K?     $6,500    TTL MSI    Omnibus
  630.     PDP-8/F    72-78?    >10K?    <$5K    TTL MSI Omnibus    Based on 8/E CPU
  631.     PDP-8/M    72-78?    >10K?    <$5K    TTL MSI Omnibus    OEM version of 8/F
  632.     PDP-8/A    75-84?    >10K?     $1,317    TTL LSI Omnibus    New CPU or 8/E CPU
  633.     VT78    78-80         $7,995    Intersil 6100    Workstation
  634.     DECmate I    80-84            Harris 6120    Workstation
  635.     DECmate II    82-86         $1,435    Harris 6120    Workstation
  636.     DECmate III    84-90         $2,695    Harris 6120    Workstation
  637.     DECmate III+85-90            Harris 6120    Workstation
  638.  
  639. Additional information is available in part two of this FAQ, where all
  640. known models of the PDP-8, along with variants, alternate marketing
  641. names, and other peculiarities are given.
  642.  
  643. The last years of the PDP-8 family were dominated by the PDP-8 compatible
  644. microprocessor based VT78 and DECmate workstations.  The Intersil 6100,
  645. also known as the CMOS-8 chip, was developed in 1976; GE later acquired
  646. Intersil.  DEC also used the followup Harris 6120 microprocessors
  647. (Introduced 1981) in many peripheral controllers for the PDP-11 and
  648. PDP-15 as well as in the DECmate series of systems.  While all of the
  649. earlier PDP-8 systems were open architecture systems, the DECmates had
  650. closed architectures with an integrated console terminals and limited
  651. peripheral options.  It is interesting to note that the Harris 6120 was
  652. a 10Mhz chip and some chips could be clocked at 15Mhz; furthermore, the
  653. 6120 was essentially based on gate array technology.
  654.  
  655. The following PDP-8 compatible or semi-compatible machines were made and
  656. sold by others; very little is known about many of these:
  657.  
  658.     MODEL         DATE    MAKER, NOTES
  659.  
  660.     TPA1001         69    Hungarian, KFKI product, transistorized.
  661.     TPA1001/i     71    Hungarian, KFKI, IC version of 1001.
  662.     TPA/i         71    Hungarian, KFKI, renamed TPA1001/i
  663.     TPA/l         7?     Hungarian, KFKI, enhanced TPA/i.
  664.     TPAl/128H     7?     Hungarian, KFKI, TPA/l with 128K memory.
  665.     TPA/s         7?    Hungarian, KFKI, based on Intersil CPU chip.
  666.     TPA Quadro     8?    Hungarian, KFKI, comparable to a DECmate.
  667.         Electronica-100  ?    Russian, discrete transistor technology.
  668.         Electronica-100I ?    Russian, probably a PDP-8/I clone.
  669.     Electrotechnica-100I ?    Yugoslavian, PDP-8/I?  Possibly same as above.
  670.     Saratov-2     ?    Russian, built like a PDP-8/M but bulkier.
  671.     SPEAR u-LINC 100 ?    SPEAR, Inc, Waltham Mass (a LINC clone!)
  672.     SPEAR u-LINC 300 ?    SPEAR, Inc, Waltham Mass (a LINC clone!)
  673.     DCC-112         70    Digital Computer Controls, PDP-8/L clone.
  674.     DCC-112H     71    Digital Computer Controls
  675.     MPS-1         74    Fabritek, PDP-8/L clone
  676.     MP-12         74    (is this just different numbering of above?)
  677.     6100 Sampler     76?    Intersil, their IM6100 promotional kit
  678.     Intercept I     7?    Intersil, based on IM6100
  679.     Intercept Jr     7?    Intersil, based on IM6100
  680.     TLF MINI-12      77     Based on IM6100, in an elegant package.
  681.     PCM-12         7?    Pacific CyberMetrix, based on Intercept bus
  682.     PCM-12A         77    Pacific CyberMetrix, fixed to clock at 4MHz
  683.     SBC-8         84-88    CESI, Based on IM6120? SCSI bus
  684.  
  685. More information on the Hungarian TPA series, built by KFKI (the Central
  686. Research Institute for Physics), was provided by Varga Akos Endre,
  687. hamster@telnet.hu; information on and photos of these machines are
  688. currently available from:
  689.  
  690.   http://www.internetto.hu/muzeum/e_tpa.html
  691.   http://www.internetto.hu/muzeum/e_tpai.html
  692.  
  693. The original machine in this series, the TPA1001, was built from the
  694. description in DEC's Small Computer Handbook.  Only after the series was
  695. in production, when a machine was exhibited in Ljubljana, Yugoslavia, was
  696. full DEC compatability demonstrated, when a DEC user booted the TPA machine
  697. from a DEC paper tape.  By the end of the TPA production run, around 900
  698. PDP-8 compatable machines had been built.  Given the Soviet era central
  699. planning for the computer industries in eastern europe, it is quite possible
  700. that the Electrotechnica and Electronica models listed above may have been
  701. TPA machines packaged for use in the USSR and other Soviet Block countries.
  702.  
  703. It is amusing to note that the name TPA is very similar in origin to the name
  704. PDP used by DEC!  There was a decree that computer development in Hungary was
  705. to cease, with all computers to be purchased from the USSR.  In response, the
  706. people at KFKI ceased developing computers and began developing "Stored Program
  707. Analyzers" or, the acronym for which is TPA in Hungarian.
  708.  
  709. The CESI (Computer Extension Systems, Inc.) machine had 128K words of local
  710. RAM on each processor card and allowed up to 4 processor cards per OMNIBUS,
  711. along with 128K words of global shared memory.  3 AMD 2901 bit-slice
  712. processor chips were used to build the 12-bit ALU and data paths, controlled
  713. by an 80-bit microword.
  714.  
  715. ------------------------------
  716.  
  717. Subject: What about the LINC/8 and PDP-12?
  718.  
  719. Wesley Clark and Charles Molnar, then at Lincoln Labs, built the LINC, or
  720. Laboratory INstrumentation Computer, as a personal laboratory computer,
  721. finishing the first in March 1962.  The machine was developed in response
  722. to the needs of Mary Brazier, a neurophysiologist at MIT who needed better
  723. laboratory tools, and it was a followup to the Average Response Computer,
  724. an 18 bit special purpose machine built in 1958 for the same purpose.
  725. When Lincoln Labs decided that the LINC did not fit their mission, in
  726. January 1963, the project moved to MIT, and then in 1964, to Washington
  727. University in St Louis.  The National Institute of Health funded the
  728. project as an experiment to see if coumputers would be a productive tool
  729. in the life sciences.  By the end of 1963, 20 LINCs had been built and
  730. debugged, many by their eventual users.
  731.  
  732. Over 24 LINC systems were built by customers before late 1964 when DEC
  733. began selling a commercial version (see Computers and Automation, Nov.
  734. 1964, page 43).  By the time DEC introduced the LINC-8, 43 LINC systems
  735. had been installed (see Computers and Automation, Mar. 1966, page 34).
  736. In total, 50 LINC systems were built, 21 by DEC, 29 by customers (see
  737. Digital at Work, page 52).  A photo of the last LINC in production use
  738. is available from http://www.mit.edu:8001/people/ijs/epl/LINC.html
  739. Wesley Clark wrote a history of the LINC, "The LINC was Early and
  740. Small", published in "A History of Personal Workstations," ACM Press,
  741. 1988, page 347.
  742.  
  743. The LINC was the first 12 bit minicomputer built using DEC hardware.
  744. Like the PDP-5 and other early DEC computers, it was built with System
  745. Modules, DEC's first family of logic modules.  Along with the CDC 160,
  746. it paved the way for the PDP-5 and PDP-8.
  747.  
  748. When compared with the PDP-8, the LINC instruction set was not as well
  749. suited for general purpose computation, but the common peripherals
  750. needed for lab work such as analog-to-digital and digital-to-analog
  751. converters were all bundled into the LINC system.  Users judged it to
  752. be a superb laboratory instrument.
  753.  
  754. One of the major innovations introduced with the LINC was the LINCtape,
  755. designed by Tom Stockebrand scaled down from an experimental tape drive
  756. developed for the TX-2 at Lincoln Labs.  LINCtapes could be carelessly
  757. pocketed or dropped on the floor without fear of data loss, and they
  758. allowed random access to data blocks.  Stockebrand improved on this idea
  759. slightly after he came to DEC, where the improved idea was called
  760. DECtape; DECtape was widely used with all DEC computers made in the
  761. late 1960's and early 1970's.
  762.  
  763. The motives behind the development of LINCtape were the same motives
  764. that led IBM to develop the floppy disk almost a decade later, and in
  765. fact, DECtape survived as a widely used medium until DEC introduced the
  766. RX01 8 inch floppy disk drive around 1975, and even after this, DECtape
  767. was only slowly phased out.
  768.  
  769. Within a year of the introduction of the PDP-8, DEC released the LINC-8,
  770. a machine that combined a PDP-8 with a LINC in one package.  The
  771. success of the LINC-8 led DEC to re-engineer the machine using TTL
  772. logic in the late 1960's; the new version was originally to be called
  773. the LINC-8/I, but it was sold as the PDP-12.  Both the LINC-8 and the
  774. PDP-12 had impressive consoles, with separate sets of lights and
  775. switches for the LINC and PDP-8 halves.
  776.  
  777. The success of the LINC-8 also led to the development of a clone, the
  778. SPEAR micro-LINC.  This machine used Motorola MECL integrated circuits
  779. and was available for delivery in (June 1965? this date must be wrong!).
  780.  
  781. The LINC-8 and PDP-12 could run essentially any PDP-8 or LINC program,
  782. with the exception of the few programs that relied on the primitive
  783. interrupt structure of the original LINC architecture; on the LINC-8,
  784. all interrupts were handled by the PDP-8 side of the hardware.  Because
  785. the LINC-8 and PDP-12 had instructions for switching between modes, a
  786. new body of software was developed that required both modes.
  787.  
  788. One feature of LINC and LINC-8 software is the common use of the graphic
  789. display for input-output.  These machines were some of the first to
  790. include such a display as a standard component, and many programs used
  791. the knobs on the analog to digital converter to move a cursor on the
  792. display in the way we now use a mouse.
  793.  
  794. Various versions of LAP, the Linc Assembly Program, were the dominant
  795. assemblers used on the LINC; the original version of LAP was a cross
  796. assembler written on the TX-2.  WISAL (WISconson Assembly Language) or
  797. LAP6-W was the version of this assembler that survived to run on the
  798. PDP-12.  Curiously, this includes a PDP-8 assembler written in LINC code.
  799.  
  800. LAP6-DIAL (Display Interactive Assembly Language) evolved from this on
  801. the PDP-12 to became the dominant operating system for the PDP-12.  The
  802. 8K version of this is DIAL MS (Mass Storage), even if it has only two
  803. LINCtape drives.  These were eventually displaced by the OS/8 variant
  804. known as OS/12.
  805.  
  806. ------------------------------
  807.  
  808. Subject: Where can I get a PDP-8 today?
  809.  
  810. The IM6100 chip may still be available (Electronic Expediters, (818)781-1910
  811. (in North America) listed them at US$23.50 each as of 10/1994), and CESI
  812. may still make their clone, for a high price, but you can't buy a new
  813. DEC PDP-8.  There are quite a few PDP-8 machines to be found in odd
  814. places on the used equipment market.  They were widely incorporated into
  815. products such as computer controlled machine tools, X-ray diffraction
  816. machines, and other industrial and lab equipment.  Many of them were
  817. sold under the EduSystem marketing program to public schools and
  818. universities, and others were used to control laboratory instrumentation.
  819. After about 1976, Reuters bought as many as 10,000 OMNIBUS based
  820. machines per year, with perhaps 2000 per year going to other customers.
  821.  
  822. Through the 1980's and 1990's, PDP-8 hardware was frequently discarded
  823. or sold for scrap, and many collectors were able to obtain CPU's,
  824. peripherals and occasional complete systems in exchange for the effort
  825. required to haul them away.  This may be changing!  In early 1999, a
  826. PDP-8 system in unknown condition was sold at auction through eBay for
  827. $1526.00; this is far less than the new cost of such a machine, but
  828. far more than the scrap value of such a system!  Owners of original DEC
  829. hardware will likely need maintenance and test supplies.  Douglas
  830. Electronics still makes extender boards and breadboards in DEC format,
  831. see:
  832.  
  833.   http://www.douglas.com/hardware/pcbs/breadboards/digital.html
  834.  
  835. As of 2000, there are still a modest number of PDP-8 systems in
  836. production use, mostly PDP-8/A systems.  These are supported by a
  837. shrinking number of commercial suppliers and maintenance contractors.
  838. For example, Michael Coffey <mdynac@netscape.net> has advertised the
  839. availability of spare parts and maintencance documents for Omnibus
  840. systems/
  841.  
  842. By the year 2000, a number of PDP-8 parts and systems have changed hands
  843. on E-bay.  Sadly, many systems are sold piecemeal, with parts such as
  844. core memory destined to hang on den and office walls.  The market is
  845. spotty, but looking back over the ebay.com sales history is a good way
  846. to get an idea of what parts might be worth.
  847.  
  848. If you can't get real hardware, you can get emulators.  Over the years,
  849. many PDP-8 emulators have been written; the best of these are
  850. indistinguishable from the real machine from a software prespective,
  851. and on a modern high-speed RISC platform, these frequently outperform
  852. the hardware they are emulating.  An emulator is available from DECUS,
  853. catalog number RB0128; This and other emulators are available from:
  854.  
  855.   ftp://metalab.unc.edu/pub/academic/computer-science/history/pdp-8/emulators
  856.   ftp://ftp.cs.uiowa.edu/public/jones/pdp8/emulator.txt.Z
  857.   http://www.tiac.net/users/mps/retro/sources/simh25a.zip
  858.   (previously ftp://ftp.digital.com/pub/DEC/sim/sources/sim_2.2d.tar.Z)
  859.  
  860. The final collection of emulators listed above includes emulators for the
  861. Nova and other DEC machines as well as the IBM 1401.
  862.  
  863. Bernhard Baehr's emulator for the Apple Mac, complete with an emulated front
  864. panel and a fair amount of software is available from:
  865.  
  866.   http://home.t-online.de/~bernhard.baehr/pdp8e/pdp8e.html
  867.  
  868. The Spare Time Gizmos emulator for Windows doesn't have the elaborate
  869. front panel interface, but it appears to be reasonably complete and has a
  870. very realistic teletype interface window.
  871.  
  872.   http://www.sparetimegizmos.com/Software/WinEight.htm
  873.  
  874. Finally, you can always build your own.  The textbook "The Art of
  875. Digital Design," second edition, by Franklin Prosser and David Winkel
  876. (Prentice-Hall, 1987, ISBN 0-13-046780-4) uses the design of a PDP-8 as
  877. a running example; development new material based on this book continues,
  878. including an asynch interface chip and, now, several implementations based
  879. on Xilinx FPGAs.  Contact Ingo Cyliax or Caleb Hess (cyliax@cs.indiana.edu
  880. or hess@cs.indiana.edu) for information on the current state of this work.
  881. Other FPGA implementation are being developed by Jon Andrews and David Conroy;
  882. see:
  883.  
  884.   http://www.jaywalk.co.uk/pdp8
  885.   http://www.jetnet.ab.ca/users/bfranchuk/index.html
  886.  
  887. "Modern VLSI Design - A system approch" by Wayne Wolf (1994 Prentice-Hall)
  888. also uses the PDP-8 as a data-path example, as does "Verilog Design Computer
  889. Design" by Mark Gordon Arnold (Prentice Hall).
  890.  
  891. It is worth noting that there are a sufficient number of PDP-8 systems
  892. still operational that some companies still manufacture peripherals.
  893. For example, Storage Computer (http://www.storage.com/) makes RK05
  894. compatable semiconductor "disk drives" that can be directly connected to
  895. the Omnibus RK05 controllers of the PDP-8/E,F,M and A.
  896.  
  897. Occasionally, someone connects a PDP-8 to the internet.  The most
  898. interesting current venture in that direciton is available at:
  899.  
  900.   http://www.pdp8.net/
  901.  
  902. This machine, when working, has complete remote control of the front
  903. panel and even the on-off switch from a Java interface, and there's a
  904. web-cam so you can see the real machine as it responds to the remote
  905. front panel operations.
  906.  
  907. ------------------------------
  908.  
  909. Subject: Where can I get PDP-8 documentation?
  910.  
  911. The key documents published by DEC describing each model of the PDP-8
  912. are all out of print, and DEC was in the habit of printing much of
  913. their documentation on newsprint with paperback bindings, which is to
  914. say, surviving copies tend to be yellow and brittle.  DEC distributed
  915. huge numbers of catalogs and programming handbooks in this inexpensive
  916. paperback format, and these circulate widely on the second-hand market.
  917. When research laboratories and electronics shops are being cleaned out,
  918. it is still common to find a few dusty, yellowed copies of these books
  919. being thrown out.
  920.  
  921. Douglas Jones has made a small number of bound photocopies of DEC's
  922. 1973 introduction to programming, perhaps the definitive introduction
  923. to the PDP-8, and the other early DEC handbooks need similar treatment
  924. before they all crumble.
  925.  
  926. Thanks to David Gesswein, a growing collection of PDP-8 documentation,
  927. including the Small Computer Handbook, the PDP-8/e/f/m maintenance
  928. manual, and prints of various boards have been scanned in and made
  929. available on the web at:
  930.  
  931.     http://highgate.comm.sfu.ca/pdp8/
  932.     http://www.pdp8.net/query_docs/query.shtml
  933.  
  934. Some PDP-8 reference material has been transcribed into Hypertext format
  935. and is available over WWW from:
  936.  
  937.     http://www.cs.uiowa.edu/~jones/pdp8/index.html
  938.  
  939. Much more material is available from:
  940.  
  941.     http://www.spiritone.com/~nabil/pdp8/
  942.  
  943. In general, maintenance manuals are hard to find, but valuable.  If you
  944. need one, you usually need to find someone willing to photocopy one of
  945. the few surviving copies.  DEC has been friendly to collectors, granting
  946. fairly broad letters of permission to reprint obsolete documentation,
  947. and the network makes if fairly easy to find someone who has the
  948. documentation you need and can get copies.  The most difficult to copy
  949. material is the large prints, many of which would be quite useful if
  950. photoreduced, but this is expensive.
  951.  
  952. ------------------------------
  953.  
  954. Subject: What operating systems were written for the PDP-8?
  955.  
  956. A punched paper-tape library of stand-alone programs was commonly used
  957. with the smallest (diskless and tapeless) configurations from the
  958. beginning up through the mid 1970's.  This included a paper-tape based
  959. text editor, the PAL III and MACRO-8 assembler, and a FORTRAN compiler,
  960. as well as a library of support routines.  Many paper tapes from this
  961. library survive to the present at various sites!  The minimum
  962. configuration expected by these tapes is a CPU with 4K memory and a
  963. teletype ASR 33 with paper tape reader and punch.  Note that much of this
  964. paper-tape-based software is based on memory-use and I/O conventions that
  965. are incompatible with later disk-based systems.
  966.  
  967. The DECtape Library System was a DECtape oriented save and restore system
  968. that was available from the start.  The resident portion of this system
  969. occupies only 17 words of memory (7600-7625 octal), and it allowed saving
  970. and restoring absolute core images as named files on a reel of DECtape.
  971. Initially, program development was still done with paper tape, and only
  972. executable memory images were stored on DECtape, but eventually, a limited
  973. DECtape-based text editor was introduced, along with a DECtape based
  974. assembler.
  975.  
  976. The 4K Disk Monitor System provided slightly better facilities.  This
  977. supported on-line program development and it worked with any device that
  978. supported 129 word blocks (DECtape, the DF32 disk, or the RF08 disk).
  979. It was quite slow, but it also used very little of the available memory.
  980.  
  981. MS/8 or the RL Monitor System, was developed starting in 1966 by
  982. Richard F. Lary; it was submitted to DECUS in 1970.  This was a disk
  983. oriented system, faster than the above, with tricks to make it run
  984. quickly on DECtape based systems.
  985.  
  986. POLY BASIC was a BASIC only system submitted to DECUS and later sold by
  987. DEC as part of its EduSystem marketing program.  EduSystem 25 Basic
  988. is available from:
  989.  
  990.     ftp://russ.ucs.indiana.edu/pub/DEC/PDP8/Langs/Edu25Basic/Ascii/
  991.  
  992. P?S/8 was developed starting in 1971 from an MS/8 foundation.  It runs
  993. on minimal PDP-8 configurations, supports somewhat device independant
  994. I/O and requires a random-access device for the file system (DECtape is
  995. random-access!).  P?S/8 runs compatibly on most PDP-8 machines including
  996. DECmates, excepting only the PDP-8/S and PDP-5.  P?S/8 is still being
  997. developed!
  998.  
  999. Richard F. Lary developed a system called the Fully Upward Compatible
  1000. Keyboard Monitor; and between a Wednesday and the following Friday, a
  1001. prototype was up and running from DECtape.  The original intention of
  1002. this project was to build a programming environment for the PDP-8 that
  1003. looked like TOPS-10 on the PDP-10.  A year later, this was released as
  1004. Programming System/8 (or PS/8), and then renamed OS/8 in 1971 because
  1005. Eli Glaser (a salesman from Long Island) said he could sell more systems
  1006. with an operating system than with a programming system, and because, by
  1007. renaming the system, DEC could increase the price despite Nixon's
  1008. wage-price freeze.
  1009.  
  1010. OS/8, developed in parallel with P?S/8, became the main PDP-8 programming
  1011. environment sold by DEC.  The minimum configuration required was 8K words
  1012. and a random-access device to hold the system.  For some devices, OS/8
  1013. requires 12K.  There are a large number of OS/8 versions that are not
  1014. quite portable across various subsets of the PDP-8 family.  RX01 images of
  1015. OS/8 Version 3Q are available, with DEC's free non-commercial use licence,
  1016. from:
  1017.  
  1018.     ftp://ftp.cs.uiowa.edu/public/jones/pdp8/os8distr.txt.Z
  1019.     ftp://ftp.digital.com/pub/DEC/sim/software/os8swre.tar.Z
  1020.  
  1021. The second site above also includes an incomplete but useful RK05 image
  1022. of OS/8 Version 3R.  Parts of the OS/8 source can be found in:
  1023.  
  1024.     ftp://russ.ucs.indiana.edu/pub/DEC/PDP8/OS8/
  1025.  
  1026. OS/8 V3D was renamed OS/78 (to match the VT78), and in followups to this
  1027. distribution, support for Omnibus machines was no longer important.  OS/78
  1028. V4 was developed for the DECmate I, and the name OS/278 used for the
  1029. versions released with later DECmate machines.  These have unnecessary
  1030. incompatabilities with earlier versions of OS/8.  OS/278 and related
  1031. material is available from DECUS as catalog item 800941, or from:
  1032.  
  1033.     ftp://ftp.update.uu.se/pub/pdp8
  1034.     ftp://metalab.unc.edu/pub/academic/computer-science/history/pdp-8/os8
  1035.  
  1036. A growing collection of OS/8 documentation, including the OS/8 software
  1037. support manual on the internals of the system is available on line from:
  1038.  
  1039.     ftp://ftp.dbit.com/pub/pdp8/doc
  1040.  
  1041. OS8 (no slash) may still be viable.  It requires 8K of main memory, an
  1042. extended arithmetic unit, and DECtape hardware.  Unlike most PDP-8
  1043. operating systems, it uses a directory structure on DECtape compatible
  1044. with that used on the PDP-10.
  1045.  
  1046. The timesharing system TSS-8 was developed by Don Witcraft and John Everett
  1047. at DEC, starting in late 1967, and with the first beta sites up and running
  1048. in the fall of 1968.  This was based on a protection architecture proposed by
  1049. Adrian Van Der Goor, a grad student of Gordon Bell's at Carnegie-Mellon.
  1050. It requires a minimum of 12K words of memory and a swapping device; on a
  1051. 24K word machine, it could give good support for 17 users.  It was
  1052. the standard operating system on the EduSystem 50 which was sold to many
  1053. small colleges and large public school systems.  The first installation was
  1054. at Lexington High School in Massachusetts, and the second was at Northern
  1055. Arizona University.  Each user gets a virtual 4K PDP-8; many of the
  1056. utilities users ran on these virtual machines were only slightly modified
  1057. versions of utilities from the Disk Monitor System or paper-tape
  1058. environments.  Internally, TSS8 consists of RMON, the resident monitor, DMON,
  1059. the disk monitor (file system), and KMON, the keyboard monitor (command shell).
  1060. BASIC was well supported, while restricted (4K) versions of FORTRAN D and
  1061. Algol were available.
  1062.  
  1063. Significant parts of TSS-8 have been found, but at this time, nobody has
  1064. managed to recover a complete working system.  Much of the available TSS/8
  1065. code can be found at:
  1066.  
  1067.     http://www.spies.com/aek/12bit
  1068.  
  1069. Jim Dempsey, an alum of the OS/8 group at DEC, developed ETOS for Educomp
  1070. (later Quodata) for the PDP-8/E; this was a true virtual machine operating
  1071. system in the spirit of IBM's VM/370, and a special board was required
  1072. to optionally trap JMP and JMS instructions; this was enabled after an
  1073. emulated CIF instruction so that the actual change of instruction field
  1074. could be emulated when the JMP or JMS was attempted.  After leaving Quodata
  1075. and founding Network-Systems Design in 1976, Dempsey went on to develop
  1076. OMNI-8, first installed at Ripon College; initially it was priced at $4900,
  1077. several hundred copies were sold.  The OMNI-8 operating system supported
  1078. the enlarged PDP-8 address space of the CESI (Computer Extension Systems
  1079. Inc) memory cards, and when CESI began making PDP-8 clones, OMNI-8 was
  1080. extended to support asymmetric multiprocessors (one CPU handled the I/O).
  1081. The end of OMNI-8 development came around 1990.  Dumps of the ETOS kernel
  1082. and drivers survive in various places, and Jim Dempsey still has the full
  1083. source for OMNI-8.
  1084.  
  1085. Other timesharing systems developed for the PDP-8 include MULTI-8
  1086. and MULTOS.  The source for MULTOS is available from:
  1087.  
  1088.     ftp://ftp.update.uu.se/pub/pdp8/multos8
  1089.  
  1090. CAPS-8 was a cassette based operating system supporting PAL and BASIC.
  1091. There are OS/8 utilities to manipulate CAPS-8 cassettes, and the file
  1092. format on cassette is compatible with a PDP-11 based system called
  1093. CAPS-11.
  1094.  
  1095. RTS/8 was a real-time system developed by DEC, developed from an earlier
  1096. system, SRT8, dating back to at least 1974.  Curiously, even the last
  1097. versions of RTS/8 continued to support paper-tape and DECtape.  RTS/8 also
  1098. offered a virtual PDP-8 for background processing, unlike ETOS, this did
  1099. not require special hardware; instead, software emulation was used to retain
  1100. control of the machine between the CIF instruction and a following
  1101. JMP or JMS.  Source code for most of the versions of RTS and SRT is
  1102. available from:
  1103.  
  1104.     ftp://metalab.unc.edu/pub/academic/computer-science/history/pdp-8/rts8
  1105.  
  1106. WPS was DEC's word processing system, developed for the 8/E with a VT50
  1107. terminal with special WPS keycaps replacing the standard keycaps, and
  1108. widely used on the 1980's vintage machines.  It was heavily promoted on
  1109. the VT-78, and when the DECmates came out, DEC began to suppress knowledge
  1110. that DECmates could run anything else.  WPS-11 was a curious distributed
  1111. system using a PDP-11 as a file server for a cluster of VT-78 WPS systems.
  1112. DECmate/WPS Version 2.3 is available from DECUS for the DECmate II and
  1113. DECmate III under the catalog entry DM0114.
  1114.  
  1115. COS-310, DEC's commercial operating system for the PDP-8, supported the
  1116. DIBOL language.  COS-310 was a derivative of MS/8 and OS/8, but with a
  1117. new text file format.  The file system is almost the same as OS/8, but
  1118. dates are recorded differently, and a few applications can even run under
  1119. both COS and OS/8.  COS was the last operating system other than WPS
  1120. promoted by DEC for the DECmates.
  1121.  
  1122. SCPSYS, developed by D. C. Amoss prior to 1974 at Clemson University, is
  1123. a system that copies most of the features of LAP (the LINC Assembly
  1124. Program) for a pure PDP-8 based system.  A DECtape of this system has
  1125. recently come to light, with one known application, Spacewar.
  1126.  
  1127. AMOS, an operating system for the PDP-8/E with TD8E DECtape interface,
  1128. was a very small system developed in Australia or New Zealand and supporting
  1129. assembly and text editing on a 4K machine.
  1130.  
  1131. ------------------------------
  1132.  
  1133. Subject: What programming languages are supported on the PDP-8
  1134.  
  1135. The PAL family of assembly languages, particularly PAL III and PAL8 are
  1136. as close to a standard assembly language as can be found for the PDP-8;
  1137. these are included with all OS/8 distributions.  They produce absolute
  1138. object code and there are versions of PAL for minimally configured
  1139. machines, although these have severe symbol table limitations.  Cross
  1140. assemblers that are somewhat compatable with PAL can be obtained from:
  1141.  
  1142.     ftp://ftp.cs.uiowa.edu/public/jones/pdp8/pal.c.Z
  1143.     ftp://ftp.cs.uiowa.edu/public/jones/pdp8/palbart.c.Z
  1144.     ftp://metalab.unc.edu/pub/academic/computer-science/history/pdp-8/emulators/gray
  1145.  
  1146. MACRO-8 was DEC's first macro assembly language for the PDP-8, but it
  1147. was rarely used outside the paper-tape environment.  MACREL and SABR are
  1148. assembly languages that produce relocatable output.  SABR is the final
  1149. pass for the ALICS II FORTRAN compiler (developed by ICS); it is included
  1150. with the standard OS/8 software distributions.  Source for these is
  1151. available from:
  1152.  
  1153.     ftp://russ.ucs.indiana.edu/pub/DEC/PDP8/PS8/FortranSabr/Ascii/
  1154.  
  1155. MACREL was developed in (unfulfilled) anticipation of similar use.  MACREL
  1156. was heavily used by the DECmate group at DEC.  MACREL is available from:
  1157.  
  1158.     ftp://ftp.update.uu.se/pub/pdp8/os8
  1159.  
  1160. RALF, the relocatable assembler supporting RTPS FORTRAN is also included
  1161. in OS/8 standard distributions.  FLAP, an absolute assembler, was derived
  1162. from RALF.  Both SABR and RALF/FALP are assemblers that handle their
  1163. intended applications but have quirky and incompatible syntax.
  1164.  
  1165. A subset of FORTRAN was supported on both the PDP-5 and the original
  1166. PDP-8.  Surviving documentation describes a DEC compiler written in 1964
  1167. by Larry Portner, nicknamed "Fivetran", and a compiler written by
  1168. Information Control Systems from 1968.  The latter, ALICS II FORTRAN,
  1169. was originally a paper tape based compiler, but it forms the basis of
  1170. the OS/8 8K FORTRAN compiler, and was also adapted to the Disk Monitor
  1171. System (the latter version had overlay support that was never carried
  1172. forward into more modern systems).
  1173.  
  1174. RTPS FORTRAN required 8K and a floating point processor; it had real-time
  1175. extensions and was a full implementation of FORTRAN IV (also known as
  1176. ANSI FORTRAN 66).  OS/8 F4 is RTPS FORTRAN stripped of the requirement
  1177. for hardware floating point (if the hardware is missing, it uses
  1178. software emulation).  Versions of FORTRAN is available from
  1179.  
  1180.     ftp://ftp.update.uu.se/pub/pdp8/os8
  1181.  
  1182. FOCAL, an interpretive language comparable to BASIC, was available on
  1183. all models of the family, including the PDP-5 and PDP-8/S.  Versions of
  1184. FOCAL run under OS/8, P?S/8 and other systems, and there were many special
  1185. purpose overlays for FOCAL developed by DEC and by various users.  DEC's
  1186. later FOCAL releases for the PDP-8 included code to deliberately introduce
  1187. subtle bugs when run on a DCC 112 computer!  Various versions of FOCAL
  1188. are available from:
  1189.  
  1190.     ftp://russ.ucs.indiana.edu/pub/DEC/PDP8/Langs/Focal/
  1191.     ftp://ftp.cs.uiowa.edu/public/jones/pdp8/coreimages.txt.Z
  1192.  
  1193. Many versions of BASIC were also available, from DEC and other sources.
  1194. DEC BASIC was widely used on PDP-8 systems sold under the EduSystem
  1195. marketing program.  A paper-tape version was available that ran in 4K
  1196. and was compatible with disk based systems, versions distributed with
  1197. OS/8 and TSS-8, an 8K stand-alone time-sharing version was available,
  1198. and there were others.  EduSystem 25 Basic is available from:
  1199.  
  1200.     ftp://russ.ucs.indiana.edu/pub/DEC/PDP8/Langs/Edu25Basic/
  1201.  
  1202. The source code for TSS-8 Basic is available from
  1203.  
  1204.     http://www.spies.com/aek/12bit
  1205.  
  1206. DIBOL was DEC's attempt at competing with COBOL in the commercial arena.
  1207. It was originally implemented under MS/8 but most versions were sold to
  1208. run under the COS operating system.
  1209.  
  1210. Algol was available from a fairly early date.  One version is available
  1211. from:
  1212.  
  1213.     ftp://russ.ucs.indiana.edu/pub/DEC/PDP8/Langs/Algol/Ascii/
  1214.  
  1215. At least two Pascal compilers were developed for the PDP-8.  One was a
  1216. Pascal-S interpreter, written in assembler, the other was a Pascal-P
  1217. compiler with a P-code interpreter written in assembler.
  1218. A Pascal S interpreter, requiring a 28K PDP-8/E configuration, is available
  1219. from:
  1220.  
  1221.     ftp://russ.ucs.indiana.edu/pub/DEC/PDP8/Langs/Pascal/Ascii
  1222.  
  1223. Another OS/8 Pascal system, the source code for which was rescued by
  1224. Larwrence LeMay, is available from:
  1225.  
  1226.     ftp://ftp.dbit.com/pub/pdp8/pascal
  1227.  
  1228. A LISP interpreters was written for the PDP-8; the original version
  1229. ran in 4K (originally written in Germany?); a disassembled and commented
  1230. version of this was the basis of expanded versions that eventually
  1231. could utilize up to 16K.  One version of LISP is available from:
  1232.  
  1233.     ftp://russ.ucs.indiana.edu/pub/DEC/PDP8/Langs/Lisp/Ascii/
  1234.  
  1235. POLY SNOBOL was a version of SNOBOL that was somewhere between
  1236. Griswold's definitions of SNOBOL 3 and SNOBOL 4.
  1237.  
  1238. TECO, the text editor, was included in the standard OS/8 distributions and
  1239. is a general purpose language (the Emacs editor began as a set of TECO
  1240. macros!).  The story of TECO on the PDP-8 is convoluted.  Russ Hamm
  1241. implemented TECO under his OS8 (without a slash) system, and then gave
  1242. a listing to Don Baccus at the Oregon Museum of Science and Industry
  1243. (OMSI) who, along with Barry Smith ported it to PS/8.  This was the
  1244. beginning of what became Oregon Software, later famous for OMSI Pascal.
  1245.  
  1246. Richard F. Lary and Stan Rabinowitz made OS/8 TECO more compatible with
  1247. other versions of TECO, and the result of this work is the version
  1248. distributed by DECUS (catalog number 110450 is the manual).  RT-11 TECO
  1249. for the PDP-11 is a port of this code.
  1250.  
  1251. DECUS also lists the PAGE8 language (catalog numbers 800936), the VISTA
  1252. editor (catalog number 800938), and the ICE text editor (catalog number
  1253. 800939).
  1254.  
  1255. ------------------------------
  1256.  
  1257. Subject: Where can I get PDP-8 software?
  1258.  
  1259. DEC is still making computers, but they've largely forgotten about the
  1260. PDP-8.  The main DEC WWW server is
  1261.  
  1262.     http://www.digital.com/
  1263.  
  1264. DECUS, the DEC User Society, is still alive and well, and their submission
  1265. form still lists PAL8 and FOCAL as languages in which they accept
  1266. submissions!  The DECUS library catalog is available on-line at
  1267. decus.org; www access is through gopher.decus.org or
  1268.  
  1269.     http://www.decus.org/
  1270.  
  1271. To quote the README file from the DECUS on-line catalog, "Items from
  1272. older DECUS Library catalogs are still also available (provided their
  1273. media can still be read), but machine readable catalog information is
  1274. not available for these."  Direct questions by E-mail to
  1275. INFORMATION@DECUS.ORG.
  1276.  
  1277. Bob Supnik at DEC has rescued OS/8 from oblivion within DEC and has
  1278. managed to get DEC to grant a non-commercial free-use licence for OS/8
  1279. to all who wish to use it.  In addition, he has released a demonstration
  1280. version of OS/8 for his PDP-8 emulator, available with a copy of the
  1281. free-use licence from:
  1282.  
  1283.     ftp://ftp.digital.com/pub/DEC/sim/software/os8swre.tar.Z
  1284.  
  1285. The following anonymous FTP sites also contain publically accessable
  1286. archives of PDP-8 software and other information:
  1287.  
  1288.     ftp://ftp.update.uu.se/pub/pdp8
  1289.     ftp://russ.ucs.indiana.edu/pub/DEC/PDP8/
  1290.     ftp://ftp.cs.uiowa.edu/pub/jones/pdp8
  1291.     ftp://metalab.unc.edu/pub/academic/computer-science/history/pdp-8
  1292.  
  1293. The latter archive also maintains an archive of traffic in alt.sys.pdp8
  1294. in the directory ...pdp8/usenet and an archive of traffic in the
  1295. pdp8-lovers mailing list in .../pdp8/pdp8-lovers.
  1296.  
  1297. The archive at Indiana contains source code for many PDP-8 compilers and
  1298. interpreters, as well as common utilities and games.
  1299.  
  1300. ------------------------------
  1301.  
  1302. Subject: Where can I get additional information?
  1303.  
  1304. The companion faq on PDP-8 models and options contains a detailed production
  1305. history of the PDP-8 as well as a high level description of incompatabilities
  1306. between models.  This is available from:
  1307.  
  1308.     http://www.faqs.org/faqs/dec-faq/
  1309.     http://www.cs.ruu.nl/wais/html/na-dir/dec-faq/.html
  1310.  
  1311. A modest attempt at an on-line PDP-8 manual is available from:
  1312.  
  1313.     http://www.cs.uiowa.edu/~jones/pdp8/man/
  1314.  
  1315. The mailing list PDP8-Lovers@dbit.com reaches a number of PDP-8
  1316. owners and users.  This list does not accept postings from
  1317. nonsubscribers; to subscribe, send mail to PDP8-Lovers-request@dbit.com
  1318.  
  1319. The pdp8-lovers mailing list has previously been hosted by onelist.com,
  1320. mc.lcs.mit.edu, ai.mit.edu, zach1.tiac.net, egroups.com and yahoo.com.
  1321. The archives for these older lists should be available on dbit.com, but
  1322. currently, the best archive is at ftp://zach.dyndns.org/pub/pdp8-lovers.
  1323.  
  1324. Many "archival" books have included fairly complete descriptions of the
  1325. PDP-8; among them, "Computer Architecture, Readings and Examples" by
  1326. Gordon Bell and Allen Newell is among the most accurate and complete,
  1327. although notationally difficult (see Chapter 5).  Gordon Bell has put
  1328. this on the web at:
  1329.  
  1330.     http://research.microsoft.com/~gbell/Computer_Structures__Readings_and_Examples/
  1331.  
  1332. ------------------------------
  1333.  
  1334. Subject: What use is a PDP-8 today?
  1335.  
  1336. What use is a Model T today?  Collectors of both come in the same basic
  1337. classes.  First, there are antiquarians who keep an old one in the
  1338. garage, polished and restored to new condition but hardly ever used.
  1339. Once a year, they warm it up and use it, just to prove that it still
  1340. works, but they don't make much practical use of it.
  1341.  
  1342. PDP-8 systems maintained by antiquarians are frequently in beautiful
  1343. shape.  Antiquarians worry about dust, chipped paint, and missing
  1344. switches, and they establish newsgroups and mailing lists to help them
  1345. locate parts and the advice needed to fix their machines.
  1346.  
  1347. In the second class are those who find old machines and soup them up,
  1348. replacing major parts to make a hotrod that only looks like the original
  1349. from the outside, or keeping the old mechanism and putting it to uses
  1350. that were never intended.  Some PDP-8 owners, for example, have built
  1351. PDP-8 systems with modern SCSI disk interfaces!  There is serious
  1352. interest in some quarters in constructing an omnibus board that would
  1353. support an IDE disk of the variety that was mass-produced for the
  1354. IBM PC/AT.
  1355.  
  1356. Last, there are the old folks who still use their old machines for their
  1357. intended purposes long after any sane economic analysis would recommend
  1358. such use.  If it ain't broke, don't fix it, and if it can be fixed,
  1359. why bother replacing it?  Both Model T Fords and the classic PDP-8
  1360. machines are simple enough that end users can maintain and repair them
  1361. indefinitely.  All you need to keep a vintage -8 running are a stock
  1362. of inexpensive silicon diodes and a stock of 2N3639B or better,
  1363. 2N3640 transistors.
  1364.  
  1365. Unlike most modern personal computers, PDP-8 systems were routinely sold
  1366. with complete maintenance manuals; these included schematic diagrams,
  1367. explanations of not only how to use the devices, but how they are built,
  1368. and suggestions to those considering building their own peripherals.
  1369. Compared with many so-called "open systems" of today, the PDP-8 was far
  1370. better documented and far more open.
  1371.  
  1372. Preservation of the PDP-8 has proven to be of immense practical value
  1373. in defending against the rising tide of patents in the area of
  1374. interactive graphics.  For example, when Sanders Associates sued the
  1375. Odyssey division of Magnavox, the key testimony in this suit was Steve
  1376. Russell's Spacewar, originally written for the PDP-1 in the fall of 1961.
  1377. The fact that documented versions of Spacewar and other computer games
  1378. dating back to the early 1960's could still be run on a surviving LINC-8
  1379. apparently played an important part in arriving at an out-of-court
  1380. settlement that ended, for practical purposes, the Sanders claim to
  1381. the technology behind all video games.  It is far easier to prove that
  1382. some software technology existed by demonstrating it on original hardware
  1383. than by waving a dusty listing in front of someone's face!
  1384.  
  1385. Finally, the PDP-8 is such a minimal machine that it is an excellent
  1386. introduction to how computers really work.  Over the years, many students
  1387. have built complete working PDP-8 systems from scratch as lab projects,
  1388. and the I/O environment on a PDP-8 is simple enough that it is a very
  1389. appropriate environment for learning operating system programming
  1390. techniques.
  1391.  
  1392. ------------------------------
  1393.  
  1394. Subject: Who's Who?
  1395.  
  1396. You can't beat the book Digital at Work (Digital Press, 1992) for short
  1397. writeups on the people inside DEC who made the PDP-8!
  1398.  
  1399. C. Gordon Bell is generally credited with the original design of the
  1400. PDP-8 (as well as designing the PDP-4, 5 and 6).  He was also involved
  1401. with recommending what became the PDP-11 when that design was competing
  1402. with the design that probably became the NOVA, and as vice president of
  1403. research, he oversaw the development of the DEC VAX family.
  1404.  
  1405. Alan Kotok worked with Bell in working up the original specifications
  1406. of the PDP-8.
  1407.  
  1408. Edson DeCastro was a key man in the design of the PDP-5 through the
  1409. PDP-8/L, then founded Data General to build the Nova.
  1410.  
  1411. Ben Gurley designed the early DEC machines, starting with the
  1412. PDP-1.  The actual design work on the -8, however, was done by Ed
  1413. deCastro, who later founded Data General to build the Nova.
  1414.  
  1415. Warren K. Smith was manager of applications engineering for Flip-Chip
  1416. modules between 1969 and 1975.  Much of the M-series TTL module family
  1417. dates from this period.
  1418.  
  1419. Saul B. Dinman, product line manager for the module product line from
  1420. 1966 to 1969 designed the PDP-8/S and built the engineering prototype,
  1421. largely in his spare time.  Most of his time was devoted to the K-series
  1422. of industrial automation modules.  Later, he founded GRI Computer Corp,
  1423. where he designed the GRI 909 16-bit minicomputer.
  1424.  
  1425. Ken Olson ran DEC from the beginning.
  1426.  
  1427. Jozsef Lukacs and Janos Bogdany designed the Hungarian TPA1001
  1428. implementation of the PDP-8 instruction set, and Laszlo Szonyi and
  1429. Pal Karadi designed the TPA/i.
  1430.  
  1431. Ed Yourdon, who later became well known as a programming methodology
  1432. guru, helped hack up the PAL III assembler for the -8 from PAL II.
  1433.  
  1434. Richard Merrill invented FOCAL and wrote the original (1968) and classic
  1435. FOCAL-69 interpreters for the PDP-8.  He also did early translations of
  1436. the interpreter to PDP-7/PDP-9 code and perhaps the earliest PDP-11
  1437. version.  In addition, he wrote the EDIT-8 paper-tape based text editor
  1438. based on the FOCAL built-in text editor.
  1439.  
  1440. Richard F. Lary developed the RL Monitor System, and then went on to
  1441. develop OS/8, with help from Ed Friedman and another programmer named
  1442. Paul, under the management of Chuck Conley.
  1443.  
  1444. Charles Lasner developed P?S/8, and he is widely known as a leader in
  1445. the movement to preserve these historic machines.  He created the
  1446. alt.sys.pdp8 newsgroup.
  1447.  
  1448. George Thissell oversaw the development of OS/8 FORTRAN-IV, with Denny
  1449. Pavlock as part of the team.
  1450.  
  1451. Wesley Clark developed the LINC while working at Lincoln Labs; this was
  1452. the first 12 bit minicomputer built with DEC parts.
  1453.  
  1454. Mary Allen Wilkes Clark developed the early LAP programs for the LINC.
  1455.  
  1456. Don Witcraft wrote the TSS-8 scheduler, command decoder and UUO
  1457. handler, after working on the first swapping monitor for the PDP-10.
  1458. John Everett wrote the disk handler, file system, TTY handler
  1459. and  680-I service routine for TSS-8, after working on the Disk Monitor
  1460. System and PAL-D, the first disk-based version of PAL.
  1461.  
  1462. Roger Pyle and John Everett wrote the PDP-8 Disk Monitor System, and
  1463. John Everett adapted PAL-III to make PAL-D for DMS.  Bob Bowering, author
  1464. of MACRO for the -6 and -10, wrote an expanded version, PAL-X, for TSS-8.
  1465.  
  1466. Jimmy Dykes was the program manager for Harris in the contract development
  1467. of the Harris 6120 microprocessor; he later moved to GE Semiconductor.
  1468. Robert M. Smith was involved in the DEC side of this joint venture, after
  1469. having designed a number of OMNIBUS interfaces during the 1970's.
  1470.  
  1471. Douglas W. Jones wrote this FAQ, but prior to the summer of 1992, he'd
  1472. never used a PDP-8.  He has also written a report on how to photocopy
  1473. and archivally bind ailing paperback books such as DEC's handouts, a
  1474. PAL-like cross assembler in C, and a UNIX-based PDP-8 emulator.
  1475.  
  1476. ------------------------------
  1477.  
  1478. End of PDP-8 Frequently Asked Questions (posted every other month)
  1479. ******************************************************************
  1480.