soc-info.h 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  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_SLD3,
  10. SOC_UNIPHIER_LD4,
  11. SOC_UNIPHIER_PRO4,
  12. SOC_UNIPHIER_SLD8,
  13. SOC_UNIPHIER_PRO5,
  14. SOC_UNIPHIER_PXS2,
  15. SOC_UNIPHIER_LD6B,
  16. SOC_UNIPHIER_LD11,
  17. SOC_UNIPHIER_LD20,
  18. SOC_UNIPHIER_UNKNOWN,
  19. };
  20. #define UNIPHIER_NR_ENABLED_SOCS \
  21. IS_ENABLED(CONFIG_ARCH_UNIPHIER_SLD3) + \
  22. IS_ENABLED(CONFIG_ARCH_UNIPHIER_LD4) + \
  23. IS_ENABLED(CONFIG_ARCH_UNIPHIER_PRO4) + \
  24. IS_ENABLED(CONFIG_ARCH_UNIPHIER_SLD8) + \
  25. IS_ENABLED(CONFIG_ARCH_UNIPHIER_PRO5) + \
  26. IS_ENABLED(CONFIG_ARCH_UNIPHIER_PXS2) + \
  27. IS_ENABLED(CONFIG_ARCH_UNIPHIER_LD6B) + \
  28. IS_ENABLED(CONFIG_ARCH_UNIPHIER_LD11) + \
  29. IS_ENABLED(CONFIG_ARCH_UNIPHIER_LD20)
  30. #define UNIPHIER_MULTI_SOC ((UNIPHIER_NR_ENABLED_SOCS) > 1)
  31. #if UNIPHIER_MULTI_SOC
  32. enum uniphier_soc_id uniphier_get_soc_type(void);
  33. #else
  34. static inline enum uniphier_soc_id uniphier_get_soc_type(void)
  35. {
  36. #if defined(CONFIG_ARCH_UNIPHIER_SLD3)
  37. return SOC_UNIPHIER_SLD3;
  38. #endif
  39. #if defined(CONFIG_ARCH_UNIPHIER_LD4)
  40. return SOC_UNIPHIER_LD4;
  41. #endif
  42. #if defined(CONFIG_ARCH_UNIPHIER_PRO4)
  43. return SOC_UNIPHIER_PRO4;
  44. #endif
  45. #if defined(CONFIG_ARCH_UNIPHIER_SLD8)
  46. return SOC_UNIPHIER_SLD8;
  47. #endif
  48. #if defined(CONFIG_ARCH_UNIPHIER_PRO5)
  49. return SOC_UNIPHIER_PRO5;
  50. #endif
  51. #if defined(CONFIG_ARCH_UNIPHIER_PXS2)
  52. return SOC_UNIPHIER_PXS2;
  53. #endif
  54. #if defined(CONFIG_ARCH_UNIPHIER_LD6B)
  55. return SOC_UNIPHIER_LD6B;
  56. #endif
  57. #if defined(CONFIG_ARCH_UNIPHIER_LD11)
  58. return SOC_UNIPHIER_LD11;
  59. #endif
  60. #if defined(CONFIG_ARCH_UNIPHIER_LD20)
  61. return SOC_UNIPHIER_LD20;
  62. #endif
  63. return SOC_UNIPHIER_UNKNOWN;
  64. }
  65. #endif
  66. int uniphier_get_soc_model(void);
  67. int uniphier_get_soc_revision(void);
  68. #endif /* __MACH_SOC_INFO_H__ */