Not Another Completely Heuristic Operating System
This article includes a list of references, but its sources remain unclear because it has insufficient inline citations. (November 2009) (Learn how and when to remove this template message)
|Developer||Thomas Anderson at University of California, Berkley|
|License||Berkeley Software Distribution|
Not Another Completely Heuristic Operating System, or Nachos, is instructional software for teaching undergraduate, and potentially graduate level operating systems courses. It was developed at the University of California, Berkeley, designed by Thomas Anderson, and is used by numerous schools around the world.
Originally written in C++ for MIPS, Nachos runs as a user-process on a host operating system. A MIPS simulator executes the code for any user programs running on top of the Nachos operating system. Ports of the Nachos code exist for a variety of architectures.
In addition to the Nachos code, a number of assignments are provided with the Nachos system. The goal of Nachos is to introduce students to concepts in operating system design and implementation by requiring them to implement significant pieces of functionality within the Nachos system.
In Nachos' case, Operating System simulator simply means that you can run an OS (a guest OS) on top of another one (the host OS), similar to Bochs/VMWare. It features emulation for:
- A CPU (a MIPS CPU)
- A hard drive
- An interrupt controller, timer, and misc. other components
which are there to run the Nachos user space applications. That means that you can write programs for Nachos, compile them with a real compiler (an old gcc compiler that produces code for MIPS) and run them. The Nachos kernel instead is compiled to the platform of the Host OS and thus runs natively on the Host OS' CPU.
Nachos version 3.4 has been the stable, commonly used version of Nachos for many years. Nachos version 4.0 has existed as a beta since approximately 1996.
Nachos has various modules implementing the functionality of a basic operating system. The wrapper functions for various system calls of the OS kernel are generally implemented in a manner similar to that of the UNIX system calls
. Various parts of the OS are instantiated as objects using the native code. For example, a class
Machineis used as the master class of the simulated machine. It contains various objects, such as
Timer, etc. which are defined to simulate various hardware aspects.
NachOS Machine - Nachos simulates a machine that roughly approximates the MIPS architecture. The machine has registers, memory and a cpu. The Nachos/MIPS machine is implemented by the Machine object, an instance of which is created when Nachos starts up. It contains methods like Run, ReadRegister, WriteRegister, etc. It also defines an interrupt object to handle interrupts. Timer and statistics are also implemented in this.
NachOS Threads - In NachOS a thread class has been defined. A thread has an associated state with it which maybe ready, running, blocked or just created. The thread object has various methods like PutThreadToSleep, YieldCPU, ThreadFork, ThreadStackAllocate, etc. Each thread runs at a virtual address space.
NachOS UserPrograms - Nachos runs user programs in their own private address space. Nachos can run any MIPS binary, assuming that it restricts itself to only making system calls that Nachos understands. In Unix, "a.out" files are stored in "coff" format. Nachos requires that executables be in the simpler "Noff" format. To convert binaries of one format to the other, use the coff2noff program.
As Nachos has not been in active development for a number of years, and possesses a number of recognized flaws (particularly with regards to portability: Nachos relies on MIPS assembly code, and requires porting to run on x86 architecture), successor projects have been initiated. In 2004, Stanford University created Pintos, a Nachos-inspired system written in C and designed to run on actual x86 hardware. In 2000, Dan Hettena at UC Berkeley ported Nachos to Java as Nachos 5.0j, in an effort to make Nachos more portable, more accessible to undergraduates, and less susceptible to subtle bugs in student code that had in earlier versions often dominated student project development time. Another Java-based version was created by Professor Peter Druschel at Rice University. It was later adapted by Professor Eugene Stark at Stony Brook University in 2003 and applied in the Operating System course. At Graz University of Technology (Austria), a system called SWEB ("Schon wieder ein Betriebssystem") has been implemented and is used to teach operating system principles.
- Nachos Home Page
- Original Usenix 1993 paper by Christopher, Procter, and Anderson.
- Extensive writeup on Nachos
- Thomas Narten's Nachos Roadmap
- Nachos for Java Walkthrough
- JNachos Home Page, another Java-based version; ported by Patrick J. McSweeney and WonKyung Park
- "Guide to Nachos, University of Pittsburgh". Retrieved 2014-02-17.
- "Compiling C and C++ Programs, University of Wisconsin". Retrieved 2014-02-17.
- "Nachos Beginner's Guide, Level 2: System calls and exceptions, Linköping University". Retrieved 2014-09-09.
- "Machine Class at Nachos Documentation, University of California, Berkeley". Retrieved 2014-09-09.
- "A road map through NachOS, Duke University". Retrieved 2015-05-05.