net: dsa: mv88e6xxx: add STU capability
[deliverable/linux.git] / drivers / net / dsa / mv88e6xxx.h
1 /*
2 * net/dsa/mv88e6xxx.h - Marvell 88e6xxx switch chip support
3 * Copyright (c) 2008 Marvell Semiconductor
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
9 */
10
11 #ifndef __MV88E6XXX_H
12 #define __MV88E6XXX_H
13
14 #include <linux/if_vlan.h>
15
16 #ifndef UINT64_MAX
17 #define UINT64_MAX (u64)(~((u64)0))
18 #endif
19
20 #define SMI_CMD 0x00
21 #define SMI_CMD_BUSY BIT(15)
22 #define SMI_CMD_CLAUSE_22 BIT(12)
23 #define SMI_CMD_OP_22_WRITE ((1 << 10) | SMI_CMD_BUSY | SMI_CMD_CLAUSE_22)
24 #define SMI_CMD_OP_22_READ ((2 << 10) | SMI_CMD_BUSY | SMI_CMD_CLAUSE_22)
25 #define SMI_CMD_OP_45_WRITE_ADDR ((0 << 10) | SMI_CMD_BUSY)
26 #define SMI_CMD_OP_45_WRITE_DATA ((1 << 10) | SMI_CMD_BUSY)
27 #define SMI_CMD_OP_45_READ_DATA ((2 << 10) | SMI_CMD_BUSY)
28 #define SMI_CMD_OP_45_READ_DATA_INC ((3 << 10) | SMI_CMD_BUSY)
29 #define SMI_DATA 0x01
30
31 /* Fiber/SERDES Registers are located at SMI address F, page 1 */
32 #define REG_FIBER_SERDES 0x0f
33 #define PAGE_FIBER_SERDES 0x01
34
35 #define REG_PORT(p) (0x10 + (p))
36 #define PORT_STATUS 0x00
37 #define PORT_STATUS_PAUSE_EN BIT(15)
38 #define PORT_STATUS_MY_PAUSE BIT(14)
39 #define PORT_STATUS_HD_FLOW BIT(13)
40 #define PORT_STATUS_PHY_DETECT BIT(12)
41 #define PORT_STATUS_LINK BIT(11)
42 #define PORT_STATUS_DUPLEX BIT(10)
43 #define PORT_STATUS_SPEED_MASK 0x0300
44 #define PORT_STATUS_SPEED_10 0x0000
45 #define PORT_STATUS_SPEED_100 0x0100
46 #define PORT_STATUS_SPEED_1000 0x0200
47 #define PORT_STATUS_EEE BIT(6) /* 6352 */
48 #define PORT_STATUS_AM_DIS BIT(6) /* 6165 */
49 #define PORT_STATUS_MGMII BIT(6) /* 6185 */
50 #define PORT_STATUS_TX_PAUSED BIT(5)
51 #define PORT_STATUS_FLOW_CTRL BIT(4)
52 #define PORT_STATUS_CMODE_MASK 0x0f
53 #define PORT_STATUS_CMODE_100BASE_X 0x8
54 #define PORT_STATUS_CMODE_1000BASE_X 0x9
55 #define PORT_STATUS_CMODE_SGMII 0xa
56 #define PORT_PCS_CTRL 0x01
57 #define PORT_PCS_CTRL_RGMII_DELAY_RXCLK BIT(15)
58 #define PORT_PCS_CTRL_RGMII_DELAY_TXCLK BIT(14)
59 #define PORT_PCS_CTRL_FC BIT(7)
60 #define PORT_PCS_CTRL_FORCE_FC BIT(6)
61 #define PORT_PCS_CTRL_LINK_UP BIT(5)
62 #define PORT_PCS_CTRL_FORCE_LINK BIT(4)
63 #define PORT_PCS_CTRL_DUPLEX_FULL BIT(3)
64 #define PORT_PCS_CTRL_FORCE_DUPLEX BIT(2)
65 #define PORT_PCS_CTRL_10 0x00
66 #define PORT_PCS_CTRL_100 0x01
67 #define PORT_PCS_CTRL_1000 0x02
68 #define PORT_PCS_CTRL_UNFORCED 0x03
69 #define PORT_PAUSE_CTRL 0x02
70 #define PORT_SWITCH_ID 0x03
71 #define PORT_SWITCH_ID_PROD_NUM_6085 0x04a
72 #define PORT_SWITCH_ID_PROD_NUM_6095 0x095
73 #define PORT_SWITCH_ID_PROD_NUM_6131 0x106
74 #define PORT_SWITCH_ID_PROD_NUM_6320 0x115
75 #define PORT_SWITCH_ID_PROD_NUM_6123 0x121
76 #define PORT_SWITCH_ID_PROD_NUM_6161 0x161
77 #define PORT_SWITCH_ID_PROD_NUM_6165 0x165
78 #define PORT_SWITCH_ID_PROD_NUM_6171 0x171
79 #define PORT_SWITCH_ID_PROD_NUM_6172 0x172
80 #define PORT_SWITCH_ID_PROD_NUM_6175 0x175
81 #define PORT_SWITCH_ID_PROD_NUM_6176 0x176
82 #define PORT_SWITCH_ID_PROD_NUM_6185 0x1a7
83 #define PORT_SWITCH_ID_PROD_NUM_6240 0x240
84 #define PORT_SWITCH_ID_PROD_NUM_6321 0x310
85 #define PORT_SWITCH_ID_PROD_NUM_6352 0x352
86 #define PORT_SWITCH_ID_PROD_NUM_6350 0x371
87 #define PORT_SWITCH_ID_PROD_NUM_6351 0x375
88 #define PORT_CONTROL 0x04
89 #define PORT_CONTROL_USE_CORE_TAG BIT(15)
90 #define PORT_CONTROL_DROP_ON_LOCK BIT(14)
91 #define PORT_CONTROL_EGRESS_UNMODIFIED (0x0 << 12)
92 #define PORT_CONTROL_EGRESS_UNTAGGED (0x1 << 12)
93 #define PORT_CONTROL_EGRESS_TAGGED (0x2 << 12)
94 #define PORT_CONTROL_EGRESS_ADD_TAG (0x3 << 12)
95 #define PORT_CONTROL_HEADER BIT(11)
96 #define PORT_CONTROL_IGMP_MLD_SNOOP BIT(10)
97 #define PORT_CONTROL_DOUBLE_TAG BIT(9)
98 #define PORT_CONTROL_FRAME_MODE_NORMAL (0x0 << 8)
99 #define PORT_CONTROL_FRAME_MODE_DSA (0x1 << 8)
100 #define PORT_CONTROL_FRAME_MODE_PROVIDER (0x2 << 8)
101 #define PORT_CONTROL_FRAME_ETHER_TYPE_DSA (0x3 << 8)
102 #define PORT_CONTROL_DSA_TAG BIT(8)
103 #define PORT_CONTROL_VLAN_TUNNEL BIT(7)
104 #define PORT_CONTROL_TAG_IF_BOTH BIT(6)
105 #define PORT_CONTROL_USE_IP BIT(5)
106 #define PORT_CONTROL_USE_TAG BIT(4)
107 #define PORT_CONTROL_FORWARD_UNKNOWN_MC BIT(3)
108 #define PORT_CONTROL_FORWARD_UNKNOWN BIT(2)
109 #define PORT_CONTROL_STATE_MASK 0x03
110 #define PORT_CONTROL_STATE_DISABLED 0x00
111 #define PORT_CONTROL_STATE_BLOCKING 0x01
112 #define PORT_CONTROL_STATE_LEARNING 0x02
113 #define PORT_CONTROL_STATE_FORWARDING 0x03
114 #define PORT_CONTROL_1 0x05
115 #define PORT_CONTROL_1_FID_11_4_MASK (0xff << 0)
116 #define PORT_BASE_VLAN 0x06
117 #define PORT_BASE_VLAN_FID_3_0_MASK (0xf << 12)
118 #define PORT_DEFAULT_VLAN 0x07
119 #define PORT_DEFAULT_VLAN_MASK 0xfff
120 #define PORT_CONTROL_2 0x08
121 #define PORT_CONTROL_2_IGNORE_FCS BIT(15)
122 #define PORT_CONTROL_2_VTU_PRI_OVERRIDE BIT(14)
123 #define PORT_CONTROL_2_SA_PRIO_OVERRIDE BIT(13)
124 #define PORT_CONTROL_2_DA_PRIO_OVERRIDE BIT(12)
125 #define PORT_CONTROL_2_JUMBO_1522 (0x00 << 12)
126 #define PORT_CONTROL_2_JUMBO_2048 (0x01 << 12)
127 #define PORT_CONTROL_2_JUMBO_10240 (0x02 << 12)
128 #define PORT_CONTROL_2_8021Q_MASK (0x03 << 10)
129 #define PORT_CONTROL_2_8021Q_DISABLED (0x00 << 10)
130 #define PORT_CONTROL_2_8021Q_FALLBACK (0x01 << 10)
131 #define PORT_CONTROL_2_8021Q_CHECK (0x02 << 10)
132 #define PORT_CONTROL_2_8021Q_SECURE (0x03 << 10)
133 #define PORT_CONTROL_2_DISCARD_TAGGED BIT(9)
134 #define PORT_CONTROL_2_DISCARD_UNTAGGED BIT(8)
135 #define PORT_CONTROL_2_MAP_DA BIT(7)
136 #define PORT_CONTROL_2_DEFAULT_FORWARD BIT(6)
137 #define PORT_CONTROL_2_FORWARD_UNKNOWN BIT(6)
138 #define PORT_CONTROL_2_EGRESS_MONITOR BIT(5)
139 #define PORT_CONTROL_2_INGRESS_MONITOR BIT(4)
140 #define PORT_RATE_CONTROL 0x09
141 #define PORT_RATE_CONTROL_2 0x0a
142 #define PORT_ASSOC_VECTOR 0x0b
143 #define PORT_ASSOC_VECTOR_HOLD_AT_1 BIT(15)
144 #define PORT_ASSOC_VECTOR_INT_AGE_OUT BIT(14)
145 #define PORT_ASSOC_VECTOR_LOCKED_PORT BIT(13)
146 #define PORT_ASSOC_VECTOR_IGNORE_WRONG BIT(12)
147 #define PORT_ASSOC_VECTOR_REFRESH_LOCKED BIT(11)
148 #define PORT_ATU_CONTROL 0x0c
149 #define PORT_PRI_OVERRIDE 0x0d
150 #define PORT_ETH_TYPE 0x0f
151 #define PORT_IN_DISCARD_LO 0x10
152 #define PORT_IN_DISCARD_HI 0x11
153 #define PORT_IN_FILTERED 0x12
154 #define PORT_OUT_FILTERED 0x13
155 #define PORT_TAG_REGMAP_0123 0x18
156 #define PORT_TAG_REGMAP_4567 0x19
157
158 #define REG_GLOBAL 0x1b
159 #define GLOBAL_STATUS 0x00
160 #define GLOBAL_STATUS_PPU_STATE BIT(15) /* 6351 and 6171 */
161 /* Two bits for 6165, 6185 etc */
162 #define GLOBAL_STATUS_PPU_MASK (0x3 << 14)
163 #define GLOBAL_STATUS_PPU_DISABLED_RST (0x0 << 14)
164 #define GLOBAL_STATUS_PPU_INITIALIZING (0x1 << 14)
165 #define GLOBAL_STATUS_PPU_DISABLED (0x2 << 14)
166 #define GLOBAL_STATUS_PPU_POLLING (0x3 << 14)
167 #define GLOBAL_MAC_01 0x01
168 #define GLOBAL_MAC_23 0x02
169 #define GLOBAL_MAC_45 0x03
170 #define GLOBAL_ATU_FID 0x01 /* 6097 6165 6351 6352 */
171 #define GLOBAL_VTU_FID 0x02 /* 6097 6165 6351 6352 */
172 #define GLOBAL_VTU_FID_MASK 0xfff
173 #define GLOBAL_VTU_SID 0x03 /* 6097 6165 6351 6352 */
174 #define GLOBAL_VTU_SID_MASK 0x3f
175 #define GLOBAL_CONTROL 0x04
176 #define GLOBAL_CONTROL_SW_RESET BIT(15)
177 #define GLOBAL_CONTROL_PPU_ENABLE BIT(14)
178 #define GLOBAL_CONTROL_DISCARD_EXCESS BIT(13) /* 6352 */
179 #define GLOBAL_CONTROL_SCHED_PRIO BIT(11) /* 6152 */
180 #define GLOBAL_CONTROL_MAX_FRAME_1632 BIT(10) /* 6152 */
181 #define GLOBAL_CONTROL_RELOAD_EEPROM BIT(9) /* 6152 */
182 #define GLOBAL_CONTROL_DEVICE_EN BIT(7)
183 #define GLOBAL_CONTROL_STATS_DONE_EN BIT(6)
184 #define GLOBAL_CONTROL_VTU_PROBLEM_EN BIT(5)
185 #define GLOBAL_CONTROL_VTU_DONE_EN BIT(4)
186 #define GLOBAL_CONTROL_ATU_PROBLEM_EN BIT(3)
187 #define GLOBAL_CONTROL_ATU_DONE_EN BIT(2)
188 #define GLOBAL_CONTROL_TCAM_EN BIT(1)
189 #define GLOBAL_CONTROL_EEPROM_DONE_EN BIT(0)
190 #define GLOBAL_VTU_OP 0x05
191 #define GLOBAL_VTU_OP_BUSY BIT(15)
192 #define GLOBAL_VTU_OP_FLUSH_ALL ((0x01 << 12) | GLOBAL_VTU_OP_BUSY)
193 #define GLOBAL_VTU_OP_VTU_LOAD_PURGE ((0x03 << 12) | GLOBAL_VTU_OP_BUSY)
194 #define GLOBAL_VTU_OP_VTU_GET_NEXT ((0x04 << 12) | GLOBAL_VTU_OP_BUSY)
195 #define GLOBAL_VTU_OP_STU_LOAD_PURGE ((0x05 << 12) | GLOBAL_VTU_OP_BUSY)
196 #define GLOBAL_VTU_OP_STU_GET_NEXT ((0x06 << 12) | GLOBAL_VTU_OP_BUSY)
197 #define GLOBAL_VTU_VID 0x06
198 #define GLOBAL_VTU_VID_MASK 0xfff
199 #define GLOBAL_VTU_VID_VALID BIT(12)
200 #define GLOBAL_VTU_DATA_0_3 0x07
201 #define GLOBAL_VTU_DATA_4_7 0x08
202 #define GLOBAL_VTU_DATA_8_11 0x09
203 #define GLOBAL_VTU_STU_DATA_MASK 0x03
204 #define GLOBAL_VTU_DATA_MEMBER_TAG_UNMODIFIED 0x00
205 #define GLOBAL_VTU_DATA_MEMBER_TAG_UNTAGGED 0x01
206 #define GLOBAL_VTU_DATA_MEMBER_TAG_TAGGED 0x02
207 #define GLOBAL_VTU_DATA_MEMBER_TAG_NON_MEMBER 0x03
208 #define GLOBAL_STU_DATA_PORT_STATE_DISABLED 0x00
209 #define GLOBAL_STU_DATA_PORT_STATE_BLOCKING 0x01
210 #define GLOBAL_STU_DATA_PORT_STATE_LEARNING 0x02
211 #define GLOBAL_STU_DATA_PORT_STATE_FORWARDING 0x03
212 #define GLOBAL_ATU_CONTROL 0x0a
213 #define GLOBAL_ATU_CONTROL_LEARN2ALL BIT(3)
214 #define GLOBAL_ATU_OP 0x0b
215 #define GLOBAL_ATU_OP_BUSY BIT(15)
216 #define GLOBAL_ATU_OP_NOP (0 << 12)
217 #define GLOBAL_ATU_OP_FLUSH_MOVE_ALL ((1 << 12) | GLOBAL_ATU_OP_BUSY)
218 #define GLOBAL_ATU_OP_FLUSH_MOVE_NON_STATIC ((2 << 12) | GLOBAL_ATU_OP_BUSY)
219 #define GLOBAL_ATU_OP_LOAD_DB ((3 << 12) | GLOBAL_ATU_OP_BUSY)
220 #define GLOBAL_ATU_OP_GET_NEXT_DB ((4 << 12) | GLOBAL_ATU_OP_BUSY)
221 #define GLOBAL_ATU_OP_FLUSH_MOVE_ALL_DB ((5 << 12) | GLOBAL_ATU_OP_BUSY)
222 #define GLOBAL_ATU_OP_FLUSH_MOVE_NON_STATIC_DB ((6 << 12) | GLOBAL_ATU_OP_BUSY)
223 #define GLOBAL_ATU_OP_GET_CLR_VIOLATION ((7 << 12) | GLOBAL_ATU_OP_BUSY)
224 #define GLOBAL_ATU_DATA 0x0c
225 #define GLOBAL_ATU_DATA_TRUNK BIT(15)
226 #define GLOBAL_ATU_DATA_TRUNK_ID_MASK 0x00f0
227 #define GLOBAL_ATU_DATA_TRUNK_ID_SHIFT 4
228 #define GLOBAL_ATU_DATA_PORT_VECTOR_MASK 0x3ff0
229 #define GLOBAL_ATU_DATA_PORT_VECTOR_SHIFT 4
230 #define GLOBAL_ATU_DATA_STATE_MASK 0x0f
231 #define GLOBAL_ATU_DATA_STATE_UNUSED 0x00
232 #define GLOBAL_ATU_DATA_STATE_UC_MGMT 0x0d
233 #define GLOBAL_ATU_DATA_STATE_UC_STATIC 0x0e
234 #define GLOBAL_ATU_DATA_STATE_UC_PRIO_OVER 0x0f
235 #define GLOBAL_ATU_DATA_STATE_MC_NONE_RATE 0x05
236 #define GLOBAL_ATU_DATA_STATE_MC_STATIC 0x07
237 #define GLOBAL_ATU_DATA_STATE_MC_MGMT 0x0e
238 #define GLOBAL_ATU_DATA_STATE_MC_PRIO_OVER 0x0f
239 #define GLOBAL_ATU_MAC_01 0x0d
240 #define GLOBAL_ATU_MAC_23 0x0e
241 #define GLOBAL_ATU_MAC_45 0x0f
242 #define GLOBAL_IP_PRI_0 0x10
243 #define GLOBAL_IP_PRI_1 0x11
244 #define GLOBAL_IP_PRI_2 0x12
245 #define GLOBAL_IP_PRI_3 0x13
246 #define GLOBAL_IP_PRI_4 0x14
247 #define GLOBAL_IP_PRI_5 0x15
248 #define GLOBAL_IP_PRI_6 0x16
249 #define GLOBAL_IP_PRI_7 0x17
250 #define GLOBAL_IEEE_PRI 0x18
251 #define GLOBAL_CORE_TAG_TYPE 0x19
252 #define GLOBAL_MONITOR_CONTROL 0x1a
253 #define GLOBAL_MONITOR_CONTROL_INGRESS_SHIFT 12
254 #define GLOBAL_MONITOR_CONTROL_EGRESS_SHIFT 8
255 #define GLOBAL_MONITOR_CONTROL_ARP_SHIFT 4
256 #define GLOBAL_MONITOR_CONTROL_MIRROR_SHIFT 0
257 #define GLOBAL_MONITOR_CONTROL_ARP_DISABLED (0xf0)
258 #define GLOBAL_CONTROL_2 0x1c
259 #define GLOBAL_CONTROL_2_NO_CASCADE 0xe000
260 #define GLOBAL_CONTROL_2_MULTIPLE_CASCADE 0xf000
261
262 #define GLOBAL_STATS_OP 0x1d
263 #define GLOBAL_STATS_OP_BUSY BIT(15)
264 #define GLOBAL_STATS_OP_NOP (0 << 12)
265 #define GLOBAL_STATS_OP_FLUSH_ALL ((1 << 12) | GLOBAL_STATS_OP_BUSY)
266 #define GLOBAL_STATS_OP_FLUSH_PORT ((2 << 12) | GLOBAL_STATS_OP_BUSY)
267 #define GLOBAL_STATS_OP_READ_CAPTURED ((4 << 12) | GLOBAL_STATS_OP_BUSY)
268 #define GLOBAL_STATS_OP_CAPTURE_PORT ((5 << 12) | GLOBAL_STATS_OP_BUSY)
269 #define GLOBAL_STATS_OP_HIST_RX ((1 << 10) | GLOBAL_STATS_OP_BUSY)
270 #define GLOBAL_STATS_OP_HIST_TX ((2 << 10) | GLOBAL_STATS_OP_BUSY)
271 #define GLOBAL_STATS_OP_HIST_RX_TX ((3 << 10) | GLOBAL_STATS_OP_BUSY)
272 #define GLOBAL_STATS_OP_BANK_1 BIT(9)
273 #define GLOBAL_STATS_COUNTER_32 0x1e
274 #define GLOBAL_STATS_COUNTER_01 0x1f
275
276 #define REG_GLOBAL2 0x1c
277 #define GLOBAL2_INT_SOURCE 0x00
278 #define GLOBAL2_INT_MASK 0x01
279 #define GLOBAL2_MGMT_EN_2X 0x02
280 #define GLOBAL2_MGMT_EN_0X 0x03
281 #define GLOBAL2_FLOW_CONTROL 0x04
282 #define GLOBAL2_SWITCH_MGMT 0x05
283 #define GLOBAL2_SWITCH_MGMT_USE_DOUBLE_TAG_DATA BIT(15)
284 #define GLOBAL2_SWITCH_MGMT_PREVENT_LOOPS BIT(14)
285 #define GLOBAL2_SWITCH_MGMT_FLOW_CONTROL_MSG BIT(13)
286 #define GLOBAL2_SWITCH_MGMT_FORCE_FLOW_CTRL_PRI BIT(7)
287 #define GLOBAL2_SWITCH_MGMT_RSVD2CPU BIT(3)
288 #define GLOBAL2_DEVICE_MAPPING 0x06
289 #define GLOBAL2_DEVICE_MAPPING_UPDATE BIT(15)
290 #define GLOBAL2_DEVICE_MAPPING_TARGET_SHIFT 8
291 #define GLOBAL2_DEVICE_MAPPING_PORT_MASK 0x0f
292 #define GLOBAL2_TRUNK_MASK 0x07
293 #define GLOBAL2_TRUNK_MASK_UPDATE BIT(15)
294 #define GLOBAL2_TRUNK_MASK_NUM_SHIFT 12
295 #define GLOBAL2_TRUNK_MAPPING 0x08
296 #define GLOBAL2_TRUNK_MAPPING_UPDATE BIT(15)
297 #define GLOBAL2_TRUNK_MAPPING_ID_SHIFT 11
298 #define GLOBAL2_INGRESS_OP 0x09
299 #define GLOBAL2_INGRESS_DATA 0x0a
300 #define GLOBAL2_PVT_ADDR 0x0b
301 #define GLOBAL2_PVT_DATA 0x0c
302 #define GLOBAL2_SWITCH_MAC 0x0d
303 #define GLOBAL2_SWITCH_MAC_BUSY BIT(15)
304 #define GLOBAL2_ATU_STATS 0x0e
305 #define GLOBAL2_PRIO_OVERRIDE 0x0f
306 #define GLOBAL2_PRIO_OVERRIDE_FORCE_SNOOP BIT(7)
307 #define GLOBAL2_PRIO_OVERRIDE_SNOOP_SHIFT 4
308 #define GLOBAL2_PRIO_OVERRIDE_FORCE_ARP BIT(3)
309 #define GLOBAL2_PRIO_OVERRIDE_ARP_SHIFT 0
310 #define GLOBAL2_EEPROM_OP 0x14
311 #define GLOBAL2_EEPROM_OP_BUSY BIT(15)
312 #define GLOBAL2_EEPROM_OP_WRITE ((3 << 12) | GLOBAL2_EEPROM_OP_BUSY)
313 #define GLOBAL2_EEPROM_OP_READ ((4 << 12) | GLOBAL2_EEPROM_OP_BUSY)
314 #define GLOBAL2_EEPROM_OP_LOAD BIT(11)
315 #define GLOBAL2_EEPROM_OP_WRITE_EN BIT(10)
316 #define GLOBAL2_EEPROM_OP_ADDR_MASK 0xff
317 #define GLOBAL2_EEPROM_DATA 0x15
318 #define GLOBAL2_PTP_AVB_OP 0x16
319 #define GLOBAL2_PTP_AVB_DATA 0x17
320 #define GLOBAL2_SMI_OP 0x18
321 #define GLOBAL2_SMI_OP_BUSY BIT(15)
322 #define GLOBAL2_SMI_OP_CLAUSE_22 BIT(12)
323 #define GLOBAL2_SMI_OP_22_WRITE ((1 << 10) | GLOBAL2_SMI_OP_BUSY | \
324 GLOBAL2_SMI_OP_CLAUSE_22)
325 #define GLOBAL2_SMI_OP_22_READ ((2 << 10) | GLOBAL2_SMI_OP_BUSY | \
326 GLOBAL2_SMI_OP_CLAUSE_22)
327 #define GLOBAL2_SMI_OP_45_WRITE_ADDR ((0 << 10) | GLOBAL2_SMI_OP_BUSY)
328 #define GLOBAL2_SMI_OP_45_WRITE_DATA ((1 << 10) | GLOBAL2_SMI_OP_BUSY)
329 #define GLOBAL2_SMI_OP_45_READ_DATA ((2 << 10) | GLOBAL2_SMI_OP_BUSY)
330 #define GLOBAL2_SMI_DATA 0x19
331 #define GLOBAL2_SCRATCH_MISC 0x1a
332 #define GLOBAL2_SCRATCH_BUSY BIT(15)
333 #define GLOBAL2_SCRATCH_REGISTER_SHIFT 8
334 #define GLOBAL2_SCRATCH_VALUE_MASK 0xff
335 #define GLOBAL2_WDOG_CONTROL 0x1b
336 #define GLOBAL2_QOS_WEIGHT 0x1c
337 #define GLOBAL2_MISC 0x1d
338
339 #define MV88E6XXX_N_FID 4096
340
341 /* List of supported models */
342 enum mv88e6xxx_model {
343 MV88E6085,
344 MV88E6095,
345 MV88E6123,
346 MV88E6131,
347 MV88E6161,
348 MV88E6165,
349 MV88E6171,
350 MV88E6172,
351 MV88E6175,
352 MV88E6176,
353 MV88E6185,
354 MV88E6240,
355 MV88E6320,
356 MV88E6321,
357 MV88E6350,
358 MV88E6351,
359 MV88E6352,
360 };
361
362 enum mv88e6xxx_family {
363 MV88E6XXX_FAMILY_NONE,
364 MV88E6XXX_FAMILY_6065, /* 6031 6035 6061 6065 */
365 MV88E6XXX_FAMILY_6095, /* 6092 6095 */
366 MV88E6XXX_FAMILY_6097, /* 6046 6085 6096 6097 */
367 MV88E6XXX_FAMILY_6165, /* 6123 6161 6165 */
368 MV88E6XXX_FAMILY_6185, /* 6108 6121 6122 6131 6152 6155 6182 6185 */
369 MV88E6XXX_FAMILY_6320, /* 6320 6321 */
370 MV88E6XXX_FAMILY_6351, /* 6171 6175 6350 6351 */
371 MV88E6XXX_FAMILY_6352, /* 6172 6176 6240 6352 */
372 };
373
374 enum mv88e6xxx_cap {
375 /* Address Translation Unit.
376 * The ATU is used to lookup and learn MAC addresses. See GLOBAL_ATU_OP.
377 */
378 MV88E6XXX_CAP_ATU,
379
380 /* Energy Efficient Ethernet.
381 */
382 MV88E6XXX_CAP_EEE,
383
384 /* EEPROM Command and Data registers.
385 * See GLOBAL2_EEPROM_OP and GLOBAL2_EEPROM_DATA.
386 */
387 MV88E6XXX_CAP_EEPROM,
388
389 /* Port State Filtering for 802.1D Spanning Tree.
390 * See PORT_CONTROL_STATE_* values in the PORT_CONTROL register.
391 */
392 MV88E6XXX_CAP_PORTSTATE,
393
394 /* PHY Polling Unit.
395 * See GLOBAL_CONTROL_PPU_ENABLE and GLOBAL_STATUS_PPU_POLLING.
396 */
397 MV88E6XXX_CAP_PPU,
398 MV88E6XXX_CAP_PPU_ACTIVE,
399
400 /* SMI PHY Command and Data registers.
401 * This requires an indirect access to PHY registers through
402 * GLOBAL2_SMI_OP, otherwise direct access to PHY registers is done.
403 */
404 MV88E6XXX_CAP_SMI_PHY,
405
406 /* Per VLAN Spanning Tree Unit (STU).
407 * The Port State database, if present, is accessed through VTU
408 * operations and dedicated SID registers. See GLOBAL_VTU_SID.
409 */
410 MV88E6XXX_CAP_STU,
411
412 /* Switch MAC/WoL/WoF register.
413 * This requires an indirect access to set the switch MAC address
414 * through GLOBAL2_SWITCH_MAC, otherwise GLOBAL_MAC_01, GLOBAL_MAC_23,
415 * and GLOBAL_MAC_45 are used with a direct access.
416 */
417 MV88E6XXX_CAP_SWITCH_MAC_WOL_WOF,
418
419 /* Internal temperature sensor.
420 * Available from any enabled port's PHY register 26, page 6.
421 */
422 MV88E6XXX_CAP_TEMP,
423 MV88E6XXX_CAP_TEMP_LIMIT,
424
425 /* In-chip Port Based VLANs.
426 * Each port VLANTable register (see PORT_BASE_VLAN) is used to restrict
427 * the output (or egress) ports to which it is allowed to send frames.
428 */
429 MV88E6XXX_CAP_VLANTABLE,
430
431 /* VLAN Table Unit.
432 * The VTU is used to program 802.1Q VLANs. See GLOBAL_VTU_OP.
433 */
434 MV88E6XXX_CAP_VTU,
435 };
436
437 /* Bitmask of capabilities */
438 #define MV88E6XXX_FLAG_ATU BIT(MV88E6XXX_CAP_ATU)
439 #define MV88E6XXX_FLAG_EEE BIT(MV88E6XXX_CAP_EEE)
440 #define MV88E6XXX_FLAG_EEPROM BIT(MV88E6XXX_CAP_EEPROM)
441 #define MV88E6XXX_FLAG_PORTSTATE BIT(MV88E6XXX_CAP_PORTSTATE)
442 #define MV88E6XXX_FLAG_PPU BIT(MV88E6XXX_CAP_PPU)
443 #define MV88E6XXX_FLAG_PPU_ACTIVE BIT(MV88E6XXX_CAP_PPU_ACTIVE)
444 #define MV88E6XXX_FLAG_SMI_PHY BIT(MV88E6XXX_CAP_SMI_PHY)
445 #define MV88E6XXX_FLAG_STU BIT(MV88E6XXX_CAP_STU)
446 #define MV88E6XXX_FLAG_SWITCH_MAC BIT(MV88E6XXX_CAP_SWITCH_MAC_WOL_WOF)
447 #define MV88E6XXX_FLAG_TEMP BIT(MV88E6XXX_CAP_TEMP)
448 #define MV88E6XXX_FLAG_TEMP_LIMIT BIT(MV88E6XXX_CAP_TEMP_LIMIT)
449 #define MV88E6XXX_FLAG_VLANTABLE BIT(MV88E6XXX_CAP_VLANTABLE)
450 #define MV88E6XXX_FLAG_VTU BIT(MV88E6XXX_CAP_VTU)
451
452 #define MV88E6XXX_FLAGS_FAMILY_6095 \
453 (MV88E6XXX_FLAG_ATU | \
454 MV88E6XXX_FLAG_PPU | \
455 MV88E6XXX_FLAG_VLANTABLE | \
456 MV88E6XXX_FLAG_VTU)
457
458 #define MV88E6XXX_FLAGS_FAMILY_6097 \
459 (MV88E6XXX_FLAG_ATU | \
460 MV88E6XXX_FLAG_PPU | \
461 MV88E6XXX_FLAG_STU | \
462 MV88E6XXX_FLAG_VLANTABLE | \
463 MV88E6XXX_FLAG_VTU)
464
465 #define MV88E6XXX_FLAGS_FAMILY_6165 \
466 (MV88E6XXX_FLAG_STU | \
467 MV88E6XXX_FLAG_SWITCH_MAC | \
468 MV88E6XXX_FLAG_TEMP | \
469 MV88E6XXX_FLAG_VTU)
470
471 #define MV88E6XXX_FLAGS_FAMILY_6185 \
472 (MV88E6XXX_FLAG_ATU | \
473 MV88E6XXX_FLAG_PPU | \
474 MV88E6XXX_FLAG_VLANTABLE | \
475 MV88E6XXX_FLAG_VTU)
476
477 #define MV88E6XXX_FLAGS_FAMILY_6320 \
478 (MV88E6XXX_FLAG_ATU | \
479 MV88E6XXX_FLAG_EEE | \
480 MV88E6XXX_FLAG_EEPROM | \
481 MV88E6XXX_FLAG_PORTSTATE | \
482 MV88E6XXX_FLAG_PPU_ACTIVE | \
483 MV88E6XXX_FLAG_SMI_PHY | \
484 MV88E6XXX_FLAG_SWITCH_MAC | \
485 MV88E6XXX_FLAG_TEMP | \
486 MV88E6XXX_FLAG_TEMP_LIMIT | \
487 MV88E6XXX_FLAG_VLANTABLE | \
488 MV88E6XXX_FLAG_VTU)
489
490 #define MV88E6XXX_FLAGS_FAMILY_6351 \
491 (MV88E6XXX_FLAG_ATU | \
492 MV88E6XXX_FLAG_PORTSTATE | \
493 MV88E6XXX_FLAG_PPU_ACTIVE | \
494 MV88E6XXX_FLAG_SMI_PHY | \
495 MV88E6XXX_FLAG_STU | \
496 MV88E6XXX_FLAG_SWITCH_MAC | \
497 MV88E6XXX_FLAG_TEMP | \
498 MV88E6XXX_FLAG_VLANTABLE | \
499 MV88E6XXX_FLAG_VTU)
500
501 #define MV88E6XXX_FLAGS_FAMILY_6352 \
502 (MV88E6XXX_FLAG_ATU | \
503 MV88E6XXX_FLAG_EEE | \
504 MV88E6XXX_FLAG_EEPROM | \
505 MV88E6XXX_FLAG_PORTSTATE | \
506 MV88E6XXX_FLAG_PPU_ACTIVE | \
507 MV88E6XXX_FLAG_SMI_PHY | \
508 MV88E6XXX_FLAG_STU | \
509 MV88E6XXX_FLAG_SWITCH_MAC | \
510 MV88E6XXX_FLAG_TEMP | \
511 MV88E6XXX_FLAG_TEMP_LIMIT | \
512 MV88E6XXX_FLAG_VLANTABLE | \
513 MV88E6XXX_FLAG_VTU)
514
515 struct mv88e6xxx_info {
516 enum mv88e6xxx_family family;
517 u16 prod_num;
518 const char *name;
519 unsigned int num_databases;
520 unsigned int num_ports;
521 unsigned long flags;
522 };
523
524 struct mv88e6xxx_atu_entry {
525 u16 fid;
526 u8 state;
527 bool trunk;
528 u16 portv_trunkid;
529 u8 mac[ETH_ALEN];
530 };
531
532 struct mv88e6xxx_vtu_stu_entry {
533 /* VTU only */
534 u16 vid;
535 u16 fid;
536
537 /* VTU and STU */
538 u8 sid;
539 bool valid;
540 u8 data[DSA_MAX_PORTS];
541 };
542
543 struct mv88e6xxx_priv_port {
544 struct net_device *bridge_dev;
545 u8 state;
546 };
547
548 struct mv88e6xxx_priv_state {
549 const struct mv88e6xxx_info *info;
550
551 /* The dsa_switch this private structure is related to */
552 struct dsa_switch *ds;
553
554 /* The device this structure is associated to */
555 struct device *dev;
556
557 /* When using multi-chip addressing, this mutex protects
558 * access to the indirect access registers. (In single-chip
559 * mode, this mutex is effectively useless.)
560 */
561 struct mutex smi_mutex;
562
563 /* The MII bus and the address on the bus that is used to
564 * communication with the switch
565 */
566 struct mii_bus *bus;
567 int sw_addr;
568
569 /* Handles automatic disabling and re-enabling of the PHY
570 * polling unit.
571 */
572 struct mutex ppu_mutex;
573 int ppu_disabled;
574 struct work_struct ppu_work;
575 struct timer_list ppu_timer;
576
577 /* This mutex serialises access to the statistics unit.
578 * Hold this mutex over snapshot + dump sequences.
579 */
580 struct mutex stats_mutex;
581
582 /* This mutex serializes phy access for chips with
583 * indirect phy addressing. It is unused for chips
584 * with direct phy access.
585 */
586 struct mutex phy_mutex;
587
588 /* This mutex serializes eeprom access for chips with
589 * eeprom support.
590 */
591 struct mutex eeprom_mutex;
592
593 struct mv88e6xxx_priv_port ports[DSA_MAX_PORTS];
594
595 DECLARE_BITMAP(port_state_update_mask, DSA_MAX_PORTS);
596
597 struct work_struct bridge_work;
598 };
599
600 enum stat_type {
601 BANK0,
602 BANK1,
603 PORT,
604 };
605
606 struct mv88e6xxx_hw_stat {
607 char string[ETH_GSTRING_LEN];
608 int sizeof_stat;
609 int reg;
610 enum stat_type type;
611 };
612
613 static inline bool mv88e6xxx_has(struct mv88e6xxx_priv_state *ps,
614 unsigned long flags)
615 {
616 return (ps->info->flags & flags) == flags;
617 }
618
619 #endif
This page took 0.044259 seconds and 5 git commands to generate.