The Amiga Operating System: Past and Present

CS – 450 – 1

Fall 2003

Aaron Hensley

Brad Campbell

Greg Mathurin

Kayla Zinn

Joshua Benson

Table of Contents

Overview3

A Brief History4

Processor Modes5

Data Structures6

Allowable Process States6

Threading7

Memory Management7

ExecSG8

File System8

Scheduling10

Deadlock10

Conclusion11

Overview: In what environment is your O/S designed to work?

In the early 1980’s the Amiga operating system known as ‘workbench’ with the graphical user interface known as ‘Intuition’ was designed originally on a 16/32bit custom-built computer codenamed ‘Lorraine’. Lorraine was designed around the Motorola 68000 processor and had 3 custom chips that handled ports and audio/video. The 3 custom chips were the ‘Agnus’ which was the address generator, ‘Denise’ which was the display adapter, and ‘Paula’ which handled the ports and audio. In order to appeal to the public, the name of the computer was changed to ‘Amiga’ which is Spanish for ‘female friend’. (Donner, Gregory 2003)

The first Amiga computer, the Amiga 1000 was released in 1985 at a price of $1295.00 and was marketed as a high-end multimedia personal computer. The Amiga 1000, capable of priority based multi-tasking, used the MC68000 processor with an internal 32bit bus, 16bit data bus, and was clocked at 7.16 MHz. The system included 256K RAM and was expandable to 512K internally, though externally, it was able to handle 8Mb fast RAM. The graphics portion had a pallet of 4096 colors in a time when the Macintosh was black and white and the IBM PC was using a 16 color CGA display. The sound processor was designed to handle 4 independent sound channels configured as two stereo channels. The computer system included a two-button mouse and an 89key keyboard. Of particular note was the keyboard itself which was hidden inside the Amiga 1000’s chassis and could be rolled out when needed. (Donner, Gregory 2003)

The Amiga went through many different models with each adding new features and improving upon the operating system’s kernel and user interface. The Amiga 500, released in 1987, was cheaper and smaller than the Amiga 1000. It replaced the ZORRO expansion slots with DMA slots and the new Workbench 1.3 introduced the command-line interface. (Knight, Gareth 2003a) The Amiga 2000, released also in 1987, separated the customer-base by being geared towards the high-end as the Amiga 500 remained a favorite as a low-end system. The Amiga 2000 shipped with the same version Workbench as the 500 model but was built around a larger desktop chassis. It sported 5 100-pin ZORO II slots and 2 16bit ISA slots and came with 1MB of memory. (Donner, Gregory 2003)

In 1990, the Amiga 3000 was sold as a very high-end system with strong graphics capability. The main processor was upgraded to the 68030 and came with ZORO III slots. Two operating systems were shipped with the Amiga 3000, the Unix System (SVR4) V, and the newly released Workbench 2.0. Until now, Kickstart was stored in a ROM chip, but with Workbench 2.0, Kickstart was booted from the hard drive. Workbench 2.0 came with a revised version of Intuition where a new gray 3d look was adopted over 1.3’s flat blue look and many other features were introduced. (Knight, Gareth 2003a) A new system geared towards the game console market was introduced in 1992. The Amiga 600 was a computer and keyboard in one. The numeric keypad had been removed, but a PCMCIA port was added. The PCMCIA port allowed many things to be added such as extra memory, expandable to 6MB, CD-ROM and other disk drives. Workbench 2.05 was preloaded and included the usual enhancements to Intuition and many bug fixes. The year 1992 also brought about the Amiga 4000 which was the most advanced yet. It came with the EC030 or EC040 process clocked at 25 MHz. It introduced the AGA chipset which allowed it to show 256,000 colors on the screen using a palette of 16.8 million colors. It shipped with 6MB of RAM, a 1.76mb High-Density disk drive and a hard drive. Workbench 3 was shipped with the Amiga 4000 which featured data types, new diagnostic tools built into the startup boot menu, color remapping, and support for the AGA chip set which was used in the Amiga 4000. (Knight, Gareth 2003a) In 1996, the Amiga 4000T was released but only in small numbers. The Amiga 4000T shipped with IDE & SCSI-2 Fast controllers, 2 video slots and came with the 68040 processor clocked at the same clock speed as the Amiga 4000 at 25 MHz. (Donner, Gregory 2003)

History of Amiga

The origins of the concept of the Amiga started back in 1982 with a company called Hi-Toro which was based in Santa Clara, California. After being hired on as CEO, Dave Morse started working on a plan for a system called ‘Lorraine’ codenamed after his wife which would be a monster game machine with a 3.5” floppy drive and a keyboard and an open architecture so 3rd party developers could create games for it. Later in 1982, Hi-Toro changed its name to Amiga Incorporated. (Knight, Gareth 2003d)

For the video subsystem, a form of blitter technology used for graphics which was called HAM, or Hold and Modify was used to display 4096 colors on the screen by changing color registers. RJ Mical, a software engineer, created the graphical user interface called Intuition. The three custom chips, Agnus, Denise, and Paula were prototyped. After two years of development, a product was ready to show off, but without sufficient funds, an investor was needed to keep Amiga Inc. alive. Atari offered Amiga Inc. money but with some strings attached. Then, on August 15th 1984, a company called Commodore International Ltd decides to buy Amiga Inc. and pay off Amiga’s debts to Atari. Commodore puts its focus on the Lorraine project and with new resources, the once monster game machine was turned into a personal computer. Eventually, after more development, the Lorraine project turned into the Amiga 1000 which was released in July of 1985. (Knight, Gareth 2003d)

Although Commodore sold an estimated 4,850,000 Amigas while in business, Commodore began to make one mistake after another which finally led to liquidation April 29th, 1994. Commodore’s first mistake was to price the Amiga 1000 too high even though it was more advanced than any other personal computer system at the time. Before the Amiga was released, Atari released the Atari ST which was a 16bit system designed with cheaper parts and sold for less than half the cost of the Amiga 1000. By 1987, the Atari ST, having more games written for it, continued to outsell the Amigas. Commodore’s second mistake came when Chairman Irving Gould, with reservations of the focus on America when 70% of the market was overseas, replaced Thomas Rattigan as head of Commodore. Gould then changed the North American operation from an independent operation to sales and marketing. He also cut the payroll from 4,700 to 3,100, and closed five plants. (Knight, Gareth 2003d)

During 1988, games eventually started being written for the Amiga that simply couldn’t run on the Atari ST. Atari, in a last ditch effort, sued Commodore saying that they had paid for the research of the Amiga. Commodore won the law suit and Atari was no longer a threat. Commodore, having conquered its main competitor, then made its third mistake. They only released on major upgrade, the Amiga 3000 in 1990 but otherwise let the market stagnate. This let Apple and Microsoft to quickly gain market-share in the workplace and by mid 90’s to start overtaking the home-computer market. Commodore released the Amiga 4000T, but only actually sold an estimated 200 computers before going out of business. (Knight, Gareth 2003d)

Processor Modes

The Amiga OS is designed to work with Motorola processors. For example, the A1200 Model runs the 68EC020 processor and the A4000/030 models run with the 68EC030 processor. Both of these processors are crippled versions of Motorola’s 680X0 processors that are cheaper. The only difference with the 68EC020 and the 68020 is that the first can only address 16 Mb of memory, only allowing for 10 Mb of RAM. The 68EC30 is not so lucky. The 68030 has a memory management unit, MMU that its’ crippled brother does not have. The most important applications that depend on this MMU are a debugging utility called Enforcer, a virtual memory emulator called GigaMem and the current versions of UNIX. A way around this limitation is to install an additional processor card of the 68030, 68040, or 68060. The Motorola 68LC040 is also used in Amiga’s. This processor is a crippled 68040 that doesn’t have Floating Point Operations (FPU) (Kellerer, 1996).

The Amiga also uses custom co-processors. Two such places in which these co-processors are used are the keyboard and the display. The display co-processor utilizes its ability to change the majority of the special purpose registers to synchronize with the video beam’s position. This allows for special effects such as mid-screen color pallet changes and splitting the screen into different horizontal slices which each have separate color depths and video resolution. For 68000 Models and above the specialized co-processor can trigger at the start or even during the blanking interval and while in the middle of lines. This ability to affect the custom chipset's registers frees up the main processor for the general tasks (Amiga Relm Smart Directory Service, 2000). These custom processors are set up as master and slave, but for the newest release of Amiga (4.0) Symmetric Multiprocessing (SMP) are planned (Wang, 1999).

Also to help out the processor (available for 68000 and above) is the custom bit blitter. The blitter is used for fast data movement that can be needed for bitplane animation. A special mode of the blitter can draw patterned lines to memory regions organized rectangularly at speeds of approximately 1 million dots per second, efficiently handling area fill. The blitter can also acquire information from up to three data sources, use one out of a possible 256 ways to combine the data and use an optional destination area to store it. Even though the blitter does draw memory cycles to a DMA channel, it makes the job much more efficient (Amiga Relm Smart Directory Service, 2000).

Data Structures

One of the more common data structures used by Commodore in their Amiga OS is the RexxStack. This is an elaborately designed stack that has also been used in other operating systems like OS/2 and UNIX as not only the go-between for applications but also for going between the operating system, shell, and applications. It is said that “In UNIX speak, it is similar to a daemon able to funnel data between separate applications and perhaps the shell itself.” According to Ioannis Tambouras the RexxStack differs from a typical stack for these reasons.

“(a) It contains buffers within the stack, and stack operations

can be applied within a region of the stack,

(b) It support multiple stacks in stack- within-stack fashion,

(c) It supports both a Perlish and Rexx syntax -- the Rexx syntax

is probably simpler.

(d) The stack scope can be internal to the application (as usual), or

the Stack can run as a daemon to enable sharing of data between

network applications, or you could use both the internal plus the

networking stacks at the same time.(Tambouras, 2003).”

Introduced in Amiga 2.04 a different handler was used for data passing between programs officially called the ‘L:Queue-Handler’ but commonly called the ‘PIPE’. This ‘pipe’ is similar to what is used in UNIX to take one program’s output and pass it to another program for input. It is different from UNIX’s ‘pipes’ in three ways. Firstly, it is a device, meaning the in/output of a program using ‘pipes’ does not have to be, although usually is, redirected standard output. ‘Pipes’ can also be used as files, except a directory which cannot be directly read and it also cannot be ‘seek’ed in. Secondly, the flush operation is not supported. If all the data inside a ‘pipe’ is not outputted it will stay. Therefore, a ‘pipe’ must always be emptied before closing. The second difference leads to the third which is that if non-outputted data is bigger then the internal buffer of the ‘pipe’ the application writing to it will block until the data is outputted. The default buffer size is 4096 bytes but can be specified to a different number in the handler name as can the number of buffers. Multiple, simultaneous ‘pipes’ can be specified by different numbers and are used to link several programs. Two of the biggest advantages of the ‘pipe’ are the freeing of RAM from having to keep the files temporarily, which keeps the system running faster then when storing the intermediate data between programs occurs on the hard drive(Kellerer, 1996).

Allowable Process States

There is barely any public information out about the process states on the Amiga operating system. The Amiga operating system keeps two separate queues, one for processes that are waiting and another for those that are currently running. Processes are referred to as states in Amiga. Therefore the waiting queue contains a list of tasks that are in a wait state because they have been blocked by an input/output request or something similar. Those tasks in the running queue are currently being switched in and out of the processor by the scheduler and have not yet been blocked. The function _TaskEnd will terminate a given task and remove it from any queue. Likewise the TaskStart function will create a new task and place it immediately into the running queue (Carter, 1995).

Threading

Amiga does not support threads in the standard sense of the definition. However, because Amiga is not memory protected and it supports both semaphores and a inter process message system, it is possible to achieve a similar effect. Amiga has the ability to lock resources and queue tasks that are waiting for the resource through its semaphore system and message system. Tasks may be exclusively locked or shared locked. The latter would be used in the instance that a space in memory needs to be read by multiple tasks and only written to by one. ObtainSemaphore() and ObtainSemaphoreShared() provide exclusive and shared locking respectively. A task may wait without being blocked by using Procure(). If the resource isn’t available at the time of Procures call then the task may continue to run or wait as necessary until it receives a bid Message at its reply port. A bid Message is sent when the last task to Procure() a resource calls Vacate(). Semaphores may be nested if a task calls ObtainSemaphore() or Procure() more than once.

Using the message system tasks can be nearly synchronized. PutMsg() sends a reference rather than copying a Msg, which is much quicker than some systems found in today’s monolithic PC desktops (Windows). This is a product of Amiga’s lack of memory protection, which has the downside of low security. PutMsg() attaches a message to a MsgPort and a Msg may only be attached to one port at a time. However, because Msgs are passed by reference a Msg may be passed from the MsgPort of one task to the next very quickly resulting in near synchronization.

Memory management: memory model, and implementation details

Exec

The original Amiga operating system started out in three parts. The first part was the multi-tasking kernel called ‘Exec’, then AmigaDOS proper which handled the high-level file system and command line interface, and finally, Intuition, which is the graphical user interface. Exec, written in 68K assembly (Amiga Inc, Hyperion 2002 ), is object oriented by design and by using inheritance extensively, is able to reduce redundancy. The memory management of Exec is based on a simple list of free memory space. The list itself, as with most lists in Exec, is based on doubly linked lists. Each node in the doubly linked list contains a miniNode which in turn contains a miniList. The miniList, like the main list is doubly linked, but it also uses dummy nodes at the head and tail of the list. The previous pointer of the head node points to the same NULL as the next pointer of the tail node.

The free space list starts out as one single node representing all of the free memory available. Memory allocation starts out with the being scanned for the first node that represents a block that is the same size or larger than what is required. Once located, the node is taken and removed from the list. If the block of memory is larger than what was needed, then the left over free space is separated and returned into the list.

There are two problems with the memory management design. One problem is that Exec does not have a list that keeps track of allocated memory and has no ability to return un-needed memory back to the free space list. This means that if a program does not de-allocate its memory using some form of cleanup method, then that part of memory is no longer accessible to the system until it is rebooted. The second problem is with fragmentation which is inherent with this type of design. As nodes are removed from the list and returned to the list, the list itself may become very large and may take a very long period of time to traverse. Again, the only way reset the fragmentation is to restart the computer.