2020-11-27 14:28:13 +05:00
|
|
|
libkernaux
|
|
|
|
==========
|
|
|
|
|
2021-12-14 06:30:30 +05:00
|
|
|
[](https://github.com/tailix/libkernaux/actions/workflows/test.yml)
|
2021-12-14 03:36:06 +05:00
|
|
|
|
2020-11-27 14:28:13 +05:00
|
|
|
Auxiliary library for kernel development.
|
2020-11-27 18:38:58 +05:00
|
|
|
|
2022-01-21 02:39:56 +05:00
|
|
|
[Topic on OSDev.org forum](https://forum.osdev.org/viewtopic.php?f=1&t=37958).
|
|
|
|
|
2020-11-27 18:38:58 +05:00
|
|
|
|
|
|
|
|
2020-11-29 04:52:51 +05:00
|
|
|
Table of contents
|
|
|
|
-----------------
|
|
|
|
|
|
|
|
* [Overview](#libkernaux)
|
|
|
|
* [Table of contents](#table-of-contents)
|
2020-11-30 06:21:22 +05:00
|
|
|
* [API](#api)
|
2022-01-22 22:18:18 +05:00
|
|
|
* [Configuration](#configuration)
|
2021-12-18 06:47:01 +05:00
|
|
|
* [Non-default options](#non-default-options)
|
2022-01-10 21:03:37 +05:00
|
|
|
* [Default options](#default-options)
|
2022-01-22 22:18:18 +05:00
|
|
|
* [Tips](#tips)
|
2021-12-16 13:14:39 +05:00
|
|
|
* [Installation](#installation)
|
|
|
|
* [Development](#development)
|
2021-12-15 05:03:40 +05:00
|
|
|
* [Cross](#cross)
|
2022-01-13 11:35:25 +05:00
|
|
|
* [Architectures](#architectures)
|
2021-12-26 11:09:23 +05:00
|
|
|
* [Portability](#portability)
|
2020-11-29 04:52:51 +05:00
|
|
|
|
|
|
|
|
|
|
|
|
2020-11-30 06:21:22 +05:00
|
|
|
API
|
|
|
|
---
|
|
|
|
|
2022-01-20 17:40:18 +05:00
|
|
|
We use [semantic versioning](https://semver.org) for stable APIs. Stable APIs
|
|
|
|
can only change when major version number is increased (or minor while major is
|
|
|
|
zero). Work-in-progress APIs can change at any time.
|
|
|
|
|
2021-12-15 16:03:14 +05:00
|
|
|
* Runtime environment
|
2022-01-20 17:40:18 +05:00
|
|
|
* Architecture-specific code (*work in progress*)
|
2021-12-20 11:14:40 +05:00
|
|
|
* [Declarations](/include/kernaux/arch/)
|
|
|
|
* [Functions](/include/kernaux/asm/)
|
2022-01-23 05:26:58 +05:00
|
|
|
* [Assertions](/include/kernaux/assert.h) (*stable since* **0.1.0**, *non-breaking since* **0.2.0**)
|
2022-01-20 21:51:54 +05:00
|
|
|
* [Assert: simple](/examples/assert_simple.c)
|
|
|
|
* [Assert: guards](/examples/assert_guards.c)
|
|
|
|
* [Panic: simple](/examples/panic_simple.c)
|
2022-01-20 22:18:18 +05:00
|
|
|
* [Panic: guards](/examples/panic_guards.c)
|
2022-01-12 15:56:39 +05:00
|
|
|
* Stack trace *(planned)*
|
2021-12-15 20:34:02 +05:00
|
|
|
* Device drivers (for debugging only)
|
2022-01-20 17:40:18 +05:00
|
|
|
* [Serial console](/include/kernaux/console.h) (*work in progress*)
|
|
|
|
* [Framebuffer](/include/kernaux/framebuffer.h) (*planned*)
|
|
|
|
* USB (*planned*)
|
2021-12-15 16:03:14 +05:00
|
|
|
* Algorithms
|
2022-01-23 05:26:58 +05:00
|
|
|
* [Simple command line parser](/include/kernaux/cmdline.h) (*stable since* **0.2.0**)
|
2021-12-15 16:03:14 +05:00
|
|
|
* [Example](/examples/cmdline.c)
|
2022-01-20 17:40:18 +05:00
|
|
|
* [Page Frame Allocator](/include/kernaux/pfa.h) (*work in progress*)
|
2021-12-15 16:03:14 +05:00
|
|
|
* [Example](/examples/pfa.c)
|
|
|
|
* Data formats
|
2022-01-20 17:40:18 +05:00
|
|
|
* [ELF](/include/kernaux/elf.h) (*work in progress*)
|
|
|
|
* [Master Boot Record](/include/kernaux/mbr.h) (*work in progress*)
|
|
|
|
* [Multiboot 2 (GRUB 2)](/include/kernaux/multiboot2.h) (*work in progress*)
|
|
|
|
* Stivale 2 (Limine) (*planned*)
|
2021-12-15 16:03:14 +05:00
|
|
|
* Utilities
|
2022-01-20 17:40:18 +05:00
|
|
|
* [Measurement units utils](/include/kernaux/units.h) (*work in progress*)
|
2021-12-15 16:03:14 +05:00
|
|
|
* [To human](/examples/units_human.c)
|
|
|
|
* Usual functions
|
2022-01-20 17:40:18 +05:00
|
|
|
* [libc replacement](/include/kernaux/libc.h) (*stable since* **0.1.0**)
|
|
|
|
* [itoa/ftoa replacement](/include/kernaux/ntoa.h) (*stable since* **0.1.0**)
|
|
|
|
* [printf replacement](/include/kernaux/printf.h) (*stable since* **0.1.0**)
|
2022-01-20 03:56:58 +05:00
|
|
|
* Code from [https://github.com/mpaland/printf](https://github.com/mpaland/printf). Thank you!
|
2022-01-20 03:45:50 +05:00
|
|
|
* [printf](/examples/printf.c)
|
|
|
|
* [vprintf](/examples/printf_va.c)
|
2022-01-20 15:28:24 +05:00
|
|
|
* [snprintf](/examples/snprintf.c)
|
|
|
|
* [vsnprintf](/examples/snprintf_va.c)
|
2020-11-30 06:21:22 +05:00
|
|
|
|
|
|
|
|
|
|
|
|
2022-01-22 22:18:18 +05:00
|
|
|
Configuration
|
|
|
|
-------------
|
|
|
|
|
|
|
|
Because this library has no external dependencies, we use **autoconf** features
|
|
|
|
to control behavior of the library, and packages to choose it's components.
|
|
|
|
Configuration options also follow the [semantic versioning](https://semver.org)
|
2022-01-23 02:37:53 +05:00
|
|
|
scheme and are split into stable and work-in-progress ones. Here we cover only
|
2022-01-22 22:18:18 +05:00
|
|
|
stable options.
|
2020-11-27 18:38:58 +05:00
|
|
|
|
2021-12-18 06:47:01 +05:00
|
|
|
### Non-default options
|
|
|
|
|
2022-01-22 22:18:18 +05:00
|
|
|
#### Packages
|
|
|
|
|
2021-12-18 06:47:01 +05:00
|
|
|
* `--with-libc` - provides the replacement for some standard C functions. Useful
|
2021-12-19 08:14:30 +05:00
|
|
|
in freestanding environment, where no libc is present. You can also separately
|
2021-12-20 07:22:43 +05:00
|
|
|
include or exclude components:
|
2022-01-23 23:41:07 +05:00
|
|
|
* `--with[out]-libc-atoi`
|
2022-01-23 23:17:03 +05:00
|
|
|
* `--with[out]-libc-isdigit`
|
2022-01-23 23:25:36 +05:00
|
|
|
* `--with[out]-libc-isspace`
|
2021-12-19 08:16:36 +05:00
|
|
|
* `--with[out]-libc-memset`
|
|
|
|
* `--with[out]-libc-strcpy`
|
|
|
|
* `--with[out]-libc-strlen`
|
2022-01-19 16:14:46 +05:00
|
|
|
* `--with[out]-libc-strnlen`
|
2021-12-18 06:47:01 +05:00
|
|
|
|
2022-01-10 21:03:37 +05:00
|
|
|
### Default options
|
|
|
|
|
2022-01-20 17:25:58 +05:00
|
|
|
#### Features
|
2022-01-20 17:22:34 +05:00
|
|
|
|
2022-01-21 18:21:47 +05:00
|
|
|
* `--enable-bloat`, disable with `--disable-bloat`
|
2022-01-19 16:40:12 +05:00
|
|
|
* `--enable-float`, disable with `--disable-float`
|
|
|
|
|
2022-01-20 17:25:58 +05:00
|
|
|
#### Packages
|
|
|
|
|
2022-01-20 17:22:34 +05:00
|
|
|
All packages all included by default. To exclude all packages except those
|
2022-01-20 17:25:58 +05:00
|
|
|
explicitly included, use `--without-all`.
|
2022-01-20 17:22:34 +05:00
|
|
|
|
2022-01-19 15:35:02 +05:00
|
|
|
* `--with[out]-ntoa`
|
2022-01-17 14:54:44 +05:00
|
|
|
* `--with[out]-printf`
|
2022-01-22 22:18:18 +05:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Tips
|
|
|
|
----
|
2022-01-10 21:03:37 +05:00
|
|
|
|
2021-12-16 13:14:39 +05:00
|
|
|
### Installation
|
2021-12-12 21:29:39 +05:00
|
|
|
|
|
|
|
```
|
|
|
|
./autogen.sh
|
2022-01-20 23:54:25 +05:00
|
|
|
./configure CFLAGS='-fPIC'
|
2021-12-12 21:29:39 +05:00
|
|
|
make
|
|
|
|
sudo make install
|
|
|
|
```
|
|
|
|
|
2021-12-14 03:26:53 +05:00
|
|
|
This is just a usual library. You can use most of it's APIs in hosted
|
|
|
|
environment.
|
2021-12-12 21:29:39 +05:00
|
|
|
|
2021-12-16 13:14:39 +05:00
|
|
|
### Development
|
|
|
|
|
|
|
|
```
|
|
|
|
./autogen.sh
|
2022-01-23 01:36:05 +05:00
|
|
|
./configure --enable-tests CFLAGS='-fPIC'
|
2021-12-16 13:14:39 +05:00
|
|
|
make
|
|
|
|
```
|
|
|
|
|
|
|
|
You can test with `make check`.
|
|
|
|
|
2021-12-15 05:03:40 +05:00
|
|
|
### Cross
|
2021-12-12 21:29:39 +05:00
|
|
|
|
2020-11-29 20:49:12 +05:00
|
|
|
Create configuration script with `./autogen.sh`.
|
|
|
|
|
2021-12-15 05:10:40 +05:00
|
|
|
Let's assume that your target triplet is `i386-elf`. Configure with
|
2022-01-12 10:07:53 +05:00
|
|
|
[cross-compiler](https://wiki.osdev.org/GCC_Cross-Compiler) in `$PATH` to make
|
|
|
|
without it in `$PATH`:
|
2020-11-27 18:38:58 +05:00
|
|
|
|
|
|
|
```
|
|
|
|
./configure \
|
2021-12-15 05:10:40 +05:00
|
|
|
--host='i386-elf' \
|
2021-12-18 06:27:45 +05:00
|
|
|
--with-libc \
|
2021-12-15 05:10:40 +05:00
|
|
|
AR="$(which i386-elf-ar)" \
|
|
|
|
CC="$(which i386-elf-gcc)" \
|
|
|
|
RANLIB="$(which i386-elf-ranlib)" \
|
2020-12-06 15:16:15 +05:00
|
|
|
CFLAGS='-ffreestanding -nostdlib -fno-builtin -fno-stack-protector'
|
2020-11-27 18:38:58 +05:00
|
|
|
```
|
|
|
|
|
2021-12-12 21:29:39 +05:00
|
|
|
You can see the following messages. It's
|
2020-12-06 16:41:36 +05:00
|
|
|
[a bug](https://savannah.gnu.org/support/index.php?110393) in **autoconf**, just
|
|
|
|
ignore it.
|
2020-12-06 15:27:55 +05:00
|
|
|
|
|
|
|
```
|
|
|
|
checking for _Bool... no
|
2020-12-07 05:11:55 +05:00
|
|
|
checking stdarg.h usability... no
|
|
|
|
checking stdarg.h presence... yes
|
|
|
|
configure: WARNING: stdarg.h: present but cannot be compiled
|
|
|
|
configure: WARNING: stdarg.h: check for missing prerequisite headers?
|
|
|
|
configure: WARNING: stdarg.h: see the Autoconf documentation
|
|
|
|
configure: WARNING: stdarg.h: section "Present But Cannot Be Compiled"
|
|
|
|
configure: WARNING: stdarg.h: proceeding with the compiler's result
|
2021-12-12 17:13:52 +05:00
|
|
|
configure: WARNING: ## ---------------------------------------------------------- ##
|
|
|
|
configure: WARNING: ## Report this to https://github.com/tailix/libkernaux/issues ##
|
|
|
|
configure: WARNING: ## ---------------------------------------------------------- ##
|
2020-12-07 05:11:55 +05:00
|
|
|
checking for stdarg.h... no
|
2020-12-06 15:27:55 +05:00
|
|
|
checking stddef.h usability... no
|
|
|
|
checking stddef.h presence... yes
|
|
|
|
configure: WARNING: stddef.h: present but cannot be compiled
|
|
|
|
configure: WARNING: stddef.h: check for missing prerequisite headers?
|
|
|
|
configure: WARNING: stddef.h: see the Autoconf documentation
|
|
|
|
configure: WARNING: stddef.h: section "Present But Cannot Be Compiled"
|
|
|
|
configure: WARNING: stddef.h: proceeding with the compiler's result
|
2021-12-12 17:13:52 +05:00
|
|
|
configure: WARNING: ## ---------------------------------------------------------- ##
|
|
|
|
configure: WARNING: ## Report this to https://github.com/tailix/libkernaux/issues ##
|
|
|
|
configure: WARNING: ## ---------------------------------------------------------- ##
|
2020-12-06 16:22:56 +05:00
|
|
|
checking for stddef.h... no
|
2020-12-06 15:27:55 +05:00
|
|
|
```
|
|
|
|
|
2022-01-17 17:33:28 +05:00
|
|
|
To install into specific directory use full path: `DESTDIR="$(pwd)/dest" make
|
|
|
|
install` instead of `DESTDIR=dest make install`.
|
2020-11-29 21:01:11 +05:00
|
|
|
|
2021-12-20 11:14:40 +05:00
|
|
|
Check if compilation targets i386: `objdump -d src/asm/i386.o`. It should output
|
|
|
|
something like this:
|
2020-11-27 18:38:58 +05:00
|
|
|
|
|
|
|
```
|
2021-12-20 11:14:40 +05:00
|
|
|
src/asm/i386.o: file format elf32-i386
|
2020-11-27 18:38:58 +05:00
|
|
|
|
|
|
|
|
|
|
|
Disassembly of section .text:
|
|
|
|
|
2022-01-15 15:42:13 +05:00
|
|
|
00000000 <kernaux_asm_i386_read_cr0>:
|
|
|
|
0: 0f 20 c0 mov %cr0,%eax
|
|
|
|
3: c3 ret
|
2020-11-27 18:38:58 +05:00
|
|
|
|
2022-01-15 15:42:13 +05:00
|
|
|
00000004 <kernaux_asm_i386_read_cr4>:
|
|
|
|
4: 0f 20 e0 mov %cr4,%eax
|
2020-11-27 18:38:58 +05:00
|
|
|
7: c3 ret
|
|
|
|
|
2022-01-15 15:42:13 +05:00
|
|
|
00000008 <kernaux_asm_i386_write_cr0>:
|
|
|
|
8: 8b 44 24 04 mov 0x4(%esp),%eax
|
|
|
|
c: 0f 22 c0 mov %eax,%cr0
|
|
|
|
f: c3 ret
|
2020-11-27 18:38:58 +05:00
|
|
|
|
2022-01-15 15:42:13 +05:00
|
|
|
00000010 <kernaux_asm_i386_write_cr3>:
|
|
|
|
10: 8b 44 24 04 mov 0x4(%esp),%eax
|
|
|
|
14: 0f 22 d8 mov %eax,%cr3
|
|
|
|
17: c3 ret
|
2020-11-27 18:38:58 +05:00
|
|
|
|
2022-01-15 15:42:13 +05:00
|
|
|
00000018 <kernaux_asm_i386_write_cr4>:
|
|
|
|
18: 8b 44 24 04 mov 0x4(%esp),%eax
|
|
|
|
1c: 0f 22 e0 mov %eax,%cr4
|
|
|
|
1f: c3 ret
|
2020-11-27 18:38:58 +05:00
|
|
|
```
|
2020-11-29 21:11:26 +05:00
|
|
|
|
|
|
|
|
|
|
|
|
2022-01-13 11:35:25 +05:00
|
|
|
Architectures
|
|
|
|
-------------
|
|
|
|
|
|
|
|
Architectures should be properly identified. We use the following scheme, but it
|
|
|
|
may change in future:
|
|
|
|
|
|
|
|
* `x86`
|
|
|
|
* `i386`
|
|
|
|
* `x86_64`
|
|
|
|
* `riscv`
|
|
|
|
* `riscv64`
|
2022-01-23 01:53:30 +05:00
|
|
|
* `arm` - we need more info, now similar to [Debian](https://www.debian.org/ports/arm/)
|
|
|
|
* `armel`
|
|
|
|
* `armhf`
|
|
|
|
* `arm64`
|
2022-01-13 11:35:25 +05:00
|
|
|
|
|
|
|
|
|
|
|
|
2021-12-26 11:09:23 +05:00
|
|
|
Portability
|
|
|
|
-----------
|
|
|
|
|
|
|
|
Except GNU/Linux, the library is periodically successfully built (starting with
|
|
|
|
`./autogen.sh`) and tested with **autoconf**, **automake**, **binutils** and
|
|
|
|
**gcc**/**clang** (depending on what is present) on the following operating
|
|
|
|
systems:
|
|
|
|
|
|
|
|
* FreeBSD 13.0
|
|
|
|
* Minix 3.3.0
|
|
|
|
* NetBSD 9.2
|
|
|
|
* OpenBSD 7.0
|