diff options
| author | Felix Morgner <felix.morgner@ost.ch> | 2025-12-15 16:37:39 +0100 |
|---|---|---|
| committer | Felix Morgner <felix.morgner@ost.ch> | 2025-12-15 16:37:39 +0100 |
| commit | d2ae06ac6c19c1d6258f2ba0888e03795712826d (patch) | |
| tree | 4f3341aff1ce250a74c02e1ee28c21321b79c567 /kernel | |
| parent | 0f09b8ff164a69195ec6c25f6aea1cb607d826f8 (diff) | |
| download | teachos-d2ae06ac6c19c1d6258f2ba0888e03795712826d.tar.xz teachos-d2ae06ac6c19c1d6258f2ba0888e03795712826d.zip | |
build: move kernel build configuration
Diffstat (limited to 'kernel')
| -rw-r--r-- | kernel/CMakeLists.txt | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/kernel/CMakeLists.txt b/kernel/CMakeLists.txt new file mode 100644 index 0000000..6bddf7c --- /dev/null +++ b/kernel/CMakeLists.txt @@ -0,0 +1,36 @@ +add_executable("kernel" + "src/kstd.cpp" + "src/main.cpp" + + # Platform Independent KAPI implementation + "src/kapi/cio.cpp" + "src/kapi/memory.cpp" + "src/kapi/system.cpp" +) + +target_include_directories("kernel" PRIVATE + "include" +) + +target_link_libraries("kernel" PRIVATE + "os::arch" + "os::kapi" +) + +target_link_options("kernel" PRIVATE + "-T${KERNEL_LINKER_SCRIPT}" + "-no-pie" + "-nostdlib" +) + +set_property(TARGET "kernel" + APPEND + PROPERTY LINK_DEPENDS + "${KERNEL_LINKER_SCRIPT}" +) + +target_disassemble("kernel") +target_extract_debug_symbols("kernel") +target_strip("kernel") + +target_generate_bootable_iso("kernel") |
