2020-11-27 04:28:13 -05:00
|
|
|
libkernaux
|
|
|
|
==========
|
|
|
|
|
2021-12-13 20:30:30 -05:00
|
|
|
[![Test](https://github.com/tailix/libkernaux/actions/workflows/test.yml/badge.svg)](https://github.com/tailix/libkernaux/actions/workflows/test.yml)
|
2021-12-13 17:36:06 -05:00
|
|
|
|
2020-11-27 04:28:13 -05:00
|
|
|
Auxiliary library for kernel development.
|
2020-11-27 08:38:58 -05:00
|
|
|
|
|
|
|
|
|
|
|
|
2020-11-28 18:52:51 -05:00
|
|
|
Table of contents
|
|
|
|
-----------------
|
|
|
|
|
|
|
|
* [Overview](#libkernaux)
|
|
|
|
* [Table of contents](#table-of-contents)
|
2020-11-29 20:21:22 -05:00
|
|
|
* [API](#api)
|
2021-12-16 03:14:39 -05:00
|
|
|
* [Tips](#tips)
|
|
|
|
* [Installation](#installation)
|
|
|
|
* [Development](#development)
|
2021-12-14 19:03:40 -05:00
|
|
|
* [Cross](#cross)
|
2020-12-07 01:55:10 -05:00
|
|
|
* [Portability](#portability)
|
2020-11-29 11:11:26 -05:00
|
|
|
* [Discussion](#discussion)
|
2021-12-16 10:06:15 -05:00
|
|
|
* [Summary](#summary)
|
|
|
|
* [Pure code size](#pure-code-size)
|
|
|
|
* [Used header files](#used-header-files)
|
2020-11-28 18:52:51 -05:00
|
|
|
|
|
|
|
|
|
|
|
|
2020-11-29 20:21:22 -05:00
|
|
|
API
|
|
|
|
---
|
|
|
|
|
2021-12-15 06:03:14 -05:00
|
|
|
* Runtime environment
|
|
|
|
* [Assertions](/include/kernaux/assert.h)
|
|
|
|
* [Example](/examples/assert.c)
|
|
|
|
* [Architecture-specific helpers](/include/kernaux/arch/)
|
2021-12-15 10:34:02 -05:00
|
|
|
* Device drivers (for debugging only)
|
|
|
|
* [Serial console](/include/kernaux/console.h)
|
|
|
|
* Framebuffer *(planned)*
|
2021-12-15 06:03:14 -05:00
|
|
|
* Algorithms
|
|
|
|
* [Simple command line parser](/include/kernaux/cmdline.h)
|
|
|
|
* [Example](/examples/cmdline.c)
|
|
|
|
* [Page Frame Allocator](/include/kernaux/pfa.h)
|
|
|
|
* [Example](/examples/pfa.c)
|
|
|
|
* Data formats
|
|
|
|
* [Multiboot 2 (GRUB 2) information parser](/include/kernaux/multiboot2.h)
|
|
|
|
* [ELF utils](/include/kernaux/elf.h) *(work in progress)*
|
|
|
|
* Utilities
|
|
|
|
* [Measurement units utils](/include/kernaux/units.h) *(work in progress)*
|
|
|
|
* [To human](/examples/units_human.c)
|
|
|
|
* Usual functions
|
|
|
|
* [libc replacement](/include/kernaux/libc.h)
|
|
|
|
* `memset`
|
|
|
|
* `strcpy`
|
|
|
|
* `strlen`
|
|
|
|
* [itoa replacement](/include/kernaux/itoa.h) *(work in progress)*
|
|
|
|
* [printf replacement](/include/kernaux/printf.h) *(work in progress)*
|
|
|
|
* [printf](/examples/printf.c)
|
|
|
|
* [printf_va](/examples/printf_va.c)
|
2020-11-29 20:21:22 -05:00
|
|
|
|
|
|
|
|
|
|
|
|
2021-12-16 03:14:39 -05:00
|
|
|
Tips
|
|
|
|
----
|
2020-11-27 08:38:58 -05:00
|
|
|
|
2021-12-16 03:14:39 -05:00
|
|
|
### Installation
|
2021-12-12 11:29:39 -05:00
|
|
|
|
|
|
|
```
|
|
|
|
./autogen.sh
|
|
|
|
./configure
|
|
|
|
make
|
|
|
|
sudo make install
|
|
|
|
```
|
|
|
|
|
2021-12-13 17:26:53 -05:00
|
|
|
This is just a usual library. You can use most of it's APIs in hosted
|
|
|
|
environment.
|
2021-12-12 11:29:39 -05:00
|
|
|
|
2021-12-16 03:14:39 -05:00
|
|
|
### Development
|
|
|
|
|
|
|
|
```
|
|
|
|
./autogen.sh
|
|
|
|
./configure --enable-assert --enable-null-guard
|
|
|
|
make
|
|
|
|
```
|
|
|
|
|
|
|
|
You can test with `make check`.
|
|
|
|
|
2021-12-14 19:03:40 -05:00
|
|
|
### Cross
|
2021-12-12 11:29:39 -05:00
|
|
|
|
2020-11-29 10:49:12 -05:00
|
|
|
Create configuration script with `./autogen.sh`.
|
|
|
|
|
2021-12-14 19:10:40 -05:00
|
|
|
Let's assume that your target triplet is `i386-elf`. Configure with
|
|
|
|
[cross-compiler](https://wiki.osdev.org/GCC_Cross-Compiler) in `$PATH` to make
|
|
|
|
without it in `$PATH`:
|
2020-11-27 08:38:58 -05:00
|
|
|
|
|
|
|
```
|
|
|
|
./configure \
|
2021-12-14 19:10:40 -05:00
|
|
|
--host='i386-elf' \
|
2021-12-15 05:45:40 -05:00
|
|
|
--enable-libc \
|
2021-12-14 19:10:40 -05:00
|
|
|
AR="$(which i386-elf-ar)" \
|
|
|
|
CC="$(which i386-elf-gcc)" \
|
|
|
|
RANLIB="$(which i386-elf-ranlib)" \
|
2020-12-06 05:16:15 -05:00
|
|
|
CFLAGS='-ffreestanding -nostdlib -fno-builtin -fno-stack-protector'
|
2020-11-27 08:38:58 -05:00
|
|
|
```
|
|
|
|
|
2021-12-12 11:29:39 -05:00
|
|
|
You can see the following messages. It's
|
2020-12-06 06:41:36 -05:00
|
|
|
[a bug](https://savannah.gnu.org/support/index.php?110393) in **autoconf**, just
|
|
|
|
ignore it.
|
2020-12-06 05:27:55 -05:00
|
|
|
|
|
|
|
```
|
|
|
|
checking for _Bool... no
|
2020-12-06 19: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 07:13:52 -05:00
|
|
|
configure: WARNING: ## ---------------------------------------------------------- ##
|
|
|
|
configure: WARNING: ## Report this to https://github.com/tailix/libkernaux/issues ##
|
|
|
|
configure: WARNING: ## ---------------------------------------------------------- ##
|
2020-12-06 19:11:55 -05:00
|
|
|
checking for stdarg.h... no
|
2020-12-06 05: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 07:13:52 -05:00
|
|
|
configure: WARNING: ## ---------------------------------------------------------- ##
|
|
|
|
configure: WARNING: ## Report this to https://github.com/tailix/libkernaux/issues ##
|
|
|
|
configure: WARNING: ## ---------------------------------------------------------- ##
|
2020-12-06 06:22:56 -05:00
|
|
|
checking for stddef.h... no
|
2020-12-06 05:27:55 -05:00
|
|
|
```
|
|
|
|
|
2020-11-27 09:27:59 -05:00
|
|
|
To install into specific directory use full path:
|
|
|
|
`DESTDIR="$(pwd)/dest" make install` instead of `DESTDIR=dest make install`.
|
|
|
|
|
2020-11-29 11:01:11 -05:00
|
|
|
When configured with cross-compiler, library can't be build and installed with
|
2020-11-29 11:41:24 -05:00
|
|
|
just `make && sudo make install`. Instead use the following commands:
|
2020-11-29 11:01:11 -05:00
|
|
|
|
|
|
|
* `make libkernaux.a`
|
2020-11-29 23:08:08 -05:00
|
|
|
* `sudo make install-exec`
|
2020-11-29 11:01:11 -05:00
|
|
|
* `sudo make install-data`
|
|
|
|
|
2020-12-07 21:56:38 -05:00
|
|
|
Check if compilation targets i386: `objdump -d src/arch/i386.o`. It should
|
2020-11-28 18:57:59 -05:00
|
|
|
output something like this:
|
2020-11-27 08:38:58 -05:00
|
|
|
|
|
|
|
```
|
2020-12-07 21:56:38 -05:00
|
|
|
src/arch/i386.o: file format elf32-i386
|
2020-11-27 08:38:58 -05:00
|
|
|
|
|
|
|
|
|
|
|
Disassembly of section .text:
|
|
|
|
|
2020-12-07 21:56:38 -05:00
|
|
|
00000000 <kernaux_arch_i386_hang>:
|
2020-11-28 18:56:33 -05:00
|
|
|
0: fa cli
|
|
|
|
1: f4 hlt
|
2020-12-07 21:56:38 -05:00
|
|
|
2: eb fc jmp 0 <kernaux_arch_i386_hang>
|
2020-11-27 08:38:58 -05:00
|
|
|
|
2020-12-07 21:56:38 -05:00
|
|
|
00000004 <kernaux_arch_i386_read_cr0>:
|
2020-11-28 18:56:33 -05:00
|
|
|
4: 0f 20 c0 mov %cr0,%eax
|
2020-11-27 08:38:58 -05:00
|
|
|
7: c3 ret
|
|
|
|
|
2020-12-07 21:56:38 -05:00
|
|
|
00000008 <kernaux_arch_i386_read_cr4>:
|
2020-11-28 18:56:33 -05:00
|
|
|
8: 0f 20 e0 mov %cr4,%eax
|
|
|
|
b: c3 ret
|
2020-11-27 08:38:58 -05:00
|
|
|
|
2020-12-07 21:56:38 -05:00
|
|
|
0000000c <kernaux_arch_i386_write_cr0>:
|
2020-11-28 18:56:33 -05:00
|
|
|
c: 8b 44 24 04 mov 0x4(%esp),%eax
|
|
|
|
10: 0f 22 c0 mov %eax,%cr0
|
|
|
|
13: c3 ret
|
2020-11-27 08:38:58 -05:00
|
|
|
|
2020-12-07 21:56:38 -05:00
|
|
|
00000014 <kernaux_arch_i386_write_cr3>:
|
2020-11-28 18:56:33 -05:00
|
|
|
14: 8b 44 24 04 mov 0x4(%esp),%eax
|
|
|
|
18: 0f 22 d8 mov %eax,%cr3
|
|
|
|
1b: c3 ret
|
|
|
|
|
2020-12-07 21:56:38 -05:00
|
|
|
0000001c <kernaux_arch_i386_write_cr4>:
|
2020-11-28 18:56:33 -05:00
|
|
|
1c: 8b 44 24 04 mov 0x4(%esp),%eax
|
|
|
|
20: 0f 22 e0 mov %eax,%cr4
|
|
|
|
23: c3 ret
|
2020-11-27 08:38:58 -05:00
|
|
|
```
|
2020-11-29 11:11:26 -05:00
|
|
|
|
|
|
|
|
|
|
|
|
2020-12-07 01:55:10 -05:00
|
|
|
Portability
|
|
|
|
-----------
|
|
|
|
|
2020-12-07 01:58:41 -05:00
|
|
|
Except GNU/Linux, the library is periodically successfully built (starting with
|
|
|
|
`./autogen.sh`) and tested with **autoconf**, **automake**, **binutils** and
|
2020-12-07 01:55:10 -05:00
|
|
|
**gcc**/**clang** (depending on what is present) on the following operating
|
|
|
|
systems:
|
|
|
|
|
2021-12-13 16:21:45 -05:00
|
|
|
* FreeBSD 13.0
|
2020-12-07 01:55:10 -05:00
|
|
|
* Minix 3.3.0
|
2021-12-13 16:21:45 -05:00
|
|
|
* NetBSD 9.2
|
|
|
|
* OpenBSD 7.0
|
2020-12-07 01:55:10 -05:00
|
|
|
|
|
|
|
|
|
|
|
|
2020-11-29 11:11:26 -05:00
|
|
|
Discussion
|
|
|
|
----------
|
|
|
|
|
|
|
|
* [Topic on OSDev.org forum](https://forum.osdev.org/viewtopic.php?f=1&t=37958)
|
2020-11-30 08:33:34 -05:00
|
|
|
* [Thread on r/osdev](https://www.reddit.com/r/osdev/comments/k3ueeu/libkernaux_auxiliary_library_for_kernel/)
|
2021-12-16 10:06:15 -05:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Summary
|
|
|
|
-------
|
|
|
|
|
|
|
|
This information is updated from time to time.
|
|
|
|
|
|
|
|
### Pure code size
|
|
|
|
|
|
|
|
`cloc --vcs=git include/ src/`
|
|
|
|
|
|
|
|
```
|
|
|
|
-------------------------------------------------------------------------------
|
|
|
|
Language files blank comment code
|
|
|
|
-------------------------------------------------------------------------------
|
|
|
|
C 12 236 19 1548
|
|
|
|
C/C++ Header 14 179 64 597
|
|
|
|
Assembly 2 7 6 28
|
|
|
|
make 1 0 0 13
|
|
|
|
-------------------------------------------------------------------------------
|
|
|
|
SUM: 29 422 89 2186
|
|
|
|
-------------------------------------------------------------------------------
|
|
|
|
```
|
|
|
|
|
|
|
|
### Used header files
|
|
|
|
|
|
|
|
`git grep '#include <' -- include/ src/ | grep -v '#include <kernaux' | awk '{ print $2; }' | sort | uniq`
|
|
|
|
|
|
|
|
* `stdarg.h`
|
|
|
|
* `stdbool.h`
|
|
|
|
* `stddef.h`
|