hardware-k2hk.h 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. /*
  2. * K2HK: SoC definitions
  3. *
  4. * (C) Copyright 2012-2014
  5. * Texas Instruments Incorporated, <www.ti.com>
  6. *
  7. * SPDX-License-Identifier: GPL-2.0+
  8. */
  9. #ifndef __ASM_ARCH_HARDWARE_K2HK_H
  10. #define __ASM_ARCH_HARDWARE_K2HK_H
  11. #define K2HK_ASYNC_EMIF_CNTRL_BASE 0x21000a00
  12. #define DAVINCI_ASYNC_EMIF_CNTRL_BASE K2HK_ASYNC_EMIF_CNTRL_BASE
  13. #define K2HK_ASYNC_EMIF_DATA_CE0_BASE 0x30000000
  14. #define K2HK_ASYNC_EMIF_DATA_CE1_BASE 0x34000000
  15. #define K2HK_ASYNC_EMIF_DATA_CE2_BASE 0x38000000
  16. #define K2HK_ASYNC_EMIF_DATA_CE3_BASE 0x3c000000
  17. #define K2HK_PLL_CNTRL_BASE 0x02310000
  18. #define CLOCK_BASE K2HK_PLL_CNTRL_BASE
  19. #define KS2_RSTCTRL (K2HK_PLL_CNTRL_BASE + 0xe8)
  20. #define KS2_RSTCTRL_KEY 0x5a69
  21. #define KS2_RSTCTRL_MASK 0xffff0000
  22. #define KS2_RSTCTRL_SWRST 0xfffe0000
  23. #define K2HK_PSC_BASE 0x02350000
  24. #define KS2_DEVICE_STATE_CTRL_BASE 0x02620000
  25. #define JTAG_ID_REG (KS2_DEVICE_STATE_CTRL_BASE + 0x18)
  26. #define K2HK_DEVSTAT (KS2_DEVICE_STATE_CTRL_BASE + 0x20)
  27. #define K2HK_MISC_CTRL (KS2_DEVICE_STATE_CTRL_BASE + 0xc7c)
  28. #define ARM_PLL_EN BIT(13)
  29. #define K2HK_SPI0_BASE 0x21000400
  30. #define K2HK_SPI1_BASE 0x21000600
  31. #define K2HK_SPI2_BASE 0x21000800
  32. #define K2HK_SPI_BASE K2HK_SPI0_BASE
  33. /* Chip configuration unlock codes and registers */
  34. #define KEYSTONE_KICK0 (KS2_DEVICE_STATE_CTRL_BASE + 0x38)
  35. #define KEYSTONE_KICK1 (KS2_DEVICE_STATE_CTRL_BASE + 0x3c)
  36. #define KEYSTONE_KICK0_MAGIC 0x83e70b13
  37. #define KEYSTONE_KICK1_MAGIC 0x95a4f1e0
  38. /* PA SS Registers */
  39. #define KS2_PASS_BASE 0x02000000
  40. /* PLL control registers */
  41. #define K2HK_MAINPLLCTL0 (KS2_DEVICE_STATE_CTRL_BASE + 0x350)
  42. #define K2HK_MAINPLLCTL1 (KS2_DEVICE_STATE_CTRL_BASE + 0x354)
  43. #define K2HK_PASSPLLCTL0 (KS2_DEVICE_STATE_CTRL_BASE + 0x358)
  44. #define K2HK_PASSPLLCTL1 (KS2_DEVICE_STATE_CTRL_BASE + 0x35C)
  45. #define K2HK_DDR3APLLCTL0 (KS2_DEVICE_STATE_CTRL_BASE + 0x360)
  46. #define K2HK_DDR3APLLCTL1 (KS2_DEVICE_STATE_CTRL_BASE + 0x364)
  47. #define K2HK_DDR3BPLLCTL0 (KS2_DEVICE_STATE_CTRL_BASE + 0x368)
  48. #define K2HK_DDR3BPLLCTL1 (KS2_DEVICE_STATE_CTRL_BASE + 0x36C)
  49. #define K2HK_ARMPLLCTL0 (KS2_DEVICE_STATE_CTRL_BASE + 0x370)
  50. #define K2HK_ARMPLLCTL1 (KS2_DEVICE_STATE_CTRL_BASE + 0x374)
  51. /* Power and Sleep Controller (PSC) Domains */
  52. #define K2HK_LPSC_MOD 0
  53. #define K2HK_LPSC_DUMMY1 1
  54. #define K2HK_LPSC_USB 2
  55. #define K2HK_LPSC_EMIF25_SPI 3
  56. #define K2HK_LPSC_TSIP 4
  57. #define K2HK_LPSC_DEBUGSS_TRC 5
  58. #define K2HK_LPSC_TETB_TRC 6
  59. #define K2HK_LPSC_PKTPROC 7
  60. #define KS2_LPSC_PA K2HK_LPSC_PKTPROC
  61. #define K2HK_LPSC_SGMII 8
  62. #define KS2_LPSC_CPGMAC K2HK_LPSC_SGMII
  63. #define K2HK_LPSC_CRYPTO 9
  64. #define K2HK_LPSC_PCIE 10
  65. #define K2HK_LPSC_SRIO 11
  66. #define K2HK_LPSC_VUSR0 12
  67. #define K2HK_LPSC_CHIP_SRSS 13
  68. #define K2HK_LPSC_MSMC 14
  69. #define K2HK_LPSC_GEM_0 15
  70. #define K2HK_LPSC_GEM_1 16
  71. #define K2HK_LPSC_GEM_2 17
  72. #define K2HK_LPSC_GEM_3 18
  73. #define K2HK_LPSC_GEM_4 19
  74. #define K2HK_LPSC_GEM_5 20
  75. #define K2HK_LPSC_GEM_6 21
  76. #define K2HK_LPSC_GEM_7 22
  77. #define K2HK_LPSC_EMIF4F_DDR3A 23
  78. #define K2HK_LPSC_EMIF4F_DDR3B 24
  79. #define K2HK_LPSC_TAC 25
  80. #define K2HK_LPSC_RAC 26
  81. #define K2HK_LPSC_RAC_1 27
  82. #define K2HK_LPSC_FFTC_A 28
  83. #define K2HK_LPSC_FFTC_B 29
  84. #define K2HK_LPSC_FFTC_C 30
  85. #define K2HK_LPSC_FFTC_D 31
  86. #define K2HK_LPSC_FFTC_E 32
  87. #define K2HK_LPSC_FFTC_F 33
  88. #define K2HK_LPSC_AI2 34
  89. #define K2HK_LPSC_TCP3D_0 35
  90. #define K2HK_LPSC_TCP3D_1 36
  91. #define K2HK_LPSC_TCP3D_2 37
  92. #define K2HK_LPSC_TCP3D_3 38
  93. #define K2HK_LPSC_VCP2X4_A 39
  94. #define K2HK_LPSC_CP2X4_B 40
  95. #define K2HK_LPSC_VCP2X4_C 41
  96. #define K2HK_LPSC_VCP2X4_D 42
  97. #define K2HK_LPSC_VCP2X4_E 43
  98. #define K2HK_LPSC_VCP2X4_F 44
  99. #define K2HK_LPSC_VCP2X4_G 45
  100. #define K2HK_LPSC_VCP2X4_H 46
  101. #define K2HK_LPSC_BCP 47
  102. #define K2HK_LPSC_DXB 48
  103. #define K2HK_LPSC_VUSR1 49
  104. #define K2HK_LPSC_XGE 50
  105. #define K2HK_LPSC_ARM_SREFLEX 51
  106. #define K2HK_LPSC_TETRIS 52
  107. /* DDR3A definitions */
  108. #define K2HK_DDR3A_EMIF_CTRL_BASE 0x21010000
  109. #define K2HK_DDR3A_EMIF_DATA_BASE 0x80000000
  110. #define K2HK_DDR3A_DDRPHYC 0x02329000
  111. /* DDR3B definitions */
  112. #define K2HK_DDR3B_EMIF_CTRL_BASE 0x21020000
  113. #define K2HK_DDR3B_EMIF_DATA_BASE 0x60000000
  114. #define K2HK_DDR3B_DDRPHYC 0x02328000
  115. /* Queue manager */
  116. #define DEVICE_QM_MANAGER_BASE 0x02a02000
  117. #define DEVICE_QM_DESC_SETUP_BASE 0x02a03000
  118. #define DEVICE_QM_MANAGER_QUEUES_BASE 0x02a80000
  119. #define DEVICE_QM_MANAGER_Q_PROXY_BASE 0x02ac0000
  120. #define DEVICE_QM_QUEUE_STATUS_BASE 0x02a40000
  121. #define DEVICE_QM_NUM_LINKRAMS 2
  122. #define DEVICE_QM_NUM_MEMREGIONS 20
  123. #define DEVICE_PA_CDMA_GLOBAL_CFG_BASE 0x02004000
  124. #define DEVICE_PA_CDMA_TX_CHAN_CFG_BASE 0x02004400
  125. #define DEVICE_PA_CDMA_RX_CHAN_CFG_BASE 0x02004800
  126. #define DEVICE_PA_CDMA_RX_FLOW_CFG_BASE 0x02005000
  127. #define DEVICE_PA_CDMA_RX_NUM_CHANNELS 24
  128. #define DEVICE_PA_CDMA_RX_NUM_FLOWS 32
  129. #define DEVICE_PA_CDMA_TX_NUM_CHANNELS 9
  130. /* MSMC control */
  131. #define K2HK_MSMC_CTRL_BASE 0x0bc00000
  132. #endif /* __ASM_ARCH_HARDWARE_H */