blob: e7dff059b867edc959c4653d3b9fc6e99ede302c [file] [log] [blame]
Vitaly Andrianovef509b92014-04-04 13:16:53 -04001/*
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 */
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +03009
Vitaly Andrianovef509b92014-04-04 13:16:53 -040010#ifndef __ASM_ARCH_HARDWARE_K2HK_H
11#define __ASM_ARCH_HARDWARE_K2HK_H
12
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +030013#define KS2_PLL_CNTRL_BASE 0x02310000
14#define KS2_CLOCK_BASE KS2_PLL_CNTRL_BASE
15#define KS2_RSTCTRL (KS2_PLL_CNTRL_BASE + 0xe8)
16#define KS2_RSTCTRL_KEY 0x5a69
17#define KS2_RSTCTRL_MASK 0xffff0000
18#define KS2_RSTCTRL_SWRST 0xfffe0000
Vitaly Andrianovef509b92014-04-04 13:16:53 -040019
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +030020#define KS2_DEVICE_STATE_CTRL_BASE 0x02620000
21#define KS2_JTAG_ID_REG (KS2_DEVICE_STATE_CTRL_BASE + 0x18)
22#define KS2_DEVSTAT (KS2_DEVICE_STATE_CTRL_BASE + 0x20)
Vitaly Andrianovef509b92014-04-04 13:16:53 -040023
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +030024#define KS2_MISC_CTRL (KS2_DEVICE_STATE_CTRL_BASE + 0xc7c)
Vitaly Andrianovef509b92014-04-04 13:16:53 -040025
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +030026#define KS2_ARM_PLL_EN BIT(13)
Vitaly Andrianovef509b92014-04-04 13:16:53 -040027
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +030028#define KS2_SPI0_BASE 0x21000400
29#define KS2_SPI1_BASE 0x21000600
30#define KS2_SPI2_BASE 0x21000800
31#define KS2_SPI_BASE KS2_SPI0_BASE
Vitaly Andrianovef509b92014-04-04 13:16:53 -040032
33/* Chip configuration unlock codes and registers */
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +030034#define KS2_KICK0 (KS2_DEVICE_STATE_CTRL_BASE + 0x38)
35#define KS2_KICK1 (KS2_DEVICE_STATE_CTRL_BASE + 0x3c)
36#define KS2_KICK0_MAGIC 0x83e70b13
37#define KS2_KICK1_MAGIC 0x95a4f1e0
Vitaly Andrianovef509b92014-04-04 13:16:53 -040038
39/* PA SS Registers */
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +030040#define KS2_PASS_BASE 0x02000000
Vitaly Andrianovef509b92014-04-04 13:16:53 -040041
42/* PLL control registers */
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +030043#define KS2_MAINPLLCTL0 (KS2_DEVICE_STATE_CTRL_BASE + 0x350)
44#define KS2_MAINPLLCTL1 (KS2_DEVICE_STATE_CTRL_BASE + 0x354)
45#define KS2_PASSPLLCTL0 (KS2_DEVICE_STATE_CTRL_BASE + 0x358)
46#define KS2_PASSPLLCTL1 (KS2_DEVICE_STATE_CTRL_BASE + 0x35C)
47#define KS2_DDR3APLLCTL0 (KS2_DEVICE_STATE_CTRL_BASE + 0x360)
48#define KS2_DDR3APLLCTL1 (KS2_DEVICE_STATE_CTRL_BASE + 0x364)
49#define KS2_DDR3BPLLCTL0 (KS2_DEVICE_STATE_CTRL_BASE + 0x368)
50#define KS2_DDR3BPLLCTL1 (KS2_DEVICE_STATE_CTRL_BASE + 0x36C)
51#define KS2_ARMPLLCTL0 (KS2_DEVICE_STATE_CTRL_BASE + 0x370)
52#define KS2_ARMPLLCTL1 (KS2_DEVICE_STATE_CTRL_BASE + 0x374)
Vitaly Andrianovef509b92014-04-04 13:16:53 -040053
54/* Power and Sleep Controller (PSC) Domains */
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +030055#define KS2_LPSC_MOD 0
56#define KS2_LPSC_DUMMY1 1
57#define KS2_LPSC_USB 2
58#define KS2_LPSC_EMIF25_SPI 3
59#define KS2_LPSC_TSIP 4
60#define KS2_LPSC_DEBUGSS_TRC 5
61#define KS2_LPSC_TETB_TRC 6
62#define KS2_LPSC_PKTPROC 7
63#define KS2_LPSC_PA KS2_LPSC_PKTPROC
64#define KS2_LPSC_SGMII 8
65#define KS2_LPSC_CPGMAC KS2_LPSC_SGMII
66#define KS2_LPSC_CRYPTO 9
67#define KS2_LPSC_PCIE 10
68#define KS2_LPSC_SRIO 11
69#define KS2_LPSC_VUSR0 12
70#define KS2_LPSC_CHIP_SRSS 13
71#define KS2_LPSC_MSMC 14
72#define KS2_LPSC_GEM_1 16
73#define KS2_LPSC_GEM_2 17
74#define KS2_LPSC_GEM_3 18
75#define KS2_LPSC_GEM_4 19
76#define KS2_LPSC_GEM_5 20
77#define KS2_LPSC_GEM_6 21
78#define KS2_LPSC_GEM_7 22
79#define KS2_LPSC_EMIF4F_DDR3A 23
80#define KS2_LPSC_EMIF4F_DDR3B 24
81#define KS2_LPSC_TAC 25
82#define KS2_LPSC_RAC 26
83#define KS2_LPSC_RAC_1 27
84#define KS2_LPSC_FFTC_A 28
85#define KS2_LPSC_FFTC_B 29
86#define KS2_LPSC_FFTC_C 30
87#define KS2_LPSC_FFTC_D 31
88#define KS2_LPSC_FFTC_E 32
89#define KS2_LPSC_FFTC_F 33
90#define KS2_LPSC_AI2 34
91#define KS2_LPSC_TCP3D_0 35
92#define KS2_LPSC_TCP3D_1 36
93#define KS2_LPSC_TCP3D_2 37
94#define KS2_LPSC_TCP3D_3 38
95#define KS2_LPSC_VCP2X4_A 39
96#define KS2_LPSC_CP2X4_B 40
97#define KS2_LPSC_VCP2X4_C 41
98#define KS2_LPSC_VCP2X4_D 42
99#define KS2_LPSC_VCP2X4_E 43
100#define KS2_LPSC_VCP2X4_F 44
101#define KS2_LPSC_VCP2X4_G 45
102#define KS2_LPSC_VCP2X4_H 46
103#define KS2_LPSC_BCP 47
104#define KS2_LPSC_DXB 48
105#define KS2_LPSC_VUSR1 49
106#define KS2_LPSC_XGE 50
107#define KS2_LPSC_ARM_SREFLEX 51
Vitaly Andrianovef509b92014-04-04 13:16:53 -0400108
Vitaly Andrianovef509b92014-04-04 13:16:53 -0400109/* DDR3A definitions */
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +0300110#define KS2_DDR3A_EMIF_CTRL_BASE 0x21010000
111#define KS2_DDR3A_EMIF_DATA_BASE 0x80000000
112#define KS2_DDR3A_DDRPHYC 0x02329000
Vitaly Andrianovef509b92014-04-04 13:16:53 -0400113/* DDR3B definitions */
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +0300114#define KS2_DDR3B_EMIF_CTRL_BASE 0x21020000
115#define KS2_DDR3B_EMIF_DATA_BASE 0x60000000
116#define KS2_DDR3B_DDRPHYC 0x02328000
Vitaly Andrianovef509b92014-04-04 13:16:53 -0400117
118/* Queue manager */
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +0300119#define KS2_QM_MANAGER_BASE 0x02a02000
120#define KS2_QM_DESC_SETUP_BASE 0x02a03000
121#define KS2_QM_MANAGER_QUEUES_BASEi 0x02a80000
122#define KS2_QM_MANAGER_Q_PROXY_BASE 0x02ac0000
123#define KS2_QM_QUEUE_STATUS_BASE 0x02a40000
Vitaly Andrianovef509b92014-04-04 13:16:53 -0400124
125/* MSMC control */
Khoronzhuk, Ivan3d315382014-07-09 23:44:44 +0300126#define KS2_MSMC_CTRL_BASE 0x0bc00000
Vitaly Andrianovef509b92014-04-04 13:16:53 -0400127
Hao Zhang7b26c1f2014-07-09 19:48:44 +0300128/* Number of DSP cores */
129#define KS2_NUM_DSPS 8
130
Vitaly Andrianovef509b92014-04-04 13:16:53 -0400131#endif /* __ASM_ARCH_HARDWARE_H */