123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156 |
- cmake_minimum_required(VERSION 3.15)
- project(kernel_main C CXX ASM)
- set(CMAKE_EXPORT_COMPILE_COMMANDS ON)
- set(CMAKE_CXX_LINK_EXECUTABLE
- "<CMAKE_LINKER> <CMAKE_CXX_LINK_FLAGS> <LINK_FLAGS> <OBJECTS> -o <TARGET> <LINK_LIBRARIES>")
- 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/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/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/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
- )
|