blob: 20158123494a44cb2e293677f947d4d60d194271 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Paul Burtonbaf37f02013-11-08 11:18:50 +00002/*
3 * Copyright (C) 2013 Imagination Technologies
Paul Burtonc5bf1612017-10-30 16:58:21 -07004 * Author: Paul Burton <paul.burton@mips.com>
Paul Burtonbaf37f02013-11-08 11:18:50 +00005 */
6
7#ifndef __MSC01_H__
8#define __MSC01_H__
9
10/*
11 * Bus Interface Unit
12 */
13
14#define MSC01_BIU_IP1BAS1L_OFS 0x0208
15#define MSC01_BIU_IP1MSK1L_OFS 0x0218
16#define MSC01_BIU_IP1BAS2L_OFS 0x0248
17#define MSC01_BIU_IP1MSK2L_OFS 0x0258
18#define MSC01_BIU_IP2BAS1L_OFS 0x0288
19#define MSC01_BIU_IP2MSK1L_OFS 0x0298
20#define MSC01_BIU_IP2BAS2L_OFS 0x02c8
21#define MSC01_BIU_IP2MSK2L_OFS 0x02d8
22#define MSC01_BIU_IP3BAS1L_OFS 0x0308
23#define MSC01_BIU_IP3MSK1L_OFS 0x0318
24#define MSC01_BIU_IP3BAS2L_OFS 0x0348
25#define MSC01_BIU_IP3MSK2L_OFS 0x0358
26#define MSC01_BIU_MCBAS1L_OFS 0x0388
27#define MSC01_BIU_MCMSK1L_OFS 0x0398
28#define MSC01_BIU_MCBAS2L_OFS 0x03c8
29#define MSC01_BIU_MCMSK2L_OFS 0x03d8
30
31/*
32 * PCI Bridge
33 */
34
35#define MSC01_PCI_SC2PMBASL_OFS 0x0208
36#define MSC01_PCI_SC2PMMSKL_OFS 0x0218
37#define MSC01_PCI_SC2PMMAPL_OFS 0x0228
38#define MSC01_PCI_SC2PIOBASL_OFS 0x0248
39#define MSC01_PCI_SC2PIOMSKL_OFS 0x0258
40#define MSC01_PCI_SC2PIOMAPL_OFS 0x0268
41#define MSC01_PCI_P2SCMSKL_OFS 0x0308
42#define MSC01_PCI_P2SCMAPL_OFS 0x0318
43#define MSC01_PCI_INTSTAT_OFS 0x0608
44#define MSC01_PCI_CFGADDR_OFS 0x0610
45#define MSC01_PCI_CFGDATA_OFS 0x0618
46#define MSC01_PCI_HEAD0_OFS 0x2000
47#define MSC01_PCI_HEAD1_OFS 0x2008
48#define MSC01_PCI_HEAD2_OFS 0x2010
49#define MSC01_PCI_HEAD3_OFS 0x2018
50#define MSC01_PCI_HEAD4_OFS 0x2020
51#define MSC01_PCI_HEAD5_OFS 0x2028
52#define MSC01_PCI_HEAD6_OFS 0x2030
53#define MSC01_PCI_HEAD7_OFS 0x2038
54#define MSC01_PCI_HEAD8_OFS 0x2040
55#define MSC01_PCI_HEAD9_OFS 0x2048
56#define MSC01_PCI_HEAD10_OFS 0x2050
57#define MSC01_PCI_HEAD11_OFS 0x2058
58#define MSC01_PCI_HEAD12_OFS 0x2060
59#define MSC01_PCI_HEAD13_OFS 0x2068
60#define MSC01_PCI_HEAD14_OFS 0x2070
61#define MSC01_PCI_HEAD15_OFS 0x2078
62#define MSC01_PCI_BAR0_OFS 0x2220
63#define MSC01_PCI_CFG_OFS 0x2380
64#define MSC01_PCI_SWAP_OFS 0x2388
65
66#define MSC01_PCI_SC2PMMSKL_MSK_MSK 0xff000000
67#define MSC01_PCI_SC2PIOMSKL_MSK_MSK 0xff000000
68
69#define MSC01_PCI_INTSTAT_TA_SHF 6
70#define MSC01_PCI_INTSTAT_TA_MSK (0x1 << MSC01_PCI_INTSTAT_TA_SHF)
71#define MSC01_PCI_INTSTAT_MA_SHF 7
72#define MSC01_PCI_INTSTAT_MA_MSK (0x1 << MSC01_PCI_INTSTAT_MA_SHF)
73
Paul Burtonbaf37f02013-11-08 11:18:50 +000074#define MSC01_PCI_HEAD0_VENDORID_SHF 0
75#define MSC01_PCI_HEAD0_DEVICEID_SHF 16
76
77#define MSC01_PCI_HEAD2_REV_SHF 0
78#define MSC01_PCI_HEAD2_CLASS_SHF 16
79
80#define MSC01_PCI_CFG_EN_SHF 15
81#define MSC01_PCI_CFG_EN_MSK (0x1 << MSC01_PCI_CFG_EN_SHF)
82#define MSC01_PCI_CFG_G_SHF 16
83#define MSC01_PCI_CFG_G_MSK (0x1 << MSC01_PCI_CFG_G_SHF)
84#define MSC01_PCI_CFG_RA_SHF 17
85#define MSC01_PCI_CFG_RA_MSK (0x1 << MSC01_PCI_CFG_RA_SHF)
86
87#define MSC01_PCI_SWAP_BAR0_BSWAP_SHF 0
88#define MSC01_PCI_SWAP_IO_BSWAP_SHF 18
89
90/*
91 * Peripheral Bus Controller
92 */
93
94#define MSC01_PBC_CLKCFG_OFS 0x0100
95#define MSC01_PBC_CS0CFG_OFS 0x0400
96#define MSC01_PBC_CS0TIM_OFS 0x0500
97#define MSC01_PBC_CS0RW_OFS 0x0600
98
99#define MSC01_PBC_CLKCFG_SHF 0
100#define MSC01_PBC_CLKCFG_MSK (0x1f << MSC01_PBC_CLKCFG_SHF)
101
102#define MSC01_PBC_CS0CFG_WS_SHF 0
103#define MSC01_PBC_CS0CFG_WS_MSK (0x1f << MSC01_PBC_CS0CFG_WS_SHF)
104#define MSC01_PBC_CS0CFG_WSIDLE_SHF 8
105#define MSC01_PBC_CS0CFG_WSIDLE_MSK (0x1f << MSC01_PBC_CS0CFG_WSIDLE_SHF)
106#define MSC01_PBC_CS0CFG_DTYP_SHF 16
107#define MSC01_PBC_CS0CFG_DTYP_MSK (0x3 << MSC01_PBC_CS0CFG_DTYP_SHF)
108#define MSC01_PBC_CS0CFG_ADM_SHF 20
109#define MSC01_PBC_CS0CFG_ADM_MSK (0x1 << MSC01_PBC_CS0CFG_ADM_SHF)
110
111#define MSC01_PBC_CS0TIM_CAT_SHF 0
112#define MSC01_PBC_CS0TIM_CAT_MSK (0x1f << MSC01_PBC_CS0TIM_CAT_SHF)
113#define MSC01_PBC_CS0TIM_CDT_SHF 8
114#define MSC01_PBC_CS0TIM_CDT_MSK (0x1f << MSC01_PBC_CS0TIM_CDT_SHF)
115
116#define MSC01_PBC_CS0RW_WAT_SHF 0
117#define MSC01_PBC_CS0RW_WAT_MSK (0x1f << MSC01_PBC_CS0RW_WAT_SHF)
118#define MSC01_PBC_CS0RW_WDT_SHF 8
119#define MSC01_PBC_CS0RW_WDT_MSK (0x1f << MSC01_PBC_CS0RW_WDT_SHF)
120#define MSC01_PBC_CS0RW_RAT_SHF 16
121#define MSC01_PBC_CS0RW_RAT_MSK (0x1f << MSC01_PBC_CS0RW_RAT_SHF)
122#define MSC01_PBC_CS0RW_RDT_SHF 24
123#define MSC01_PBC_CS0RW_RDT_MSK (0x1f << MSC01_PBC_CS0RW_RDT_SHF)
124
125#endif /* __MSC01_H__ */