global_data.h 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. /* SPDX-License-Identifier: GPL-2.0+ */
  2. /*
  3. * (C) Copyright 2002-2010
  4. * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
  5. */
  6. #ifndef __ASM_GBL_DATA_H
  7. #define __ASM_GBL_DATA_H
  8. #include "config.h"
  9. #include "asm/types.h"
  10. /* Architecture-specific global data */
  11. struct arch_global_data {
  12. #if defined(CONFIG_FSL_ESDHC)
  13. u32 sdhc_clk;
  14. #if defined(CONFIG_FSL_ESDHC_ADAPTER_IDENT)
  15. u8 sdhc_adapter;
  16. #endif
  17. #endif
  18. #if defined(CONFIG_MPC8xx)
  19. unsigned long brg_clk;
  20. #endif
  21. #if defined(CONFIG_CPM2)
  22. /* There are many clocks on the MPC8260 - see page 9-5 */
  23. unsigned long vco_out;
  24. unsigned long cpm_clk;
  25. unsigned long scc_clk;
  26. unsigned long brg_clk;
  27. #endif
  28. /* TODO: sjg@chromium.org: Should these be unslgned long? */
  29. #if defined(CONFIG_MPC83xx)
  30. /* There are other clocks in the MPC83XX */
  31. u32 csb_clk;
  32. # if defined(CONFIG_MPC8308) || defined(CONFIG_MPC831x) || \
  33. defined(CONFIG_MPC834x) || defined(CONFIG_MPC837x)
  34. u32 tsec1_clk;
  35. u32 tsec2_clk;
  36. u32 usbdr_clk;
  37. # elif defined(CONFIG_MPC8309)
  38. u32 usbdr_clk;
  39. # endif
  40. # if defined(CONFIG_MPC834x)
  41. u32 usbmph_clk;
  42. # endif /* CONFIG_MPC834x */
  43. # if defined(CONFIG_MPC8315)
  44. u32 tdm_clk;
  45. # endif
  46. u32 core_clk;
  47. u32 enc_clk;
  48. u32 lbiu_clk;
  49. u32 lclk_clk;
  50. # if defined(CONFIG_MPC8308) || defined(CONFIG_MPC831x) || \
  51. defined(CONFIG_MPC837x)
  52. u32 pciexp1_clk;
  53. u32 pciexp2_clk;
  54. # endif
  55. # if defined(CONFIG_MPC837x) || defined(CONFIG_MPC8315)
  56. u32 sata_clk;
  57. # endif
  58. # if defined(CONFIG_MPC8360)
  59. u32 mem_sec_clk;
  60. # endif /* CONFIG_MPC8360 */
  61. #endif
  62. #if defined(CONFIG_MPC85xx) || defined(CONFIG_MPC86xx)
  63. u32 lbc_clk;
  64. void *cpu;
  65. #endif /* CONFIG_MPC85xx || CONFIG_MPC86xx */
  66. #if defined(CONFIG_MPC83xx) || defined(CONFIG_MPC85xx) || \
  67. defined(CONFIG_MPC86xx)
  68. u32 i2c1_clk;
  69. u32 i2c2_clk;
  70. #endif
  71. #if defined(CONFIG_QE)
  72. u32 qe_clk;
  73. u32 brg_clk;
  74. uint mp_alloc_base;
  75. uint mp_alloc_top;
  76. #endif /* CONFIG_QE */
  77. #if defined(CONFIG_FSL_LAW)
  78. u32 used_laws;
  79. #endif
  80. #if defined(CONFIG_E500)
  81. u32 used_tlb_cams[(CONFIG_SYS_NUM_TLBCAMS+31)/32];
  82. #endif
  83. unsigned long reset_status; /* reset status register at boot */
  84. #if defined(CONFIG_MPC83xx)
  85. unsigned long arbiter_event_attributes;
  86. unsigned long arbiter_event_address;
  87. #endif
  88. #if defined(CONFIG_CPM2)
  89. unsigned int dp_alloc_base;
  90. unsigned int dp_alloc_top;
  91. #endif
  92. #ifdef CONFIG_SYS_FPGA_COUNT
  93. unsigned fpga_state[CONFIG_SYS_FPGA_COUNT];
  94. #endif
  95. #if defined(CONFIG_WD_MAX_RATE)
  96. unsigned long long wdt_last; /* trace watch-dog triggering rate */
  97. #endif
  98. #if defined(CONFIG_LWMON5)
  99. unsigned long kbd_status;
  100. #endif
  101. };
  102. #include <asm-generic/global_data.h>
  103. #if 1
  104. #define DECLARE_GLOBAL_DATA_PTR register volatile gd_t *gd asm ("r2")
  105. #else /* We could use plain global data, but the resulting code is bigger */
  106. #define XTRN_DECLARE_GLOBAL_DATA_PTR extern
  107. #define DECLARE_GLOBAL_DATA_PTR XTRN_DECLARE_GLOBAL_DATA_PTR \
  108. gd_t *gd
  109. #endif
  110. #endif /* __ASM_GBL_DATA_H */