cmake_minimum_required(VERSION 3.15) project(kernel_main C CXX ASM) set(CMAKE_EXPORT_COMPILE_COMMANDS ON) set(CMAKE_CXX_LINK_EXECUTABLE " -o ") set(C_CXX_FLAGS "-nostdinc -nostdlib -W -Wall -Wextra -Wno-stringop-overflow -Wno-builtin-declaration-mismatch -Wno-format -fverbose-asm -fno-exceptions -ffreestanding -fno-pic -mno-red-zone -mstack-protector-guard=global -mcmodel=kernel") set(CMAKE_C_FLAGS "${C_CXX_FLAGS} -Werror=implicit-int -Werror=implicit-function-declaration -Werror=strict-aliasing") set(CMAKE_CXX_FLAGS "${C_CXX_FLAGS} -fno-use-cxa-atexit -fno-rtti") set(CMAKE_CXX_LINK_FLAGS "-z noexecstack --gc-sections") SET(CMAKE_ASM_FLAGS "${CFLAGS} -x assembler-with-cpp") set(CMAKE_CXX_STANDARD 20) if (CMAKE_BUILD_TYPE STREQUAL "Debug") set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -DDEBUG -O0 -g") set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -DDEBUG -O0 -g") set(CARGO_BUILD_TYPE "debug") set(CARGO_BUILD_FLAGS "") elseif(CMAKE_BUILD_TYPE STREQUAL "Release") set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -O2 -g -DNDEBUG") set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -O2 -g -DNDEBUG") set(CARGO_BUILD_TYPE "release") set(CARGO_BUILD_FLAGS "--release") endif() if (NOT DEFINED FDISK_BIN) set(FDISK_BIN fdisk) endif() add_subdirectory(gblibc) add_subdirectory(gblibstdc++) add_subdirectory(user-space-program) set(BOOTLOADER_SOURCES src/boot.s src/mbr.S src/asm/interrupt.s ) set(KERNEL_MAIN_SOURCES src/dev/builtin-chardev.cc src/kinit.cpp src/kernel/async/waitlist.cc src/kernel/async/lock.cc src/kernel/allocator.cc src/kernel/interrupt.cpp src/kernel/process.cpp src/kernel/tty.cpp src/kernel/syscall.cpp src/kernel/syscall/fileops.cc src/kernel/syscall/infoops.cc src/kernel/syscall/mount.cc src/kernel/syscall/procops.cc src/kernel/mem/mm_list.cc src/kernel/mem/paging.cc src/kernel/mem/slab.cc src/kernel/module.cc src/kernel/vfs.cpp src/kernel/vga.cpp src/kernel/hw/acpi.cc src/kernel/hw/pci.cc src/kernel/hw/serial.cc src/kernel/hw/timer.cc src/kernel/task/thread.cc src/kernel/task/readyqueue.cc src/kernel/user/thread_local.cc src/kernel/vfs/filearr.cc src/kernel/signal.cpp src/net/ethernet.cc src/types/crc.cc src/types/elf.cpp src/types/libstdcpp.cpp include/defs.hpp include/kernel/async/waitlist.hpp include/kernel/async/lock.hpp include/kernel/tty.hpp include/kernel/interrupt.hpp include/kernel/irq.hpp include/kernel/process.hpp include/kernel/syscall.hpp include/kernel/mem/mm_list.hpp include/kernel/mem/paging.hpp include/kernel/mem/slab.hpp include/kernel/mem/types.hpp include/kernel/mem/vm_area.hpp include/kernel/module.hpp include/kernel/utsname.hpp include/kernel/vfs.hpp include/kernel/vfs/dentry.hpp include/kernel/vfs/file.hpp include/kernel/vfs/filearr.hpp include/kernel/vga.hpp include/kernel/signal.hpp include/kernel/task/forward.hpp include/kernel/task/thread.hpp include/kernel/task/readyqueue.hpp include/kernel/hw/acpi.hpp include/kernel/hw/pci.hpp include/kernel/hw/port.hpp include/kernel/hw/serial.hpp include/kernel/hw/timer.hpp include/kernel/input/keycodes.h include/kernel/user/thread_local.hpp include/net/arp.hpp include/net/ethernet.hpp include/net/netdev.hpp include/types/bitmap.hpp include/types/buffer.hpp include/types/elf.hpp include/types/list.hpp include/types/types.h include/types/allocator.hpp include/types/cplusplus.hpp include/kernel/log.hpp ) add_executable(kernel.out ${KERNEL_MAIN_SOURCES} ${BOOTLOADER_SOURCES}) add_dependencies(kernel.out rustpart) target_link_libraries(kernel.out gblibc gblibstdc++ gbos_rust_part) target_include_directories(kernel.out PRIVATE ${PROJECT_SOURCE_DIR}/include) target_link_options(kernel.out PRIVATE -T "${CMAKE_SOURCE_DIR}/src/kernel.ld" -L "${CMAKE_BINARY_DIR}/x86_64-unknown-none/${CARGO_BUILD_TYPE}" ) set_target_properties(kernel.out PROPERTIES LINK_DEPENDS "${CMAKE_SOURCE_DIR}/src/kernel.ld") set_source_files_properties(src/mbr.S PROPERTIES OBJECT_DEPENDS "${CMAKE_BINARY_DIR}/x86_64-unknown-none/${CARGO_BUILD_TYPE}/libgbos_rust_part.a" ) add_custom_target(rustpart COMMAND cargo build ${CARGO_BUILD_FLAGS} ) add_custom_command(OUTPUT mbr_hole.bin DEPENDS kernel.out COMMAND ${CMAKE_OBJCOPY} --strip-debug -O binary ${CMAKE_BINARY_DIR}/kernel.out mbr_hole.bin ) add_custom_target(boot.img DEPENDS mbr_hole.bin DEPENDS user_space_programs COMMAND dd if=mbr_hole.bin of=boot.img COMMAND dd if=/dev/zero of=boot.img bs=`expr 512 \\* 1024 \\* 1024` count=0 seek=1 COMMAND sh -c \"echo n\; echo\; echo\; echo\; echo\; echo a\; echo w\" | ${FDISK_BIN} boot.img COMMAND mkfs.fat --offset=2048 -v -n SYSTEM boot.img COMMAND mcopy -i boot.img@@1M ${CMAKE_BINARY_DIR}/user-space-program/hello-world.out ::hello COMMAND mcopy -i boot.img@@1M ${CMAKE_BINARY_DIR}/user-space-program/interrupt-test.out ::int COMMAND mcopy -i boot.img@@1M ${CMAKE_BINARY_DIR}/user-space-program/stack-test.out ::stack COMMAND mcopy -i boot.img@@1M ${CMAKE_BINARY_DIR}/user-space-program/init.out ::init COMMAND mcopy -i boot.img@@1M ${CMAKE_BINARY_DIR}/user-space-program/priv-test.out ::priv COMMAND mcopy -i boot.img@@1M ${CMAKE_SOURCE_DIR}/busybox-minimal ::busybox_ COMMAND mcopy -i boot.img@@1M ${CMAKE_SOURCE_DIR}/busybox ::busybox COMMAND mcopy -i boot.img@@1M ${CMAKE_SOURCE_DIR}/init_script.sh ::initsh ) add_custom_command(OUTPUT run POST_BUILD DEPENDS boot.img COMMAND bochs -f ${CMAKE_SOURCE_DIR}/bochs.conf )