Oberon (operating system)
The Oberon System is a modular, single-user, single-process, multitasking operating system written in the programming language of the same name. It was originally developed in the late 1980s at ETH Zürich. The Oberon System has an unconventional visual text user interface instead of a conventional CLI or GUI. This "TUI" was very innovative in its time and influenced the design of the Acme text editor for the Plan 9 from Bell Labs operating system.
The latest version of the Oberon System, Project Oberon 2013, is still maintained by Niklaus Wirth and a number of collaborators but older ETH versions of the Oberon Systems have been orphaned. The Oberon System also evolved into the multi-process, SMP-capable Bluebottle operating system, with a zooming user interface.
History
The Oberon operating system was originally developed as part of the NS32032-based Ceres workstation project. It was written almost entirely in the Oberon programming language.The basic system was designed and implemented by Niklaus Wirth and Jürg Gutknecht and its design and implementation is fully documented in their book "Project Oberon". The user Interface and programmers reference is found in Martin Reiser's book "The Oberon System". It was later extended and ported to other hardware
by a team at ETH-Zürich and there was recognition in popular magazines.
Wirth and Gutknecht referred to themselves as 'part-time programmers' in the book 'Project Oberon'. In late 2013, a couple of months before his 80th birthday, Niklaus Wirth published a second edition of Project Oberon. It details the implementation of the Oberon System using a RISC CPU of his own design realized on a Xilinx FPGA board. It was presented at the symposium organized for his 80th birthday at ETHZ. In the meantime several emulators for this version were implemented.
According to Josef Templ, a former member of the developer group at Eidgenössische Technische Hochschule, Zürich and later member of the "Institut für Systemsoftware" of Johannes Kepler University of Linz, where one of the versions was maintained, the genealogy of the different versions of the Oberon System was the following:
User interface
Oberon has a text user interface, which has to be differentiated from the terminal user interface. It combines the point-and-click convenience of a graphical user interface with the linguistic strength of a command line interface and is closely tied to the naming conventions of the Oberon language. Any text appearing anywhere on the screen can be edited and can therefore be used as command input. Commands are activated by a middle-mouse click on a text fragment of the form Module.Command. A command is defined by any procedure which is exported and has an empty argument list. Parameters to the command have to be defined before executing the middle click and must be explicitly scanned and retrieved by the procedure. There are no checks nor any questions asked during command execution. This is sometimes called a "non-modal" user interface. Nothing like a command prompt is required.Although radically different from a command line, the TUI is very efficient and powerful. A steep ascent in the early learning curve makes it a little bit difficult in the beginning. No questions are asked: this is a deliberate design decision, which needs getting used to. Most editors ask the user when closing a modified text: this is not the case in the Oberon System. The usage of the TUI and programming interface is fully documented in Martin Reiser's book "The Oberon System". A short introduction to the user interface can be found on Niklaus Wirth's home page. The later Versions of System Oberon, Oberon V4 and Oberon System 3, enhanced the basic interface with different but incompatible implementations for buttons, drop down menus, and other active elements. V4 used for that purpose a dedicated control character embedded in normal text in contrast to System 3, which extended the kernel by introducing persistent objects. Both extensions include a large set of user interface elements.
Mastering the Oberon user interface, both the purely textual and also the so-called Gadgets System, is absolutely non-trivial. Therefore, it is recommended to proceed after a successful installation of Oberon System 3 to André Fischers . An expanded version of this tutorial was published as a book, which it is out of print now. The whole book is available in electronic form under a single user license in every installed version of System 3. More information how to get your own copy of the Oberon Companion may be found in the section of the Oberon Wikibook.
Similar user Interfaces have yet to appear in more commonplace operating systems. Rob Pike's Acme system under Plan 9 from Bell Labs was strongly inspired by the Oberon TUI. Whether the worksheet interface of the Macintosh Programmer's Workshop influenced Oberon's TUI or vice versa is difficult to decide: the Oberon System was based on Wirth's previous computer design the Lilith, and both the Apple Macintosh and the Oberon System have the same roots: they were all inspired by the Alto developed at Xerox PARC.
Versions and availability
V1 was the first usable version some time before the Oberon Trilogy was published. A major change in the text model together with the editor called Write yielded V2. As foreshadowed in the table in section history above there was a major fork in the beginning of 1990s: V4 vs. System 3: The group around Jürg Gutknecht introduced persistent objects and object-libraries thereby extending the kernel. The group around :de:Hanspeter Mössenböck|Hanspeter Mössenböck realized similar features by introducing active elements mapped to a special character thereby extending fonts without changing the kernel. System 3 was sometimes also called Spirit of Oberon and later renamed to ETH Oberon, whereas V4 was sometimes also called Linz Oberon.. As of 2017 the Oberon OS is available for several hardware platforms, generally in no cost versions and from several sources, which is quite confusing. The Oberon OS is typically extremely compact. Even with an Oberon compiler, assorted utilities including a web browser, TCP/IP networking, and a GUI, the entire package can be compressed to a single 3.5" floppy disk. There are/were versions which emulated the Oberon OS on top of another operating system and versions which run on bare hardware. The latter ones are called Native Oberon. There are/were native versions for the Ceres, Intel IA-32, and ARM platforms. In 2013 Niklaus Wirth adapted the basic system as described in "Project Oberon" to a current FPGA design. According to the preface of the 2013 edition, the whole system compiles in less than 10 seconds on a Spartan-3 board. This version is sometimes also called V5, despite it being much more similar functionally to the original V1 running on the Ceres than any of the later versions.
A version of the Oberon System 3, which was integrated in the Microsoft Windows OS was called Plugin Oberon. Plugin Oberon supported the binary format called OMI aka "slim binaries", which allowed portable object code between Intel x86, Motorola 68K, and PowerPC architectures. Slim binaries were invented by Michael Franz in the early 1990s. They were motivated and opposed to the "fat binaries" invented by Apple during the transition from 68K to PowerPC architectures. OMI provided portable code based on a compressed version of the abstract syntax tree. The approach of a compressed abstract syntax tree is revived for Graal and Truffle.
The version called Oberon V4 is closer to the original operating system developed by N. Wirth & J. Gutknecht. It was originally developed at ETHZ, but when H.P. Mössenböck went to the development of V4 moved also. Therefore, V4 is sometimes also called Linz-Oberon in contrast to ETH-Oberon. The most recent version of V4 and extensions are available at . Oberon V4 appears to be orphaned, there are almost no changes since 2000. Another repository of V4 is Claudio Nieder's , which also shows difference between the different V4 implementations. Since 2013 this page moved to/is mirrored at . V4 is closer to what would now be called an integrated development environment than an operating system of its own. There were many extensions written for V4, which are still available from the ; some documentation can be found on their , more information is normally included in the packages and it is given in Oberon's special rich text format.
Around 2010, the computer science department at ETH Zurich has begun exploring active objects and concurrency for operating systems, and has released an early version of a new language Active Oberon and a new operating system for it, first called AOS and — due to copyright issues — now called A2, and/or Bluebottle. It is available from ETH Zurich with most source via the Internet. Native versions, i.e. running on the bare hardware, are currently possible for Intel IA-32 and X86-64 single- and multi-processor systems and for the StrongARM CPU family, versions running on top of another operating system are available on Windows, Unix, Linux, and OS-X. More detailed information about A2 can be found on the :ru:A2 |russian Wikipedia pages about A2.
As a part of an industrial research project the Native Systems Group of ETH Zurich has developed an application-specific operating system called stailaOS which is based on the latest version Oberon OS. It is targeted towards applications like real-time analytics, high performance trading systems, main memory based ERP etc.
Native Oberon
Native Oberon stands for the Oberon System running on bare hardware. PC-Native Oberon is the version of the Oberon operating system which runs on IA-32 PC hardware. There has never been a V4 Native Oberon, so every information here in this section implicitly assumes that it is System 3. Native Oberon has minimal hardware requirements. The basic system runs from a single HD-Floppy and additional software can be installed through the network. The full installation includes the Gadgets GUI. It is written completely in the Oberon programming language.A version called LNO, which uses Linux as hardware abstraction layer also exists. Its goal was to be as compatible as possible to PC-Native Oberon. Other versions of the Oberon System, i.e. without Native in the name, had partially modified interfaces of low level modules. In 2015 Peter Matthias revitalized LNO under the Name OLR as a multi-platform Distribution running seamlessly under Intel x86, RISC-V, MIPS, and ARM. It runs nicely on the Raspberry Pi and on the inexpensive CHIP computer; with some tweaking it runs nicely under Tiny Core Linux. OLR interfaces with Linux kernel by direct System calls. OLR currently misses a network layer.
Project Oberon 2013
In 2013 Niklaus Wirth and Paul Reed completed a re-implementation of the original Oberon System for the Digilent Xilinx Spartan 3 FPGA Starter Board. The work includes a revision of "Project Oberon", identified as . In 2015 Paul Reed collaborated with Victor Yurkovsky in the creation of , a Xilinx Spartan 3-based computer designed specifically to run Oberon. The system has since been ported to a Xilinx Spartan 6 FPGA Development Board by . Peter de Wachter implemented an for it, which was also ported to by Michael Schierl, running in , and ported to Free Pascal/ by . Andreas Pirklbauer maintains an and extensions of Project Oberon 2013 at GitHub.Gallery
Glossary
A2, Yet another name for the Active Object System, 2003.ALO, ARM Linux Oberon; in LNO family and for ARM CPU.
AOS, Active Object System, 2002. Renamed to A2 because of rumored copyright issues.
BB, BlackBox Component Builder. Component Pascal IDE from .
Bluebottle OS, And again another name for the Active Object System, 2003.
CP, Component Pascal. A dialect in the Oberon family most similar to Oberon-2.
ETHO, Oberon as developed at Eidgenössische Technische Hochschule Zürich.
, The compiler for Active Oberon, appearing in AOS.
LEO, Linux ETH Oberon. ETHO 2.4.3 for Linux x86.
LNO, Linux Native Oberon.
NO, Native Oberon. Oberon running on bare hardware rather than atop another operating system.
OLR, Oberon Linux Revival. A version of NO which uses Linux as a HAL and runs on x86, ARM, and MIPS.
OP2, The Portable Oberon-2 Compiler. OP2 was developed to port Oberon onto commercially available platforms.
PACO, PArallel COmpiler. Appears in A2. Compiles each scope in an independent thread.
RISC5, the CPU of Project Oberon 2013 based upon Wirth's RISC architecture. Not to be confused with RISC-V.
UnixAOS, Unix-based AOS.
WinAOS, Windows-based AOS.