HelenOS
OS family | Multiserver operating systems |
---|---|
Source model | Open source |
Latest release | 0.8.0 / December 19, 2018 |
Repository | |
Platforms | IA-32, AMD64, IA-64, ARM, MIPS, PowerPC, SPARC V9 |
Kernel type | Microkernel |
License | BSD |
Official website | www |
HelenOS[1][2][3][4] is an operating system based on a multiserver microkernel design. The source code of HelenOS is written in C and published under a BSD License.
Technical overview
The microkernel handles multitasking, memory management and inter-process communication. It also provides kernel-based threads and supports symmetric multiprocessing.
Typical to microkernel design, file systems, networking, device drivers and graphical user interface are isolated from each other into a collection of user space components that communicate via a message bus.
Each process (called task) can contain several threads (preemptively scheduled by the kernel) which, in turn, can contain several fibers scheduled cooperatively in user space. Device and file-system drivers, as well as other system services, are implemented by a collection of user-space tasks (servers), creating thus the multiserver nature of HelenOS.
Tasks communicate via HelenOS IPC, which is connection-oriented and asynchronous. It can be used to send small fixed-size messages, blocks of bytes or to negotiate sharing of memory. Messages can be forwarded without copying bulk data or mapping memory to the address space of middle-men tasks.
Development
HelenOS development is community-driven. The developer community consists of a small core team, mainly staff and former and contemporary students of the Faculty of Mathematics and Physics at Charles University in Prague, and a number of contributors around the world.[5] In 2011, 2012 and 2014, HelenOS participated in the Google Summer of Code as a mentoring organization.[6][7][8] In 2013, the project was a mentoring organization in the ESA Summer of Code in Space 2013 program.[9]
The source code of HelenOS is published under the BSD licence, while some third-party components are available under the GNU General Public License.[10] Both of these licences are free software licences, making HelenOS free software.
Hardware support
HelenOS runs on several different CPU architectures including ARM, x86-64, IA-32, IA-64 (Itanium), MIPS, PowerPC (32-bit only), and SPARC V9. At some point in time[further explanation needed], various versions of HelenOS ran on real hardware from each architecture (as opposed to running only in a simulator of that architecture).
HelenOS supports PATA, SATA, USB mass storage, USB HID, an Atheros USB WiFi dongle, several Ethernet network cards, SoundBlaster 16 and Intel HDA audio devices, serial ports, keyboards, mice and framebuffers.
Research and academic use
HelenOS is being used for research[11][12] in the area of software components and verification by the Department of Distributed and Dependable Systems, Charles University, Prague. Besides that, HelenOS has been used by students as a platform for software projects and master theses.[13]
References
- ^ hpr1447 :: HPR Coverage at FOSDEM 2014 Part 1/5
- ^ HelenOS Micro-Kernel OS Still Marching On
- ^ HelenOS - the operating system that launched a thousand processes, DistroWatch Weekly, Issue 350, 19 April 2010
- ^ HelenOS nikdy nebude dokončený, říká jeho autor Jakub Jermář
- ^ HelenOS Contributors measured by Ohloh
- ^ List of projects accepted into Google Summer of Code 2011
- ^ List of projects accepted into Google Summer of Code 2012
- ^ List of projects accepted into Google Summer of Code 2014
- ^ Selected mentoring organizations
- ^ HelenOS analysis by Ohloh
- ^ Institutional research plan MSM0021620838 - Modern methods, structures and systems of computer science (2005-2011, MSM)
- ^ Research @ D3S
- ^ Defended HelenOS theses at Faculty of Mathematics and Physics, Charles University in Prague
External links
- HelenOS home page
- HelenOS on GitHub