init.h 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. /*
  2. * Copyright (C) 2015-2016 Socionext Inc.
  3. * Author: Masahiro Yamada <yamada.masahiro@socionext.com>
  4. *
  5. * SPDX-License-Identifier: GPL-2.0+
  6. */
  7. #ifndef __MACH_INIT_H
  8. #define __MACH_INIT_H
  9. #include <linux/types.h>
  10. #define UNIPHIER_MAX_NR_DRAM_CH 3
  11. struct uniphier_dram_ch {
  12. unsigned long size;
  13. unsigned int width;
  14. };
  15. struct uniphier_board_data {
  16. unsigned int dram_freq;
  17. struct uniphier_dram_ch dram_ch[UNIPHIER_MAX_NR_DRAM_CH];
  18. unsigned int flags;
  19. #define UNIPHIER_BD_DRAM_SPARSE BIT(9)
  20. #define UNIPHIER_BD_DDR3PLUS BIT(8)
  21. #define UNIPHIER_BD_BOARD_GET_TYPE(f) ((f) & 0x7)
  22. #define UNIPHIER_BD_BOARD_LD20_REF 0 /* LD20 reference */
  23. #define UNIPHIER_BD_BOARD_LD20_GLOBAL 1 /* LD20 TV Set */
  24. #define UNIPHIER_BD_BOARD_LD20_C1 2 /* LD20 TV Set C1 */
  25. #define UNIPHIER_BD_BOARD_LD21_REF 3 /* LD21 reference */
  26. #define UNIPHIER_BD_BOARD_LD21_GLOBAL 4 /* LD21 TV Set */
  27. };
  28. const struct uniphier_board_data *uniphier_get_board_param(void);
  29. int uniphier_sld3_init(const struct uniphier_board_data *bd);
  30. int uniphier_ld4_init(const struct uniphier_board_data *bd);
  31. int uniphier_pro4_init(const struct uniphier_board_data *bd);
  32. int uniphier_sld8_init(const struct uniphier_board_data *bd);
  33. int uniphier_pro5_init(const struct uniphier_board_data *bd);
  34. int uniphier_pxs2_init(const struct uniphier_board_data *bd);
  35. int uniphier_ld11_init(const struct uniphier_board_data *bd);
  36. int uniphier_ld20_init(const struct uniphier_board_data *bd);
  37. #if defined(CONFIG_MICRO_SUPPORT_CARD)
  38. void uniphier_sbc_init_admulti(void);
  39. void uniphier_sbc_init_savepin(void);
  40. void uniphier_ld4_sbc_init(void);
  41. void uniphier_pxs2_sbc_init(void);
  42. void uniphier_ld11_sbc_init(void);
  43. #else
  44. static inline void uniphier_sbc_init_admulti(void)
  45. {
  46. }
  47. static inline void uniphier_sbc_init_savepin(void)
  48. {
  49. }
  50. static inline void uniphier_ld4_sbc_init(void)
  51. {
  52. }
  53. static inline void uniphier_pxs2_sbc_init(void)
  54. {
  55. }
  56. static inline void uniphier_ld11_sbc_init(void)
  57. {
  58. }
  59. #endif
  60. void uniphier_sld3_bcu_init(const struct uniphier_board_data *bd);
  61. void uniphier_ld4_bcu_init(const struct uniphier_board_data *bd);
  62. int uniphier_memconf_2ch_init(const struct uniphier_board_data *bd);
  63. int uniphier_memconf_3ch_no_disbit_init(const struct uniphier_board_data *bd);
  64. int uniphier_memconf_3ch_init(const struct uniphier_board_data *bd);
  65. int uniphier_sld3_dpll_init(const struct uniphier_board_data *bd);
  66. int uniphier_ld4_dpll_init(const struct uniphier_board_data *bd);
  67. int uniphier_pro4_dpll_init(const struct uniphier_board_data *bd);
  68. int uniphier_sld8_dpll_init(const struct uniphier_board_data *bd);
  69. int uniphier_pro5_dpll_init(const struct uniphier_board_data *bd);
  70. int uniphier_pxs2_dpll_init(const struct uniphier_board_data *bd);
  71. int uniphier_ld11_dpll_init(const struct uniphier_board_data *bd);
  72. int uniphier_ld20_dpll_init(const struct uniphier_board_data *bd);
  73. void uniphier_sld3_early_clk_init(void);
  74. void uniphier_ld11_early_clk_init(void);
  75. void uniphier_sld3_dram_clk_init(void);
  76. void uniphier_pro5_dram_clk_init(void);
  77. void uniphier_pxs2_dram_clk_init(void);
  78. void uniphier_ld11_dram_clk_init(void);
  79. void uniphier_ld20_dram_clk_init(void);
  80. int uniphier_sld3_umc_init(const struct uniphier_board_data *bd);
  81. int uniphier_ld4_umc_init(const struct uniphier_board_data *bd);
  82. int uniphier_pro4_umc_init(const struct uniphier_board_data *bd);
  83. int uniphier_sld8_umc_init(const struct uniphier_board_data *bd);
  84. int uniphier_pro5_umc_init(const struct uniphier_board_data *bd);
  85. int uniphier_pxs2_umc_init(const struct uniphier_board_data *bd);
  86. int uniphier_ld20_umc_init(const struct uniphier_board_data *bd);
  87. int uniphier_ld11_umc_init(const struct uniphier_board_data *bd);
  88. void uniphier_sld3_pll_init(void);
  89. void uniphier_ld4_pll_init(void);
  90. void uniphier_pro4_pll_init(void);
  91. void uniphier_ld11_pll_init(void);
  92. void uniphier_ld20_pll_init(void);
  93. void uniphier_pxs3_pll_init(void);
  94. void uniphier_ld4_clk_init(void);
  95. void uniphier_pro4_clk_init(void);
  96. void uniphier_pro5_clk_init(void);
  97. void uniphier_pxs2_clk_init(void);
  98. void uniphier_ld11_clk_init(void);
  99. void uniphier_ld20_clk_init(void);
  100. void uniphier_pxs3_clk_init(void);
  101. unsigned int uniphier_boot_device_raw(void);
  102. int uniphier_have_internal_stm(void);
  103. int uniphier_boot_from_backend(void);
  104. int uniphier_pin_init(const char *pinconfig_name);
  105. void uniphier_smp_kick_all_cpus(void);
  106. void cci500_init(int nr_slaves);
  107. #undef pr_warn
  108. #define pr_warn(fmt, args...) printf(fmt, ##args)
  109. #undef pr_err
  110. #define pr_err(fmt, args...) printf(fmt, ##args)
  111. #endif /* __MACH_INIT_H */