bootinfo.h 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. /*
  2. * This file is subject to the terms and conditions of the GNU General Public
  3. * License. See the file COPYING in the main directory of this archive
  4. * for more details.
  5. *
  6. * Copyright (C) 1995, 1996, 2003 by Ralf Baechle
  7. * Copyright (C) 1995, 1996 Andreas Busse
  8. * Copyright (C) 1995, 1996 Stoned Elipot
  9. * Copyright (C) 1995, 1996 Paul M. Antoine.
  10. * Copyright (C) 2009 Zhang Le
  11. */
  12. #ifndef _ASM_BOOTINFO_H
  13. #define _ASM_BOOTINFO_H
  14. #include <linux/types.h>
  15. #include <asm/setup.h>
  16. /*
  17. * The MACH_ IDs are sort of equivalent to PCI product IDs. As such the
  18. * numbers do not necessarily reflect technical relations or similarities
  19. * between systems.
  20. */
  21. /*
  22. * Valid machtype values for group unknown
  23. */
  24. #define MACH_UNKNOWN 0 /* whatever... */
  25. /*
  26. * Valid machtype for group DEC
  27. */
  28. #define MACH_DSUNKNOWN 0
  29. #define MACH_DS23100 1 /* DECstation 2100 or 3100 */
  30. #define MACH_DS5100 2 /* DECsystem 5100 */
  31. #define MACH_DS5000_200 3 /* DECstation 5000/200 */
  32. #define MACH_DS5000_1XX 4 /* DECstation 5000/120, 125, 133, 150 */
  33. #define MACH_DS5000_XX 5 /* DECstation 5000/20, 25, 33, 50 */
  34. #define MACH_DS5000_2X0 6 /* DECstation 5000/240, 260 */
  35. #define MACH_DS5400 7 /* DECsystem 5400 */
  36. #define MACH_DS5500 8 /* DECsystem 5500 */
  37. #define MACH_DS5800 9 /* DECsystem 5800 */
  38. #define MACH_DS5900 10 /* DECsystem 5900 */
  39. /*
  40. * Valid machtype for group PMC-MSP
  41. */
  42. #define MACH_MSP4200_EVAL 0 /* PMC-Sierra MSP4200 Evaluation */
  43. #define MACH_MSP4200_GW 1 /* PMC-Sierra MSP4200 Gateway demo */
  44. #define MACH_MSP4200_FPGA 2 /* PMC-Sierra MSP4200 Emulation */
  45. #define MACH_MSP7120_EVAL 3 /* PMC-Sierra MSP7120 Evaluation */
  46. #define MACH_MSP7120_GW 4 /* PMC-Sierra MSP7120 Residential GW */
  47. #define MACH_MSP7120_FPGA 5 /* PMC-Sierra MSP7120 Emulation */
  48. #define MACH_MSP_OTHER 255 /* PMC-Sierra unknown board type */
  49. /*
  50. * Valid machtype for group Mikrotik
  51. */
  52. #define MACH_MIKROTIK_RB532 0 /* Mikrotik RouterBoard 532 */
  53. #define MACH_MIKROTIK_RB532A 1 /* Mikrotik RouterBoard 532A */
  54. /*
  55. * Valid machtype for Loongson family
  56. */
  57. enum loongson_machine_type {
  58. MACH_LOONGSON_UNKNOWN,
  59. MACH_LEMOTE_FL2E,
  60. MACH_LEMOTE_FL2F,
  61. MACH_LEMOTE_ML2F7,
  62. MACH_LEMOTE_YL2F89,
  63. MACH_DEXXON_GDIUM2F10,
  64. MACH_LEMOTE_NAS,
  65. MACH_LEMOTE_LL2F,
  66. MACH_LOONGSON_GENERIC,
  67. MACH_LOONGSON_END
  68. };
  69. /*
  70. * Valid machtype for group INGENIC
  71. */
  72. #define MACH_INGENIC_JZ4730 0 /* JZ4730 SOC */
  73. #define MACH_INGENIC_JZ4740 1 /* JZ4740 SOC */
  74. extern char *system_type;
  75. const char *get_system_type(void);
  76. extern unsigned long mips_machtype;
  77. #define BOOT_MEM_MAP_MAX 32
  78. #define BOOT_MEM_RAM 1
  79. #define BOOT_MEM_ROM_DATA 2
  80. #define BOOT_MEM_RESERVED 3
  81. #define BOOT_MEM_INIT_RAM 4
  82. /*
  83. * A memory map that's built upon what was determined
  84. * or specified on the command line.
  85. */
  86. struct boot_mem_map {
  87. int nr_map;
  88. struct boot_mem_map_entry {
  89. phys_addr_t addr; /* start of memory segment */
  90. phys_addr_t size; /* size of memory segment */
  91. long type; /* type of memory segment */
  92. } map[BOOT_MEM_MAP_MAX];
  93. };
  94. extern struct boot_mem_map boot_mem_map;
  95. extern void add_memory_region(phys_addr_t start, phys_addr_t size, long type);
  96. extern void detect_memory_region(phys_addr_t start, phys_addr_t sz_min, phys_addr_t sz_max);
  97. extern void prom_init(void);
  98. extern void prom_free_prom_memory(void);
  99. extern void free_init_pages(const char *what,
  100. unsigned long begin, unsigned long end);
  101. extern void (*free_init_pages_eva)(void *begin, void *end);
  102. /*
  103. * Initial kernel command line, usually setup by prom_init()
  104. */
  105. extern char arcs_cmdline[COMMAND_LINE_SIZE];
  106. /*
  107. * Registers a0, a1, a3 and a4 as passed to the kernel entry by firmware
  108. */
  109. extern unsigned long fw_arg0, fw_arg1, fw_arg2, fw_arg3;
  110. #ifdef CONFIG_USE_OF
  111. extern unsigned long fw_passed_dtb;
  112. #endif
  113. /*
  114. * Platform memory detection hook called by setup_arch
  115. */
  116. extern void plat_mem_setup(void);
  117. #ifdef CONFIG_SWIOTLB
  118. /*
  119. * Optional platform hook to call swiotlb_setup().
  120. */
  121. extern void plat_swiotlb_setup(void);
  122. #else
  123. static inline void plat_swiotlb_setup(void) {}
  124. #endif /* CONFIG_SWIOTLB */
  125. #ifdef CONFIG_USE_OF
  126. /**
  127. * plat_get_fdt() - Return a pointer to the platform's device tree blob
  128. *
  129. * This function provides a platform independent API to get a pointer to the
  130. * flattened device tree blob. The interface between bootloader and kernel
  131. * is not consistent across platforms so it is necessary to provide this
  132. * API such that common startup code can locate the FDT.
  133. *
  134. * This is used by the KASLR code to get command line arguments and random
  135. * seed from the device tree. Any platform wishing to use KASLR should
  136. * provide this API and select SYS_SUPPORTS_RELOCATABLE.
  137. *
  138. * Return: Pointer to the flattened device tree blob.
  139. */
  140. extern void *plat_get_fdt(void);
  141. #endif /* CONFIG_USE_OF */
  142. #endif /* _ASM_BOOTINFO_H */