source: mainline/README.md@ f2416ec3

Last change on this file since f2416ec3 was f3a7b0d, checked in by Martin Decky <martin@…>, 5 years ago

Use more appropriate cross-compiler installation locations

The toolchain.sh and configure.sh scripts use the
$XDG_DATA_HOME/HelenOS/cross (i.e. $HOME/.local/share/HelenOS/cross)
location by default now. This allows the cross-compiler to be
installed without super user privileges and thus hopefully lowers the
entry barrier for newcomers.

To install the cross-compiler to a system-wide location, run the
toolchain.sh script with the —system-wide option. The default
system-wide location is /opt/HelenOS/cross now.

The configure.sh script falls back to /opt/HelenOS/cross and the
previously used /usr/local/cross. Thus recompiling an already
installed cross-compiler toolchain is not necessary.

The possibility to override the cross-compiler location using
$CROSS_PREFIX or having the cross-compiler available in $PATH
retained.

  • Property mode set to 100644
File size: 5.0 KB
RevLine 
[23d45152]1# HelenOS
2
3HelenOS is a portable microkernel-based multiserver operating
4system designed and implemented from scratch. It decomposes key
5operating system functionality such as file systems, networking,
6device drivers and graphical user interface into a collection of
7fine-grained user space components that interact with each other
8via message passing. A failure or crash of one component does not
9directly harm others. HelenOS is therefore flexible, modular,
10extensible, fault tolerant and easy to understand.
11
[adc07b5]12![screenshot](http://www.helenos.org/raw-attachment/wiki/Screenshots/screenshot.png "Screenshot")
13
[03bf4fc]14HelenOS aims to be compatible with the C11 and C++14 standards, but does not
15aspire to be a clone of any existing operating system and trades compatibility
16with legacy APIs for cleaner design. Most of HelenOS components have been made
17to order specifically for HelenOS so that its essential parts can stay free of
18adaptation layers, glue code, franken-components and the maintenance burden
19incurred by them.
[23d45152]20
21* [Website](http://helenos.org)
22* [Wiki](http://helenos.org/wiki)
23* [Tickets](http://www.helenos.org/report/1)
24* [How to contribute](http://www.helenos.org/wiki/HowToContribute)
25
26## Portability
27
[5b5f3eb]28HelenOS runs on eight different processor architectures and machines ranging
[23d45152]29from embedded ARM devices and single-board computers through multicore 32-bit
30and 64-bit desktop PCs to 64-bit Itanium and SPARC rack-mount servers.
31
32## Building
33
34### Building the toolchain
35
36In order to build HelenOS, one must first build the cross-compiler toolchain
[f3a7b0d]37(the default installation location can be overridden by specifying the
38`CROSS_PREFIX` environment variable) by running (example for the amd64
39architecture, further list of targets can be found in the `default` directory):
[23d45152]40
41```
42$ cd HelenOS/tools
43$ ./toolchain.sh amd64
44```
45
46The toolchain script will print a list of software packages that are required
47for the toolchain to correctly build. Make sure you install all the dependencies.
48Unfortunately, the script cannot install the required dependencies for you automatically
49since the host environments are very diverse. In case the compilation of the toolchain
50fails half way through, try to analyze the error message(s), add appropriate missing
51dependencies and try again.
52
[1a4ec93f]53As an example, here are some of the packages you will need for Ubuntu 16.04:
[23d45152]54
55```
[1a4ec93f]56$ sudo apt install build-essential wget texinfo flex bison dialog python-yaml genisoimage
[23d45152]57```
58
59Whereas for CentOS/Fedora, you will need:
60
61```
62# sudo dnf group install 'Development Tools'
[f3a7b0d]63# sudo dnf install wget texinfo PyYAML genisoimage flex bison
[23d45152]64```
[f3a7b0d]65
[23d45152]66In case the toolchain script won't work no matter how hard you try, let us know.
67Please supply as many relevant information (your OS and distribution, list of
68installed packages with version information, the output of the toolchain script, etc.) as
69possible.
70
71### Configuring the build
72
[1a4ec93f]73Since the summer of 2019, HelenOS uses the Meson build system.
74Make sure you have a recent-enough version of Meson and Ninja.
75The safest bet is installing both using `pip3` tool.
[23d45152]76
[1a4ec93f]77```sh
78$ pip3 install ninja
79$ pip3 install meson
[23d45152]80```
81
[1a4ec93f]82Meson does not support in-tree builds, so you have to create a directory
83for your build. You can have as many build directories as you want, each with
84its own configuration. `cd` into your build directory and run `configure.sh`
85script which exists in the source root. `configure.sh` can be run with a profile
86name, to use one of the predefined profiles, or without arguments for interactive
87configuration.
88
89```sh
90$ git clone https://github.com/HelenOS/helenos.git
91$ mkdir -p build/amd64
92$ cd build/amd64
93$ ../../helenos/configure.sh amd64
94```
[23d45152]95
96Note: If you installed the toolchain to a custom directory, make sure `CROSS_PREFIX`
97environment variable is correctly set.
98
[1a4ec93f]99Once configuration is finished, use `ninja` to build HelenOS.
100Invoking `ninja` without arguments builds all binaries and
101debug files, but not bootable image. This is because during
102development, most builds are incremental and only meant to check
103that code builds properly. In this case, the time-consuming process of
104creating a boot image is not useful and takes most time. This behavior
105might change in the future.
106
107In case you want to rebuild the bootable image, you must invoke
108`ninja image_path`. This also emits the name of the bootable image into the
109file `image_path` in build directory.
110
111```
112$ ninja
113$ ninja image_path
114```
115
116Now HelenOS should automatically start building.
117
[23d45152]118### Running the OS
119
[1a4ec93f]120When you get the command line back, there should be an `image.iso` file in the build
[23d45152]121root directory. If you have QEMU, you should be able to start HelenOS by running:
122
123```
124$ ./tools/ew.py
125```
126
127For additional information about running HelenOS, see
128[UsersGuide/RunningInQEMU](http://www.helenos.org/wiki/UsersGuide/RunningInQEMU) or
129[UsersGuide/RunningInVirtualBox](http://www.helenos.org/wiki/UsersGuide/RunningInVirtualBox) or
[63d46341]130see the files in tools/conf.
[23d45152]131
132## License
[f1380b7]133
[23d45152]134HelenOS is open source, free software. Its source code is available under
135the BSD license. Some third-party components are licensed under GPL.
Note: See TracBrowser for help on using the repository browser.