e820_x86.h 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
  2. #ifndef _ASM_X86_E820_H
  3. #define _ASM_X86_E820_H
  4. #define E820MAP 0x2d0 /* our map */
  5. #define E820MAX 128 /* number of entries in E820MAP */
  6. /*
  7. * Legacy E820 BIOS limits us to 128 (E820MAX) nodes due to the
  8. * constrained space in the zeropage. If we have more nodes than
  9. * that, and if we've booted off EFI firmware, then the EFI tables
  10. * passed us from the EFI firmware can list more nodes. Size our
  11. * internal memory map tables to have room for these additional
  12. * nodes, based on up to three entries per node for which the
  13. * kernel was built: MAX_NUMNODES == (1 << CONFIG_NODES_SHIFT),
  14. * plus E820MAX, allowing space for the possible duplicate E820
  15. * entries that might need room in the same arrays, prior to the
  16. * call to sanitize_e820_map() to remove duplicates. The allowance
  17. * of three memory map entries per node is "enough" entries for
  18. * the initial hardware platform motivating this mechanism to make
  19. * use of additional EFI map entries. Future platforms may want
  20. * to allow more than three entries per node or otherwise refine
  21. * this size.
  22. */
  23. #define E820_X_MAX E820MAX
  24. #define E820NR 0x1e8 /* # entries in E820MAP */
  25. #define E820_RAM 1
  26. #define E820_RESERVED 2
  27. #define E820_ACPI 3
  28. #define E820_NVS 4
  29. #define E820_UNUSABLE 5
  30. #define E820_PMEM 7
  31. /*
  32. * This is a non-standardized way to represent ADR or NVDIMM regions that
  33. * persist over a reboot. The kernel will ignore their special capabilities
  34. * unless the CONFIG_X86_PMEM_LEGACY option is set.
  35. *
  36. * ( Note that older platforms also used 6 for the same type of memory,
  37. * but newer versions switched to 12 as 6 was assigned differently. Some
  38. * time they will learn... )
  39. */
  40. #define E820_PRAM 12
  41. /*
  42. * reserved RAM used by kernel itself
  43. * if CONFIG_INTEL_TXT is enabled, memory of this type will be
  44. * included in the S3 integrity calculation and so should not include
  45. * any memory that BIOS might alter over the S3 transition
  46. */
  47. #define E820_RESERVED_KERN 128
  48. #ifndef __ASSEMBLY__
  49. #include <linux/types.h>
  50. struct e820entry {
  51. __u64 addr; /* start of memory segment */
  52. __u64 size; /* size of memory segment */
  53. __u32 type; /* type of memory segment */
  54. } __attribute__((packed));
  55. struct e820map {
  56. __u32 nr_map;
  57. struct e820entry map[E820_X_MAX];
  58. };
  59. #define ISA_START_ADDRESS 0xa0000
  60. #define ISA_END_ADDRESS 0x100000
  61. #define BIOS_BEGIN 0x000a0000
  62. #define BIOS_END 0x00100000
  63. #define BIOS_ROM_BASE 0xffe00000
  64. #define BIOS_ROM_END 0xffffffff
  65. #endif /* __ASSEMBLY__ */
  66. #endif /* _ASM_X86_E820_H */