This is a text-only version of the following page on https://raymii.org:
---
Title       :   Running Adventure on the DEC PDP-8 with SIMH
Author      :   Remy van Elst
Date        :   23-07-2015
URL         :   https://raymii.org/s/articles/Running_ADVENT-on-the-PDP-8-with-SIMH.html
Format      :   Markdown/HTML
---



[![pdp-8][1]][1]

 * An original PDP-8/i.

In this guide I'll show you how run the classic Colossal Cave Adventure game on
a PDP-8, emulated by the SIMH emulator. The PDP-8 was an 12 bit minicomputer
made in 1964 by DEC, the Digital Equipment Corporation. We will install and set
up SIMH, the emulator with a RK05 diskimage running OS/8. We will use FORTRAN on
OS/8 to load ADVENTURE, then we use our brain to play the game. As a bonus, I
also show you how to edit files using EDIT, and show you a bit of the OS/8
system.

<p class="ad"> <b>Recently I removed all Google Ads from this site due to their invasive tracking, as well as Google Analytics. Please, if you found this content useful, consider a small donation using any of the options below:</b><br><br> <a href="https://leafnode.nl">I'm developing an open source monitoring app called  Leaf Node Monitoring, for windows, linux & android. Go check it out!</a><br><br> <a href="https://github.com/sponsors/RaymiiOrg/">Consider sponsoring me on Github. It means the world to me if you show your appreciation and you'll help pay the server costs.</a><br><br> <a href="https://www.digitalocean.com/?refcode=7435ae6b8212">You can also sponsor me by getting a Digital Ocean VPS. With this referral link you'll get $100 credit for 60 days. </a><br><br> </p>


### Introduction

I've recently accuired a PDP-8 remake, the [PiDP-8/i by Oscar Vermeulen][3].
This beautiful piece of hand made hardware uses a Raspberry Pi to emulate a
PDP-8 with SIMH. The front panel actually works, you can use the switched to
load paper tapes, the RIM and BIN loader and all the other legacy goodness. It
is a bit smaller than a real PDP-8, it is scale 2:3. The real PDP-8 has 1.5 cm
switched, the PiDP-8 has 1.0 cm switches.

I have an interest in legacy systems like the PDP-11, VAX/VMS and other
mainframes and minicomputers. The PiDP-8/i allows me to have a small piece of
this legacy myself. It also motivated me to learn more about the PDP-8 and it's
hard and software. It also inspired me to write this article about it. Since
these systems are way older than me, emulation and recreation are the only way
for me to use them, sadly.

I really encourage you to check out the PiDP-8. Order one as well, you can
either get a kit to construct yourself, or order an assembled version. Support
this beautiful piece of work!

[![pidp-8][4]][4]

 * The [PiDP-8/i remake by Oscar Vermeulen][3].

SIMH is an emulator which not only emulates a PDP-8, but a lot more older
mainframes and minicomputers. See the [website][5] for more information about
SIMH.

This guide shows you how to run the classic Colossal Cave ADVENTURE game on an
emulated PDP-8 with SIMH. We will use Ubuntu 14.04 as our host operating system,
but any OS that runs SIMH will do.

[If you like this article, consider sponsoring me by trying out a Digital Ocean
VPS. With this link you'll get a $5 VPS for 2 months free (as in, you get $10
credit). (referral link)][2]

Colossal Cave was written by Willie Crowther and quickly became one of the most
popular games of that time. Because it was written in FORTRAN it was ported to
various machines, even to the IBM-PC and the Apple II.

The PDP-8 can run plain paper tapes with software, but later in it's lifetime it
got access to magnetic disks and therefore is able to run actual operating
systems. The ADVENTURE game runs, via FORTRAN, on the OS/8 operating system for
the PDP-8. Wikipedia has more information on [OS/8][6], that is a very
interesting read.

[![pdp-11][7]][7]

 * An original PDP-8/i with attached periferals.

We will use a disk image graciously provided by Rick Murphy with both OS/8 and
the adventure program already compiled in it. You can download it from [Rick
Murphy's website][8] [(direct link to the rk5)][9] or from [here][10]. This is a
disk image in the [RK05 DECpak][11] disk format. The RK05 is a moving head
magnetic disk drive approximately 2.5 MB on a 14", single-platter IBM-2315-style
front-loading removable disk cartridge.

[![RK05][12]][12]

 * An original RK05 drive with a mounted RT-11 disk pack.

### Installing and configuring SIMH

First create a folder where you will store the disk image and the configuration
files, and go in that folder:



   mkdir pdp8
   cd pdp8


Ubuntu, and many other operating systems, have packages available for SIMH. We
can use the built in package manager to install simh:



   apt-get install simh


If your distro doesn't have simh, see their website for installation
instructions.

Download the prepared disk image:



   wget https://raymii.org/s/inc/downloads/pdp/advent.rk05


To make the start up proces easier you can set up an 'pdp8.ini' file with a few
commands in it. SIMH will load and run these commands at startup if you execute
the `pdp8` command.

Our `pdp8.ini` file has the following in it:



   set cpu 32K
   set cpu idle
   attach rk0 advent.rk05
   boot rk0
   exit


First it sets up the CPU. Then it attached the `advent.rk05` file as the first
disk and finally it boots up from that attached disk.

Do note that you don't need to create this file, you can also enter these
commands manually at the simh prompt.

### Running the PDP-8

In the current folder, execute the following command to start up simh with our
configuration file:



   pdp8


If all goes well, you should see something like below:



   $ pdp8

   PDP-8 simulator V3.8-1

   .


Some distributions, like Arch name the command `simh-pdp8`. It does the same
thing.

Congratiulations, you are now in a 1960's era operating system. Look around a
bit, for example, execute the `DIR` command:



   .DIR

   DIRECT.SV   7            FRTS  .SV  26            BASIC .WS  11
   PIP   .SV  11            PASS2 .SV  20            SET   .SV  20
   FOTP  .SV   8            PASS2O.SV   5            RTFLOP.SV  15
   [...]
   BRTS  .SV  15            LCSYS .BI   3            ADVENT.LD 145
   F4    .SV  20            UCSYS .BI   3            LOAD  .LS   8

    162 FILES IN 2648 BLOCKS -  544 FREE BLOCKS


You can get help at any moment using the `HELP` command:



   .HELP
   <[?3L[?4L[?5L[?5LHJ\
   OS/8 MONITOR COMMANDS

   CMD     PROG    EXPL

   ASSIGN  KBM     ASSIGNS LOGICAL NAME
   BACKSP  CAMP    BACKSPACES DEV
   BASIC   BASIC   ENTERS BASIC SYSTEM
   BOOT    BOOT    BOOTSTRAPS TO DEV
   CCL     CCL     DISABLES CCL
   COMPARE SRCCOM  COMPARES FILES
   COMPILE PAL8    COMPILES PROG
       F4/FORT
       BASIC
       RALF
       SABR
   COPY    FOTP     COPIES FILES
   CREATE  EDIT     OPENS FILE FOR EDITING
   [...]
   #NNN    TAKE INTERNAL OCTAL FORM OF FILENAME
   @FILE   REPLACE IN CMD LINE BY FILE'S CONTENTS
   $       COMPLEMENT DEFAULT ALTMODE SWITCH


### Editing files on OS/8 with EDIT

If you just want to run adventure, skip this section.

You can edit a file for example, using a LINE EDITOR. First create the file, in
this example, `A.PA`.



   .CREATE A.PA

   #


You can edit files with the `EDIT` command later on.

Your prompt changes from a `.` to a `#`. If this is an existing file, you must
read the first page into the buffer by typing



   #R


To insert text at the top of the buffer, use `I`. To append to the end, use `A`.



   #I
   THIS IS A TEST


Press `CTRL+L` to exit the edit prompt.

You can start inserting before any line by typing `$nI` where `$n` is the line
number (which is never displayed). For example, to insert a line before line 20,
use `20I`.

The `L` command lists the current buffer:



   #L
   THIS IS A TEST


`5L` displays line 5 and `1,5L` displays lines 1 through 5. `.` indicates the
current line. If you type `.L` the current line is displayed.

To delete a line, use `$nD` where `$n` is `.` or a line number. To change a line
use `$nC` where `$n` is `.` or a line number. It deletes the line indicated by
`$n`, then waits for you to type in a replacement.

As said, EDIT reads a page from disk into the buffer. When you are done with
that page and ready to move to the next type `N`. This writes the existing page
to the output file (`P` command), clears the buffer (`K` command), and reads the
next page from the input file (`R` command). You can use the `P`, `K`, and `R`
commands individually, but be careful. Doing these commands out of sequence can
mess up your file.

When you are done editing, use the `E` command to exit. This will write the
current buffer to the output file, then copy all remaining pages from the input
to the output file if you aren't already on the last page.



   #E


You can use the `TYPE` command to see the contents of a file:



   .TYPE A.PA
   THIS IS A TEST


See [this page][13] for a detailed guide on using PDP-8 EDIT.

### Running Adventure

To run Adventure we first need to run the FORTRAN environment. Start it up with
the following command `R FRTS`:



   .R FRTS
   *


Your prompt changes to a `*`. The `HELP` command explains what the `R` command
does:



   R   KBM   RUNS PROGRAM FROM SYS:


Tell the FORTRAN system we want to load Adventure with the following command,
`ADVENT.LD`:



   *ADVENT.LD


Press the ESCAPE key on your keyboard to start the execution. Below you'll find
the full sequence of commands plus some ADVENTURE output:



   $ pdp8

   PDP-8 simulator V3.8-1

   .R FRTS
   *ADVENT
   *$
   WELCOME TO ADVENTURE!!  WOULD YOU LIKE INSTRUCTIONS?

   > NO
   YOU ARE STANDING AT THE END OF A ROAD BEFORE A SMALL BRICK BUILDING.
   AROUND YOU IS A FOREST.  A SMALL STREAM FLOWS OUT OF THE BUILDING AND
   DOWN A GULLY.

   > ENTER
   YOU ARE INSIDE A BUILDING, A WELL HOUSE FOR A LARGE SPRING.

   THERE ARE SOME KEYS ON THE GROUND HERE.

   THERE IS A SHINY BRASS LAMP NEARBY.

   THERE IS FOOD HERE.

   THERE IS A BOTTLE OF WATER HERE.

   > TAKE LAMP
   TAKEN.

   >


To exit SIMH and the PDP-8, press `CTRL+E`. SIMH will stop and you will be back
at your command prompt.

You can view some more help on the PDP-8 SIMH version by executing (in OS/8) the
following command:



   .TYPE ADVENT.DC


Enjoy!

  [1]: https://raymii.org/s/inc/img/pdp-8-i.jpg
  [2]: https://www.digitalocean.com/?refcode=7435ae6b8212
  [3]: http://obsolescence.wix.com/obsolescence#!pidp-8/cbie
  [4]: https://raymii.org/s/inc/img/pidp-8-i.jpg
  [5]: http://simh.trailing-edge.com/
  [6]: https://en.wikipedia.org/wiki/OS/8
  [7]: https://raymii.org/s/inc/img/pdp-8-i-big.jpg
  [8]: http://www.rickmurphy.net/adventure.html
  [9]: http://www.rickmurphy.net/advent/advent.rk05
  [10]: https://raymii.org/s/inc/downloads/pdp/advent.rk05
  [11]: https://en.wikipedia.org/wiki/RK05
  [12]: https://raymii.org/s/inc/img/RK05.jpg
  [13]: https://bigdanzblog.wordpress.com/2014/05/23/editing-files-on-a-pdp-8-using-os8-edit/

---

License:
All the text on this website is free as in freedom unless stated otherwise.
This means you can use it in any way you want, you can copy it, change it
the way you like and republish it, as long as you release the (modified)
content under the same license to give others the same freedoms you've got
and place my name and a link to this site with the article as source.

This site uses Google Analytics for statistics and Google Adwords for
advertisements. You are tracked and Google knows everything about you.
Use an adblocker like ublock-origin if you don't want it.

All the code on this website is licensed under the GNU GPL v3 license
unless already licensed under a license which does not allows this form
of licensing or if another license is stated on that page / in that software:

   This program is free software: you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation, either version 3 of the License, or
   (at your option) any later version.

   This program is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.

   You should have received a copy of the GNU General Public License
   along with this program.  If not, see <http://www.gnu.org/licenses/>.

Just to be clear, the information on this website is for meant for educational
purposes and you use it at your own risk. I do not take responsibility if you
screw something up. Use common sense, do not 'rm -rf /' as root for example.
If you have any questions then do not hesitate to contact me.

See https://raymii.org/s/static/About.html for details.