Kickstart (Amiga)
Kickstart is the bootstrap firmware of the Amiga computers developed by Commodore International. Its purpose is to initialize the Amiga hardware and core components of AmigaOS and then attempt to boot from a bootable volume, such as a floppy disk. Most Amiga models were shipped with the Kickstart firmware stored on ROM chips.
Versions
Commodore's AmigaOS was formed of both the Kickstart firmware and a software component provided on disk (with the software portion often termed as Workbench). For most AmigaOS updates the Kickstart version number was matched to the Workbench version number. Confusingly, Commodore also used internal revision numbers for Kickstart chips. For example, there were several Kickstart revisions designated as version 2.0.[1]
Version summary
Kickstart version | V-number | Retailed with Amiga models | Launch date | ROM capacity | Autoconfig present in ROM[2] | Early boot menu | Boot from PCMCIA and ATA | Autodetect memory |
---|---|---|---|---|---|---|---|---|
<0.4[3] | <V24[4] | Lorraine, first prototype[5] | 1983[6] | 64 KB[5] | No | No | No | No |
0.4[7] | V23 V24[4] | Amiga "Velvet"[8] | 1984[8] | 128 KB[8] | No | No | No | No |
0.6, 0.7, 0.9[9] | V26 V27 V29[10] | Amiga 1000 Beta | 1985 | 256 KB | No | No | No | No |
1.0[11] | (none)[12] | Amiga 1000 | 1985 | 256 KB | No | No | No | No |
1.1[13] | V31 (NTSC) / V32 (PAL)[4] | Amiga 1000 | 1985–1986 | 256 KB | No | No | No | No |
1.2[14] | V33[4] | Amiga 500, Amiga 1000, Amiga 2000 | 1987 | 256 KB | No Auto Boot from Hard Disk | No | No | No |
1.3[15][16][17][18][19][20] | V34[4] | Amiga 500, Amiga 2000, Commodore CDTV, Amiga 3000 | 1988 | 256 KB | Yes | No | No | No |
1.4[21] | V35[4] | Amiga 3000 | 1990 | 512 KB | ||||
2.0–2.05[22][23][24][25] | V36-38[4] | Amiga 500+, Amiga 600, Amiga 2000, Amiga 3000 | 1990 | 512 KB | Yes | Yes | 2.05+ | No |
3.0[26] | V39[4] | Amiga 1200, Amiga 4000 | 1992 | 512 KB | Yes | Yes | Yes | No |
3.1[27] | V40[4] | Amiga 1200, Amiga 4000T | 1993 | 512 KB | Yes | Yes | Yes | Yes |
Amiga CD32 | 1993 | 1 MB | ||||||
3.1.4[28] | V46 | Amiga 500, Amiga 600, Amiga 2000, Amiga 1200 | 2018 | 512 KB | ||||
3.2[29] | V43 | Amiga Walker, last prototype | 1996 | 1 MB |
The first Amiga model, the A1000, required that Kickstart 1.x be loaded from floppy disk into a 256 KB section of RAM called the writable control store (WCS). Some A1000 software titles (notably Dragon's Lair) provided an alternative code-base in order to use the extra 256 KB for data. Later Amiga models had Kickstart embedded in a ROM chip, thus improving boot times. Many Amiga 1000 computers were modified to take these chips.
Kickstart was stored in 256 KB ROM chips for releases prior to AmigaOS 2.0. Later releases used 512 KB ROM chips containing additional and improved functionality. The Amiga CD32 featured a 1 MB ROM (Kickstart 3.1) with additional firmware and an integrated file system for CD-ROM.
Early A3000 models were, like the A1000, also shipped with Kickstart on floppy disk, and used a 1.4 BETA ROM as bootstrap. Either Kickstart 1.3 or 2.0 could be extracted to a partition specifically named WB_1.3 or WB_2.x, respectively, and put in DEVS:kickstart, an absolute system location from where the A3000 system will find it at bootstrap and copy its image into RAM. This early A3000 supported both ROM based Kickstarts and disk-based Kickstarts, although not simultaneously. An A3000 configured to use disk-based Kickstart images had the benefit of being able to boot various versions of AmigaOS without additional tools, simply by selecting the appropriate Kickstart image at boot time.
The Commodore CDTV featured additional firmware ROMs which are not technically part of the Amiga Kickstart. The CDTV's original firmware ROMs must be upgraded in order to install a Kickstart version later than 1.3.
AmigaOS 2.1 was a pure software update and did not require matching Kickstart ROM chips. Workbench 2.1 ran on all Kickstart ROMs of the 2.0x family. Later releases of AmigaOS (3.5 and 3.9) were also software only and did not include matching ROM upgrades instead requiring Kickstart 3.1, with ROM-file based Kickstart components replacing those in ROM. Kickstart modules of AmigaOS 4 are stored on the boot disk partition.
Up to Kickstart v2.0 (V36) only 512-byte blocks were supported.[30] Motorola 68040 uses write caches that requires the use of the functions CacheClearU() and CacheControl() to flush cache when program code has been modified. These functions are only available in Kickstart 2.0 or better.[31]
Function
Upon start-up or reset the Kickstart performs a number of diagnostic and system checks and then initializes the Amiga chipset and some core OS components. It will then check for connected boot devices and attempt to boot from the one with the highest boot priority. If no boot device is present a screen will be displayed asking the user to insert a boot disk – typically a floppy disk. Insertion of such a bootable disk (other than workbench-like disk) will result in:
a) a command line interface ("CLI") prompt to operate with ROM-internal and disks commands (including programs, scripts) (if the disk is non-workbench, or empty), or
b) a (basic) point and click UI named "Workbench" if the disk contains at least "loadwb" in the "startup-sequence" script residing inside the "s"-folder on this disk.
c) the disk booting into a customized workbench or an application, keeping the OS "alive" in the background.
d) a game or other application directly starting up, taking over all the hardware resources of this computer by avoiding to establish core Exec multitasking, driver initialization etc.
The Kickstart contains many of the core components of the Amiga's operating system, such as:
- Exec – the Amiga's multi-tasking kernel
- Intuition – functionality for GUI, screens, windowing and handling of input/output devices
- Autoconfig – functionality to automatically initialize or boot from compliant expansion hardware
- Floppy disk device driver and file system to read and boot from floppy disk
- DOS library for file access and handling
- AmigaDOS – Command Line Interface (CLI) functionality and a number of core CLI commands
- Graphics library for basic drawing and raster graphics functions using the native Amiga chipset
- Audio device driver for the native Amiga sound hardware
- Device drivers for the Amiga keyboard and mouse/gameports
Kickstart 1.3 is the first version to support booting from a hard disk drive.[32]
From AmigaOS release 2.0 onwards Kickstart also contained device drivers to boot from devices on IDE controllers, support for PC Card ports and various other hardware built into Amiga models.
Diagnostic test
The screen color after power-on shows the result of the self-test.
If everything is working the following screen color sequence will be displayed:
- Dark grey – Hardware working and the registers are readable.[33]
- Light grey – ROM verified.[33]
- White – Initialization is alright. Ready to boot.[33]
These colors indicate a problem:
- Red – Bad Kickstart-ROM[34]
- Green – No chip RAM found, or it is damaged[34]
- Blue – Custom chip problem (Denise, Paula, Agnus)[34]
- Yellow – Mostly a bad CPU (no trap routine) or a bad Zorro expansion card.[34] CPU exception error before the "Guru Meditation" trapping software was enabled.[33]
- Light green – CIA problem[35]
- Light Grey – If it stops at grey, the CIA may be defective[35]
- Black/stripes – ROM or CIA problem[35]
- Black – No video output.[35]
The keyboard LED uses blink codes where:
- One blink means the keyboard ROM has a checksum error[35]
- Two blinks means RAM failure[35]
- Three blinks means watchdog timer failure.[35]
- When the Caps Lock key is repeatedly pressed approx. 10 times, the Caps Lock LED turning on and off each time indicates the CPU is correctly reading the CIAs. If the Caps Lock LED sticks on or off, the CPU is not servicing CIA interrupt requests.[35]
Usage
In general, to run a specific Workbench version a Kickstart with a matching or greater version number is required.
It is not generally possible to boot directly into the Workbench windowing environment from Kickstart alone. Though much of the functionality required for Workbench is contained in Kickstart some disk-based components are needed to launch it.
From release 2.0 onwards it is possible to enter a boot menu by holding down both mouse buttons at power on or reset. This allows the user to choose a boot device, set parameters for backwards compatibility and examine Autoconfig hardware.
With third-party software, it is possible to use an alternate Kickstart to the version stored in the embedded ROM chip. Such software allows a Kickstart version to be loaded from file into RAM – for example Kickstart 1.3 may be loaded in order to run old software incompatible with Kickstart 2.0 or later. Several third-party vendors produced hardware Kickstart switchers (dual-boot systems) in the form of socket doublers in order to allow two ROM chips to plug into a single motherboard socket with some mechanism to switch between them. These became popular with users who had problems with later Kickstart versions causing incompatibility with earlier software titles.
An MMU-enabled Amiga is able to "shadow" Kickstart from the embedded ROM chip (or from file) into RAM and pass control to it at start-up. This is often preferable as RAM access times are significantly faster than ROM, particularly on expanded systems. At subsequent resets the copy of Kickstart is re-used, reducing boot time and allowing faster access and execution of Kickstart functionality. Similar shadowing functions were also developed for some devices without MMU hardware.
References
- ↑ "The Big Book of Amiga Hardware - Custom Chips: Kickstart". http://bboah.amiga-resistance.info/cgi-bin/showhardware_en.cgi?HARDID=1459.
- ↑ http://wiki.classicamiga.com/Kickstart_Roms_Explained
- ↑ http://cloanto.com/amiga/roms/help/version.html
- ↑ 4.0 4.1 4.2 4.3 4.4 4.5 4.6 4.7 4.8 "Mysterious Ways - How to Code the Amiga - Important Kickstart Differences on Amiga". mways.co.uk. http://www.mways.co.uk/amiga/howtocode/text/kickstart.php. Retrieved 2013-06-09.
- ↑ 5.0 5.1 "Amiga Lorraine". amigahistory.co.uk. 2007-06-10. http://www.amigahistory.plus.com/prototypes/lorraine.html. Retrieved 2013-06-09.
- ↑ "The History of the Amiga". amigahistory.co.uk. 2007-06-10. http://www.amigahistory.co.uk/ahistory.html. Retrieved 2013-06-09.
- ↑ http://scacom.bplaced.net/Collection/velvet/velveten.php
- ↑ 8.0 8.1 8.2 "Amiga 1000 Developer 'VELVET'". Stefan Egger. 2015–16. http://scacom.bplaced.net/Collection/velvet/velveten.php. Retrieved 2016-07-30.
- ↑ https://www.gregdonner.org/workbench/wb_b0x.html
- ↑ "Kickstart Roms Explained". http://wiki.classicamiga.com/Kickstart_Roms_Explained.
- ↑ http://www.gregdonner.org/workbench/wb_10.html
- ↑ "Kickstart Roms Explained". http://wiki.classicamiga.com/Kickstart_Roms_Explained.
- ↑ http://www.gregdonner.org/workbench/wb_11.html
- ↑ http://www.gregdonner.org/workbench/wb_12.html
- ↑ http://www.gregdonner.org/workbench/wb_13.html
- ↑ http://www.gregdonner.org/workbench/wb_131.html
- ↑ http://www.gregdonner.org/workbench/wb_132.html
- ↑ http://www.gregdonner.org/workbench/wb_133.html
- ↑ http://www.gregdonner.org/workbench/wb_134.html
- ↑ http://www.gregdonner.org/workbench/wb_2024.html
- ↑ http://www.gregdonner.org/workbench/wb_b14.html
- ↑ http://www.gregdonner.org/workbench/wb_b20x.html
- ↑ http://www.gregdonner.org/workbench/wb_20.html
- ↑ http://www.gregdonner.org/workbench/wb_204.html
- ↑ http://www.gregdonner.org/workbench/wb_205.html
- ↑ http://www.gregdonner.org/workbench/wb_30.html
- ↑ http://www.gregdonner.org/workbench/wb_31.html
- ↑ http://www.gregdonner.org/workbench/wb_314.html
- ↑ http://www.gregdonner.org/workbench/wb_b32_40.html
- ↑ "32 / Expansion Board Drivers / RigidDiskBlock and Alternate Filesystems". amigadev.elowar.com. http://amigadev.elowar.com/read/ADCD_2.1/Libraries_Manual_guide/node041F.html. Retrieved 2013-06-09.
- ↑ "Mysterious Ways - How to Code the Amiga - General Guidelines". mways.co.uk. http://www.mways.co.uk/amiga/howtocode/text/generalguidelines.php#relocatable. Retrieved 2013-06-13.
- ↑ "WORDSYNC" ADDENDUM to the SupraDrive Operator s Manual". http://amiga.resource.cx/manual/SupraDrive_Addendum.pdf. 090429 amiga.resource.cx
- ↑ 33.0 33.1 33.2 33.3 amigahistory.co.uk - What your Amiga is telling you
- ↑ 34.0 34.1 34.2 34.3 "blinking power led/no screen on amiga 500". Archived from the original on 2012-04-03. https://web.archive.org/web/20120403044629/http://eab.abime.net/showthread.php?t=497.
- ↑ 35.0 35.1 35.2 35.3 35.4 35.5 35.6 35.7 "A3000 Booting Problems". https://amiga.serveftp.net/A3000_HardwareGuide/booting-problems.html.
ru:AmigaOS#Kickstart