init.h 4.2 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_BOARD_GET_TYPE(f) ((f) & 0x7)
  23. #define UNIPHIER_BD_BOARD_LD20_REF 0 /* LD20 reference */
  24. #define UNIPHIER_BD_BOARD_LD20_GLOBAL 1 /* LD20 TV Set */
  25. #define UNIPHIER_BD_BOARD_LD20_C1 2 /* LD20 TV Set C1 */
  26. #define UNIPHIER_BD_BOARD_LD21_REF 3 /* LD21 reference */
  27. #define UNIPHIER_BD_BOARD_LD21_GLOBAL 4 /* LD21 TV Set */
  28. };
  29. const struct uniphier_board_data *uniphier_get_board_param(void);
  30. int uniphier_sld3_init(const struct uniphier_board_data *bd);
  31. int uniphier_ld4_init(const struct uniphier_board_data *bd);
  32. int uniphier_pro4_init(const struct uniphier_board_data *bd);
  33. int uniphier_sld8_init(const struct uniphier_board_data *bd);
  34. int uniphier_pro5_init(const struct uniphier_board_data *bd);
  35. int uniphier_pxs2_init(const struct uniphier_board_data *bd);
  36. int uniphier_ld11_init(const struct uniphier_board_data *bd);
  37. int uniphier_ld20_init(const struct uniphier_board_data *bd);
  38. #if defined(CONFIG_MICRO_SUPPORT_CARD)
  39. int uniphier_sbc_init_admulti(const struct uniphier_board_data *bd);
  40. int uniphier_sbc_init_savepin(const struct uniphier_board_data *bd);
  41. int uniphier_ld4_sbc_init(const struct uniphier_board_data *bd);
  42. int uniphier_pxs2_sbc_init(const struct uniphier_board_data *bd);
  43. #else
  44. static inline int uniphier_sbc_init_admulti(
  45. const struct uniphier_board_data *bd)
  46. {
  47. return 0;
  48. }
  49. static inline int uniphier_sbc_init_savepin(
  50. const struct uniphier_board_data *bd)
  51. {
  52. return 0;
  53. }
  54. static inline int uniphier_ld4_sbc_init(const struct uniphier_board_data *bd)
  55. {
  56. return 0;
  57. }
  58. static inline int uniphier_pxs2_sbc_init(const struct uniphier_board_data *bd)
  59. {
  60. return 0;
  61. }
  62. #endif
  63. int uniphier_sld3_bcu_init(const struct uniphier_board_data *bd);
  64. int uniphier_ld4_bcu_init(const struct uniphier_board_data *bd);
  65. int memconf_init(const struct uniphier_board_data *bd);
  66. int uniphier_sld3_memconf_init(const struct uniphier_board_data *bd);
  67. int uniphier_pxs2_memconf_init(const struct uniphier_board_data *bd);
  68. int uniphier_sld3_dpll_init(const struct uniphier_board_data *bd);
  69. int uniphier_ld4_dpll_init(const struct uniphier_board_data *bd);
  70. int uniphier_pro4_dpll_init(const struct uniphier_board_data *bd);
  71. int uniphier_sld8_dpll_init(const struct uniphier_board_data *bd);
  72. int uniphier_ld11_dpll_init(const struct uniphier_board_data *bd);
  73. int uniphier_ld20_dpll_init(const struct uniphier_board_data *bd);
  74. int uniphier_ld4_early_clk_init(const struct uniphier_board_data *bd);
  75. int uniphier_pro5_early_clk_init(const struct uniphier_board_data *bd);
  76. int uniphier_pxs2_early_clk_init(const struct uniphier_board_data *bd);
  77. int uniphier_ld11_early_clk_init(const struct uniphier_board_data *bd);
  78. int uniphier_ld20_early_clk_init(const struct uniphier_board_data *bd);
  79. int uniphier_ld4_umc_init(const struct uniphier_board_data *bd);
  80. int uniphier_pro4_umc_init(const struct uniphier_board_data *bd);
  81. int uniphier_sld8_umc_init(const struct uniphier_board_data *bd);
  82. int uniphier_pxs2_umc_init(const struct uniphier_board_data *bd);
  83. int uniphier_ld20_umc_init(const struct uniphier_board_data *bd);
  84. int uniphier_ld11_umc_init(const struct uniphier_board_data *bd);
  85. void uniphier_sld3_pll_init(void);
  86. void uniphier_ld4_pll_init(void);
  87. void uniphier_pro4_pll_init(void);
  88. void uniphier_ld11_pll_init(void);
  89. int uniphier_ld20_pll_init(const struct uniphier_board_data *bd);
  90. void uniphier_ld4_clk_init(void);
  91. void uniphier_pro4_clk_init(void);
  92. void uniphier_pro5_clk_init(void);
  93. void uniphier_pxs2_clk_init(void);
  94. void uniphier_ld11_clk_init(void);
  95. void uniphier_ld20_clk_init(void);
  96. int uniphier_pin_init(const char *pinconfig_name);
  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 */