Skip to content

Ansible-based bootstrap environment for old UNIXes

License

Notifications You must be signed in to change notification settings

jupo42/booterizer

 
 

Repository files navigation

booterizer

booterizer is designed to quickly configure a Raspberry Pi or a disposable VM to boot a specific version of the SGI IRIX installer over the network on an SGI machine without a whole lot of fuss.

Table of Contents

TL;DR: Use a Raspberry Pi

The new Raspberry Pi version of Booterizer consists of pre-built images that you can write to a SD card. This is a significantly easier and faster method than using Vagrant.

Follow the Raspberry Pi instructions.

Overview

Supported IRIX Versions

booterizer was designed for IRIX 6.5.30, the last version of IRIX for SGI. Use this as your first choice. booterizer also fully supports IRIX 6.5.22 for older SGI systems that can run 6.5. Use this for Indys and Challenge L servers. booterizer even works with IRIX 5.3 for classic SGI systems that cannot run 6.5.x (See Callahan's Booterizer 5.3)

booterizer is not secure and may interfere with other network services (e.g. DHCP) so please don't leave it running long-term. I recommend only attaching the network interface to an isolated network for this purpose and then vagrant halt or vagrant destroy the VM when you are done installing.

The booterizer VM provides the following services:

  • BOOTP server (via isc-dhcp)
  • TFTP server (via tftpd-hpa)
  • RSH server (via rsh-server)

NOTE: This fork no longer supports CD images. It may again in the future, if there is demand. If you must extract from CD media, see the original project at https://github.com/halfmanhalftaco/irixboot. This version will obtain the contents of the CD-ROMs for you automatically.

Target SGI Systems

I am not sure what range of IRIX versions this will work with or what SGI machines are compatible. Personal testing and user reports show the following (at minimum) should be compatible:

SGI System CPU IRIX System Fx Verified by
Fuel all 6.5.30 fx.64 unxmaal
Octane1 all 6.5.30 fx.64 diller
Octane2 all 6.5.30 fx.64 unxmaal
Challenge L R10k 6.5.22 fx.ARCS dillera
O2 R4k 6.5.30 fx.ARCS dillera
O2 R10k 6.5.30 fx.64 dillera
Origin 2100 R12k 6.5.30 fx.64 dillera
Indy R4600PC 6.5.22 fx.ARCS PeteT
Indigo2 R10k 6.5.22 fx.ARCS dillera
Onyx2 R12k 6.5.30 fx.64 chrsmeca

I suspect that most other hardware and OS versions released in those timeframes will also work SGI obviously kept the netboot/install process pretty consistent so I'd expect it to work on probably any MIPS-based SGI system.

Where to get help

NEW: Raspberry Pi SD Card Image

Requirements

  • Raspberry Pi 4 (This is what I have. Let me know if others work.)
  • 16GB+ SD card
  • Booterizer Pi Image
  • Extraction software that supports xz

Pi Image Usage Instructions

  • Extract the compressed image
  • Write it to a 16GB+ SD card using Etcher or something
  • Connect your SGI system via ethernet to your Pi
  • Boot your Pi
  • Log in with default, pi/raspberry
sudo -i
cd /root/projects/github/booterizer
  • Configure WiFi networking and connect to your network (use raspi-config)
  • Modify settings.yml for ONLY these values:
    • irixversion = 6.5.30, 6.5.22, etc
    • clientname = your SGI's hostname
    • clientether = your SGI's MAC address
cd ansible/
ansible-playbook -i inventory.yml rpi_booterizer.yml
reboot
  • Skip down to the "Booting" section below
  • You can find available partitioners and media by running /irix/display_results.sh

Pi Image Build Instructions

If you don't have precisely the same hardware as I used to create the image it may not work properly for you.

In this case, you can install Booterizer on whatever Pi you might have.

apt update ; apt install -y python3-pip sshpass wget curl git
mkdir -p /root/projects/github
cd /root/projects/github
git clone https://github.com/unxmaal/booterizer.git
cd /root/projects/github/booterizer
  • Modify settings.yml
    • to connect to your network
    • to install 6.5.22
      • Note: we're creating an image that has both 6.5.30 and 6.5.22. Adjust as desired.
cd ansible
pip3 install -r requirements.tx
reboot
  • Log into the Pi and become root
cd /root/projects/github/booterizer/ansible
ansible-playbook -i inventory.yml rpi_booterizer.yml
  • When this completes, modify settings.yml to install 6.5.30
  • Run ansible-playbook again
ansible-playbook -i inventory.yml rpi_booterizer.yml
  • NOTE: If you've connected your Pi to WiFi, clear your networking info from /etc/wpa_supplicant/wpa_supplicant.conf
apt-get clean -y ; apt-get autoclean -y
dd if=/dev/zero of=/EMPTY bs=1M ;rm -f /EMPTY
halt -p
  • Use Apple-Pi Baker to copy the SD card image to a file

Vagrant VM

Requirements

  • VirtualBox
  • Vagrant 2.2.3 or higher
    • vagrant plugin install vagrant-guest_ansible
  • Ansible/Python 2.7.6 or higher
  • VM host with TWO network interfaces
    • I very much recommend using a host with two built-in interfaces, such as one WiFi and one Ethernet

Installation of Prerequisite software for macOS (Host)

  • macOS has Brew - which can install Vagrant and VirtualBox for you from the command line with one command.
  • Install Brew following directions at their website here: https://brew.sh/
  • If you have brew installed you can install Vagrant, VB, and Ansible (Which will also install Python as a dependency):
brew cask install vagrant
brew cask install virtualbox
brew install ansible
  • If you already have Python installed outside of Brew, instead of installing Ansible through Brew, install it through pip:
sudo pip install ansible

Installation of Prerequisite software for Ubuntu (Host)

  • Installing recent Vagrant must be done manually on Ubuntu Bionic/18.04 and older. Just using apt-get will install an older version we don't want to use. The procedure below will validate the package using its checksum.
  • We need to install VirtualBox (to run the virtual Linux server for the SGI installation media)
  • We need to install Vagrant to configure and kick of provisioning of the new VM
  • We need to install Ansible to provision the new VM
sudo apt-get install virtualbox

# Vagrant - Ubuntu 20.04 (Focal) and newer
sudo apt-get install vagrant

# Vagrant - Ubuntu 18.04 (Bionic) and older
wget -c https://releases.hashicorp.com/vagrant/2.2.3/vagrant_2.2.3_x86_64.deb
wget -c https://releases.hashicorp.com/vagrant/2.2.3/vagrant_2.2.3_SHA256SUMS
wget -c https://releases.hashicorp.com/vagrant/2.2.3/vagrant_2.2.3_SHA256SUMS.sig
gpg --verify vagrant_2.2.3_SHA256SUMS.sig vagrant_2.2.3_SHA256SUMS
shasum -a 256 -c <(cat vagrant_2.2.3_SHA256SUMS | grep 64.deb) -s
sudo dpkg -i vagrant_2.2.3_x86_64.deb
rm vagrant_2.2.3*

sudo apt-add-repository ppa:ansible/ansible
sudo apt update && sudo apt install ansible -y

Verify Versions

Verify your installed versions:

vagrant -v
ansible --version

You should have:

  • Ansible 2.7.6 or higher
  • Vagrant 2.2.3 or higher

Having an exact version of VirtualBox is not critical- as long as you have the proper version of Vagrant, it will run VirtualBox for you.

Vagrant Plugins

  • Whichever host OS (macOS or Linux) you are using, install the Vagrant plugin with this command:
vagrant plugin install vagrant-vbguest

This will install a plugin that will automatically update any VirtualBox VMs with the latest guest additions

Now we can move on and start to configure the Vagrant file and start up the VM...

Vagrant Booterizer Setup

By default, this Vagrant VM will fetch proper IRIX installation packages as per the settings in settings.yml.

Settings

These settings are found in settings.yml. Edit them to suit your environment:

Set this to the version of IRIX you are installing.

irixversion: "6.5.30"

Currently installmethod is only ftp/http. Choose ftp here and http will be used if available. CD is no longer supported.

installmethod: "ftp"

Pick your install mirror

  • the same files are in both locations
  • choose only one of these
installmirror: "https://sgi-irix.s3.amazonaws.com"

This is the new hostname for your SGI post-installation

clientname: "sgi"

Whatever domain you use at home, or make one up for the install

clientdomain: "devonshire.local"

Internal network your SGI will be on. Note this is the actual "network", in the technical subnetting sense of the term.

network: "192.168.0.0"

Internal network's netmask

netmask: "255.255.255.0"

booterizer's host IP. This is the VM's IP on its internal point to point link to the target SGI client machine.

  • this must be a unique, unused IP address in the subnet that your home/office router has created
hostip: "192.168.0.40"

The SGI client box's IP address

  • this must be a unique, unused IP address in the subnet that your home/office router has created
  • it cannot be the same as the Host IP above.
clientip: "192.168.0.41"

The SGI box's physical hardware address, from printenv at PROM

printenv eaddr

will return the SGI MAC address.

  • older PROMs use the command: eaddr to obtain this
  • if you cannot find the MAC address (some PROM do not show it - setup here and then watch the daemon.log file in the booterizer VM as you run the DHCP command to start the fx partitioner- you will see the real SGI MAC try and connect to your booterizer host. Copy it and re-configure)
clientether: "08:00:69:0e:af:65"

This is the name of the interface on your physical machine that's connected to your SGI box. In my case, it's the Ethernet adapter, which is en0.

  • A Macintosh will usually use en0.
  • By default the Linux kernel will usually assign this to eth0, however many distros have switched to predictable naming.
  • If you are unsure of what your distro uses or do not know the interface name, check the interfaces using ip link.
bridgenic: "en0"

Networking overview

The booterizer VM's fake network interfaces map to your physical host as follows:

Physical Host booterizer
Home LAN-connected NIC Adapter 1, NAT, eth0
SGI-connected NIC Adapter 2, Bridged, eth1

NOTE: This VM starts a BOOTP server that will listen to broadcast traffic on your network. It is configured to ignore anything but the target system but if you have another DHCP/BOOTP server on the LAN segment the queries from the SGI hardware may get answered by your network's existing DHCP server which will cause problems. You may want to temporarily disable DHCP/BOOTP if you are running it on your LAN, configure it to not reply to queries from the SGI system, or put SGI hardware on a separate LAN (my recommendation).

  • Note: This is usually not an issue, but it may be, YMMV

One possible setup

Image of a possible network setup for Booterizer

IRIX media

This VM will now be able to sync installation media from S3 using HTTP.

Vagrant will automatically create a vagrant/irix directory on your host machine that is shared between it and the VM. It will then fetch the installation media archives only if they are missing from that directory.

You can keep both 6.5.22 and 6.5.30 media on the same host for different installations on various SGI machines.

Now that your configuration is complete, you're ready to start up the VM and set up the SGI.

vagrant up

Booting your SGI from Booterizer

If you have a null-modem cable and a serial port available in your host computer, in this point you might want to consider installation using serial console instead of using a keyboard and display connected to your SGI. However, that is totally optional. When using booterizer not much typing is needed in any case.

When the PROM menu appears choose: Enter Command Monitor

Set IP address in PROM

  • Set the netaddr of your SGI to match your local network settings, and the specific IP address you picked for it and put into the settings.yml file as clientip:
setenv netaddr 192.168.0.41

The address above is only a sample. You should pick an unused IP in your local network's subnet.

Setting System Timezone

While you are in the PROM you should set the timezone to something appropriate for where you live.

setenv Timezone EST5EDT

would set the timezone to Eastern Time for example.

FX to Partition Disks

Now examine the final output of the vagrant provision or vagrant up command, to find the proper command to boot into fx, the SGI disk partitioner.

  • Look for: __ Partitioners found
   __________________  Partitioners found __________________
    bootp():/6.5.30/Overlay/disc1/stand/fx.64
    bootp():/6.5.30/Overlay/disc1/stand/fx.ARCS
  • Copy and paste that entire line starting with bootp into the PROM (doing this via serial is easier to cut and paste.)
  • Older systems use fx.ARCS (such as Indigos, Indys, and some O2s with R4k CPUs)
  • O2 and newer systems use fx.64
  • NOTE: I really don't understand why, but some PROMs and architectures (e.g. Indy) insist you remove the leading '/' from the path. If you get errors or inst otherwise fails, try bootp():6.5.30/Overlay/disc1/dist.

Starting the fx Partitioner

> bootp():/6.5.30/Overlay/disc1/stand/fx.64

Setting $netaddr to 192.168.251.34 (from server )
Obtaining /6.5.30/Overlay/disc1/stand/fx.64 from server
95040+26448+7168+2805248+50056d+5908+8928 entry: 0x8fd4aa40
Currently in safe read-only mode.
Do you require extended mode with all options available? (no) yes
SGI Version 6.5 ARCS BE  Jul 20, 2006
...

Now continue with the partitioning process.

Using the fx Partitioner

You should use fx to partition your internal disk- read the section "Partitioning the disk" at Getting an Indy Desktop for more thorough directions.

In a nutshell, you want to [re]partition and then select [ro]ot only. Then .. to escape that menu and [ex]it to quit fx and go back to the PROM to start a remote installation to install IRIX on the newly partitioned hard drive.

Here is a run-thru:

----- please choose one (? for help, .. to quit this menu)-----
[exi]t             [d]ebug/           [l]abel/           [a]uto
[b]adblock/        [exe]rcise/        [r]epartition/
fx> r

----- partitions-----
part  type        blocks            Megabytes   (base+size)
  0: xfs      266240 + 585671260     130 + 285972
  1: raw        4096 + 262144         2 + 128
  8: volhdr        0 + 4096           0 + 2
 10: volume        0 + 585937500       0 + 286102

capacity is 585937500 blocks

----- please choose one (? for help, .. to quit this menu)-----
[ro]otdrive           [o]ptiondrive         [e]xpert
[u]srrootdrive        [re]size
fx/repartition> ro

fx/repartition/rootdrive: type of data partition = (xfs)
Warning: you will need to re-install all software and restore user data
from backups after changing the partition layout.  Changing partitions
will cause all data on the drive to be lost.  Be sure you have the drive
backed up if it contains any user data.  Continue? yes


----- please choose one (? for help, .. to quit this menu)-----
[ro]otdrive           [o]ptiondrive         [e]xpert
[u]srrootdrive        [re]size
fx/repartition> ..

----- please choose one (? for help, .. to quit this menu)-----
[exi]t             [d]ebug/           [l]abel/           [a]uto
[b]adblock/        [exe]rcise/        [r]epartition/
fx> exi

Wiping a disk for clean IRIX install

Often you have have a drive with IRIX already installed, and you want to do a clean install. You need to wipe the disk with mkfs, running the partitioner on the drive is not enough. The reason is that if your partitions are exactly the same as they were on the old installation, when you run inst it will still pickup settings in /etc from the old install and assume you are doing an upgrade. To wipe the disk is easy- but you have to run inst, wipe, then reboot so that inst won't pick up the old installation and create a fresh miniroot and use default values.

Here is a sample run-thru:

Admin> 11

                   ** Clean Disks Procedure **

      If you agree to it, this procedure will clean your disks,
      removing all data from the root and (if present) the user
      file systems.

      Boot device partitions zero (0) and, if present, six (6)
      will be erased (using mkfs).  This will destroy all data on
      them.  These partitions will then be remounted under /root
      and (if present) /root/usr.

      If you have data on these file systems you want to save,
      answer "no" below, and backup the data before cleaning
      your disks.

      Any other file systems or logical volumes will be unmounted
      and forgotten about until you choose to reconfigure and
      remount them.


        Are you sure you want to clean your disks ?
                   { (y)es, (n)o, (sh)ell, (h)elp }: y

WARNING: There appears to be a valid file system on /dev/dsk/realroot already.
Making a new file system will destroy all existing data on it.

Make new file system on /dev/dsk/realroot? yes

Doing: mkfs -b size=4096 /dev/dsk/realroot
meta-data=/dev/dsk/realroot      isize=256    agcount=70, agsize=1048576 blks
         =                       sectsz=512   attr=0, parent=0
data     =                       bsize=4096   blocks=73208907, imaxpct=25
         =                       sunit=0      swidth=0 blks, unwritten=1
         =                       mmr=0
naming   =version 2              bsize=4096   mixed-case=Y
log      =internal log           bsize=4096   blocks=8936, version=1
         =                       sectsz=512    sunit=0 blks, lazy-count=0
realtime =none                   extsz=65536  blocks=0, rtextents=0

Mounting file systems:

    /dev/miniroot            on  /
    /dev/dsk/realroot        on  /root


Re-initializing installation history database
Reading product descriptions ..   0%
WARNING: Assuming no hist file
Reading product descriptions .. 100% Done.

And from here you just exit and reboot.

Running inst (IRIX installer)

NOTE: After booterizer initializes, it displays a list of all dist subdirectories for your convenience. Use this list to preserve your sanity while running inst.

The installer can be reached through the monitor GUI as follows:

  • At the maintenance boot screen, select "Install Software"
  • If it prompts you for an IP address, enter the same address you entered into the Vagrantfile config for clientip.
  • Use booterizer as the install server hostname.
  • For the installation path, this depends on your directory structure. If you use the structure example from above, you would use the path /6.5.30/Overlay/disc1/dist.
    • NOTE: If you get errors or inst otherwise fails, remove the leading '/' from the path: 6.5.30/Overlay/disc1/dist.
  • This should load the miniroot over the network and boot into the installer.
  • From inst, choose Option 13, Admin menu
    • booterizer generates a 'selections' file that contains all of the media paths for inst to load
    • load booterizer:selections
    • You can press q to skip the readmes for each media item
    • Choose 'feature stream' when asked
    • When inst is done loading media, it will prompt for the next location. Type
    • done
  • From inst, Admin menu
    • booterizer provides a 'commands' file that contains all of the commands for inst to run

    • source booterizer:commands

    • Just in case, sourced commands are:

      return
      keep *
      install standard
      keep incompleteoverlays
      remove java_dev*
      remove java2_plugin*
      conflicts
      # there should be no conflicts
      go
      # go for a walk
      quit
      # go for another walk
      [elf binaries are prepared for use]
      # the system will prompt to reboot
      

Example run

System Maintenance Menu

1) Start System
2) Install System Software
3) Run Diagnostics
4) Recover System
5) Enter Command Monitor

Option? 2


                         Installing System Software...

                       Press <Esc> to return to the menu.



1) Remote Directory  2)[Local CD-ROM]
      *a) Local SCSI CD-ROM drive 6, on controller 0

Enter 1-2 to select source type, a to select the source, <esc> to quit,
or <enter> to start: 1


Enter the name of the remote host: 192.168.251.99
Enter the remote directory: 6.5.30/Overlay/disc1/dist


1)[Remote Directory]  2) Local CD-ROM
      *a) Remote directory 6.5.30/Overlay/disc1/dist from server 192.168.251.99.

Enter 1-2 to select source type, a to select the source, <esc> to quit,
or <enter> to start:


Setting $netaddr to 192.168.251.82 (from server )
Copying installation program to disk.
......... 10% ......... 20% ......... 30% ......... 40% ......... 50%
......... 60% ......... 70% ......... 80% ......... 90% ......... 100%
Copy complete
IRIX Release 6.5 IP27 Version 07202013 System V - 64 Bit
Copyright 1987-2006 Silicon Graphics, Inc.
All Rights Reserved.
...

And from here inst runs and installs/creates a miniroot, then mounts the miniroot and then runs inst. Follow the directions above.

IRIX installation is finished

At this point your system should come back up (ensure you go back into PROM and setenv console g if you set it to d for a serial installation!) and you can login as root, no password.

Now there are many many more configurations you need to do before starting to use the system. Running EZSetup does a tiny fraction of these. The irix_ansible project does a whole lot more!

Provisioning your IRIX host with irix_ansible

booterizer automatically installs irix_ansible, which allows for easy configuration of your IRIX system.

It performs the following tasks, and more:

  • install wget, python, and openssh
  • start sshd
  • installs nekodeps
  • installs base packages
  • performs security hardening

irix_ansible should be run immediately after your IRIX host has been installed, and has booted for the first time:

  • Connect your IRIX host to your home LAN
  • vagrant ssh
  • sudo -i
  • Follow the irix_ansible README to create your own ansible vault
    • group_vars/default/vault.yml
  • Place your vault password in /home/vagrant/.vault_pass.txt
  • Continue with the irix_ansible README

PRO TIP

Take a look in the expect/ directory for my own personal install scripts, written in expect. You can use them as a guide for what to select during an installation -- or if you're really brave/foolish, follow the enclosed README to run those scripts over serial console.

Installation using serial console

To help installations it is often easier to do an install via the SGI's serial port and your host computer (Mac or Linux). With serial port you are able to:

  • Copy and paste commands from this page onto the serial comms program running on your workstation.
  • Save the output from the SGI for posterity or help.

This requires a null-modem serial cable, and a serial port on the host computer. Note that some modern PC serial ports might not work reliably with an old SGI. A good-quality USB to RS-232 adapter should work well.

Assuming you have connected up your SGI's serial port 1 to your workstation, and you are running a serial app, and you have set it (usually) to 9600/8/N/E then you are probably seeing the PROM menu and other characters from the SGI serial port during the system POST.

To setup the console to serial output for the installation you must set this console variable:

setenv console d

This will ensure a smooth installation session.

When you are done you should set the console back to graphical virtual console:

setenv console g

Please check following links for more information about correct null-modem serial cable wiring and more:

Troubleshooting

I'm having trouble with the Vagrant Booterizer

Generally, if you have trouble with the Vagrant-based booterizer, use the Raspberry Pi Version. It's easier, faster, and nearly everything's already done for you.

Problems running inst from Serial port

setenv console d

And then continue installation as above.

Ansible fails to pull images

  • During extraction if you get this ansible failure:
TASK [fetch_files : Extracting overlay disc 1] *********************************
fatal: [default]: FAILED! => changed=false
  msg: Failed to find handler for "/vagrant/irix/6.5.30/Overlay/disc1/disc1.tar.gz". Make sure the required command to extract the file is installed. Command "/bin/tar" could not handle archive. Command "unzip" not found.

The file didn't download fully. vagrant ssh into the host, move into that directory and delete the tar file. Then use the vagrant provision command to pull that tarball again and re-extract.

  • Example
rm /vagrant/irix/6.5.30/Overlay/disc1/disc1.tar.gz
  • Then back on you main host run the provision again:
~/booterizer (master) $ vagrant provision

License

MIT License

Portions of this project are: Copyright (c) 2018 Andrew Liles Copyright (c) 2018 Eric Dodd

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

About

Ansible-based bootstrap environment for old UNIXes

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Jinja 59.6%
  • Shell 40.4%