init.h 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  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 base;
  13. unsigned long size;
  14. unsigned int width;
  15. };
  16. struct uniphier_board_data {
  17. unsigned int dram_freq;
  18. unsigned int dram_nr_ch;
  19. struct uniphier_dram_ch dram_ch[UNIPHIER_MAX_NR_DRAM_CH];
  20. unsigned int flags;
  21. #define UNIPHIER_BD_DDR3PLUS BIT(2)
  22. #define UNIPHIER_BD_PACKAGE_LD21 1
  23. #define UNIPHIER_BD_PACKAGE_TYPE(f) ((f) & 0x3)
  24. };
  25. const struct uniphier_board_data *uniphier_get_board_param(void);
  26. int uniphier_sld3_init(const struct uniphier_board_data *bd);
  27. int uniphier_ld4_init(const struct uniphier_board_data *bd);
  28. int uniphier_pro4_init(const struct uniphier_board_data *bd);
  29. int uniphier_sld8_init(const struct uniphier_board_data *bd);
  30. int uniphier_pro5_init(const struct uniphier_board_data *bd);
  31. int uniphier_pxs2_init(const struct uniphier_board_data *bd);
  32. int uniphier_ld11_init(const struct uniphier_board_data *bd);
  33. int uniphier_ld20_init(const struct uniphier_board_data *bd);
  34. #if defined(CONFIG_MICRO_SUPPORT_CARD)
  35. int uniphier_sbc_init_admulti(const struct uniphier_board_data *bd);
  36. int uniphier_sbc_init_savepin(const struct uniphier_board_data *bd);
  37. int uniphier_ld4_sbc_init(const struct uniphier_board_data *bd);
  38. int uniphier_pxs2_sbc_init(const struct uniphier_board_data *bd);
  39. #else
  40. static inline int uniphier_sbc_init_admulti(
  41. const struct uniphier_board_data *bd)
  42. {
  43. return 0;
  44. }
  45. static inline int uniphier_sbc_init_savepin(
  46. const struct uniphier_board_data *bd)
  47. {
  48. return 0;
  49. }
  50. static inline int uniphier_ld4_sbc_init(const struct uniphier_board_data *bd)
  51. {
  52. return 0;
  53. }
  54. static inline int uniphier_pxs2_sbc_init(const struct uniphier_board_data *bd)
  55. {
  56. return 0;
  57. }
  58. #endif
  59. int uniphier_sld3_bcu_init(const struct uniphier_board_data *bd);
  60. int uniphier_ld4_bcu_init(const struct uniphier_board_data *bd);
  61. int memconf_init(const struct uniphier_board_data *bd);
  62. int uniphier_sld3_memconf_init(const struct uniphier_board_data *bd);
  63. int uniphier_pxs2_memconf_init(const struct uniphier_board_data *bd);
  64. int uniphier_sld3_pll_init(const struct uniphier_board_data *bd);
  65. int uniphier_ld4_pll_init(const struct uniphier_board_data *bd);
  66. int uniphier_pro4_pll_init(const struct uniphier_board_data *bd);
  67. int uniphier_sld8_pll_init(const struct uniphier_board_data *bd);
  68. int uniphier_sld3_enable_dpll_ssc(const struct uniphier_board_data *bd);
  69. int uniphier_ld4_enable_dpll_ssc(const struct uniphier_board_data *bd);
  70. int uniphier_ld4_early_clk_init(const struct uniphier_board_data *bd);
  71. int uniphier_pro5_early_clk_init(const struct uniphier_board_data *bd);
  72. int uniphier_pxs2_early_clk_init(const struct uniphier_board_data *bd);
  73. int uniphier_ld11_early_clk_init(const struct uniphier_board_data *bd);
  74. int uniphier_ld20_early_clk_init(const struct uniphier_board_data *bd);
  75. int uniphier_sld3_early_pin_init(const struct uniphier_board_data *bd);
  76. int uniphier_ld20_early_pin_init(const struct uniphier_board_data *bd);
  77. int uniphier_ld4_umc_init(const struct uniphier_board_data *bd);
  78. int uniphier_pro4_umc_init(const struct uniphier_board_data *bd);
  79. int uniphier_sld8_umc_init(const struct uniphier_board_data *bd);
  80. int uniphier_pxs2_umc_init(const struct uniphier_board_data *bd);
  81. int uniphier_ld20_umc_init(const struct uniphier_board_data *bd);
  82. int uniphier_ld11_umc_init(const struct uniphier_board_data *bd);
  83. void uniphier_sld3_pin_init(void);
  84. void uniphier_ld4_pin_init(void);
  85. void uniphier_pro4_pin_init(void);
  86. void uniphier_sld8_pin_init(void);
  87. void uniphier_pro5_pin_init(void);
  88. void uniphier_pxs2_pin_init(void);
  89. void uniphier_ld6b_pin_init(void);
  90. void uniphier_ld20_pin_init(void);
  91. void uniphier_ld4_clk_init(void);
  92. void uniphier_pro4_clk_init(void);
  93. void uniphier_pro5_clk_init(void);
  94. void uniphier_pxs2_clk_init(void);
  95. void uniphier_ld11_clk_init(void);
  96. void uniphier_ld20_clk_init(void);
  97. void uniphier_smp_kick_all_cpus(void);
  98. void cci500_init(int nr_slaves);
  99. #define pr_err(fmt, args...) printf(fmt, ##args)
  100. #endif /* __MACH_INIT_H */