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
Line 
1/*
2 * Copyright (c) 2009 Jiri Svoboda
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
29/** @addtogroup genarch
30 * @{
31 */
32/** @file
33 */
34
35#ifndef KERN_MULTIBOOT_H_
36#define KERN_MULTIBOOT_H_
37
38#define MULTIBOOT_HEADER_MAGIC 0x1badb002
39#define MULTIBOOT_HEADER_FLAGS 0x00010003
40
41#define MULTIBOOT_LOADER_MAGIC 0x2badb002
42
43#ifndef __ASM__
44
45#include <typedefs.h>
46#include <arch/boot/memmap.h>
47
48/** Convert 32-bit multiboot address to a pointer. */
49#define MULTIBOOT_PTR(mba) ((void *) (uintptr_t) (mba))
50
51/** Multiboot 32-bit address. */
52typedef uint32_t mbaddr_t;
53
54/** Multiboot module structure */
55typedef struct {
56 mbaddr_t start;
57 mbaddr_t end;
58 mbaddr_t string;
59 uint32_t reserved;
60} __attribute__((packed)) multiboot_module_t;
61
62/** Multiboot mmap structure */
63typedef struct {
64 uint32_t size;
65 e820memmap_t mm_info;
66} __attribute__((packed)) multiboot_memmap_t;
67
68/** Multiboot information structure */
69typedef struct {
70 uint32_t flags;
71 uint32_t mem_lower;
72 uint32_t mem_upper;
73
74 uint32_t boot_device;
75 uint32_t cmdline;
76
77 uint32_t mods_count;
78 mbaddr_t mods_addr;
79
80 uint32_t syms[4];
81
82 uint32_t mmap_length;
83 mbaddr_t mmap_addr;
84
85 /* ... */
86} __attribute__((packed)) multiboot_info_t;
87
88enum multiboot_info_flags {
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
96
97 /* ... */
98};
99
100extern void multiboot_extract_command(char *, size_t, const char *);
101extern void multiboot_info_parse(uint32_t, const multiboot_info_t *);
102
103#endif /* __ASM__ */
104
105#endif
106
107/** @}
108 */
Note: See TracBrowser for help on using the repository browser.