Auxiliary library for kernel development
Go to file
Alex Kotov 962a1c557d
Use GitHub Actions
2021-12-14 03:24:25 +05:00
.github/workflows Use GitHub Actions 2021-12-14 03:24:25 +05:00
examples Start working on measurement unit utils 2021-12-14 00:39:36 +05:00
include Move ELF utils to separate source file 2021-12-14 03:07:00 +05:00
src Move ELF utils to separate source file 2021-12-14 03:07:00 +05:00
tests Enable CFLAGS "-pedantic" 2021-12-14 01:51:49 +05:00
.gitignore Add tests for measurement units utils 2021-12-14 01:23:22 +05:00
AUTHORS Initial commit 2020-11-27 14:29:28 +05:00
COPYING Update LICENSE 2021-12-12 23:27:49 +05:00
ChangeLog Initial commit 2020-11-27 14:29:28 +05:00
INSTALL Initial commit 2020-11-27 14:29:28 +05:00
Makefile.am Move ELF utils to separate source file 2021-12-14 03:07:00 +05:00
NEWS Initial commit 2020-11-27 14:29:28 +05:00
README Initial commit 2020-11-27 14:29:28 +05:00
README.md Fix portability info 2021-12-14 02:21:45 +05:00
autogen.sh Add script autogen.sh 2020-11-27 16:54:13 +05:00
configure.ac Move ELF utils to separate source file 2021-12-14 03:07:00 +05:00

README.md

libkernaux

Auxiliary library for kernel development.

Table of contents

API

Tips

Compilation

./autogen.sh
./configure
make
sudo make install

You can test with make check.

It's just a usual library. You can use most of it's APIs in hosted environment.

Cross-compilation

Create configuration script with ./autogen.sh.

Configure with cross-compiler in $PATH to make without it in $PATH:

./configure \
  --host='i386-elftailix' \
  AR="$(which i386-elftailix-ar)" \
  CC="$(which i386-elftailix-gcc)" \
  RANLIB="$(which i386-elftailix-ranlib)" \
  CFLAGS='-ffreestanding -nostdlib -fno-builtin -fno-stack-protector'

You can see the following messages. It's a bug in autoconf, just ignore it.

checking for _Bool... no
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
configure: WARNING:     ## ---------------------------------------------------------- ##
configure: WARNING:     ## Report this to https://github.com/tailix/libkernaux/issues ##
configure: WARNING:     ## ---------------------------------------------------------- ##
checking for stdarg.h... no
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
configure: WARNING:     ## ---------------------------------------------------------- ##
configure: WARNING:     ## Report this to https://github.com/tailix/libkernaux/issues ##
configure: WARNING:     ## ---------------------------------------------------------- ##
checking for stddef.h... no

To install into specific directory use full path: DESTDIR="$(pwd)/dest" make install instead of DESTDIR=dest make install.

When configured with cross-compiler, library can't be build and installed with just make && sudo make install. Instead use the following commands:

  • make libkernaux.a
  • sudo make install-exec
  • sudo make install-data

Check if compilation targets i386: objdump -d src/arch/i386.o. It should output something like this:

src/arch/i386.o:     file format elf32-i386


Disassembly of section .text:

00000000 <kernaux_arch_i386_hang>:
   0:   fa                    cli
   1:   f4                    hlt
   2:   eb fc                 jmp    0 <kernaux_arch_i386_hang>

00000004 <kernaux_arch_i386_read_cr0>:
   4:   0f 20 c0              mov    %cr0,%eax
   7:   c3                    ret

00000008 <kernaux_arch_i386_read_cr4>:
   8:   0f 20 e0              mov    %cr4,%eax
   b:   c3                    ret

0000000c <kernaux_arch_i386_write_cr0>:
   c:   8b 44 24 04           mov    0x4(%esp),%eax
  10:   0f 22 c0              mov    %eax,%cr0
  13:   c3                    ret

00000014 <kernaux_arch_i386_write_cr3>:
  14:   8b 44 24 04           mov    0x4(%esp),%eax
  18:   0f 22 d8              mov    %eax,%cr3
  1b:   c3                    ret

0000001c <kernaux_arch_i386_write_cr4>:
  1c:   8b 44 24 04           mov    0x4(%esp),%eax
  20:   0f 22 e0              mov    %eax,%cr4
  23:   c3                    ret

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

Discussion