Tom Rini | 10e4779 | 2018-05-06 17:58:06 -0400 | [diff] [blame] | 1 | // SPDX-License-Identifier: GPL-2.0+ |
Bin Meng | a489963 | 2015-10-07 20:19:10 -0700 | [diff] [blame] | 2 | /* |
| 3 | * Copyright (C) 2015, Bin Meng <bmeng.cn@gmail.com> |
Bin Meng | a489963 | 2015-10-07 20:19:10 -0700 | [diff] [blame] | 4 | */ |
| 5 | |
Bin Meng | 1a4e82d | 2018-06-27 20:38:01 -0700 | [diff] [blame] | 6 | #include <efi_loader.h> |
Sughosh Ganu | 526eebd | 2024-10-15 21:07:13 +0530 | [diff] [blame] | 7 | #include <lmb.h> |
Bin Meng | a489963 | 2015-10-07 20:19:10 -0700 | [diff] [blame] | 8 | #include <asm/e820.h> |
Simon Glass | 3ba929a | 2020-10-30 21:38:53 -0600 | [diff] [blame] | 9 | #include <asm/global_data.h> |
Bin Meng | a489963 | 2015-10-07 20:19:10 -0700 | [diff] [blame] | 10 | |
| 11 | DECLARE_GLOBAL_DATA_PTR; |
| 12 | |
| 13 | /* |
| 14 | * Install a default e820 table with 4 entries as follows: |
| 15 | * |
| 16 | * 0x000000-0x0a0000 Useable RAM |
| 17 | * 0x0a0000-0x100000 Reserved for ISA |
| 18 | * 0x100000-gd->ram_size Useable RAM |
| 19 | * CONFIG_PCIE_ECAM_BASE PCIe ECAM |
| 20 | */ |
Bin Meng | 3838d71 | 2018-04-11 22:02:10 -0700 | [diff] [blame] | 21 | __weak unsigned int install_e820_map(unsigned int max_entries, |
Bin Meng | 4b8fc74 | 2018-04-11 22:02:11 -0700 | [diff] [blame] | 22 | struct e820_entry *entries) |
Bin Meng | a489963 | 2015-10-07 20:19:10 -0700 | [diff] [blame] | 23 | { |
| 24 | entries[0].addr = 0; |
| 25 | entries[0].size = ISA_START_ADDRESS; |
| 26 | entries[0].type = E820_RAM; |
| 27 | entries[1].addr = ISA_START_ADDRESS; |
| 28 | entries[1].size = ISA_END_ADDRESS - ISA_START_ADDRESS; |
| 29 | entries[1].type = E820_RESERVED; |
| 30 | entries[2].addr = ISA_END_ADDRESS; |
| 31 | entries[2].size = gd->ram_size - ISA_END_ADDRESS; |
| 32 | entries[2].type = E820_RAM; |
| 33 | entries[3].addr = CONFIG_PCIE_ECAM_BASE; |
| 34 | entries[3].size = CONFIG_PCIE_ECAM_SIZE; |
| 35 | entries[3].type = E820_RESERVED; |
| 36 | |
| 37 | return 4; |
| 38 | } |
Bin Meng | 1a4e82d | 2018-06-27 20:38:01 -0700 | [diff] [blame] | 39 | |
Stephen Warren | d0de806 | 2018-08-30 15:43:43 -0600 | [diff] [blame] | 40 | #if CONFIG_IS_ENABLED(EFI_LOADER) |
Bin Meng | 1a4e82d | 2018-06-27 20:38:01 -0700 | [diff] [blame] | 41 | void efi_add_known_memory(void) |
| 42 | { |
| 43 | struct e820_entry e820[E820MAX]; |
| 44 | unsigned int i, num; |
Sughosh Ganu | 526eebd | 2024-10-15 21:07:13 +0530 | [diff] [blame] | 45 | u64 start; |
Bin Meng | 1a4e82d | 2018-06-27 20:38:01 -0700 | [diff] [blame] | 46 | int type; |
| 47 | |
| 48 | num = install_e820_map(ARRAY_SIZE(e820), e820); |
| 49 | |
| 50 | for (i = 0; i < num; ++i) { |
| 51 | start = e820[i].addr; |
Bin Meng | 1a4e82d | 2018-06-27 20:38:01 -0700 | [diff] [blame] | 52 | |
| 53 | switch (e820[i].type) { |
| 54 | case E820_RAM: |
| 55 | type = EFI_CONVENTIONAL_MEMORY; |
| 56 | break; |
| 57 | case E820_RESERVED: |
| 58 | type = EFI_RESERVED_MEMORY_TYPE; |
| 59 | break; |
| 60 | case E820_ACPI: |
| 61 | type = EFI_ACPI_RECLAIM_MEMORY; |
| 62 | break; |
| 63 | case E820_NVS: |
| 64 | type = EFI_ACPI_MEMORY_NVS; |
| 65 | break; |
| 66 | case E820_UNUSABLE: |
| 67 | default: |
| 68 | type = EFI_UNUSABLE_MEMORY; |
| 69 | break; |
| 70 | } |
| 71 | |
Sughosh Ganu | 526eebd | 2024-10-15 21:07:13 +0530 | [diff] [blame] | 72 | if (type != EFI_CONVENTIONAL_MEMORY) |
Michael Walle | 282d386 | 2020-05-17 12:29:19 +0200 | [diff] [blame] | 73 | efi_add_memory_map(start, e820[i].size, type); |
Bin Meng | 1a4e82d | 2018-06-27 20:38:01 -0700 | [diff] [blame] | 74 | } |
| 75 | } |
Stephen Warren | d0de806 | 2018-08-30 15:43:43 -0600 | [diff] [blame] | 76 | #endif /* CONFIG_IS_ENABLED(EFI_LOADER) */ |
Sughosh Ganu | 526eebd | 2024-10-15 21:07:13 +0530 | [diff] [blame] | 77 | |
| 78 | #if CONFIG_IS_ENABLED(LMB_ARCH_MEM_MAP) |
| 79 | void lmb_arch_add_memory(void) |
| 80 | { |
| 81 | struct e820_entry e820[E820MAX]; |
| 82 | unsigned int i, num; |
| 83 | u64 ram_top; |
| 84 | |
| 85 | num = install_e820_map(ARRAY_SIZE(e820), e820); |
| 86 | |
| 87 | ram_top = (u64)gd->ram_top & ~EFI_PAGE_MASK; |
| 88 | if (!ram_top) |
| 89 | ram_top = 0x100000000ULL; |
| 90 | |
| 91 | for (i = 0; i < num; ++i) { |
| 92 | if (e820[i].type == E820_RAM) { |
| 93 | u64 start, size, rgn_top; |
| 94 | |
| 95 | start = e820[i].addr; |
| 96 | size = e820[i].size; |
| 97 | rgn_top = start + size; |
| 98 | |
| 99 | if (start > ram_top) |
| 100 | continue; |
| 101 | |
| 102 | if (rgn_top > ram_top) |
| 103 | size -= rgn_top - ram_top; |
| 104 | |
| 105 | lmb_add(start, size); |
| 106 | } |
| 107 | } |
| 108 | } |
| 109 | #endif /* CONFIG_IS_ENABLED(LMB_ARCH_MEM_MAP) */ |