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_DPLL_SSC_GET_RATE(f) (((f) >> 8) & 0x3)
  22. #define UNIPHIER_BD_DPLL_SSC_RATE(r) (((r) & 0x3) << 8)
  23. #define UNIPHIER_BD_DDR3PLUS BIT(2)
  24. #define UNIPHIER_BD_BOARD_GET_TYPE(f) ((f) & 0x3)
  25. #define UNIPHIER_BD_BOARD_LD20_REF 0 /* LD20 reference */
  26. #define UNIPHIER_BD_BOARD_LD20_GLOBAL 1 /* LD20 TV Set */
  27. #define UNIPHIER_BD_BOARD_LD21_REF 2 /* LD21 reference */
  28. #define UNIPHIER_BD_BOARD_LD21_GLOBAL 3 /* LD21 TV Set */
  29. };
  30. const struct uniphier_board_data *uniphier_get_board_param(void);
  31. int uniphier_sld3_init(const struct uniphier_board_data *bd);
  32. int uniphier_ld4_init(const struct uniphier_board_data *bd);
  33. int uniphier_pro4_init(const struct uniphier_board_data *bd);
  34. int uniphier_sld8_init(const struct uniphier_board_data *bd);
  35. int uniphier_pro5_init(const struct uniphier_board_data *bd);
  36. int uniphier_pxs2_init(const struct uniphier_board_data *bd);
  37. int uniphier_ld11_init(const struct uniphier_board_data *bd);
  38. int uniphier_ld20_init(const struct uniphier_board_data *bd);
  39. #if defined(CONFIG_MICRO_SUPPORT_CARD)
  40. int uniphier_sbc_init_admulti(const struct uniphier_board_data *bd);
  41. int uniphier_sbc_init_savepin(const struct uniphier_board_data *bd);
  42. int uniphier_ld4_sbc_init(const struct uniphier_board_data *bd);
  43. int uniphier_pxs2_sbc_init(const struct uniphier_board_data *bd);
  44. #else
  45. static inline int uniphier_sbc_init_admulti(
  46. const struct uniphier_board_data *bd)
  47. {
  48. return 0;
  49. }
  50. static inline int uniphier_sbc_init_savepin(
  51. const struct uniphier_board_data *bd)
  52. {
  53. return 0;
  54. }
  55. static inline int uniphier_ld4_sbc_init(const struct uniphier_board_data *bd)
  56. {
  57. return 0;
  58. }
  59. static inline int uniphier_pxs2_sbc_init(const struct uniphier_board_data *bd)
  60. {
  61. return 0;
  62. }
  63. #endif
  64. int uniphier_sld3_bcu_init(const struct uniphier_board_data *bd);
  65. int uniphier_ld4_bcu_init(const struct uniphier_board_data *bd);
  66. int memconf_init(const struct uniphier_board_data *bd);
  67. int uniphier_sld3_memconf_init(const struct uniphier_board_data *bd);
  68. int uniphier_pxs2_memconf_init(const struct uniphier_board_data *bd);
  69. int uniphier_sld3_dpll_init(const struct uniphier_board_data *bd);
  70. int uniphier_ld4_dpll_init(const struct uniphier_board_data *bd);
  71. int uniphier_pro4_dpll_init(const struct uniphier_board_data *bd);
  72. int uniphier_sld8_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. int uniphier_ld20_pll_init(const struct uniphier_board_data *bd);
  89. void uniphier_ld4_clk_init(void);
  90. void uniphier_pro4_clk_init(void);
  91. void uniphier_pro5_clk_init(void);
  92. void uniphier_pxs2_clk_init(void);
  93. void uniphier_ld11_clk_init(void);
  94. void uniphier_ld20_clk_init(void);
  95. int uniphier_pin_init(const char *pinconfig_name);
  96. void uniphier_smp_kick_all_cpus(void);
  97. void cci500_init(int nr_slaves);
  98. #define pr_err(fmt, args...) printf(fmt, ##args)
  99. #endif /* __MACH_INIT_H */