Documenti di Didattica
Documenti di Professioni
Documenti di Cultura
Oberon System
Implemented on a
Low-Cost FPGA Board
by Niklaus Wirth
Professor (retired)
Swiss Federal Institute of Technology (ETH)
Zurich, Switzerland
wirth@inf.ethz.ch
I
n 1988, Jürg Gutknecht and I completed
and published the programming language
A Xilinx Spartan-3 board Oberon [1,2] as the successor to two oth-
er languages, Pascal and Modula-2, which
becomes the basis for I had developed earlier in my career. We
originally designed the Oberon language to be
revamping the author’s more streamlined and efficient than Modula-2 so
that it could better help academics teach system
Oberon programming programming to computer science students. To
advance this endeavor, in 1990 we developed the
language and compiler for Oberon operating system (OS) as a modern im-
plementation for workstations that use windows
use in software education. and have word-processing abilities. We then
published a book that details both the Oberon
compiler and and the operating system of the
same name. The book, entitled Project Oberon,
includes thorough instructions and source code.
A few years ago, my friend Paul Reed suggest-
ed that I revise and reprint the book because
of its value for teaching system design, and be-
cause it serves as a good starting point to help
would-be innovators build dependable systems
from scratch.
There was a big obstacle, however. The com-
piler I originally developed targeted a processor
that has essentially disappeared. Thus, my solu-
tion was to rewrite a compiler for a modern pro-
cessor. But after doing quite a bit of research, I
couldn’t find a processor that satisfied my cri-
teria for clarity, regularity and simplicity. So I
designed my own. I was able to bring this idea
to fruition because of the modern FPGA, as it
RISC5TOP
RISC5
The parser calls procedures in the ported variables. The base addresses are
ORP parser 968
code generator module. They direct- loaded on demand from a system-glob-
ORG code generator 1120
ly append instructions in a code array. al module table, whose address is held
ORB base def 435
Forward-branch instructions are pro- in register R12. R15 is used for return
ORS scanner 311
vided with jump addresses at the end of addresses (link), as determined by the
a module’s compilation (fixups), when RISC architecture. Thus, R0 - R11 are The compiler occupies 115,912
all branch destinations are known. available for expression evaluation and bytes (22 percent) of the module
All variable addresses are relative to a for passing procedure parameters. space and 17,508 bytes (4 percent) of
base register. This is R14 (stack pointer) The entire compiler consists of four the heap (before any compilation). Its
for local variables (set at procedure en- relatively small and efficient modules source code is about 65 kbytes long.
try at run-time), or R13 for global and im- (line counts shown): Compilation of the compiler itself
takes only a few seconds on the 25- operations must be restricted to driver portant advantage is the presence of
MHz RISC processor [8]. modules accessing device interfaces, and static RAM on this board, which makes
The compiler always generates checks they are easily recognized by SYSTEM interfacing straightforward (even for
for array indices and for references in their import lists. The entire system is byte selection). Unfortunately, newer
through pointers with value NIL. It caus- programmed in Oberon itself, and no use boards all feature dynamic RAM, which
es a trap in case of violation. This tech- of assembler code is required. is, albeit larger, very much more compli-
nique ensures a high degree of security I chose the Digilent Spartan-3 devel- cated to interface, requiring circuits for
against errors and corruption. In fact, sys- opment board because of its low cost refresh and initialization (calibration).
tem integrity can be violated only by the and simplicity, which makes it suitable This circuitry alone can be as complex
use of operations in the pseudo-module for educational institutions to acquire as the entire processor with static RAM.
SYSTEM, namely PUT and COPY. These sets of the kits for classrooms. An im- Even if a controller is provided on-chip,
this counteracts our principle of laying ence and technology, students are paradigm. Here the student was asked
everything open for inspection. exposed to many master examples of to write programs right from the start,
design before they are asked to exper- before having read any examples.
CLOSING THOUGHTS iment with their own attempts. Pro- The reason for this dire fact was
More than 40 years ago, C.A.R. Hoare gramming and software design stood that there existed almost no litera- RISC
remarked that in all branches of sci- in marked contrast to this sensible ture with sizable master examples. I
therefore decided to remedy the situ-
ation somewhat, and I wrote the book
on Algorithms and Data Structures
in 1975. Subsequently (with J. Gut- RS
knecht), having been charged with
the task of teaching a course on oper-
System ating systems, I designed the system
Oberon (1986-88).
Since then, the teaching of pro-
gramming has not markedly improved,
TextFrame whereas systems have dramatical-
ly increased in size and complexity.
Although the open-source endeavor
is to be welcomed, it has not really
changed the situation, since most pro-
MenuView grams have been constructed “to run,”
but not really for human consump-
tion, for being understood.
I continue to make the daring pro-
Oberon posal that all programs should be de-
signed not just for computers, but for
human reading. They should be pub-
lishable. This is a task much harder
Viewers Texts Input than creating executable programs,
even correct and efficient ones. It im-
plies that no part must be specified in
assembler code.
The result of ignoring this “hu-
Display Modules Fonts man factor” is that in many places
new applications are not carefully
designed, but rather debugged into
existence, sometimes with dismal
Files consequences. An important ingredi-
ent to achieve understandability is to
adhere to simplicity and regularity,
and to renounce unnecessary embel-
lishments, to avoid bells and whistles
FileDir
and to distinguish between conven-
tional and convenient.
The small size of this system is wit-
ness to how much can be achieved
Kernel with how little. The Oberon system’s
dimensions are ridiculously small
compared with most modern oper-
ating systems, although it includes a
Figure 3 – The system and its modules file system, a text editor and a viewer
(windows) management. The side ef-
Multiplier
36 Xcell Journal Second Quarter 2015
XPERIMENT
That’s Genius!
Realize the Genius of
Your Design with S2C’s
Prodigy Prototyping Platform