]> git.proxmox.com Git - mirror_ubuntu-artful-kernel.git/blob - drivers/net/dsa/mv88e6xxx/mv88e6xxx.h
d04184c7e06861b32f9090c55cceb5a40d647241
[mirror_ubuntu-artful-kernel.git] / drivers / net / dsa / mv88e6xxx / mv88e6xxx.h
1 /*
2 * Marvell 88e6xxx common definitions
3 *
4 * Copyright (c) 2008 Marvell Semiconductor
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 */
11
12 #ifndef __MV88E6XXX_H
13 #define __MV88E6XXX_H
14
15 #include <linux/if_vlan.h>
16 #include <linux/gpio/consumer.h>
17
18 #ifndef UINT64_MAX
19 #define UINT64_MAX (u64)(~((u64)0))
20 #endif
21
22 #define SMI_CMD 0x00
23 #define SMI_CMD_BUSY BIT(15)
24 #define SMI_CMD_CLAUSE_22 BIT(12)
25 #define SMI_CMD_OP_22_WRITE ((1 << 10) | SMI_CMD_BUSY | SMI_CMD_CLAUSE_22)
26 #define SMI_CMD_OP_22_READ ((2 << 10) | SMI_CMD_BUSY | SMI_CMD_CLAUSE_22)
27 #define SMI_CMD_OP_45_WRITE_ADDR ((0 << 10) | SMI_CMD_BUSY)
28 #define SMI_CMD_OP_45_WRITE_DATA ((1 << 10) | SMI_CMD_BUSY)
29 #define SMI_CMD_OP_45_READ_DATA ((2 << 10) | SMI_CMD_BUSY)
30 #define SMI_CMD_OP_45_READ_DATA_INC ((3 << 10) | SMI_CMD_BUSY)
31 #define SMI_DATA 0x01
32
33 /* PHY Registers */
34 #define PHY_PAGE 0x16
35 #define PHY_PAGE_COPPER 0x00
36
37 #define ADDR_SERDES 0x0f
38 #define SERDES_PAGE_FIBER 0x01
39
40 #define PORT_STATUS 0x00
41 #define PORT_STATUS_PAUSE_EN BIT(15)
42 #define PORT_STATUS_MY_PAUSE BIT(14)
43 #define PORT_STATUS_HD_FLOW BIT(13)
44 #define PORT_STATUS_PHY_DETECT BIT(12)
45 #define PORT_STATUS_LINK BIT(11)
46 #define PORT_STATUS_DUPLEX BIT(10)
47 #define PORT_STATUS_SPEED_MASK 0x0300
48 #define PORT_STATUS_SPEED_10 0x0000
49 #define PORT_STATUS_SPEED_100 0x0100
50 #define PORT_STATUS_SPEED_1000 0x0200
51 #define PORT_STATUS_EEE BIT(6) /* 6352 */
52 #define PORT_STATUS_AM_DIS BIT(6) /* 6165 */
53 #define PORT_STATUS_MGMII BIT(6) /* 6185 */
54 #define PORT_STATUS_TX_PAUSED BIT(5)
55 #define PORT_STATUS_FLOW_CTRL BIT(4)
56 #define PORT_STATUS_CMODE_MASK 0x0f
57 #define PORT_STATUS_CMODE_100BASE_X 0x8
58 #define PORT_STATUS_CMODE_1000BASE_X 0x9
59 #define PORT_STATUS_CMODE_SGMII 0xa
60 #define PORT_PCS_CTRL 0x01
61 #define PORT_PCS_CTRL_RGMII_DELAY_RXCLK BIT(15)
62 #define PORT_PCS_CTRL_RGMII_DELAY_TXCLK BIT(14)
63 #define PORT_PCS_CTRL_FC BIT(7)
64 #define PORT_PCS_CTRL_FORCE_FC BIT(6)
65 #define PORT_PCS_CTRL_LINK_UP BIT(5)
66 #define PORT_PCS_CTRL_FORCE_LINK BIT(4)
67 #define PORT_PCS_CTRL_DUPLEX_FULL BIT(3)
68 #define PORT_PCS_CTRL_FORCE_DUPLEX BIT(2)
69 #define PORT_PCS_CTRL_10 0x00
70 #define PORT_PCS_CTRL_100 0x01
71 #define PORT_PCS_CTRL_1000 0x02
72 #define PORT_PCS_CTRL_UNFORCED 0x03
73 #define PORT_PAUSE_CTRL 0x02
74 #define PORT_SWITCH_ID 0x03
75 #define PORT_SWITCH_ID_PROD_NUM_6085 0x04a
76 #define PORT_SWITCH_ID_PROD_NUM_6095 0x095
77 #define PORT_SWITCH_ID_PROD_NUM_6131 0x106
78 #define PORT_SWITCH_ID_PROD_NUM_6320 0x115
79 #define PORT_SWITCH_ID_PROD_NUM_6123 0x121
80 #define PORT_SWITCH_ID_PROD_NUM_6161 0x161
81 #define PORT_SWITCH_ID_PROD_NUM_6165 0x165
82 #define PORT_SWITCH_ID_PROD_NUM_6171 0x171
83 #define PORT_SWITCH_ID_PROD_NUM_6172 0x172
84 #define PORT_SWITCH_ID_PROD_NUM_6175 0x175
85 #define PORT_SWITCH_ID_PROD_NUM_6176 0x176
86 #define PORT_SWITCH_ID_PROD_NUM_6185 0x1a7
87 #define PORT_SWITCH_ID_PROD_NUM_6240 0x240
88 #define PORT_SWITCH_ID_PROD_NUM_6321 0x310
89 #define PORT_SWITCH_ID_PROD_NUM_6352 0x352
90 #define PORT_SWITCH_ID_PROD_NUM_6350 0x371
91 #define PORT_SWITCH_ID_PROD_NUM_6351 0x375
92 #define PORT_CONTROL 0x04
93 #define PORT_CONTROL_USE_CORE_TAG BIT(15)
94 #define PORT_CONTROL_DROP_ON_LOCK BIT(14)
95 #define PORT_CONTROL_EGRESS_UNMODIFIED (0x0 << 12)
96 #define PORT_CONTROL_EGRESS_UNTAGGED (0x1 << 12)
97 #define PORT_CONTROL_EGRESS_TAGGED (0x2 << 12)
98 #define PORT_CONTROL_EGRESS_ADD_TAG (0x3 << 12)
99 #define PORT_CONTROL_HEADER BIT(11)
100 #define PORT_CONTROL_IGMP_MLD_SNOOP BIT(10)
101 #define PORT_CONTROL_DOUBLE_TAG BIT(9)
102 #define PORT_CONTROL_FRAME_MODE_NORMAL (0x0 << 8)
103 #define PORT_CONTROL_FRAME_MODE_DSA (0x1 << 8)
104 #define PORT_CONTROL_FRAME_MODE_PROVIDER (0x2 << 8)
105 #define PORT_CONTROL_FRAME_ETHER_TYPE_DSA (0x3 << 8)
106 #define PORT_CONTROL_DSA_TAG BIT(8)
107 #define PORT_CONTROL_VLAN_TUNNEL BIT(7)
108 #define PORT_CONTROL_TAG_IF_BOTH BIT(6)
109 #define PORT_CONTROL_USE_IP BIT(5)
110 #define PORT_CONTROL_USE_TAG BIT(4)
111 #define PORT_CONTROL_FORWARD_UNKNOWN_MC BIT(3)
112 #define PORT_CONTROL_FORWARD_UNKNOWN BIT(2)
113 #define PORT_CONTROL_STATE_MASK 0x03
114 #define PORT_CONTROL_STATE_DISABLED 0x00
115 #define PORT_CONTROL_STATE_BLOCKING 0x01
116 #define PORT_CONTROL_STATE_LEARNING 0x02
117 #define PORT_CONTROL_STATE_FORWARDING 0x03
118 #define PORT_CONTROL_1 0x05
119 #define PORT_CONTROL_1_FID_11_4_MASK (0xff << 0)
120 #define PORT_BASE_VLAN 0x06
121 #define PORT_BASE_VLAN_FID_3_0_MASK (0xf << 12)
122 #define PORT_DEFAULT_VLAN 0x07
123 #define PORT_DEFAULT_VLAN_MASK 0xfff
124 #define PORT_CONTROL_2 0x08
125 #define PORT_CONTROL_2_IGNORE_FCS BIT(15)
126 #define PORT_CONTROL_2_VTU_PRI_OVERRIDE BIT(14)
127 #define PORT_CONTROL_2_SA_PRIO_OVERRIDE BIT(13)
128 #define PORT_CONTROL_2_DA_PRIO_OVERRIDE BIT(12)
129 #define PORT_CONTROL_2_JUMBO_1522 (0x00 << 12)
130 #define PORT_CONTROL_2_JUMBO_2048 (0x01 << 12)
131 #define PORT_CONTROL_2_JUMBO_10240 (0x02 << 12)
132 #define PORT_CONTROL_2_8021Q_MASK (0x03 << 10)
133 #define PORT_CONTROL_2_8021Q_DISABLED (0x00 << 10)
134 #define PORT_CONTROL_2_8021Q_FALLBACK (0x01 << 10)
135 #define PORT_CONTROL_2_8021Q_CHECK (0x02 << 10)
136 #define PORT_CONTROL_2_8021Q_SECURE (0x03 << 10)
137 #define PORT_CONTROL_2_DISCARD_TAGGED BIT(9)
138 #define PORT_CONTROL_2_DISCARD_UNTAGGED BIT(8)
139 #define PORT_CONTROL_2_MAP_DA BIT(7)
140 #define PORT_CONTROL_2_DEFAULT_FORWARD BIT(6)
141 #define PORT_CONTROL_2_FORWARD_UNKNOWN BIT(6)
142 #define PORT_CONTROL_2_EGRESS_MONITOR BIT(5)
143 #define PORT_CONTROL_2_INGRESS_MONITOR BIT(4)
144 #define PORT_RATE_CONTROL 0x09
145 #define PORT_RATE_CONTROL_2 0x0a
146 #define PORT_ASSOC_VECTOR 0x0b
147 #define PORT_ASSOC_VECTOR_HOLD_AT_1 BIT(15)
148 #define PORT_ASSOC_VECTOR_INT_AGE_OUT BIT(14)
149 #define PORT_ASSOC_VECTOR_LOCKED_PORT BIT(13)
150 #define PORT_ASSOC_VECTOR_IGNORE_WRONG BIT(12)
151 #define PORT_ASSOC_VECTOR_REFRESH_LOCKED BIT(11)
152 #define PORT_ATU_CONTROL 0x0c
153 #define PORT_PRI_OVERRIDE 0x0d
154 #define PORT_ETH_TYPE 0x0f
155 #define PORT_IN_DISCARD_LO 0x10
156 #define PORT_IN_DISCARD_HI 0x11
157 #define PORT_IN_FILTERED 0x12
158 #define PORT_OUT_FILTERED 0x13
159 #define PORT_TAG_REGMAP_0123 0x18
160 #define PORT_TAG_REGMAP_4567 0x19
161
162 #define GLOBAL_STATUS 0x00
163 #define GLOBAL_STATUS_PPU_STATE BIT(15) /* 6351 and 6171 */
164 /* Two bits for 6165, 6185 etc */
165 #define GLOBAL_STATUS_PPU_MASK (0x3 << 14)
166 #define GLOBAL_STATUS_PPU_DISABLED_RST (0x0 << 14)
167 #define GLOBAL_STATUS_PPU_INITIALIZING (0x1 << 14)
168 #define GLOBAL_STATUS_PPU_DISABLED (0x2 << 14)
169 #define GLOBAL_STATUS_PPU_POLLING (0x3 << 14)
170 #define GLOBAL_MAC_01 0x01
171 #define GLOBAL_MAC_23 0x02
172 #define GLOBAL_MAC_45 0x03
173 #define GLOBAL_ATU_FID 0x01
174 #define GLOBAL_VTU_FID 0x02
175 #define GLOBAL_VTU_FID_MASK 0xfff
176 #define GLOBAL_VTU_SID 0x03 /* 6097 6165 6351 6352 */
177 #define GLOBAL_VTU_SID_MASK 0x3f
178 #define GLOBAL_CONTROL 0x04
179 #define GLOBAL_CONTROL_SW_RESET BIT(15)
180 #define GLOBAL_CONTROL_PPU_ENABLE BIT(14)
181 #define GLOBAL_CONTROL_DISCARD_EXCESS BIT(13) /* 6352 */
182 #define GLOBAL_CONTROL_SCHED_PRIO BIT(11) /* 6152 */
183 #define GLOBAL_CONTROL_MAX_FRAME_1632 BIT(10) /* 6152 */
184 #define GLOBAL_CONTROL_RELOAD_EEPROM BIT(9) /* 6152 */
185 #define GLOBAL_CONTROL_DEVICE_EN BIT(7)
186 #define GLOBAL_CONTROL_STATS_DONE_EN BIT(6)
187 #define GLOBAL_CONTROL_VTU_PROBLEM_EN BIT(5)
188 #define GLOBAL_CONTROL_VTU_DONE_EN BIT(4)
189 #define GLOBAL_CONTROL_ATU_PROBLEM_EN BIT(3)
190 #define GLOBAL_CONTROL_ATU_DONE_EN BIT(2)
191 #define GLOBAL_CONTROL_TCAM_EN BIT(1)
192 #define GLOBAL_CONTROL_EEPROM_DONE_EN BIT(0)
193 #define GLOBAL_VTU_OP 0x05
194 #define GLOBAL_VTU_OP_BUSY BIT(15)
195 #define GLOBAL_VTU_OP_FLUSH_ALL ((0x01 << 12) | GLOBAL_VTU_OP_BUSY)
196 #define GLOBAL_VTU_OP_VTU_LOAD_PURGE ((0x03 << 12) | GLOBAL_VTU_OP_BUSY)
197 #define GLOBAL_VTU_OP_VTU_GET_NEXT ((0x04 << 12) | GLOBAL_VTU_OP_BUSY)
198 #define GLOBAL_VTU_OP_STU_LOAD_PURGE ((0x05 << 12) | GLOBAL_VTU_OP_BUSY)
199 #define GLOBAL_VTU_OP_STU_GET_NEXT ((0x06 << 12) | GLOBAL_VTU_OP_BUSY)
200 #define GLOBAL_VTU_VID 0x06
201 #define GLOBAL_VTU_VID_MASK 0xfff
202 #define GLOBAL_VTU_VID_VALID BIT(12)
203 #define GLOBAL_VTU_DATA_0_3 0x07
204 #define GLOBAL_VTU_DATA_4_7 0x08
205 #define GLOBAL_VTU_DATA_8_11 0x09
206 #define GLOBAL_VTU_STU_DATA_MASK 0x03
207 #define GLOBAL_VTU_DATA_MEMBER_TAG_UNMODIFIED 0x00
208 #define GLOBAL_VTU_DATA_MEMBER_TAG_UNTAGGED 0x01
209 #define GLOBAL_VTU_DATA_MEMBER_TAG_TAGGED 0x02
210 #define GLOBAL_VTU_DATA_MEMBER_TAG_NON_MEMBER 0x03
211 #define GLOBAL_STU_DATA_PORT_STATE_DISABLED 0x00
212 #define GLOBAL_STU_DATA_PORT_STATE_BLOCKING 0x01
213 #define GLOBAL_STU_DATA_PORT_STATE_LEARNING 0x02
214 #define GLOBAL_STU_DATA_PORT_STATE_FORWARDING 0x03
215 #define GLOBAL_ATU_CONTROL 0x0a
216 #define GLOBAL_ATU_CONTROL_LEARN2ALL BIT(3)
217 #define GLOBAL_ATU_OP 0x0b
218 #define GLOBAL_ATU_OP_BUSY BIT(15)
219 #define GLOBAL_ATU_OP_NOP (0 << 12)
220 #define GLOBAL_ATU_OP_FLUSH_MOVE_ALL ((1 << 12) | GLOBAL_ATU_OP_BUSY)
221 #define GLOBAL_ATU_OP_FLUSH_MOVE_NON_STATIC ((2 << 12) | GLOBAL_ATU_OP_BUSY)
222 #define GLOBAL_ATU_OP_LOAD_DB ((3 << 12) | GLOBAL_ATU_OP_BUSY)
223 #define GLOBAL_ATU_OP_GET_NEXT_DB ((4 << 12) | GLOBAL_ATU_OP_BUSY)
224 #define GLOBAL_ATU_OP_FLUSH_MOVE_ALL_DB ((5 << 12) | GLOBAL_ATU_OP_BUSY)
225 #define GLOBAL_ATU_OP_FLUSH_MOVE_NON_STATIC_DB ((6 << 12) | GLOBAL_ATU_OP_BUSY)
226 #define GLOBAL_ATU_OP_GET_CLR_VIOLATION ((7 << 12) | GLOBAL_ATU_OP_BUSY)
227 #define GLOBAL_ATU_DATA 0x0c
228 #define GLOBAL_ATU_DATA_TRUNK BIT(15)
229 #define GLOBAL_ATU_DATA_TRUNK_ID_MASK 0x00f0
230 #define GLOBAL_ATU_DATA_TRUNK_ID_SHIFT 4
231 #define GLOBAL_ATU_DATA_PORT_VECTOR_MASK 0x3ff0
232 #define GLOBAL_ATU_DATA_PORT_VECTOR_SHIFT 4
233 #define GLOBAL_ATU_DATA_STATE_MASK 0x0f
234 #define GLOBAL_ATU_DATA_STATE_UNUSED 0x00
235 #define GLOBAL_ATU_DATA_STATE_UC_MGMT 0x0d
236 #define GLOBAL_ATU_DATA_STATE_UC_STATIC 0x0e
237 #define GLOBAL_ATU_DATA_STATE_UC_PRIO_OVER 0x0f
238 #define GLOBAL_ATU_DATA_STATE_MC_NONE_RATE 0x05
239 #define GLOBAL_ATU_DATA_STATE_MC_STATIC 0x07
240 #define GLOBAL_ATU_DATA_STATE_MC_MGMT 0x0e
241 #define GLOBAL_ATU_DATA_STATE_MC_PRIO_OVER 0x0f
242 #define GLOBAL_ATU_MAC_01 0x0d
243 #define GLOBAL_ATU_MAC_23 0x0e
244 #define GLOBAL_ATU_MAC_45 0x0f
245 #define GLOBAL_IP_PRI_0 0x10
246 #define GLOBAL_IP_PRI_1 0x11
247 #define GLOBAL_IP_PRI_2 0x12
248 #define GLOBAL_IP_PRI_3 0x13
249 #define GLOBAL_IP_PRI_4 0x14
250 #define GLOBAL_IP_PRI_5 0x15
251 #define GLOBAL_IP_PRI_6 0x16
252 #define GLOBAL_IP_PRI_7 0x17
253 #define GLOBAL_IEEE_PRI 0x18
254 #define GLOBAL_CORE_TAG_TYPE 0x19
255 #define GLOBAL_MONITOR_CONTROL 0x1a
256 #define GLOBAL_MONITOR_CONTROL_INGRESS_SHIFT 12
257 #define GLOBAL_MONITOR_CONTROL_EGRESS_SHIFT 8
258 #define GLOBAL_MONITOR_CONTROL_ARP_SHIFT 4
259 #define GLOBAL_MONITOR_CONTROL_MIRROR_SHIFT 0
260 #define GLOBAL_MONITOR_CONTROL_ARP_DISABLED (0xf0)
261 #define GLOBAL_CONTROL_2 0x1c
262 #define GLOBAL_CONTROL_2_NO_CASCADE 0xe000
263 #define GLOBAL_CONTROL_2_MULTIPLE_CASCADE 0xf000
264
265 #define GLOBAL_STATS_OP 0x1d
266 #define GLOBAL_STATS_OP_BUSY BIT(15)
267 #define GLOBAL_STATS_OP_NOP (0 << 12)
268 #define GLOBAL_STATS_OP_FLUSH_ALL ((1 << 12) | GLOBAL_STATS_OP_BUSY)
269 #define GLOBAL_STATS_OP_FLUSH_PORT ((2 << 12) | GLOBAL_STATS_OP_BUSY)
270 #define GLOBAL_STATS_OP_READ_CAPTURED ((4 << 12) | GLOBAL_STATS_OP_BUSY)
271 #define GLOBAL_STATS_OP_CAPTURE_PORT ((5 << 12) | GLOBAL_STATS_OP_BUSY)
272 #define GLOBAL_STATS_OP_HIST_RX ((1 << 10) | GLOBAL_STATS_OP_BUSY)
273 #define GLOBAL_STATS_OP_HIST_TX ((2 << 10) | GLOBAL_STATS_OP_BUSY)
274 #define GLOBAL_STATS_OP_HIST_RX_TX ((3 << 10) | GLOBAL_STATS_OP_BUSY)
275 #define GLOBAL_STATS_OP_BANK_1 BIT(9)
276 #define GLOBAL_STATS_COUNTER_32 0x1e
277 #define GLOBAL_STATS_COUNTER_01 0x1f
278
279 #define GLOBAL2_INT_SOURCE 0x00
280 #define GLOBAL2_INT_MASK 0x01
281 #define GLOBAL2_MGMT_EN_2X 0x02
282 #define GLOBAL2_MGMT_EN_0X 0x03
283 #define GLOBAL2_FLOW_CONTROL 0x04
284 #define GLOBAL2_SWITCH_MGMT 0x05
285 #define GLOBAL2_SWITCH_MGMT_USE_DOUBLE_TAG_DATA BIT(15)
286 #define GLOBAL2_SWITCH_MGMT_PREVENT_LOOPS BIT(14)
287 #define GLOBAL2_SWITCH_MGMT_FLOW_CONTROL_MSG BIT(13)
288 #define GLOBAL2_SWITCH_MGMT_FORCE_FLOW_CTRL_PRI BIT(7)
289 #define GLOBAL2_SWITCH_MGMT_RSVD2CPU BIT(3)
290 #define GLOBAL2_DEVICE_MAPPING 0x06
291 #define GLOBAL2_DEVICE_MAPPING_UPDATE BIT(15)
292 #define GLOBAL2_DEVICE_MAPPING_TARGET_SHIFT 8
293 #define GLOBAL2_DEVICE_MAPPING_PORT_MASK 0x0f
294 #define GLOBAL2_TRUNK_MASK 0x07
295 #define GLOBAL2_TRUNK_MASK_UPDATE BIT(15)
296 #define GLOBAL2_TRUNK_MASK_NUM_SHIFT 12
297 #define GLOBAL2_TRUNK_MASK_HASK BIT(11)
298 #define GLOBAL2_TRUNK_MAPPING 0x08
299 #define GLOBAL2_TRUNK_MAPPING_UPDATE BIT(15)
300 #define GLOBAL2_TRUNK_MAPPING_ID_SHIFT 11
301 #define GLOBAL2_IRL_CMD 0x09
302 #define GLOBAL2_IRL_CMD_BUSY BIT(15)
303 #define GLOBAL2_IRL_CMD_OP_INIT_ALL ((0x001 << 12) | GLOBAL2_IRL_CMD_BUSY)
304 #define GLOBAL2_IRL_CMD_OP_INIT_SEL ((0x010 << 12) | GLOBAL2_IRL_CMD_BUSY)
305 #define GLOBAL2_IRL_CMD_OP_WRITE_SEL ((0x011 << 12) | GLOBAL2_IRL_CMD_BUSY)
306 #define GLOBAL2_IRL_CMD_OP_READ_SEL ((0x100 << 12) | GLOBAL2_IRL_CMD_BUSY)
307 #define GLOBAL2_IRL_DATA 0x0a
308 #define GLOBAL2_PVT_ADDR 0x0b
309 #define GLOBAL2_PVT_ADDR_BUSY BIT(15)
310 #define GLOBAL2_PVT_ADDR_OP_INIT_ONES ((0x01 << 12) | GLOBAL2_PVT_ADDR_BUSY)
311 #define GLOBAL2_PVT_ADDR_OP_WRITE_PVLAN ((0x03 << 12) | GLOBAL2_PVT_ADDR_BUSY)
312 #define GLOBAL2_PVT_ADDR_OP_READ ((0x04 << 12) | GLOBAL2_PVT_ADDR_BUSY)
313 #define GLOBAL2_PVT_DATA 0x0c
314 #define GLOBAL2_SWITCH_MAC 0x0d
315 #define GLOBAL2_ATU_STATS 0x0e
316 #define GLOBAL2_PRIO_OVERRIDE 0x0f
317 #define GLOBAL2_PRIO_OVERRIDE_FORCE_SNOOP BIT(7)
318 #define GLOBAL2_PRIO_OVERRIDE_SNOOP_SHIFT 4
319 #define GLOBAL2_PRIO_OVERRIDE_FORCE_ARP BIT(3)
320 #define GLOBAL2_PRIO_OVERRIDE_ARP_SHIFT 0
321 #define GLOBAL2_EEPROM_CMD 0x14
322 #define GLOBAL2_EEPROM_CMD_BUSY BIT(15)
323 #define GLOBAL2_EEPROM_CMD_OP_WRITE ((0x3 << 12) | GLOBAL2_EEPROM_CMD_BUSY)
324 #define GLOBAL2_EEPROM_CMD_OP_READ ((0x4 << 12) | GLOBAL2_EEPROM_CMD_BUSY)
325 #define GLOBAL2_EEPROM_CMD_OP_LOAD ((0x6 << 12) | GLOBAL2_EEPROM_CMD_BUSY)
326 #define GLOBAL2_EEPROM_CMD_RUNNING BIT(11)
327 #define GLOBAL2_EEPROM_CMD_WRITE_EN BIT(10)
328 #define GLOBAL2_EEPROM_CMD_ADDR_MASK 0xff
329 #define GLOBAL2_EEPROM_DATA 0x15
330 #define GLOBAL2_PTP_AVB_OP 0x16
331 #define GLOBAL2_PTP_AVB_DATA 0x17
332 #define GLOBAL2_SMI_PHY_CMD 0x18
333 #define GLOBAL2_SMI_PHY_CMD_BUSY BIT(15)
334 #define GLOBAL2_SMI_PHY_CMD_MODE_22 BIT(12)
335 #define GLOBAL2_SMI_PHY_CMD_OP_22_WRITE_DATA ((0x1 << 10) | \
336 GLOBAL2_SMI_PHY_CMD_MODE_22 | \
337 GLOBAL2_SMI_PHY_CMD_BUSY)
338 #define GLOBAL2_SMI_PHY_CMD_OP_22_READ_DATA ((0x2 << 10) | \
339 GLOBAL2_SMI_PHY_CMD_MODE_22 | \
340 GLOBAL2_SMI_PHY_CMD_BUSY)
341 #define GLOBAL2_SMI_PHY_DATA 0x19
342 #define GLOBAL2_SCRATCH_MISC 0x1a
343 #define GLOBAL2_SCRATCH_BUSY BIT(15)
344 #define GLOBAL2_SCRATCH_REGISTER_SHIFT 8
345 #define GLOBAL2_SCRATCH_VALUE_MASK 0xff
346 #define GLOBAL2_WDOG_CONTROL 0x1b
347 #define GLOBAL2_QOS_WEIGHT 0x1c
348 #define GLOBAL2_MISC 0x1d
349
350 #define MV88E6XXX_N_FID 4096
351
352 /* List of supported models */
353 enum mv88e6xxx_model {
354 MV88E6085,
355 MV88E6095,
356 MV88E6123,
357 MV88E6131,
358 MV88E6161,
359 MV88E6165,
360 MV88E6171,
361 MV88E6172,
362 MV88E6175,
363 MV88E6176,
364 MV88E6185,
365 MV88E6240,
366 MV88E6320,
367 MV88E6321,
368 MV88E6350,
369 MV88E6351,
370 MV88E6352,
371 };
372
373 enum mv88e6xxx_family {
374 MV88E6XXX_FAMILY_NONE,
375 MV88E6XXX_FAMILY_6065, /* 6031 6035 6061 6065 */
376 MV88E6XXX_FAMILY_6095, /* 6092 6095 */
377 MV88E6XXX_FAMILY_6097, /* 6046 6085 6096 6097 */
378 MV88E6XXX_FAMILY_6165, /* 6123 6161 6165 */
379 MV88E6XXX_FAMILY_6185, /* 6108 6121 6122 6131 6152 6155 6182 6185 */
380 MV88E6XXX_FAMILY_6320, /* 6320 6321 */
381 MV88E6XXX_FAMILY_6351, /* 6171 6175 6350 6351 */
382 MV88E6XXX_FAMILY_6352, /* 6172 6176 6240 6352 */
383 };
384
385 enum mv88e6xxx_cap {
386 /* Two different tag protocols can be used by the driver. All
387 * switches support DSA, but only later generations support
388 * EDSA.
389 */
390 MV88E6XXX_CAP_EDSA,
391
392 /* Energy Efficient Ethernet.
393 */
394 MV88E6XXX_CAP_EEE,
395
396 /* Multi-chip Addressing Mode.
397 * Some chips respond to only 2 registers of its own SMI device address
398 * when it is non-zero, and use indirect access to internal registers.
399 */
400 MV88E6XXX_CAP_SMI_CMD, /* (0x00) SMI Command */
401 MV88E6XXX_CAP_SMI_DATA, /* (0x01) SMI Data */
402
403 /* PHY Registers.
404 */
405 MV88E6XXX_CAP_PHY_PAGE, /* (0x16) Page Register */
406
407 /* Fiber/SERDES Registers (SMI address F).
408 */
409 MV88E6XXX_CAP_SERDES,
410
411 /* Switch Global (1) Registers.
412 */
413 MV88E6XXX_CAP_G1_ATU_FID, /* (0x01) ATU FID Register */
414 MV88E6XXX_CAP_G1_VTU_FID, /* (0x02) VTU FID Register */
415
416 /* Switch Global 2 Registers.
417 * The device contains a second set of global 16-bit registers.
418 */
419 MV88E6XXX_CAP_GLOBAL2,
420 MV88E6XXX_CAP_G2_MGMT_EN_2X, /* (0x02) MGMT Enable Register 2x */
421 MV88E6XXX_CAP_G2_MGMT_EN_0X, /* (0x03) MGMT Enable Register 0x */
422 MV88E6XXX_CAP_G2_IRL_CMD, /* (0x09) Ingress Rate Command */
423 MV88E6XXX_CAP_G2_IRL_DATA, /* (0x0a) Ingress Rate Data */
424 MV88E6XXX_CAP_G2_PVT_ADDR, /* (0x0b) Cross Chip Port VLAN Addr */
425 MV88E6XXX_CAP_G2_PVT_DATA, /* (0x0c) Cross Chip Port VLAN Data */
426 MV88E6XXX_CAP_G2_POT, /* (0x0f) Priority Override Table */
427 MV88E6XXX_CAP_G2_EEPROM_CMD, /* (0x14) EEPROM Command */
428 MV88E6XXX_CAP_G2_EEPROM_DATA, /* (0x15) EEPROM Data */
429
430 /* PHY Polling Unit.
431 * See GLOBAL_CONTROL_PPU_ENABLE and GLOBAL_STATUS_PPU_POLLING.
432 */
433 MV88E6XXX_CAP_PPU,
434 MV88E6XXX_CAP_PPU_ACTIVE,
435
436 /* Per VLAN Spanning Tree Unit (STU).
437 * The Port State database, if present, is accessed through VTU
438 * operations and dedicated SID registers. See GLOBAL_VTU_SID.
439 */
440 MV88E6XXX_CAP_STU,
441
442 /* Internal temperature sensor.
443 * Available from any enabled port's PHY register 26, page 6.
444 */
445 MV88E6XXX_CAP_TEMP,
446 MV88E6XXX_CAP_TEMP_LIMIT,
447
448 /* VLAN Table Unit.
449 * The VTU is used to program 802.1Q VLANs. See GLOBAL_VTU_OP.
450 */
451 MV88E6XXX_CAP_VTU,
452 };
453
454 /* Bitmask of capabilities */
455 #define MV88E6XXX_FLAG_EDSA BIT_ULL(MV88E6XXX_CAP_EDSA)
456 #define MV88E6XXX_FLAG_EEE BIT_ULL(MV88E6XXX_CAP_EEE)
457
458 #define MV88E6XXX_FLAG_SMI_CMD BIT_ULL(MV88E6XXX_CAP_SMI_CMD)
459 #define MV88E6XXX_FLAG_SMI_DATA BIT_ULL(MV88E6XXX_CAP_SMI_DATA)
460
461 #define MV88E6XXX_FLAG_PHY_PAGE BIT_ULL(MV88E6XXX_CAP_PHY_PAGE)
462
463 #define MV88E6XXX_FLAG_SERDES BIT_ULL(MV88E6XXX_CAP_SERDES)
464
465 #define MV88E6XXX_FLAG_G1_ATU_FID BIT_ULL(MV88E6XXX_CAP_G1_ATU_FID)
466 #define MV88E6XXX_FLAG_G1_VTU_FID BIT_ULL(MV88E6XXX_CAP_G1_VTU_FID)
467
468 #define MV88E6XXX_FLAG_GLOBAL2 BIT_ULL(MV88E6XXX_CAP_GLOBAL2)
469 #define MV88E6XXX_FLAG_G2_MGMT_EN_2X BIT_ULL(MV88E6XXX_CAP_G2_MGMT_EN_2X)
470 #define MV88E6XXX_FLAG_G2_MGMT_EN_0X BIT_ULL(MV88E6XXX_CAP_G2_MGMT_EN_0X)
471 #define MV88E6XXX_FLAG_G2_IRL_CMD BIT_ULL(MV88E6XXX_CAP_G2_IRL_CMD)
472 #define MV88E6XXX_FLAG_G2_IRL_DATA BIT_ULL(MV88E6XXX_CAP_G2_IRL_DATA)
473 #define MV88E6XXX_FLAG_G2_PVT_ADDR BIT_ULL(MV88E6XXX_CAP_G2_PVT_ADDR)
474 #define MV88E6XXX_FLAG_G2_PVT_DATA BIT_ULL(MV88E6XXX_CAP_G2_PVT_DATA)
475 #define MV88E6XXX_FLAG_G2_POT BIT_ULL(MV88E6XXX_CAP_G2_POT)
476 #define MV88E6XXX_FLAG_G2_EEPROM_CMD BIT_ULL(MV88E6XXX_CAP_G2_EEPROM_CMD)
477 #define MV88E6XXX_FLAG_G2_EEPROM_DATA BIT_ULL(MV88E6XXX_CAP_G2_EEPROM_DATA)
478
479 #define MV88E6XXX_FLAG_PPU BIT_ULL(MV88E6XXX_CAP_PPU)
480 #define MV88E6XXX_FLAG_PPU_ACTIVE BIT_ULL(MV88E6XXX_CAP_PPU_ACTIVE)
481 #define MV88E6XXX_FLAG_STU BIT_ULL(MV88E6XXX_CAP_STU)
482 #define MV88E6XXX_FLAG_TEMP BIT_ULL(MV88E6XXX_CAP_TEMP)
483 #define MV88E6XXX_FLAG_TEMP_LIMIT BIT_ULL(MV88E6XXX_CAP_TEMP_LIMIT)
484 #define MV88E6XXX_FLAG_VTU BIT_ULL(MV88E6XXX_CAP_VTU)
485
486 /* EEPROM Programming via Global2 with 16-bit data */
487 #define MV88E6XXX_FLAGS_EEPROM16 \
488 (MV88E6XXX_FLAG_G2_EEPROM_CMD | \
489 MV88E6XXX_FLAG_G2_EEPROM_DATA)
490
491 /* Ingress Rate Limit unit */
492 #define MV88E6XXX_FLAGS_IRL \
493 (MV88E6XXX_FLAG_G2_IRL_CMD | \
494 MV88E6XXX_FLAG_G2_IRL_DATA)
495
496 /* Multi-chip Addressing Mode */
497 #define MV88E6XXX_FLAGS_MULTI_CHIP \
498 (MV88E6XXX_FLAG_SMI_CMD | \
499 MV88E6XXX_FLAG_SMI_DATA)
500
501 /* Cross-chip Port VLAN Table */
502 #define MV88E6XXX_FLAGS_PVT \
503 (MV88E6XXX_FLAG_G2_PVT_ADDR | \
504 MV88E6XXX_FLAG_G2_PVT_DATA)
505
506 /* Fiber/SERDES Registers at SMI address F, page 1 */
507 #define MV88E6XXX_FLAGS_SERDES \
508 (MV88E6XXX_FLAG_PHY_PAGE | \
509 MV88E6XXX_FLAG_SERDES)
510
511 #define MV88E6XXX_FLAGS_FAMILY_6095 \
512 (MV88E6XXX_FLAG_GLOBAL2 | \
513 MV88E6XXX_FLAG_G2_MGMT_EN_0X | \
514 MV88E6XXX_FLAG_PPU | \
515 MV88E6XXX_FLAG_VTU | \
516 MV88E6XXX_FLAGS_MULTI_CHIP)
517
518 #define MV88E6XXX_FLAGS_FAMILY_6097 \
519 (MV88E6XXX_FLAG_G1_ATU_FID | \
520 MV88E6XXX_FLAG_G1_VTU_FID | \
521 MV88E6XXX_FLAG_GLOBAL2 | \
522 MV88E6XXX_FLAG_G2_MGMT_EN_2X | \
523 MV88E6XXX_FLAG_G2_MGMT_EN_0X | \
524 MV88E6XXX_FLAG_G2_POT | \
525 MV88E6XXX_FLAG_PPU | \
526 MV88E6XXX_FLAG_STU | \
527 MV88E6XXX_FLAG_VTU | \
528 MV88E6XXX_FLAGS_IRL | \
529 MV88E6XXX_FLAGS_MULTI_CHIP | \
530 MV88E6XXX_FLAGS_PVT)
531
532 #define MV88E6XXX_FLAGS_FAMILY_6165 \
533 (MV88E6XXX_FLAG_G1_ATU_FID | \
534 MV88E6XXX_FLAG_G1_VTU_FID | \
535 MV88E6XXX_FLAG_GLOBAL2 | \
536 MV88E6XXX_FLAG_G2_MGMT_EN_2X | \
537 MV88E6XXX_FLAG_G2_MGMT_EN_0X | \
538 MV88E6XXX_FLAG_G2_POT | \
539 MV88E6XXX_FLAG_STU | \
540 MV88E6XXX_FLAG_TEMP | \
541 MV88E6XXX_FLAG_VTU | \
542 MV88E6XXX_FLAGS_IRL | \
543 MV88E6XXX_FLAGS_MULTI_CHIP | \
544 MV88E6XXX_FLAGS_PVT)
545
546 #define MV88E6XXX_FLAGS_FAMILY_6185 \
547 (MV88E6XXX_FLAG_GLOBAL2 | \
548 MV88E6XXX_FLAG_G2_MGMT_EN_0X | \
549 MV88E6XXX_FLAGS_MULTI_CHIP | \
550 MV88E6XXX_FLAG_PPU | \
551 MV88E6XXX_FLAG_VTU)
552
553 #define MV88E6XXX_FLAGS_FAMILY_6320 \
554 (MV88E6XXX_FLAG_EDSA | \
555 MV88E6XXX_FLAG_EEE | \
556 MV88E6XXX_FLAG_GLOBAL2 | \
557 MV88E6XXX_FLAG_G2_MGMT_EN_2X | \
558 MV88E6XXX_FLAG_G2_MGMT_EN_0X | \
559 MV88E6XXX_FLAG_G2_POT | \
560 MV88E6XXX_FLAG_PPU_ACTIVE | \
561 MV88E6XXX_FLAG_TEMP | \
562 MV88E6XXX_FLAG_TEMP_LIMIT | \
563 MV88E6XXX_FLAG_VTU | \
564 MV88E6XXX_FLAGS_EEPROM16 | \
565 MV88E6XXX_FLAGS_IRL | \
566 MV88E6XXX_FLAGS_MULTI_CHIP | \
567 MV88E6XXX_FLAGS_PVT)
568
569 #define MV88E6XXX_FLAGS_FAMILY_6351 \
570 (MV88E6XXX_FLAG_EDSA | \
571 MV88E6XXX_FLAG_G1_ATU_FID | \
572 MV88E6XXX_FLAG_G1_VTU_FID | \
573 MV88E6XXX_FLAG_GLOBAL2 | \
574 MV88E6XXX_FLAG_G2_MGMT_EN_2X | \
575 MV88E6XXX_FLAG_G2_MGMT_EN_0X | \
576 MV88E6XXX_FLAG_G2_POT | \
577 MV88E6XXX_FLAG_PPU_ACTIVE | \
578 MV88E6XXX_FLAG_STU | \
579 MV88E6XXX_FLAG_TEMP | \
580 MV88E6XXX_FLAG_VTU | \
581 MV88E6XXX_FLAGS_IRL | \
582 MV88E6XXX_FLAGS_MULTI_CHIP | \
583 MV88E6XXX_FLAGS_PVT)
584
585 #define MV88E6XXX_FLAGS_FAMILY_6352 \
586 (MV88E6XXX_FLAG_EDSA | \
587 MV88E6XXX_FLAG_EEE | \
588 MV88E6XXX_FLAG_G1_ATU_FID | \
589 MV88E6XXX_FLAG_G1_VTU_FID | \
590 MV88E6XXX_FLAG_GLOBAL2 | \
591 MV88E6XXX_FLAG_G2_MGMT_EN_2X | \
592 MV88E6XXX_FLAG_G2_MGMT_EN_0X | \
593 MV88E6XXX_FLAG_G2_POT | \
594 MV88E6XXX_FLAG_PPU_ACTIVE | \
595 MV88E6XXX_FLAG_STU | \
596 MV88E6XXX_FLAG_TEMP | \
597 MV88E6XXX_FLAG_TEMP_LIMIT | \
598 MV88E6XXX_FLAG_VTU | \
599 MV88E6XXX_FLAGS_EEPROM16 | \
600 MV88E6XXX_FLAGS_IRL | \
601 MV88E6XXX_FLAGS_MULTI_CHIP | \
602 MV88E6XXX_FLAGS_PVT | \
603 MV88E6XXX_FLAGS_SERDES)
604
605 struct mv88e6xxx_ops;
606
607 struct mv88e6xxx_info {
608 enum mv88e6xxx_family family;
609 u16 prod_num;
610 const char *name;
611 unsigned int num_databases;
612 unsigned int num_ports;
613 unsigned int port_base_addr;
614 unsigned int global1_addr;
615 unsigned int age_time_coeff;
616 unsigned long long flags;
617 const struct mv88e6xxx_ops *ops;
618 };
619
620 struct mv88e6xxx_atu_entry {
621 u16 fid;
622 u8 state;
623 bool trunk;
624 u16 portv_trunkid;
625 u8 mac[ETH_ALEN];
626 };
627
628 struct mv88e6xxx_vtu_entry {
629 u16 vid;
630 u16 fid;
631 u8 sid;
632 bool valid;
633 u8 data[DSA_MAX_PORTS];
634 };
635
636 struct mv88e6xxx_bus_ops;
637
638 struct mv88e6xxx_priv_port {
639 struct net_device *bridge_dev;
640 };
641
642 struct mv88e6xxx_chip {
643 const struct mv88e6xxx_info *info;
644
645 /* The dsa_switch this private structure is related to */
646 struct dsa_switch *ds;
647
648 /* The device this structure is associated to */
649 struct device *dev;
650
651 /* This mutex protects the access to the switch registers */
652 struct mutex reg_lock;
653
654 /* The MII bus and the address on the bus that is used to
655 * communication with the switch
656 */
657 const struct mv88e6xxx_bus_ops *smi_ops;
658 struct mii_bus *bus;
659 int sw_addr;
660
661 /* Handles automatic disabling and re-enabling of the PHY
662 * polling unit.
663 */
664 const struct mv88e6xxx_bus_ops *phy_ops;
665 struct mutex ppu_mutex;
666 int ppu_disabled;
667 struct work_struct ppu_work;
668 struct timer_list ppu_timer;
669
670 /* This mutex serialises access to the statistics unit.
671 * Hold this mutex over snapshot + dump sequences.
672 */
673 struct mutex stats_mutex;
674
675 struct mv88e6xxx_priv_port ports[DSA_MAX_PORTS];
676
677 /* A switch may have a GPIO line tied to its reset pin. Parse
678 * this from the device tree, and use it before performing
679 * switch soft reset.
680 */
681 struct gpio_desc *reset;
682
683 /* set to size of eeprom if supported by the switch */
684 int eeprom_len;
685
686 /* Device node for the MDIO bus */
687 struct device_node *mdio_np;
688
689 /* And the MDIO bus itself */
690 struct mii_bus *mdio_bus;
691 };
692
693 struct mv88e6xxx_bus_ops {
694 int (*read)(struct mv88e6xxx_chip *chip, int addr, int reg, u16 *val);
695 int (*write)(struct mv88e6xxx_chip *chip, int addr, int reg, u16 val);
696 };
697
698 struct mv88e6xxx_ops {
699 int (*set_switch_mac)(struct mv88e6xxx_chip *chip, u8 *addr);
700
701 int (*phy_read)(struct mv88e6xxx_chip *chip, int addr, int reg,
702 u16 *val);
703 int (*phy_write)(struct mv88e6xxx_chip *chip, int addr, int reg,
704 u16 val);
705 };
706
707 enum stat_type {
708 BANK0,
709 BANK1,
710 PORT,
711 };
712
713 struct mv88e6xxx_hw_stat {
714 char string[ETH_GSTRING_LEN];
715 int sizeof_stat;
716 int reg;
717 enum stat_type type;
718 };
719
720 static inline bool mv88e6xxx_has(struct mv88e6xxx_chip *chip,
721 unsigned long flags)
722 {
723 return (chip->info->flags & flags) == flags;
724 }
725
726 static inline unsigned int mv88e6xxx_num_databases(struct mv88e6xxx_chip *chip)
727 {
728 return chip->info->num_databases;
729 }
730
731 static inline unsigned int mv88e6xxx_num_ports(struct mv88e6xxx_chip *chip)
732 {
733 return chip->info->num_ports;
734 }
735
736 int mv88e6xxx_read(struct mv88e6xxx_chip *chip, int addr, int reg, u16 *val);
737 int mv88e6xxx_write(struct mv88e6xxx_chip *chip, int addr, int reg, u16 val);
738 int mv88e6xxx_update(struct mv88e6xxx_chip *chip, int addr, int reg,
739 u16 update);
740 int mv88e6xxx_wait(struct mv88e6xxx_chip *chip, int addr, int reg, u16 mask);
741
742 #endif