diff options
author | Danny Holman <dholman@gymli.org> | 2025-10-19 21:43:56 -0500 |
---|---|---|
committer | Danny Holman <dholman@gymli.org> | 2025-10-19 21:43:56 -0500 |
commit | b2d5436d35ce223f9d8b2d8d598c1e0b5e053c4a (patch) | |
tree | bbeb08cdb5d1ddb0ece37025d7c13b1091b4e32d /include/bootabi/bootparam.h | |
parent | build: align all build files (diff) | |
download | box-b2d5436d35ce223f9d8b2d8d598c1e0b5e053c4a.tar.gz box-b2d5436d35ce223f9d8b2d8d598c1e0b5e053c4a.tar.zst box-b2d5436d35ce223f9d8b2d8d598c1e0b5e053c4a.zip |
include: create the basics of a libc
Create the most basic files for a POSIX-conformant standard C library
implementation. These basic files should be enough to get the bootloader
and kernel off the ground and not much else. Additional testing should
be done on these files.
Signed-off-by: Danny Holman <dholman@gymli.org>
Diffstat (limited to '')
-rw-r--r-- | include/bootabi/bootparam.h | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/include/bootabi/bootparam.h b/include/bootabi/bootparam.h new file mode 100644 index 0000000..0ec28d9 --- /dev/null +++ b/include/bootabi/bootparam.h @@ -0,0 +1,60 @@ +/* + * Copyright (C) 2025 Danny Holman <dholman@gymli.org> + * + * This file is part of BoxOS, a free and open-source Unix-like operating + * system. + * + * BoxOS is free software; you can redistribute it and/or modify under the + * terms of the GNU General Public License as published by the Free Software + * Foundation; either version 2 of the License, or (at your option) any later + * version. + * + * BoxOS is distributed in the hope it will be useful, but WITHOUT ANY WARRANTY; + * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A + * PARTICULAR PURPOSE. See the GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License along with + * BoxOS; if not, see <https://www.gnu.org/licenses/>. + */ + +#ifndef SYS_BOOTPARAM_H +#define SYS_BOOTPARAM_H + +#include <stdint.h> +#include <stddef.h> + +#define FIRMWARE_UEFI 1 +#define FIRMWARE_OSBI 2 + +#define MAX_CMDLINE_SIZE 1024 + +#define BOOTPARAM_MAGIC 0x424F4F54 // "BOOT" + +enum mem_type { + MEM_USABLE, + MEM_IO, + MEM_ACPI, + MEM_ACPI_RECLAIM, + MEM_PERSIST, + MEM_FIRMWARE, +}; + +typedef struct mmap_entry { + uint8_t mem_type; + uint64_t num_pages; + uintptr_t start; + struct mmap_entry *next; +} mmap_entry_t; + +typedef struct bootparam { + uint32_t magic; + uint32_t firmware_id; + void *stack_ptr; + void *heap_ptr; + void *firmware_params; + uint32_t num_mmap_entries; + mmap_entry_t *mmap; + char cmdline[MAX_CMDLINE_SIZE]; +} bootparam_t; + +#endif |