hc
2024-05-09 b9d5c334faa47a75f1f28e72d203fc0334e8471d
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
/*
 * include/asm-mips/txx9/tx4927pcic.h
 * TX4927 PCI controller definitions.
 *
 * This file is subject to the terms and conditions of the GNU General Public
 * License.  See the file "COPYING" in the main directory of this archive
 * for more details.
 */
#ifndef __ASM_TXX9_TX4927PCIC_H
#define __ASM_TXX9_TX4927PCIC_H
 
#include <linux/pci.h>
#include <linux/irqreturn.h>
 
struct tx4927_pcic_reg {
   u32 pciid;
   u32 pcistatus;
   u32 pciccrev;
   u32 pcicfg1;
   u32 p2gm0plbase;        /* +10 */
   u32 p2gm0pubase;
   u32 p2gm1plbase;
   u32 p2gm1pubase;
   u32 p2gm2pbase;        /* +20 */
   u32 p2giopbase;
   u32 unused0;
   u32 pcisid;
   u32 unused1;        /* +30 */
   u32 pcicapptr;
   u32 unused2;
   u32 pcicfg2;
   u32 g2ptocnt;        /* +40 */
   u32 unused3[15];
   u32 g2pstatus;        /* +80 */
   u32 g2pmask;
   u32 pcisstatus;
   u32 pcimask;
   u32 p2gcfg;        /* +90 */
   u32 p2gstatus;
   u32 p2gmask;
   u32 p2gccmd;
   u32 unused4[24];        /* +a0 */
   u32 pbareqport;        /* +100 */
   u32 pbacfg;
   u32 pbastatus;
   u32 pbamask;
   u32 pbabm;        /* +110 */
   u32 pbacreq;
   u32 pbacgnt;
   u32 pbacstate;
   u64 g2pmgbase[3];        /* +120 */
   u64 g2piogbase;
   u32 g2pmmask[3];        /* +140 */
   u32 g2piomask;
   u64 g2pmpbase[3];        /* +150 */
   u64 g2piopbase;
   u32 pciccfg;        /* +170 */
   u32 pcicstatus;
   u32 pcicmask;
   u32 unused5;
   u64 p2gmgbase[3];        /* +180 */
   u64 p2giogbase;
   u32 g2pcfgadrs;        /* +1a0 */
   u32 g2pcfgdata;
   u32 unused6[8];
   u32 g2pintack;
   u32 g2pspc;
   u32 unused7[12];        /* +1d0 */
   u64 pdmca;        /* +200 */
   u64 pdmga;
   u64 pdmpa;
   u64 pdmctr;
   u64 pdmcfg;        /* +220 */
   u64 pdmsts;
};
 
/* bits for PCICMD */
/* see PCI_COMMAND_XXX in linux/pci_regs.h */
 
/* bits for PCISTAT */
/* see PCI_STATUS_XXX in linux/pci_regs.h */
 
/* bits for IOBA/MBA */
/* see PCI_BASE_ADDRESS_XXX in linux/pci_regs.h */
 
/* bits for G2PSTATUS/G2PMASK */
#define TX4927_PCIC_G2PSTATUS_ALL    0x00000003
#define TX4927_PCIC_G2PSTATUS_TTOE    0x00000002
#define TX4927_PCIC_G2PSTATUS_RTOE    0x00000001
 
/* bits for PCIMASK (see also PCI_STATUS_XXX in linux/pci_regs.h */
#define TX4927_PCIC_PCISTATUS_ALL    0x0000f900
 
/* bits for PBACFG */
#define TX4927_PCIC_PBACFG_FIXPA    0x00000008
#define TX4927_PCIC_PBACFG_RPBA 0x00000004
#define TX4927_PCIC_PBACFG_PBAEN    0x00000002
#define TX4927_PCIC_PBACFG_BMCEN    0x00000001
 
/* bits for PBASTATUS/PBAMASK */
#define TX4927_PCIC_PBASTATUS_ALL    0x00000001
#define TX4927_PCIC_PBASTATUS_BM    0x00000001
 
/* bits for G2PMnGBASE */
#define TX4927_PCIC_G2PMnGBASE_BSDIS    0x0000002000000000ULL
#define TX4927_PCIC_G2PMnGBASE_ECHG    0x0000001000000000ULL
 
/* bits for G2PIOGBASE */
#define TX4927_PCIC_G2PIOGBASE_BSDIS    0x0000002000000000ULL
#define TX4927_PCIC_G2PIOGBASE_ECHG    0x0000001000000000ULL
 
/* bits for PCICSTATUS/PCICMASK */
#define TX4927_PCIC_PCICSTATUS_ALL    0x000007b8
#define TX4927_PCIC_PCICSTATUS_PME    0x00000400
#define TX4927_PCIC_PCICSTATUS_TLB    0x00000200
#define TX4927_PCIC_PCICSTATUS_NIB    0x00000100
#define TX4927_PCIC_PCICSTATUS_ZIB    0x00000080
#define TX4927_PCIC_PCICSTATUS_PERR    0x00000020
#define TX4927_PCIC_PCICSTATUS_SERR    0x00000010
#define TX4927_PCIC_PCICSTATUS_GBE    0x00000008
#define TX4927_PCIC_PCICSTATUS_IWB    0x00000002
#define TX4927_PCIC_PCICSTATUS_E2PDONE    0x00000001
 
/* bits for PCICCFG */
#define TX4927_PCIC_PCICCFG_GBWC_MASK    0x0fff0000
#define TX4927_PCIC_PCICCFG_HRST    0x00000800
#define TX4927_PCIC_PCICCFG_SRST    0x00000400
#define TX4927_PCIC_PCICCFG_IRBER    0x00000200
#define TX4927_PCIC_PCICCFG_G2PMEN(ch)    (0x00000100>>(ch))
#define TX4927_PCIC_PCICCFG_G2PM0EN    0x00000100
#define TX4927_PCIC_PCICCFG_G2PM1EN    0x00000080
#define TX4927_PCIC_PCICCFG_G2PM2EN    0x00000040
#define TX4927_PCIC_PCICCFG_G2PIOEN    0x00000020
#define TX4927_PCIC_PCICCFG_TCAR    0x00000010
#define TX4927_PCIC_PCICCFG_ICAEN    0x00000008
 
/* bits for P2GMnGBASE */
#define TX4927_PCIC_P2GMnGBASE_TMEMEN    0x0000004000000000ULL
#define TX4927_PCIC_P2GMnGBASE_TBSDIS    0x0000002000000000ULL
#define TX4927_PCIC_P2GMnGBASE_TECHG    0x0000001000000000ULL
 
/* bits for P2GIOGBASE */
#define TX4927_PCIC_P2GIOGBASE_TIOEN    0x0000004000000000ULL
#define TX4927_PCIC_P2GIOGBASE_TBSDIS    0x0000002000000000ULL
#define TX4927_PCIC_P2GIOGBASE_TECHG    0x0000001000000000ULL
 
#define TX4927_PCIC_IDSEL_AD_TO_SLOT(ad)    ((ad) - 11)
#define TX4927_PCIC_MAX_DEVNU    TX4927_PCIC_IDSEL_AD_TO_SLOT(32)
 
/* bits for PDMCFG */
#define TX4927_PCIC_PDMCFG_RSTFIFO    0x00200000
#define TX4927_PCIC_PDMCFG_EXFER    0x00100000
#define TX4927_PCIC_PDMCFG_REQDLY_MASK    0x00003800
#define TX4927_PCIC_PDMCFG_REQDLY_NONE    (0 << 11)
#define TX4927_PCIC_PDMCFG_REQDLY_16    (1 << 11)
#define TX4927_PCIC_PDMCFG_REQDLY_32    (2 << 11)
#define TX4927_PCIC_PDMCFG_REQDLY_64    (3 << 11)
#define TX4927_PCIC_PDMCFG_REQDLY_128    (4 << 11)
#define TX4927_PCIC_PDMCFG_REQDLY_256    (5 << 11)
#define TX4927_PCIC_PDMCFG_REQDLY_512    (6 << 11)
#define TX4927_PCIC_PDMCFG_REQDLY_1024    (7 << 11)
#define TX4927_PCIC_PDMCFG_ERRIE    0x00000400
#define TX4927_PCIC_PDMCFG_NCCMPIE    0x00000200
#define TX4927_PCIC_PDMCFG_NTCMPIE    0x00000100
#define TX4927_PCIC_PDMCFG_CHNEN    0x00000080
#define TX4927_PCIC_PDMCFG_XFRACT    0x00000040
#define TX4927_PCIC_PDMCFG_BSWAP    0x00000020
#define TX4927_PCIC_PDMCFG_XFRSIZE_MASK 0x0000000c
#define TX4927_PCIC_PDMCFG_XFRSIZE_1DW    0x00000000
#define TX4927_PCIC_PDMCFG_XFRSIZE_1QW    0x00000004
#define TX4927_PCIC_PDMCFG_XFRSIZE_4QW    0x00000008
#define TX4927_PCIC_PDMCFG_XFRDIRC    0x00000002
#define TX4927_PCIC_PDMCFG_CHRST    0x00000001
 
/* bits for PDMSTS */
#define TX4927_PCIC_PDMSTS_REQCNT_MASK    0x3f000000
#define TX4927_PCIC_PDMSTS_FIFOCNT_MASK 0x00f00000
#define TX4927_PCIC_PDMSTS_FIFOWP_MASK    0x000c0000
#define TX4927_PCIC_PDMSTS_FIFORP_MASK    0x00030000
#define TX4927_PCIC_PDMSTS_ERRINT    0x00000800
#define TX4927_PCIC_PDMSTS_DONEINT    0x00000400
#define TX4927_PCIC_PDMSTS_CHNEN    0x00000200
#define TX4927_PCIC_PDMSTS_XFRACT    0x00000100
#define TX4927_PCIC_PDMSTS_ACCMP    0x00000080
#define TX4927_PCIC_PDMSTS_NCCMP    0x00000040
#define TX4927_PCIC_PDMSTS_NTCMP    0x00000020
#define TX4927_PCIC_PDMSTS_CFGERR    0x00000008
#define TX4927_PCIC_PDMSTS_PCIERR    0x00000004
#define TX4927_PCIC_PDMSTS_CHNERR    0x00000002
#define TX4927_PCIC_PDMSTS_DATAERR    0x00000001
#define TX4927_PCIC_PDMSTS_ALL_CMP    0x000000e0
#define TX4927_PCIC_PDMSTS_ALL_ERR    0x0000000f
 
struct tx4927_pcic_reg __iomem *get_tx4927_pcicptr(
   struct pci_controller *channel);
void tx4927_pcic_setup(struct tx4927_pcic_reg __iomem *pcicptr,
              struct pci_controller *channel, int extarb);
void tx4927_report_pcic_status(void);
char *tx4927_pcibios_setup(char *str);
void tx4927_dump_pcic_settings(void);
irqreturn_t tx4927_pcierr_interrupt(int irq, void *dev_id);
 
#endif /* __ASM_TXX9_TX4927PCIC_H */