soc_info.h 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. /*
  2. * Copyright (C) 2015 Masahiro Yamada <yamada.masahiro@socionext.com>
  3. *
  4. * SPDX-License-Identifier: GPL-2.0+
  5. */
  6. #ifndef __MACH_SOC_INFO_H__
  7. #define __MACH_SOC_INFO_H__
  8. enum uniphier_soc_id {
  9. SOC_UNIPHIER_PH1_SLD3,
  10. SOC_UNIPHIER_PH1_LD4,
  11. SOC_UNIPHIER_PH1_PRO4,
  12. SOC_UNIPHIER_PH1_SLD8,
  13. SOC_UNIPHIER_PH1_PRO5,
  14. SOC_UNIPHIER_PROXSTREAM2,
  15. SOC_UNIPHIER_PH1_LD6B,
  16. SOC_UNIPHIER_UNKNOWN,
  17. };
  18. #define UNIPHIER_NR_ENABLED_SOCS \
  19. IS_ENABLED(CONFIG_ARCH_UNIPHIER_PH1_SLD3) + \
  20. IS_ENABLED(CONFIG_ARCH_UNIPHIER_PH1_LD4) + \
  21. IS_ENABLED(CONFIG_ARCH_UNIPHIER_PH1_PRO4) + \
  22. IS_ENABLED(CONFIG_ARCH_UNIPHIER_PH1_SLD8) + \
  23. IS_ENABLED(CONFIG_ARCH_UNIPHIER_PH1_PRO5) + \
  24. IS_ENABLED(CONFIG_ARCH_UNIPHIER_PROXSTREAM2) + \
  25. IS_ENABLED(CONFIG_ARCH_UNIPHIER_PH1_LD6B)
  26. #define UNIPHIER_MULTI_SOC ((UNIPHIER_NR_ENABLED_SOCS) > 1)
  27. #if UNIPHIER_MULTI_SOC
  28. enum uniphier_soc_id uniphier_get_soc_type(void);
  29. #else
  30. static inline enum uniphier_soc_id uniphier_get_soc_type(void)
  31. {
  32. #if defined(CONFIG_ARCH_UNIPHIER_PH1_SLD3)
  33. return SOC_UNIPHIER_PH1_SLD3;
  34. #endif
  35. #if defined(CONFIG_ARCH_UNIPHIER_PH1_LD4)
  36. return SOC_UNIPHIER_PH1_LD4;
  37. #endif
  38. #if defined(CONFIG_ARCH_UNIPHIER_PH1_PRO4)
  39. return SOC_UNIPHIER_PH1_PRO4;
  40. #endif
  41. #if defined(CONFIG_ARCH_UNIPHIER_PH1_SLD8)
  42. return SOC_UNIPHIER_PH1_SLD8;
  43. #endif
  44. #if defined(CONFIG_ARCH_UNIPHIER_PH1_PRO5)
  45. return SOC_UNIPHIER_PH1_PRO5;
  46. #endif
  47. #if defined(CONFIG_ARCH_UNIPHIER_PROXSTREAM2)
  48. return SOC_UNIPHIER_PROXSTREAM2;
  49. #endif
  50. #if defined(CONFIG_ARCH_UNIPHIER_PH1_LD6B)
  51. return SOC_UNIPHIER_PH1_LD6B;
  52. #endif
  53. return SOC_UNIPHIER_UNKNOWN;
  54. }
  55. #endif
  56. int uniphier_get_soc_model(void);
  57. int uniphier_get_soc_revision(void);
  58. #endif /* __MACH_SOC_INFO_H__ */