Jump to content

HelenOS: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
m not a modifier
Update latest version and release date
Line 6: Line 6:
| caption =
| caption =
| family = Multiserver operating systems
| family = Multiserver operating systems
| latest_release_version = 0.9.1
| latest_release_version = 0.11.1
| latest_release_date = {{Start date and age|2019|05|11}}
| latest_release_date = {{Start date and age|2021|03|29}}
| programmed in = [[C (programming language)|C]]
| programmed in = [[C (programming language)|C]]
| kernel_type = [[Microkernel]]
| kernel_type = [[Microkernel]]

Revision as of 20:57, 29 March 2021

HelenOS
Written inC
OS familyMultiserver operating systems
Source modelOpen source
Latest release0.11.1 / March 29, 2021; 3 years ago (2021-03-29)
Repository
PlatformsIA-32, AMD64, IA-64, ARM, MIPS, PowerPC, SPARC V9, RISC-V
Kernel typeMicrokernel
LicenseBSD
Official websitewww.helenos.org

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), SPARC V9 and RISC-V.[11] 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[12][13] 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.[14]

References

  1. ^ hpr1447 :: HPR Coverage at FOSDEM 2014 Part 1/5
  2. ^ HelenOS Micro-Kernel OS Still Marching On
  3. ^ HelenOS - the operating system that launched a thousand processes, DistroWatch Weekly, Issue 350, 19 April 2010
  4. ^ HelenOS nikdy nebude dokončený, říká jeho autor Jakub Jermář
  5. ^ HelenOS Contributors measured by Ohloh
  6. ^ List of projects accepted into Google Summer of Code 2011
  7. ^ List of projects accepted into Google Summer of Code 2012
  8. ^ List of projects accepted into Google Summer of Code 2014
  9. ^ "Selected mentoring organizations". Archived from the original on 2017-07-16. Retrieved 2020-01-11.
  10. ^ HelenOS analysis by Ohloh
  11. ^ FOSDEM (2019-02-11), Lessons learned from porting HelenOS to RISC-V Pros and cons of RISC-V from a microkernel OS point …, retrieved 2019-02-25
  12. ^ Institutional research plan MSM0021620838 - Modern methods, structures and systems of computer science (2005-2011, MSM)
  13. ^ Research @ D3S
  14. ^ Defended HelenOS theses at Faculty of Mathematics and Physics, Charles University in Prague[permanent dead link]