git @ Cat's Eye Technologies Funicular / 820ebca
Update README, FreeDOS install instructions, NetBSD sources. Chris Pressey 10 years ago
3 changed file(s) with 108 addition(s) and 46 deletion(s). Raw diff Collapse all Expand all
00 Funicular
11 =========
22
3 **Funicular** is a system to semi-automate the creation of development
4 environments on eclectic architectures. It is currently vapourware.
3 **Funicular** is a system that semi-automates the creation of development
4 environments on eclectic architectures. It is currently a work in progress.
55
6 Here, "eclectic architectures" is not terribly-well defined, but it includes
6 "Semi-automate" means it automates what it can, and provides repeatable
7 instructions for you to follow for what it can't.
8
9 "Eclectic architectures" is not terribly-well defined, but it includes
710 retrocomputing and esoteric architectures. Basically, if you've got an
8 emulator for it, you might be able to build and run a system for it, using
9 Funicular.
11 emulator for it and install and support images for it, you might be able
12 to install and outfit and and run a system for it, using Funicular.
1013
1114 It's kind of like a Vagrant for the lunatic fringe, eh?
1215
13 Each funicular is defined by a `Funicularfile`. This file is written in
14 the configuration subset of Lua, and gives the configuration for the funicular;
15 it looks something like
16 It currently supports:
1617
17 return {
18 platform = NetBSD_6,
19 system_image = 'wd0.img',
20 setup_image = 'setup-netbsd.iso',
21 }
18 * NetBSD under QEMU
19 * FreeDOS under QEMU (to a certain degree)
2220
23 A funicular is generally based around a particular Platform
24 (Amiga[DOS]-Gondola, NetBSD-Gondola, FreeDOS-Gondola).
21 We hope that it will soon support:
2522
26 The Platform defines a default Architecture, which in turn defines a
27 default Emulator.
23 * AmigaDOS under E-UAE
2824
29 In truth, Architectures are many-to-many with Platforms, which are
30 many-to-many with Emulators — so there are lots of possibilities, and the
31 Architecture may vary (NetBSD on i386 vs mips or whatnot) and the
32 emulator may vary (UAE or E-UAE, QEMU or Bochs, etc.)
25 And one day:
3326
34 Images
35 ------
27 * Commodore 64 KERNAL under VICE
28 * VIC-20 KERNAL under VICE
29 * AppleDOS under an Apple 2 emulator
3630
37 Image {
38 filename: string
39 type: disk-image | cdrom-image | host-file-mapped
40 }
31 It is hoped that Funicular will eventually replace the discrete, ad-hoc
32 projects [NetBSD-Gondola](https://github.com/catseye/NetBSD-Gondola),
33 [FreeDOS-Gondola](https://github.com/catseye/FreeDOS-Gondola), and
34 [Amiga-Gondola](https://github.com/catseye/Amiga-Gondola).
4135
42 An Image has one of three distinct roles:
36 Concepts
37 --------
4338
44 * `system_image`: contains one operating system; boots into that operating
39 ### Funiculars, Platforms, Architectures, Emulators ###
40
41 Each funicular is defined by a `Funicularfile` in a particular directory
42 dedicated to that funicular (in analogy with `Makefile`, `Vagrantfile`, etc.)
43
44 A funicular is generally based around a particular Platform. The Platform
45 defines a default Architecture, which in turn defines a default Emulator.
46
47 In truth, it is more complicated than that. Architectures have a many-to-many
48 relationship with Platforms, which themselves have a many-to-many relationship
49 with Emulators.
50
51 For example, the NetBSD Platform could be on i386 or MIPS Architecture, and the
52 QEMU emulator can emulate both i386 and SPARC, while the i386 architecture can
53 be emulated by both QEMU and Bochs.
54
55 So, there are lots of possibilities. But, we can stick to certain "defaults"
56 for now; not only because they are "opinionated" (I'd rather use QEMU than
57 Bochs) but also because it makes it a lot simpler. Hopefully we'll come up
58 with a sane way to customize all the relationships at some point.
59
60 ### Images ###
61
62 An Image has one of several roles:
63
64 * **System Image**: contains one operating system; boots into that operating
4565 system, if applicable; persistent and mutable; often contains utilities;
4666 also generally contains a work area for installing and building STUFF
47 * `install_image`: CDROM (or other readonly) image which installs the operating
67
68 * **Support Image**: like a system image, but read-only, but required for
69 the Platform or Architecture to operate. Often in the form of ROM images.
70 May or may not be supplied with an Emulator, depending on licensing
71 requirements.
72
73 * **Install Image**: CDROM (or other readonly) image which installs the operating
4874 system to the system-image; generally not needed after that point
49 * `setup_image`: CDROM (or other readonly) image which contains STUFF
75
76 * **Setup Image**: CDROM (or other readonly) image which contains STUFF
5077 to install and build in the work area; ephemeral (recreated by funicular
51 as needed from toolshelf sources)
78 as needed from acquired sources)
5279
53 There is a fourth role; from a system-image, a funicular may be able to
54 create a
55
56 * `work_image`: contains a skeletal operating system and a subset of the
80 * **Distribution Image**: contains a skeletal operating system and a subset of the
5781 STUFF so built. intended to be used as a "distributed product" —
5882 for other (web) emulators, bootable USB sticks, or whatnot
83
84 Usage
85 -----
86
87 To bring up a funicular, you generally follow these steps:
88
89 * Acquire an install image for the Platform (e.g. a NetBSD install ISO.)
90 * Acquire an appropriate Emulator (e.g. `toolshelf dock @@qemu`.)
91 * Run `funicular init 4000` to create a 4G (or whatever) system image.
92 * Run `funicular install` to install the platform onto the system image.
93 * Run `funicular setup` to fetch various pieces of software and install
94 them too on the system image.
95 * Run `funicular start` to use your funicular for whatever you want.
1818 http://www.tortall.net/projects/yasm/releases/yasm-1.2.0-dos.exe
1919 http://www.lua.org/ftp/lua-5.2.2.tar.gz
2020 ]],
21 instructions = [[
22 Yes.
23 We will have many instructions here.
24 You bet.
21
22 install_instructions = [[
23 * select "Install to Hard Disk"
24 * select "f" to start FDISK
25 * FAT32 -- no
26 * 1 -- create DOS partition
27 * 1 -- create Primary DOS partition
28 * Use maximum available size -- yes
29 * Press Esc to continue
30 * Press Esc to exit FDISK. System will now restart...
31 * select "Install to Hard Disk"
32 * press 1 to start installing
33 * select English or whatever
34 * You need to format. -- yes ... proceed? yes.
35 * 1 -- continue with installation
36 * 1 -- start installation
37 * Enter, Enter, the above directories are correct, yes
38 * just base and util should be enough, down-arrow to DONE
39 * N.B.! util is required for UPX!
40 * proceed with installation -- yes
41 * down-arrow to DONE
42 * proceed with installation -- yes -- ...wait...
43 * Press any key to continue
44 * down-arrow to DONE
45 * proceed with installation -- yes
46 * Press any key to continue -- ...watch flickering...
47 * What to do with the bootloader? -- 1
48 * select "Boot from system harddisk"
49 * Hit Enter for the JEMMEX option, should be fine
50 * viola, `C:\>`. You can now just stop the emulator.
51 ]],
52
53 setup_instructions = [[
54 ...
2555 ]],
2656 }
2757
3434 https://bitbucket.org/catseye/animals
3535 https://bitbucket.org/catseye/apple-befunge
3636 https://bitbucket.org/catseye/arboretuum
37 https://bitbucket.org/catseye/atari-2600-skeleton
3837 https://bitbucket.org/catseye/befos
3938 https://bitbucket.org/catseye/befunge-93
4039 https://bitbucket.org/catseye/beta-juliet
6766 https://bitbucket.org/catseye/flip
6867 https://bitbucket.org/catseye/flobnar
6968 https://bitbucket.org/catseye/funge-98
69 https://bitbucket.org/catseye/funicular
7070 https://bitbucket.org/catseye/gemooy
7171 https://bitbucket.org/catseye/granola-m
7272 https://bitbucket.org/catseye/hev
8585 https://bitbucket.org/catseye/muriel
8686 https://bitbucket.org/catseye/mzstorkipiwanbotbotbot
8787 https://bitbucket.org/catseye/n-dcnc
88 https://bitbucket.org/catseye/netbsd-gondola
8988 https://bitbucket.org/catseye/netusb
9089 https://bitbucket.org/catseye/nhohnhehr
9190 https://bitbucket.org/catseye/noit-o-mnain-worb
9897 https://bitbucket.org/catseye/redgreen
9998 https://bitbucket.org/catseye/realpath
10099 https://bitbucket.org/catseye/robin
101 https://bitbucket.org/catseye/rooibos
102100 https://bitbucket.org/catseye/rube
103101 https://bitbucket.org/catseye/rube-ii
104102 https://bitbucket.org/catseye/sally
137135 https://bitbucket.org/catseye/ophis
138136 https://bitbucket.org/catseye/openzz
139137 https://bitbucket.org/catseye/minischeme
140
141 https://bitbucket.org/catseye/ymattw-cdiff
142 https://bitbucket.org/catseye/cpressey-tree
143138 ]],
144139
145140 install_instructions = [[