Graeme Russ | 1bab104 | 2010-04-24 00:05:49 +1000 | [diff] [blame] | 1 | #ifndef _ASM_X86_E820_H |
| 2 | #define _ASM_X86_E820_H |
Graeme Russ | 1bab104 | 2010-04-24 00:05:49 +1000 | [diff] [blame] | 3 | |
Bin Meng | 27947c9 | 2015-04-21 12:21:35 +0800 | [diff] [blame] | 4 | #define E820MAX 128 /* number of entries in E820MAP */ |
Graeme Russ | 1bab104 | 2010-04-24 00:05:49 +1000 | [diff] [blame] | 5 | |
Simon Glass | f92c54e | 2025-03-15 14:25:53 +0000 | [diff] [blame] | 6 | #ifdef __ASSEMBLY__ |
| 7 | |
Graeme Russ | 1bab104 | 2010-04-24 00:05:49 +1000 | [diff] [blame] | 8 | #define E820_RAM 1 |
| 9 | #define E820_RESERVED 2 |
| 10 | #define E820_ACPI 3 |
| 11 | #define E820_NVS 4 |
| 12 | #define E820_UNUSABLE 5 |
Simon Glass | aad0d76 | 2020-09-05 14:50:50 -0600 | [diff] [blame] | 13 | #define E820_COUNT 6 /* Number of types */ |
Graeme Russ | 1bab104 | 2010-04-24 00:05:49 +1000 | [diff] [blame] | 14 | |
Simon Glass | f92c54e | 2025-03-15 14:25:53 +0000 | [diff] [blame] | 15 | #else |
| 16 | |
Graeme Russ | 1bab104 | 2010-04-24 00:05:49 +1000 | [diff] [blame] | 17 | #include <linux/types.h> |
Bin Meng | 27947c9 | 2015-04-21 12:21:35 +0800 | [diff] [blame] | 18 | |
Simon Glass | f92c54e | 2025-03-15 14:25:53 +0000 | [diff] [blame] | 19 | /* Available e820 memory-region types */ |
| 20 | enum e820_type { |
| 21 | E820_RAM = 1, |
| 22 | E820_RESERVED, |
| 23 | E820_ACPI, |
| 24 | E820_NVS, |
| 25 | E820_UNUSABLE, |
| 26 | |
| 27 | E820_COUNT, |
| 28 | }; |
| 29 | |
Bin Meng | 4b8fc74 | 2018-04-11 22:02:11 -0700 | [diff] [blame] | 30 | struct e820_entry { |
Graeme Russ | 1bab104 | 2010-04-24 00:05:49 +1000 | [diff] [blame] | 31 | __u64 addr; /* start of memory segment */ |
| 32 | __u64 size; /* size of memory segment */ |
| 33 | __u32 type; /* type of memory segment */ |
| 34 | } __attribute__((packed)); |
| 35 | |
Graeme Russ | 1bab104 | 2010-04-24 00:05:49 +1000 | [diff] [blame] | 36 | #define ISA_START_ADDRESS 0xa0000 |
| 37 | #define ISA_END_ADDRESS 0x100000 |
| 38 | |
Simon Glass | f92c54e | 2025-03-15 14:25:53 +0000 | [diff] [blame] | 39 | /** |
| 40 | * Context to use for e820_add() |
| 41 | * |
| 42 | * @entries: Table being filled in |
| 43 | * @addr: Current address we are up to |
| 44 | * @count: Number of entries added to @entries so far |
| 45 | * @max_entries: Maximum number of entries allowed |
| 46 | */ |
| 47 | struct e820_ctx { |
| 48 | struct e820_entry *entries; |
| 49 | u64 addr; |
| 50 | int count; |
| 51 | int max_entries; |
| 52 | }; |
| 53 | |
| 54 | /** |
| 55 | * e820_init() - Start setting up an e820 table |
| 56 | * |
| 57 | * @ctx: Context to set up |
| 58 | * @entries: Place to put entries |
| 59 | * @max_entries: Maximum size of @entries |
| 60 | */ |
| 61 | void e820_init(struct e820_ctx *ctx, struct e820_entry *entries, |
| 62 | int max_entries); |
| 63 | |
| 64 | /** |
| 65 | * e820_add() - Add an entry to the table |
| 66 | * |
| 67 | * @ctx: Context |
| 68 | * @type: Type of entry |
| 69 | * @addr: Start address of entry |
| 70 | * @size Size of entry |
| 71 | */ |
| 72 | void e820_add(struct e820_ctx *ctx, enum e820_type type, u64 addr, u64 size); |
| 73 | |
| 74 | /** |
| 75 | * e820_to_addr() - Add an entry that covers the space up to a given address |
| 76 | * |
| 77 | * @ctx: Context |
| 78 | * @type: Type of entry |
| 79 | * @end_addr: Address where the entry should finish |
| 80 | */ |
| 81 | void e820_to_addr(struct e820_ctx *ctx, enum e820_type type, u64 end_addr); |
| 82 | |
| 83 | /** |
| 84 | * e820_next() - Add an entry that carries on from the last one |
| 85 | * |
| 86 | * @ctx: Context |
| 87 | * @type: Type of entry |
| 88 | * @size Size of entry |
| 89 | */ |
| 90 | void e820_next(struct e820_ctx *ctx, enum e820_type type, u64 size); |
| 91 | |
| 92 | /** |
| 93 | * e820_finish() - Finish the table |
| 94 | * |
| 95 | * Checks the table is not too large, panics if so |
| 96 | * |
| 97 | * @ctx: Context |
| 98 | * Returns: Number of entries |
| 99 | */ |
| 100 | int e820_finish(struct e820_ctx *ctx); |
| 101 | |
Simon Glass | 02c5120 | 2021-03-15 18:00:23 +1300 | [diff] [blame] | 102 | /* Implementation-defined function to install an e820 map */ |
Bin Meng | 3838d71 | 2018-04-11 22:02:10 -0700 | [diff] [blame] | 103 | unsigned int install_e820_map(unsigned int max_entries, |
Bin Meng | 4b8fc74 | 2018-04-11 22:02:11 -0700 | [diff] [blame] | 104 | struct e820_entry *); |
Simon Glass | 02c5120 | 2021-03-15 18:00:23 +1300 | [diff] [blame] | 105 | |
| 106 | /** |
Simon Glass | f92c54e | 2025-03-15 14:25:53 +0000 | [diff] [blame] | 107 | * e820_dump() - Dump the e820 table |
| 108 | * |
| 109 | * @entries: Pointer to start of table |
| 110 | * @count: Number of entries in the table |
| 111 | */ |
| 112 | void e820_dump(struct e820_entry *entries, uint count); |
| 113 | |
| 114 | /** |
Simon Glass | 02c5120 | 2021-03-15 18:00:23 +1300 | [diff] [blame] | 115 | * cb_install_e820_map() - Install e820 map provided by coreboot sysinfo |
| 116 | * |
| 117 | * This should be used when booting from coreboot, since in that case the |
| 118 | * memory areas are provided by coreboot in its sysinfo. |
| 119 | * |
| 120 | * @max_entries: Maximum number of entries to write |
| 121 | * @entries: Place to put entires |
Heinrich Schuchardt | 47b4c02 | 2022-01-19 18:05:50 +0100 | [diff] [blame] | 122 | * Return: number of entries written |
Simon Glass | 02c5120 | 2021-03-15 18:00:23 +1300 | [diff] [blame] | 123 | */ |
| 124 | unsigned int cb_install_e820_map(unsigned int max_entries, |
| 125 | struct e820_entry *entries); |
| 126 | |
Simon Glass | b106f07 | 2025-03-15 14:25:52 +0000 | [diff] [blame] | 127 | /** |
| 128 | * e820_dump() - Dump an e820 table |
| 129 | * |
| 130 | * @entries: Pointer to first entry |
| 131 | * @count: Number of entries in the table |
| 132 | */ |
| 133 | void e820_dump(struct e820_entry *entries, uint count); |
| 134 | |
Simon Glass | dd23446 | 2020-09-22 12:45:29 -0600 | [diff] [blame] | 135 | #endif /* __ASSEMBLY__ */ |
Bin Meng | a489963 | 2015-10-07 20:19:10 -0700 | [diff] [blame] | 136 | |
Graeme Russ | 1bab104 | 2010-04-24 00:05:49 +1000 | [diff] [blame] | 137 | #endif /* _ASM_X86_E820_H */ |