Inferno (operating system)
From Wikipedia, the free encyclopedia
Inferno 4th Edition |
|
Company / developer | Bell Labs / Vita Nuova Holdings |
---|---|
OS family | "Unix successor" |
Working state | Current |
Source model | Free Software / Open source |
Latest stable release | Fourth Edition / February 2, 2007 |
Supported platforms | x86, MIPS, ARM, PowerPC, SPARC |
Kernel type | Virtual machine |
License | GPL / LGPL / MIT |
Website | Vita Nuova |
Inferno is an operating system for creating and supporting distributed services. It was based on the experience of Plan 9 from Bell Labs, and the further research of Bell Labs into operating systems, languages, on-the-fly compilers, graphics, security, networking and portability.
Inferno applications are portable across a broad mix of hardware, networks, and environments. It defines a virtual machine (Dis) that can be implemented on any real machine, provides a type-safe language (Limbo) that is compiled to portable byte code, and, more significantly, it includes a virtual operating system that supplies the same interfaces whether Inferno runs natively on hardware or is hosted as an application on other systems.
A communications protocol called Styx is applied uniformly to access both local and remote resources, which applications use by calling standard file operations, open, read, write, and close. As of the fourth edition of Inferno, Styx is identical to Plan 9's newer version of its hallmark 9P protocol, 9P2000.
The name of the operating system and of its associated programs, as well as of the company Vita Nuova Holdings that produces it, were inspired by the literary works of Dante Alighieri, particularly the Divine Comedy.
Contents |
[edit] Design principles
Inferno was first made in 1995 by members of Bell Labs' Computer Science Research division to bring ideas of Plan 9 from Bell Labs to a wider range of devices and networks. Inferno is a distributed operating system based on three basic principles drawn from Plan 9:
- Resources as files: all resources are represented as files within a hierarchical file system
- Namespaces: the application view of the network is a single, coherent namespace that appears as a hierarchical file system but may represent physically separated (locally or remotely) resources
- Standard communication protocol: a standard protocol, called Styx, is used to access all resources, both local and remote
To handle the diversity of network environments it was intended to be used in, the designers decided a virtual machine was a necessary component of the system. This is the same conclusion of the Oak project that became Java, but arrived at independently. The Dis virtual machine is a register machine intended to closely match the architecture it runs on, as opposed to the stack machine of the JVM. An advantage of this approach is the relative simplicity of creating a just-in-time compiler for new architectures.
The virtual machine provides memory management designed to be efficient on devices with as little as 1 MB of memory and without memory-mapping hardware. Its garbage collector is a hybrid of reference counting and a real-time coloring collector that gathers cyclic data.
The Inferno kernel contains the virtual machine, on-the-fly compiler, scheduler, devices, protocol stacks, and the namespace evaluator for each process' file namespace, and the root of the filesystem hierarchy. The kernel also includes some builtin modules that provide interfaces of the virtual operating system, such as system calls, graphics, security, and math modules.
The Bell Labs Technical Journal paper[1] introducing Inferno listed the several dimensions of portability and versatility provided by the OS,
- Portability across processors: it currently runs on Intel, Sparc, MIPS, ARM, HP-PA, and PowerPC architectures and is readily portable to others.
- Portability across environments: it runs as a stand-alone operating system on small terminals, and also as a user application under Windows NT, Windows 95, Unix (Irix, Solaris, FreeBSD, Linux, AIX, HP/UX) and Plan 9. In all of these environments, Inferno applications see an identical interface.
- Distributed design: the identical environment is established at the user's terminal and at the server, and each may import the resources (for example, the attached I/O devices or networks) of the other. Aided by the communications facilities of the run-time system, applications may be split easily (and even dynamically) between client and server.
- Minimal hardware requirements: it runs useful applications stand-alone on machines with as little as 1 MB of memory, and does not require memory-mapping hardware.
- Portable applications: Inferno applications are written in the type-safe language Limbo, whose binary representation is identical over all platforms.
- Dynamic adaptability: applications may, depending on the hardware or other resources available, load different program modules to perform a specific function. For example, a video player application might use any of several different decoder modules.
These design choices were directed to provide standard interfaces that free content and service providers from concern of the details of diverse hardware, software, and networks over which their content is delivered.
[edit] History
Date | Release | Comment |
---|---|---|
1996 | Inferno Beta | Released by Bell Labs |
May 1997 | Inferno Release 1.0 | Winter 1997 Bell Labs Technical Journal Article |
July 1999 | Inferno 2nd Edition | Released by Lucent's Inferno Business Unit |
June 2001 | Inferno 3rd Edition | Released by Vitanuova |
2004 | Inferno 4th Edition | Open Source release; changes to many interfaces (incompatible with earlier editions); includes support for 9P2000. |
Inferno is a descendant of Plan 9, and shares many design concepts and even source code in the kernel, particularly around devices and the Styx/9P2000 protocol.
Inferno shares with Plan 9 the Unix heritage from Bell Labs and the Unix philosophy. Many of the command line tools in Inferno were Plan 9 tools that were translated to Limbo.
In March-April 1997 IEEE Internet Computing included an ad for Inferno networking software. It claimed that various devices could now communicate over "any network" including the Internet, telecommunications and LANs. The ad stated that video games could talk to computers (a PlayStation was pictured), cell phones could access email and there was voice mail via TV.
Lucent initially tried to sell source code licenses of Inferno but found few buyers. Lucent did little marketing and missed the importance of the Internet and Inferno's relation to it. During the same time Sun Microsystems was heavily marketing their Java Programming language, which was targeting a similar market, with analogous technology, that worked in web browsers and also filled the demand for object-oriented languages fashionable at that time. Lucent licensed Java from Sun claiming that all Inferno devices would be made to run Java. A Java byte code to Dis byte code translator was written to facilitate that. However, Inferno still did not find customers. The Inferno Business Unit closed after three years and the rights to the system were transferred to Vitanuova, Inferno being a commercial failure for Lucent.
Lucent used Inferno in at least two internal products: the Lucent VPN Firewall Brick, and the Lucent Pathstar phone switch.
Once Vitanuova owned the rights, they continued development and offered commercial licenses to the complete system, and free downloads and licenses (not GPL compatible) for all the system except the kernel and VM. They ported the software to new hardware and focused on distributed applications. Eventually, Vitanuova released the source under the GPLv2 licenses and the Inferno-os is now an open source project.
[edit] Ports
Inferno runs directly on native hardware and also as an application providing a virtual operating system which runs on other platforms. Applications can be developed and run on all Inferno platforms without modification or recompilation.
Native ports include: x86, MIPS, ARM, PowerPC, SPARC.
Hosted or Virtual OS ports include: Microsoft Windows, Linux, FreeBSD, Plan 9, Mac OS X, Solaris, IRIX, UnixWare.
Inferno can also be hosted by a plugin to Internet Explorer. According to Vita Nuova, plugins for others browsers are underway.[2]
Inferno is also ported to OpenMoko [1].
[edit] License
Inferno 4th edition was released in early 2005 as free software. Specifically, it was dual-licensed under two sets of licenses. Users could either obtain it under a set of free software licenses, or they could obtain it under a more traditional commercial license. In the case of the free software license scheme, different parts of the system were covered by different licenses, including the GNU General Public License, the GNU Lesser General Public License, the Lucent Public License, and the MIT License. Subsequently Vita Nuova has made it possible to acquire the entire system (excluding the fonts, which are sub-licensed from Bigelow and Holmes) under the GPLv2. All three license options are currently available.
[edit] Books
The textbook Inferno Programming with Limbo ISBN 0470843527 (Chichester: John Wiley & Sons, 2003), by Phillip Stanley-Marbell, describes the 3rd edition of the Inferno operating system, though it focuses more on the Limbo language and its interfaces to the Inferno system, than on the Inferno system itself. For example, it provides little information on Inferno's versatile command shell, which is understandable since it is a programming language textbook.
Another textbook Principles of Operating Systems: Design and Applications ISBN 1418837695 (Course Technology, 2008), by Brian Stuart, uses Inferno for examples of operating system design.
The book "The Inferno Programming Book: An Introduction to Programming for the Inferno Distributed System", by Martin Atkins, Charles Forsyth, Rob Pike and Howard Trickey, was intended to provide the operating-system-centric point of view, but was unfortunately never completed/released by its authors.
[edit] References
- ^ Bell Labs Technical Journal
- ^ Plugins, Vita Nuova.
[edit] See also
- List of Inferno applications
- Plan 9 from Bell Labs
- Unix
- Language-based system
- JNode
- Singularity (operating system) Similar experimental operating system from Microsoft Research
[edit] External links
- Inferno Project on Google Code
- Inferno Fourth Edition Download, including source code
- Documentation papers for the latest inferno release.
- Other documents of interest.
- Inferno design principles
- Mailing list and other resources
- Screenshots
- Developing with Inferno Blog
- Inferno browser plugin
- Inferno projects at the GSoC.
- Inferno on OLPC
Other links
- Ninetimes: News and articles about Inferno, Plan 9 and related technologies
- Unofficial FAQ
- Inferno programmer's notebook - A journal made by an Inferno user
- Inferno tutorial at the University of Reading e-Science Centre
- Copy of the original Lucent Inferno website
- Archives of the original Inferno mailing list