Exec (Amiga) Explained

Exec
Developer:Carl Sassenrath
Family:AmigaOS
Working State:Current
Source Model:Closed source
Latest Release Version:4.1 Final Edition Update 2
Marketing Target:AmigaOS
Language:English
Update Model:Compile from source code
Supported Platforms:Amiga Motorola 68000 series (MC680x0, 68k)
Kernel Type:Microkernel
Ui:Command-line interface
License:Proprietary

Exec is the kernel of AmigaOS. It is a 13 KB multitasking microkernel which enabled pre-emptive multitasking in as little as 256 KB of memory (as supplied with the first Amiga 1000s). Exec provided functions for multitasking, memory management, and handling of interrupts and dynamic shared libraries.[1] [2]

It acts as a scheduler for tasks running on the system, providing pre-emptive multitasking with prioritized round-robin scheduling. Exec also provides access to other libraries and high-level inter-process communication via message passing. Other comparable microkernels have had performance problems because of the need to copy messages between address spaces. Since the Amiga has only one address space, Exec message passing is quite efficient. The only fixed memory address in the Amiga software (address 4) is a pointer to exec.library, which can then be used to access other libraries. Exec was designed and implemented by Carl Sassenrath.[3]

Exec

Unlike newer modern operating systems, the exec kernel does not run "privileged". Contemporary operating systems for the Motorola 68000, such as Atari TOS and SunOS used trap instructions to invoke kernel functions. This made the kernel functions run in the 68000's supervisor mode, while user software ran in the unprivileged user mode. By contrast, exec function calls are made with the library jump table, and the kernel code normally executes in user mode. Whenever supervisor mode is needed, either by the kernel or user programs, the library functions Supervisor or SuperState are used.

One limit of the Exec kernel was that an uncooperative program could disable multitasking for a long time, or indefinitely, by invoking Exec's calls Forbid or Disable, with no later invocation of corresponding Permit or Enable, causing the environment to run as one task. Multitasking could also be disabled by programs which, by software bug or intent, modify Exec's data structures or the code stored in random-access memory (RAM), possibly due to lack of memory management unit (MMU) support.

Even with such limits, Exec satisfies the definition of preemptive scheduling algorithm, using a preemptive scheduling routine and basing its interrupt intervals on a clock.[4]

Linux kernel developer Linus Torvalds once described the Amiga design as cooperative,[5] even though it uses a preemptive scheduling policy. The reason for that, he argued, was because the lack of [memory] protection between tasks, meant a task could hinder the system from operating preemptively. As tasks would need to choose not to stop the preemptive mechanism this would reduce to a kind of inverted cooperative system. This kind of conflation between protection and scheduler policy is nonstandard.

ExecSG

ExecSG (Second Generation) is the kernel used by AmigaOS 4. This kernel was licensed by Hyperion Entertainment from Thomas Frieden and Hans-Jörg Frieden.[6] It exposes the same functions and structures as the Amiga Exec kernel but runs on PowerPC processors only. The ultimate origin of ExecSG is unspecified.

External links

Notes and References

  1. Book: Sassenrath, Carl . 1986 . Amiga ROM Kernel Reference Manual . Exec.
  2. News: Holloway . Tim . January 1991 . The Object-Oriented Amiga Exec: The design of the Amiga operating-system kernel follows the rules of object-oriented programming . . January 1991 . 329–332, 234 . 0360-5280 . Byte.
  3. Web site: Carl Sassenrath . 2022-05-23 .
  4. Book: Stallings, William . 2009 . Operating Systems - Internals and Design Principles . . 6th . Upper Saddle River, NJ . 9788120336292.
  5. Torvalds . Linus . October 17, 1996 . Jalleen mahtava uusi keksinto m$oftilta . Again, a great new invention from M$ . fi . sfnet.atk.sodat . 545idd$3fj@linux.cs.Helsinki.FI . The Amiga is "pseudo-pre-emptive" multitasking, which Amiga people call pre-emptive, but it really is not. WinNT in this regard, is light years ahead. ... due to lack of memory protection. Any program can take possession of the machine completely and thus prevent multitasking. Multitasking in Amiga is co-operative because it requires approval and help from running applications [... muistinsuojauksen puutteen vuoksi. Mikä tahansa ohjelma voi ottaa koneen haltuunsa täysin ja estää siten moniajo. Eli Amigan moniajo on kooperatiivinen, koska se vaatii sen että ajettavat ohjelmat hyväksyvät sen moniajon ja auttavat sitä] . February 25, 2011 .
  6. Web site: Justia: Hyperion Entertainment vs. Amiga Inc..