From cbc5988c2073b22cf4808ab86930b981d58b4d30 Mon Sep 17 00:00:00 2001 From: ichdream Date: Wed, 11 Aug 2021 13:03:45 +0800 Subject: [PATCH] =?UTF-8?q?=E6=B7=BB=E5=8A=A0multiboot.h=E6=8E=A5=E5=8F=A3?= =?UTF-8?q?=E5=87=BD=E6=95=B0,=20=E4=BB=8Emultiboot=E4=B8=AD=E6=8F=90?= =?UTF-8?q?=E5=8F=96=E4=BF=A1=E6=81=AF?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- include/multiboot.h | 95 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 95 insertions(+) create mode 100644 include/multiboot.h diff --git a/include/multiboot.h b/include/multiboot.h new file mode 100644 index 0000000..5888d11 --- /dev/null +++ b/include/multiboot.h @@ -0,0 +1,95 @@ +/* +* +* +* +* date: 2021-08-11 +* email: ichdream@foxmail.com +*/ + +#ifndef INCLUDE_MULTIBOOT_H_ +#define INCLUDE_MULTIBOOT_H_ + +#include "types.h" + +/** + * 启动后,在32位内核进入点,机器状态如下: + * 1. CS 指向基地址为 0x00000000,限长为4G – 1的代码段描述符。 + * 2. DS,SS,ES,FS 和 GS 指向基地址为0x00000000,限长为4G – 1的数据段描述符。 + * 3. A20 地址线已经打开。 + * 4. 页机制被禁止。 + * 5. 中断被禁止。 + * 6. EAX = 0x2BADB002 + * 7. 系统信息和启动信息块的线性地址保存在 EBX中(相当于一个指针)。 + * 以下即为这个信息块的结构 + */ + +typedef +struct multiboot_t { + uint32_t flags; // Multiboot 的版本信息 + /** + * 从 BIOS 获知的可用内存 + * + * mem_lower和mem_upper分别指出了低端和高端内存的大小,单位是K。 + * 低端内存的首地址是0,高端内存的首地址是1M。 + * 低端内存的最大可能值是640K。 + * 高端内存的最大可能值是最大值减去1M。但并不保证是这个值。 + */ + uint32_t mem_lower; + uint32_t mem_upper; + + uint32_t boot_device; // 指出引导程序从哪个BIOS磁盘设备载入的OS映像 + uint32_t cmdline; // 内核命令行 + uint32_t mods_count; // boot 模块列表 + uint32_t mods_addr; + + /** + * ELF 格式内核映像的section头表、每项的大小、一共有几项以及作为名字索引的字符串表。 + * 它们对应于可执行可连接格式(ELF)的program头中的shdr_* 项(shdr_num等)。 + * 所有的section都会被载入,ELF section头的物理地址域指向所有的section在内存中的位置。 + */ + uint32_t num; + uint32_t size; + uint32_t addr; + uint32_t shndx; + + /** + * 以下两项指出保存由BIOS提供的内存分布的缓冲区的地址和长度 + * mmap_addr是缓冲区的地址,mmap_length是缓冲区的总大小 + * 缓冲区由一个或者多个下面的大小/结构对 mmap_entry_t(size实际上是用来跳过下一个对的)组成 + */ + uint32_t mmap_length; + uint32_t mmap_addr; + + uint32_t drives_length; // 指出第一个驱动器结构的物理地址 + uint32_t drives_addr; // 指出第一个驱动器这个结构的大小 + uint32_t config_table; // ROM 配置表 + uint32_t boot_loader_name; // boot loader 的名字 + uint32_t apm_table; // APM 表 + uint32_t vbe_control_info; + uint32_t vbe_mode_info; + uint32_t vbe_mode; + uint32_t vbe_interface_seg; + uint32_t vbe_interface_off; + uint32_t vbe_interface_len; +} __attribute__((packed)) multiboot_t; + +/** + * size是相关结构的大小,单位是字节,它可能大于最小值20 + * base_addr_low是启动地址的低32位,base_addr_high是高32位,启动地址总共有64位 + * length_low是内存区域大小的低32位,length_high是内存区域大小的高32位,总共是64位 + * type是相应地址区间的类型,1代表可用RAM,所有其它的值代表保留区域 + */ +typedef +struct mmap_entry_t { + uint32_t size; // 留意 size 是不含 size 自身变量的大小 + uint32_t base_addr_low; + uint32_t base_addr_high; + uint32_t length_low; + uint32_t length_high; + uint32_t type; +} __attribute__((packed)) mmap_entry_t; + +// 声明全局的 multiboot_t * 指针 +extern multiboot_t *glb_mboot_ptr; + +#endif // INCLUDE_MULTIBOOT_H_ \ No newline at end of file