source: mainline/kernel/genarch/include/multiboot/multiboot.h@ e6a356dd

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since e6a356dd was 1f5c9c96, checked in by Martin Decky <martin@…>, 14 years ago

implement multiboot v2 specification and use it in GRUB for UEFI

  • improve multiboot v1 code, move defines to a common location
  • rename VESA framebuffer stuff to generic "boot framebuffer"
  • small collateral changes
  • Property mode set to 100644
File size: 3.0 KB
RevLine 
[4b241f3]1/*
[5d8d71e]2 * Copyright (c) 2009 Jiri Svoboda
[4b241f3]3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
[5d8d71e]29/** @addtogroup genarch
[4b241f3]30 * @{
31 */
32/** @file
33 */
34
[5d8d71e]35#ifndef KERN_MULTIBOOT_H_
36#define KERN_MULTIBOOT_H_
[4b241f3]37
[1f5c9c96]38#define MULTIBOOT_HEADER_MAGIC 0x1badb002
39#define MULTIBOOT_HEADER_FLAGS 0x00010003
40
41#define MULTIBOOT_LOADER_MAGIC 0x2badb002
42
43#ifndef __ASM__
44
[d99c1d2]45#include <typedefs.h>
[4b241f3]46#include <arch/boot/memmap.h>
47
[1f5c9c96]48/** Convert 32-bit multiboot address to a pointer. */
49#define MULTIBOOT_PTR(mba) ((void *) (uintptr_t) (mba))
50
[5d8d71e]51/** Multiboot 32-bit address. */
52typedef uint32_t mbaddr_t;
53
[1f5c9c96]54/** Multiboot module structure */
[4b241f3]55typedef struct {
[5d8d71e]56 mbaddr_t start;
57 mbaddr_t end;
58 mbaddr_t string;
[4b241f3]59 uint32_t reserved;
[1f5c9c96]60} __attribute__((packed)) multiboot_module_t;
[4b241f3]61
62/** Multiboot mmap structure */
63typedef struct {
64 uint32_t size;
65 e820memmap_t mm_info;
[1f5c9c96]66} __attribute__((packed)) multiboot_memmap_t;
[4b241f3]67
68/** Multiboot information structure */
69typedef struct {
70 uint32_t flags;
[5d8d71e]71 uint32_t mem_lower;
72 uint32_t mem_upper;
[deca67b]73
[4b241f3]74 uint32_t boot_device;
[5d8d71e]75 uint32_t cmdline;
[deca67b]76
[4b241f3]77 uint32_t mods_count;
[5d8d71e]78 mbaddr_t mods_addr;
[deca67b]79
[4b241f3]80 uint32_t syms[4];
[deca67b]81
[4b241f3]82 uint32_t mmap_length;
[5d8d71e]83 mbaddr_t mmap_addr;
[deca67b]84
[4b241f3]85 /* ... */
[1f5c9c96]86} __attribute__((packed)) multiboot_info_t;
[4b241f3]87
[5d8d71e]88enum multiboot_info_flags {
[1f5c9c96]89 MULTIBOOT_INFO_FLAGS_MEM = 0x01,
90 MULTIBOOT_INFO_FLAGS_BOOT = 0x02,
91 MULTIBOOT_INFO_FLAGS_CMDLINE = 0x04,
92 MULTIBOOT_INFO_FLAGS_MODS = 0x08,
93 MULTIBOOT_INFO_FLAGS_SYMS1 = 0x10,
94 MULTIBOOT_INFO_FLAGS_SYMS2 = 0x20,
95 MULTIBOOT_INFO_FLAGS_MMAP = 0x40
[deca67b]96
[4b241f3]97 /* ... */
98};
99
[1f5c9c96]100extern void multiboot_extract_command(char *, size_t, const char *);
[5d8d71e]101extern void multiboot_info_parse(uint32_t, const multiboot_info_t *);
102
[1f5c9c96]103#endif /* __ASM__ */
104
[4b241f3]105#endif
106
107/** @}
108 */
Note: See TracBrowser for help on using the repository browser.