blob: c7527c0c77ccb9f21e309402d17d41e0f996f006 [file] [log] [blame]
Lennert Buytenhek91da11f2008-10-07 13:44:02 +00001/*
Vivien Didelot0d3cd4b2016-06-21 12:28:19 -04002 * Marvell 88e6xxx common definitions
3 *
Lennert Buytenhek91da11f2008-10-07 13:44:02 +00004 * 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
Vivien Didelot194fea72015-08-10 09:09:47 -040015#include <linux/if_vlan.h>
Andrew Lunndc30c352016-10-16 19:56:49 +020016#include <linux/irq.h>
Andrew Lunn52638f72016-05-10 23:27:22 +020017#include <linux/gpio/consumer.h>
Vivien Didelot194fea72015-08-10 09:09:47 -040018
Andrew Lunn80c46272015-06-20 18:42:30 +020019#ifndef UINT64_MAX
20#define UINT64_MAX (u64)(~((u64)0))
21#endif
22
Andrew Lunncca8b132015-04-02 04:06:39 +020023#define SMI_CMD 0x00
24#define SMI_CMD_BUSY BIT(15)
25#define SMI_CMD_CLAUSE_22 BIT(12)
26#define SMI_CMD_OP_22_WRITE ((1 << 10) | SMI_CMD_BUSY | SMI_CMD_CLAUSE_22)
27#define SMI_CMD_OP_22_READ ((2 << 10) | SMI_CMD_BUSY | SMI_CMD_CLAUSE_22)
28#define SMI_CMD_OP_45_WRITE_ADDR ((0 << 10) | SMI_CMD_BUSY)
29#define SMI_CMD_OP_45_WRITE_DATA ((1 << 10) | SMI_CMD_BUSY)
30#define SMI_CMD_OP_45_READ_DATA ((2 << 10) | SMI_CMD_BUSY)
31#define SMI_CMD_OP_45_READ_DATA_INC ((3 << 10) | SMI_CMD_BUSY)
32#define SMI_DATA 0x01
Guenter Roeckb2eb0662015-04-02 04:06:30 +020033
Vivien Didelot09cb7df2016-08-15 17:19:01 -040034/* PHY Registers */
35#define PHY_PAGE 0x16
36#define PHY_PAGE_COPPER 0x00
37
38#define ADDR_SERDES 0x0f
39#define SERDES_PAGE_FIBER 0x01
Patrick Uiterwijk13a7ebb2016-03-30 01:39:41 +000040
Andrew Lunncca8b132015-04-02 04:06:39 +020041#define PORT_STATUS 0x00
42#define PORT_STATUS_PAUSE_EN BIT(15)
43#define PORT_STATUS_MY_PAUSE BIT(14)
44#define PORT_STATUS_HD_FLOW BIT(13)
45#define PORT_STATUS_PHY_DETECT BIT(12)
46#define PORT_STATUS_LINK BIT(11)
47#define PORT_STATUS_DUPLEX BIT(10)
48#define PORT_STATUS_SPEED_MASK 0x0300
49#define PORT_STATUS_SPEED_10 0x0000
50#define PORT_STATUS_SPEED_100 0x0100
51#define PORT_STATUS_SPEED_1000 0x0200
52#define PORT_STATUS_EEE BIT(6) /* 6352 */
53#define PORT_STATUS_AM_DIS BIT(6) /* 6165 */
54#define PORT_STATUS_MGMII BIT(6) /* 6185 */
55#define PORT_STATUS_TX_PAUSED BIT(5)
56#define PORT_STATUS_FLOW_CTRL BIT(4)
Patrick Uiterwijk13a7ebb2016-03-30 01:39:41 +000057#define PORT_STATUS_CMODE_MASK 0x0f
58#define PORT_STATUS_CMODE_100BASE_X 0x8
59#define PORT_STATUS_CMODE_1000BASE_X 0x9
60#define PORT_STATUS_CMODE_SGMII 0xa
Andrew Lunncca8b132015-04-02 04:06:39 +020061#define PORT_PCS_CTRL 0x01
Andrew Lunne7e72ac2015-08-31 15:56:51 +020062#define PORT_PCS_CTRL_RGMII_DELAY_RXCLK BIT(15)
63#define PORT_PCS_CTRL_RGMII_DELAY_TXCLK BIT(14)
Andrew Lunn54d792f2015-05-06 01:09:47 +020064#define PORT_PCS_CTRL_FC BIT(7)
65#define PORT_PCS_CTRL_FORCE_FC BIT(6)
66#define PORT_PCS_CTRL_LINK_UP BIT(5)
67#define PORT_PCS_CTRL_FORCE_LINK BIT(4)
68#define PORT_PCS_CTRL_DUPLEX_FULL BIT(3)
69#define PORT_PCS_CTRL_FORCE_DUPLEX BIT(2)
70#define PORT_PCS_CTRL_10 0x00
71#define PORT_PCS_CTRL_100 0x01
72#define PORT_PCS_CTRL_1000 0x02
73#define PORT_PCS_CTRL_UNFORCED 0x03
74#define PORT_PAUSE_CTRL 0x02
Andrew Lunncca8b132015-04-02 04:06:39 +020075#define PORT_SWITCH_ID 0x03
Vivien Didelotf6271e62016-04-17 13:23:59 -040076#define PORT_SWITCH_ID_PROD_NUM_6085 0x04a
77#define PORT_SWITCH_ID_PROD_NUM_6095 0x095
78#define PORT_SWITCH_ID_PROD_NUM_6131 0x106
79#define PORT_SWITCH_ID_PROD_NUM_6320 0x115
80#define PORT_SWITCH_ID_PROD_NUM_6123 0x121
81#define PORT_SWITCH_ID_PROD_NUM_6161 0x161
82#define PORT_SWITCH_ID_PROD_NUM_6165 0x165
83#define PORT_SWITCH_ID_PROD_NUM_6171 0x171
84#define PORT_SWITCH_ID_PROD_NUM_6172 0x172
85#define PORT_SWITCH_ID_PROD_NUM_6175 0x175
86#define PORT_SWITCH_ID_PROD_NUM_6176 0x176
87#define PORT_SWITCH_ID_PROD_NUM_6185 0x1a7
88#define PORT_SWITCH_ID_PROD_NUM_6240 0x240
89#define PORT_SWITCH_ID_PROD_NUM_6321 0x310
90#define PORT_SWITCH_ID_PROD_NUM_6352 0x352
91#define PORT_SWITCH_ID_PROD_NUM_6350 0x371
92#define PORT_SWITCH_ID_PROD_NUM_6351 0x375
Andrew Lunncca8b132015-04-02 04:06:39 +020093#define PORT_CONTROL 0x04
Andrew Lunn54d792f2015-05-06 01:09:47 +020094#define PORT_CONTROL_USE_CORE_TAG BIT(15)
95#define PORT_CONTROL_DROP_ON_LOCK BIT(14)
96#define PORT_CONTROL_EGRESS_UNMODIFIED (0x0 << 12)
97#define PORT_CONTROL_EGRESS_UNTAGGED (0x1 << 12)
98#define PORT_CONTROL_EGRESS_TAGGED (0x2 << 12)
99#define PORT_CONTROL_EGRESS_ADD_TAG (0x3 << 12)
100#define PORT_CONTROL_HEADER BIT(11)
101#define PORT_CONTROL_IGMP_MLD_SNOOP BIT(10)
102#define PORT_CONTROL_DOUBLE_TAG BIT(9)
103#define PORT_CONTROL_FRAME_MODE_NORMAL (0x0 << 8)
104#define PORT_CONTROL_FRAME_MODE_DSA (0x1 << 8)
105#define PORT_CONTROL_FRAME_MODE_PROVIDER (0x2 << 8)
106#define PORT_CONTROL_FRAME_ETHER_TYPE_DSA (0x3 << 8)
107#define PORT_CONTROL_DSA_TAG BIT(8)
108#define PORT_CONTROL_VLAN_TUNNEL BIT(7)
109#define PORT_CONTROL_TAG_IF_BOTH BIT(6)
110#define PORT_CONTROL_USE_IP BIT(5)
111#define PORT_CONTROL_USE_TAG BIT(4)
112#define PORT_CONTROL_FORWARD_UNKNOWN_MC BIT(3)
113#define PORT_CONTROL_FORWARD_UNKNOWN BIT(2)
Andrew Lunncca8b132015-04-02 04:06:39 +0200114#define PORT_CONTROL_STATE_MASK 0x03
115#define PORT_CONTROL_STATE_DISABLED 0x00
116#define PORT_CONTROL_STATE_BLOCKING 0x01
117#define PORT_CONTROL_STATE_LEARNING 0x02
118#define PORT_CONTROL_STATE_FORWARDING 0x03
119#define PORT_CONTROL_1 0x05
Vivien Didelot2db9ce12016-02-26 13:16:04 -0500120#define PORT_CONTROL_1_FID_11_4_MASK (0xff << 0)
Andrew Lunncca8b132015-04-02 04:06:39 +0200121#define PORT_BASE_VLAN 0x06
Vivien Didelot2db9ce12016-02-26 13:16:04 -0500122#define PORT_BASE_VLAN_FID_3_0_MASK (0xf << 12)
Andrew Lunncca8b132015-04-02 04:06:39 +0200123#define PORT_DEFAULT_VLAN 0x07
Vivien Didelotb8fee952015-08-13 12:52:19 -0400124#define PORT_DEFAULT_VLAN_MASK 0xfff
Andrew Lunncca8b132015-04-02 04:06:39 +0200125#define PORT_CONTROL_2 0x08
Andrew Lunn54d792f2015-05-06 01:09:47 +0200126#define PORT_CONTROL_2_IGNORE_FCS BIT(15)
127#define PORT_CONTROL_2_VTU_PRI_OVERRIDE BIT(14)
128#define PORT_CONTROL_2_SA_PRIO_OVERRIDE BIT(13)
129#define PORT_CONTROL_2_DA_PRIO_OVERRIDE BIT(12)
130#define PORT_CONTROL_2_JUMBO_1522 (0x00 << 12)
131#define PORT_CONTROL_2_JUMBO_2048 (0x01 << 12)
132#define PORT_CONTROL_2_JUMBO_10240 (0x02 << 12)
Vivien Didelot8efdda42015-08-13 12:52:23 -0400133#define PORT_CONTROL_2_8021Q_MASK (0x03 << 10)
134#define PORT_CONTROL_2_8021Q_DISABLED (0x00 << 10)
135#define PORT_CONTROL_2_8021Q_FALLBACK (0x01 << 10)
136#define PORT_CONTROL_2_8021Q_CHECK (0x02 << 10)
137#define PORT_CONTROL_2_8021Q_SECURE (0x03 << 10)
Andrew Lunn54d792f2015-05-06 01:09:47 +0200138#define PORT_CONTROL_2_DISCARD_TAGGED BIT(9)
139#define PORT_CONTROL_2_DISCARD_UNTAGGED BIT(8)
140#define PORT_CONTROL_2_MAP_DA BIT(7)
141#define PORT_CONTROL_2_DEFAULT_FORWARD BIT(6)
142#define PORT_CONTROL_2_FORWARD_UNKNOWN BIT(6)
143#define PORT_CONTROL_2_EGRESS_MONITOR BIT(5)
144#define PORT_CONTROL_2_INGRESS_MONITOR BIT(4)
Andrew Lunncca8b132015-04-02 04:06:39 +0200145#define PORT_RATE_CONTROL 0x09
146#define PORT_RATE_CONTROL_2 0x0a
147#define PORT_ASSOC_VECTOR 0x0b
Andrew Lunn4c7ea3c2015-11-03 10:52:36 -0500148#define PORT_ASSOC_VECTOR_HOLD_AT_1 BIT(15)
149#define PORT_ASSOC_VECTOR_INT_AGE_OUT BIT(14)
150#define PORT_ASSOC_VECTOR_LOCKED_PORT BIT(13)
151#define PORT_ASSOC_VECTOR_IGNORE_WRONG BIT(12)
152#define PORT_ASSOC_VECTOR_REFRESH_LOCKED BIT(11)
Andrew Lunn54d792f2015-05-06 01:09:47 +0200153#define PORT_ATU_CONTROL 0x0c
154#define PORT_PRI_OVERRIDE 0x0d
155#define PORT_ETH_TYPE 0x0f
Andrew Lunncca8b132015-04-02 04:06:39 +0200156#define PORT_IN_DISCARD_LO 0x10
157#define PORT_IN_DISCARD_HI 0x11
158#define PORT_IN_FILTERED 0x12
159#define PORT_OUT_FILTERED 0x13
Andrew Lunn54d792f2015-05-06 01:09:47 +0200160#define PORT_TAG_REGMAP_0123 0x18
161#define PORT_TAG_REGMAP_4567 0x19
Andrew Lunncca8b132015-04-02 04:06:39 +0200162
Andrew Lunncca8b132015-04-02 04:06:39 +0200163#define GLOBAL_STATUS 0x00
164#define GLOBAL_STATUS_PPU_STATE BIT(15) /* 6351 and 6171 */
165/* Two bits for 6165, 6185 etc */
166#define GLOBAL_STATUS_PPU_MASK (0x3 << 14)
167#define GLOBAL_STATUS_PPU_DISABLED_RST (0x0 << 14)
168#define GLOBAL_STATUS_PPU_INITIALIZING (0x1 << 14)
169#define GLOBAL_STATUS_PPU_DISABLED (0x2 << 14)
170#define GLOBAL_STATUS_PPU_POLLING (0x3 << 14)
Andrew Lunndc30c352016-10-16 19:56:49 +0200171#define GLOBAL_STATUS_IRQ_AVB 8
172#define GLOBAL_STATUS_IRQ_DEVICE 7
173#define GLOBAL_STATUS_IRQ_STATS 6
174#define GLOBAL_STATUS_IRQ_VTU_PROBLEM 5
175#define GLOBAL_STATUS_IRQ_VTU_DONE 4
176#define GLOBAL_STATUS_IRQ_ATU_PROBLEM 3
177#define GLOBAL_STATUS_IRQ_ATU_DONE 2
178#define GLOBAL_STATUS_IRQ_TCAM_DONE 1
179#define GLOBAL_STATUS_IRQ_EEPROM_DONE 0
Andrew Lunncca8b132015-04-02 04:06:39 +0200180#define GLOBAL_MAC_01 0x01
181#define GLOBAL_MAC_23 0x02
182#define GLOBAL_MAC_45 0x03
Vivien Didelot6dc10bb2016-09-29 12:21:55 -0400183#define GLOBAL_ATU_FID 0x01
184#define GLOBAL_VTU_FID 0x02
Vivien Didelotb8fee952015-08-13 12:52:19 -0400185#define GLOBAL_VTU_FID_MASK 0xfff
186#define GLOBAL_VTU_SID 0x03 /* 6097 6165 6351 6352 */
187#define GLOBAL_VTU_SID_MASK 0x3f
Andrew Lunncca8b132015-04-02 04:06:39 +0200188#define GLOBAL_CONTROL 0x04
189#define GLOBAL_CONTROL_SW_RESET BIT(15)
190#define GLOBAL_CONTROL_PPU_ENABLE BIT(14)
191#define GLOBAL_CONTROL_DISCARD_EXCESS BIT(13) /* 6352 */
192#define GLOBAL_CONTROL_SCHED_PRIO BIT(11) /* 6152 */
193#define GLOBAL_CONTROL_MAX_FRAME_1632 BIT(10) /* 6152 */
Andrew Lunn54d792f2015-05-06 01:09:47 +0200194#define GLOBAL_CONTROL_RELOAD_EEPROM BIT(9) /* 6152 */
Andrew Lunncca8b132015-04-02 04:06:39 +0200195#define GLOBAL_CONTROL_DEVICE_EN BIT(7)
196#define GLOBAL_CONTROL_STATS_DONE_EN BIT(6)
197#define GLOBAL_CONTROL_VTU_PROBLEM_EN BIT(5)
198#define GLOBAL_CONTROL_VTU_DONE_EN BIT(4)
199#define GLOBAL_CONTROL_ATU_PROBLEM_EN BIT(3)
200#define GLOBAL_CONTROL_ATU_DONE_EN BIT(2)
201#define GLOBAL_CONTROL_TCAM_EN BIT(1)
202#define GLOBAL_CONTROL_EEPROM_DONE_EN BIT(0)
203#define GLOBAL_VTU_OP 0x05
Vivien Didelot6b17e862015-08-13 12:52:18 -0400204#define GLOBAL_VTU_OP_BUSY BIT(15)
205#define GLOBAL_VTU_OP_FLUSH_ALL ((0x01 << 12) | GLOBAL_VTU_OP_BUSY)
Vivien Didelot7dad08d2015-08-13 12:52:21 -0400206#define GLOBAL_VTU_OP_VTU_LOAD_PURGE ((0x03 << 12) | GLOBAL_VTU_OP_BUSY)
Vivien Didelotb8fee952015-08-13 12:52:19 -0400207#define GLOBAL_VTU_OP_VTU_GET_NEXT ((0x04 << 12) | GLOBAL_VTU_OP_BUSY)
Vivien Didelot0d3b33e2015-08-13 12:52:22 -0400208#define GLOBAL_VTU_OP_STU_LOAD_PURGE ((0x05 << 12) | GLOBAL_VTU_OP_BUSY)
209#define GLOBAL_VTU_OP_STU_GET_NEXT ((0x06 << 12) | GLOBAL_VTU_OP_BUSY)
Andrew Lunncca8b132015-04-02 04:06:39 +0200210#define GLOBAL_VTU_VID 0x06
Vivien Didelotb8fee952015-08-13 12:52:19 -0400211#define GLOBAL_VTU_VID_MASK 0xfff
212#define GLOBAL_VTU_VID_VALID BIT(12)
Andrew Lunncca8b132015-04-02 04:06:39 +0200213#define GLOBAL_VTU_DATA_0_3 0x07
214#define GLOBAL_VTU_DATA_4_7 0x08
215#define GLOBAL_VTU_DATA_8_11 0x09
Vivien Didelotb8fee952015-08-13 12:52:19 -0400216#define GLOBAL_VTU_STU_DATA_MASK 0x03
217#define GLOBAL_VTU_DATA_MEMBER_TAG_UNMODIFIED 0x00
218#define GLOBAL_VTU_DATA_MEMBER_TAG_UNTAGGED 0x01
219#define GLOBAL_VTU_DATA_MEMBER_TAG_TAGGED 0x02
220#define GLOBAL_VTU_DATA_MEMBER_TAG_NON_MEMBER 0x03
Vivien Didelot0d3b33e2015-08-13 12:52:22 -0400221#define GLOBAL_STU_DATA_PORT_STATE_DISABLED 0x00
222#define GLOBAL_STU_DATA_PORT_STATE_BLOCKING 0x01
223#define GLOBAL_STU_DATA_PORT_STATE_LEARNING 0x02
224#define GLOBAL_STU_DATA_PORT_STATE_FORWARDING 0x03
Andrew Lunncca8b132015-04-02 04:06:39 +0200225#define GLOBAL_ATU_CONTROL 0x0a
Andrew Lunn54d792f2015-05-06 01:09:47 +0200226#define GLOBAL_ATU_CONTROL_LEARN2ALL BIT(3)
Andrew Lunncca8b132015-04-02 04:06:39 +0200227#define GLOBAL_ATU_OP 0x0b
228#define GLOBAL_ATU_OP_BUSY BIT(15)
229#define GLOBAL_ATU_OP_NOP (0 << 12)
Vivien Didelot7fb5e752015-09-04 14:34:12 -0400230#define GLOBAL_ATU_OP_FLUSH_MOVE_ALL ((1 << 12) | GLOBAL_ATU_OP_BUSY)
231#define GLOBAL_ATU_OP_FLUSH_MOVE_NON_STATIC ((2 << 12) | GLOBAL_ATU_OP_BUSY)
Andrew Lunncca8b132015-04-02 04:06:39 +0200232#define GLOBAL_ATU_OP_LOAD_DB ((3 << 12) | GLOBAL_ATU_OP_BUSY)
233#define GLOBAL_ATU_OP_GET_NEXT_DB ((4 << 12) | GLOBAL_ATU_OP_BUSY)
Vivien Didelot7fb5e752015-09-04 14:34:12 -0400234#define GLOBAL_ATU_OP_FLUSH_MOVE_ALL_DB ((5 << 12) | GLOBAL_ATU_OP_BUSY)
235#define GLOBAL_ATU_OP_FLUSH_MOVE_NON_STATIC_DB ((6 << 12) | GLOBAL_ATU_OP_BUSY)
Andrew Lunncca8b132015-04-02 04:06:39 +0200236#define GLOBAL_ATU_OP_GET_CLR_VIOLATION ((7 << 12) | GLOBAL_ATU_OP_BUSY)
237#define GLOBAL_ATU_DATA 0x0c
Andrew Lunn8a0a2652015-06-20 18:42:29 +0200238#define GLOBAL_ATU_DATA_TRUNK BIT(15)
Vivien Didelotfd231c82015-08-10 09:09:50 -0400239#define GLOBAL_ATU_DATA_TRUNK_ID_MASK 0x00f0
240#define GLOBAL_ATU_DATA_TRUNK_ID_SHIFT 4
Andrew Lunn8a0a2652015-06-20 18:42:29 +0200241#define GLOBAL_ATU_DATA_PORT_VECTOR_MASK 0x3ff0
242#define GLOBAL_ATU_DATA_PORT_VECTOR_SHIFT 4
Andrew Lunncca8b132015-04-02 04:06:39 +0200243#define GLOBAL_ATU_DATA_STATE_MASK 0x0f
244#define GLOBAL_ATU_DATA_STATE_UNUSED 0x00
245#define GLOBAL_ATU_DATA_STATE_UC_MGMT 0x0d
246#define GLOBAL_ATU_DATA_STATE_UC_STATIC 0x0e
247#define GLOBAL_ATU_DATA_STATE_UC_PRIO_OVER 0x0f
248#define GLOBAL_ATU_DATA_STATE_MC_NONE_RATE 0x05
249#define GLOBAL_ATU_DATA_STATE_MC_STATIC 0x07
250#define GLOBAL_ATU_DATA_STATE_MC_MGMT 0x0e
251#define GLOBAL_ATU_DATA_STATE_MC_PRIO_OVER 0x0f
252#define GLOBAL_ATU_MAC_01 0x0d
253#define GLOBAL_ATU_MAC_23 0x0e
254#define GLOBAL_ATU_MAC_45 0x0f
255#define GLOBAL_IP_PRI_0 0x10
256#define GLOBAL_IP_PRI_1 0x11
257#define GLOBAL_IP_PRI_2 0x12
258#define GLOBAL_IP_PRI_3 0x13
259#define GLOBAL_IP_PRI_4 0x14
260#define GLOBAL_IP_PRI_5 0x15
261#define GLOBAL_IP_PRI_6 0x16
262#define GLOBAL_IP_PRI_7 0x17
263#define GLOBAL_IEEE_PRI 0x18
264#define GLOBAL_CORE_TAG_TYPE 0x19
265#define GLOBAL_MONITOR_CONTROL 0x1a
Andrew Lunn15966a22015-05-06 01:09:49 +0200266#define GLOBAL_MONITOR_CONTROL_INGRESS_SHIFT 12
267#define GLOBAL_MONITOR_CONTROL_EGRESS_SHIFT 8
268#define GLOBAL_MONITOR_CONTROL_ARP_SHIFT 4
269#define GLOBAL_MONITOR_CONTROL_MIRROR_SHIFT 0
270#define GLOBAL_MONITOR_CONTROL_ARP_DISABLED (0xf0)
Andrew Lunncca8b132015-04-02 04:06:39 +0200271#define GLOBAL_CONTROL_2 0x1c
Andrew Lunn15966a22015-05-06 01:09:49 +0200272#define GLOBAL_CONTROL_2_NO_CASCADE 0xe000
273#define GLOBAL_CONTROL_2_MULTIPLE_CASCADE 0xf000
274
Andrew Lunncca8b132015-04-02 04:06:39 +0200275#define GLOBAL_STATS_OP 0x1d
276#define GLOBAL_STATS_OP_BUSY BIT(15)
277#define GLOBAL_STATS_OP_NOP (0 << 12)
278#define GLOBAL_STATS_OP_FLUSH_ALL ((1 << 12) | GLOBAL_STATS_OP_BUSY)
279#define GLOBAL_STATS_OP_FLUSH_PORT ((2 << 12) | GLOBAL_STATS_OP_BUSY)
280#define GLOBAL_STATS_OP_READ_CAPTURED ((4 << 12) | GLOBAL_STATS_OP_BUSY)
281#define GLOBAL_STATS_OP_CAPTURE_PORT ((5 << 12) | GLOBAL_STATS_OP_BUSY)
282#define GLOBAL_STATS_OP_HIST_RX ((1 << 10) | GLOBAL_STATS_OP_BUSY)
283#define GLOBAL_STATS_OP_HIST_TX ((2 << 10) | GLOBAL_STATS_OP_BUSY)
284#define GLOBAL_STATS_OP_HIST_RX_TX ((3 << 10) | GLOBAL_STATS_OP_BUSY)
Andrew Lunnf5e2ed02015-12-23 13:23:17 +0100285#define GLOBAL_STATS_OP_BANK_1 BIT(9)
Andrew Lunncca8b132015-04-02 04:06:39 +0200286#define GLOBAL_STATS_COUNTER_32 0x1e
287#define GLOBAL_STATS_COUNTER_01 0x1f
288
Andrew Lunncca8b132015-04-02 04:06:39 +0200289#define GLOBAL2_INT_SOURCE 0x00
290#define GLOBAL2_INT_MASK 0x01
291#define GLOBAL2_MGMT_EN_2X 0x02
292#define GLOBAL2_MGMT_EN_0X 0x03
293#define GLOBAL2_FLOW_CONTROL 0x04
294#define GLOBAL2_SWITCH_MGMT 0x05
Andrew Lunn54d792f2015-05-06 01:09:47 +0200295#define GLOBAL2_SWITCH_MGMT_USE_DOUBLE_TAG_DATA BIT(15)
296#define GLOBAL2_SWITCH_MGMT_PREVENT_LOOPS BIT(14)
297#define GLOBAL2_SWITCH_MGMT_FLOW_CONTROL_MSG BIT(13)
298#define GLOBAL2_SWITCH_MGMT_FORCE_FLOW_CTRL_PRI BIT(7)
299#define GLOBAL2_SWITCH_MGMT_RSVD2CPU BIT(3)
Andrew Lunncca8b132015-04-02 04:06:39 +0200300#define GLOBAL2_DEVICE_MAPPING 0x06
Andrew Lunn54d792f2015-05-06 01:09:47 +0200301#define GLOBAL2_DEVICE_MAPPING_UPDATE BIT(15)
302#define GLOBAL2_DEVICE_MAPPING_TARGET_SHIFT 8
Andrew Lunnd35bd872015-06-20 18:42:32 +0200303#define GLOBAL2_DEVICE_MAPPING_PORT_MASK 0x0f
Andrew Lunncca8b132015-04-02 04:06:39 +0200304#define GLOBAL2_TRUNK_MASK 0x07
Andrew Lunn54d792f2015-05-06 01:09:47 +0200305#define GLOBAL2_TRUNK_MASK_UPDATE BIT(15)
306#define GLOBAL2_TRUNK_MASK_NUM_SHIFT 12
Vivien Didelot51540412016-07-18 20:45:32 -0400307#define GLOBAL2_TRUNK_MASK_HASK BIT(11)
Andrew Lunncca8b132015-04-02 04:06:39 +0200308#define GLOBAL2_TRUNK_MAPPING 0x08
Andrew Lunn54d792f2015-05-06 01:09:47 +0200309#define GLOBAL2_TRUNK_MAPPING_UPDATE BIT(15)
310#define GLOBAL2_TRUNK_MAPPING_ID_SHIFT 11
Vivien Didelot8ec61c72016-07-18 20:45:37 -0400311#define GLOBAL2_IRL_CMD 0x09
312#define GLOBAL2_IRL_CMD_BUSY BIT(15)
313#define GLOBAL2_IRL_CMD_OP_INIT_ALL ((0x001 << 12) | GLOBAL2_IRL_CMD_BUSY)
314#define GLOBAL2_IRL_CMD_OP_INIT_SEL ((0x010 << 12) | GLOBAL2_IRL_CMD_BUSY)
315#define GLOBAL2_IRL_CMD_OP_WRITE_SEL ((0x011 << 12) | GLOBAL2_IRL_CMD_BUSY)
316#define GLOBAL2_IRL_CMD_OP_READ_SEL ((0x100 << 12) | GLOBAL2_IRL_CMD_BUSY)
317#define GLOBAL2_IRL_DATA 0x0a
Andrew Lunncca8b132015-04-02 04:06:39 +0200318#define GLOBAL2_PVT_ADDR 0x0b
Vivien Didelot63ed8802016-07-18 20:45:35 -0400319#define GLOBAL2_PVT_ADDR_BUSY BIT(15)
320#define GLOBAL2_PVT_ADDR_OP_INIT_ONES ((0x01 << 12) | GLOBAL2_PVT_ADDR_BUSY)
321#define GLOBAL2_PVT_ADDR_OP_WRITE_PVLAN ((0x03 << 12) | GLOBAL2_PVT_ADDR_BUSY)
322#define GLOBAL2_PVT_ADDR_OP_READ ((0x04 << 12) | GLOBAL2_PVT_ADDR_BUSY)
Andrew Lunncca8b132015-04-02 04:06:39 +0200323#define GLOBAL2_PVT_DATA 0x0c
324#define GLOBAL2_SWITCH_MAC 0x0d
Andrew Lunncca8b132015-04-02 04:06:39 +0200325#define GLOBAL2_ATU_STATS 0x0e
326#define GLOBAL2_PRIO_OVERRIDE 0x0f
Andrew Lunn15966a22015-05-06 01:09:49 +0200327#define GLOBAL2_PRIO_OVERRIDE_FORCE_SNOOP BIT(7)
328#define GLOBAL2_PRIO_OVERRIDE_SNOOP_SHIFT 4
329#define GLOBAL2_PRIO_OVERRIDE_FORCE_ARP BIT(3)
330#define GLOBAL2_PRIO_OVERRIDE_ARP_SHIFT 0
Vivien Didelot855b1932016-07-20 18:18:35 -0400331#define GLOBAL2_EEPROM_CMD 0x14
332#define GLOBAL2_EEPROM_CMD_BUSY BIT(15)
333#define GLOBAL2_EEPROM_CMD_OP_WRITE ((0x3 << 12) | GLOBAL2_EEPROM_CMD_BUSY)
334#define GLOBAL2_EEPROM_CMD_OP_READ ((0x4 << 12) | GLOBAL2_EEPROM_CMD_BUSY)
335#define GLOBAL2_EEPROM_CMD_OP_LOAD ((0x6 << 12) | GLOBAL2_EEPROM_CMD_BUSY)
336#define GLOBAL2_EEPROM_CMD_RUNNING BIT(11)
337#define GLOBAL2_EEPROM_CMD_WRITE_EN BIT(10)
338#define GLOBAL2_EEPROM_CMD_ADDR_MASK 0xff
Andrew Lunncca8b132015-04-02 04:06:39 +0200339#define GLOBAL2_EEPROM_DATA 0x15
340#define GLOBAL2_PTP_AVB_OP 0x16
341#define GLOBAL2_PTP_AVB_DATA 0x17
Vivien Didelot57c67cf2016-08-15 17:18:59 -0400342#define GLOBAL2_SMI_PHY_CMD 0x18
343#define GLOBAL2_SMI_PHY_CMD_BUSY BIT(15)
344#define GLOBAL2_SMI_PHY_CMD_MODE_22 BIT(12)
345#define GLOBAL2_SMI_PHY_CMD_OP_22_WRITE_DATA ((0x1 << 10) | \
346 GLOBAL2_SMI_PHY_CMD_MODE_22 | \
347 GLOBAL2_SMI_PHY_CMD_BUSY)
348#define GLOBAL2_SMI_PHY_CMD_OP_22_READ_DATA ((0x2 << 10) | \
349 GLOBAL2_SMI_PHY_CMD_MODE_22 | \
350 GLOBAL2_SMI_PHY_CMD_BUSY)
351#define GLOBAL2_SMI_PHY_DATA 0x19
Andrew Lunncca8b132015-04-02 04:06:39 +0200352#define GLOBAL2_SCRATCH_MISC 0x1a
Andrew Lunn56d95e22015-06-20 18:42:33 +0200353#define GLOBAL2_SCRATCH_BUSY BIT(15)
354#define GLOBAL2_SCRATCH_REGISTER_SHIFT 8
355#define GLOBAL2_SCRATCH_VALUE_MASK 0xff
Andrew Lunncca8b132015-04-02 04:06:39 +0200356#define GLOBAL2_WDOG_CONTROL 0x1b
357#define GLOBAL2_QOS_WEIGHT 0x1c
358#define GLOBAL2_MISC 0x1d
Guenter Roeckdefb05b2015-03-26 18:36:38 -0700359
Vivien Didelot3285f9e2016-02-26 13:16:03 -0500360#define MV88E6XXX_N_FID 4096
361
Vivien Didelotf81ec902016-05-09 13:22:58 -0400362/* List of supported models */
363enum mv88e6xxx_model {
364 MV88E6085,
365 MV88E6095,
366 MV88E6123,
367 MV88E6131,
368 MV88E6161,
369 MV88E6165,
370 MV88E6171,
371 MV88E6172,
372 MV88E6175,
373 MV88E6176,
374 MV88E6185,
375 MV88E6240,
376 MV88E6320,
377 MV88E6321,
378 MV88E6350,
379 MV88E6351,
380 MV88E6352,
381};
382
Vivien Didelot22356472016-04-17 13:24:00 -0400383enum mv88e6xxx_family {
384 MV88E6XXX_FAMILY_NONE,
385 MV88E6XXX_FAMILY_6065, /* 6031 6035 6061 6065 */
386 MV88E6XXX_FAMILY_6095, /* 6092 6095 */
387 MV88E6XXX_FAMILY_6097, /* 6046 6085 6096 6097 */
388 MV88E6XXX_FAMILY_6165, /* 6123 6161 6165 */
389 MV88E6XXX_FAMILY_6185, /* 6108 6121 6122 6131 6152 6155 6182 6185 */
390 MV88E6XXX_FAMILY_6320, /* 6320 6321 */
391 MV88E6XXX_FAMILY_6351, /* 6171 6175 6350 6351 */
392 MV88E6XXX_FAMILY_6352, /* 6172 6176 6240 6352 */
393};
394
Vivien Didelot8c9983a2016-05-09 13:22:39 -0400395enum mv88e6xxx_cap {
Andrew Lunn2bbb33b2016-08-22 16:01:02 +0200396 /* Two different tag protocols can be used by the driver. All
397 * switches support DSA, but only later generations support
398 * EDSA.
399 */
400 MV88E6XXX_CAP_EDSA,
401
Vivien Didelotaadbdb82016-05-09 13:22:44 -0400402 /* Energy Efficient Ethernet.
403 */
404 MV88E6XXX_CAP_EEE,
405
Vivien Didelota0ffff22016-08-15 17:18:58 -0400406 /* Multi-chip Addressing Mode.
407 * Some chips respond to only 2 registers of its own SMI device address
408 * when it is non-zero, and use indirect access to internal registers.
409 */
410 MV88E6XXX_CAP_SMI_CMD, /* (0x00) SMI Command */
411 MV88E6XXX_CAP_SMI_DATA, /* (0x01) SMI Data */
412
Vivien Didelot09cb7df2016-08-15 17:19:01 -0400413 /* PHY Registers.
414 */
415 MV88E6XXX_CAP_PHY_PAGE, /* (0x16) Page Register */
416
417 /* Fiber/SERDES Registers (SMI address F).
418 */
419 MV88E6XXX_CAP_SERDES,
420
Vivien Didelot6dc10bb2016-09-29 12:21:55 -0400421 /* Switch Global (1) Registers.
422 */
423 MV88E6XXX_CAP_G1_ATU_FID, /* (0x01) ATU FID Register */
424 MV88E6XXX_CAP_G1_VTU_FID, /* (0x02) VTU FID Register */
425
Vivien Didelot97299342016-07-18 20:45:30 -0400426 /* Switch Global 2 Registers.
427 * The device contains a second set of global 16-bit registers.
428 */
429 MV88E6XXX_CAP_GLOBAL2,
Andrew Lunndc30c352016-10-16 19:56:49 +0200430 MV88E6XXX_CAP_G2_INT, /* (0x00) Interrupt Status */
Vivien Didelot47395ed2016-07-18 20:45:33 -0400431 MV88E6XXX_CAP_G2_MGMT_EN_2X, /* (0x02) MGMT Enable Register 2x */
432 MV88E6XXX_CAP_G2_MGMT_EN_0X, /* (0x03) MGMT Enable Register 0x */
Vivien Didelot8ec61c72016-07-18 20:45:37 -0400433 MV88E6XXX_CAP_G2_IRL_CMD, /* (0x09) Ingress Rate Command */
434 MV88E6XXX_CAP_G2_IRL_DATA, /* (0x0a) Ingress Rate Data */
Vivien Didelot63ed8802016-07-18 20:45:35 -0400435 MV88E6XXX_CAP_G2_PVT_ADDR, /* (0x0b) Cross Chip Port VLAN Addr */
436 MV88E6XXX_CAP_G2_PVT_DATA, /* (0x0c) Cross Chip Port VLAN Data */
Vivien Didelot9bda8892016-07-18 20:45:36 -0400437 MV88E6XXX_CAP_G2_POT, /* (0x0f) Priority Override Table */
Vivien Didelot97299342016-07-18 20:45:30 -0400438
Vivien Didelot8c9983a2016-05-09 13:22:39 -0400439 /* PHY Polling Unit.
440 * See GLOBAL_CONTROL_PPU_ENABLE and GLOBAL_STATUS_PPU_POLLING.
441 */
442 MV88E6XXX_CAP_PPU,
Vivien Didelot552238b2016-05-09 13:22:49 -0400443 MV88E6XXX_CAP_PPU_ACTIVE,
Vivien Didelot6d5834a2016-05-09 13:22:40 -0400444
Vivien Didelotcb9b9022016-05-10 15:44:29 -0400445 /* Per VLAN Spanning Tree Unit (STU).
446 * The Port State database, if present, is accessed through VTU
447 * operations and dedicated SID registers. See GLOBAL_VTU_SID.
448 */
449 MV88E6XXX_CAP_STU,
450
Vivien Didelot6594f612016-05-09 13:22:42 -0400451 /* Internal temperature sensor.
452 * Available from any enabled port's PHY register 26, page 6.
453 */
454 MV88E6XXX_CAP_TEMP,
455 MV88E6XXX_CAP_TEMP_LIMIT,
Vivien Didelot936f2342016-05-09 13:22:46 -0400456
Vivien Didelot54d77b52016-05-09 13:22:47 -0400457 /* VLAN Table Unit.
458 * The VTU is used to program 802.1Q VLANs. See GLOBAL_VTU_OP.
459 */
460 MV88E6XXX_CAP_VTU,
Vivien Didelot8c9983a2016-05-09 13:22:39 -0400461};
Vivien Didelotb5058d72016-05-09 13:22:38 -0400462
Vivien Didelot8c9983a2016-05-09 13:22:39 -0400463/* Bitmask of capabilities */
Andrew Lunnd6b10232016-09-21 01:40:32 +0200464#define MV88E6XXX_FLAG_EDSA BIT_ULL(MV88E6XXX_CAP_EDSA)
465#define MV88E6XXX_FLAG_EEE BIT_ULL(MV88E6XXX_CAP_EEE)
Vivien Didelota0ffff22016-08-15 17:18:58 -0400466
Andrew Lunnd6b10232016-09-21 01:40:32 +0200467#define MV88E6XXX_FLAG_SMI_CMD BIT_ULL(MV88E6XXX_CAP_SMI_CMD)
468#define MV88E6XXX_FLAG_SMI_DATA BIT_ULL(MV88E6XXX_CAP_SMI_DATA)
Vivien Didelota0ffff22016-08-15 17:18:58 -0400469
Andrew Lunnd6b10232016-09-21 01:40:32 +0200470#define MV88E6XXX_FLAG_PHY_PAGE BIT_ULL(MV88E6XXX_CAP_PHY_PAGE)
Vivien Didelot09cb7df2016-08-15 17:19:01 -0400471
Andrew Lunnd6b10232016-09-21 01:40:32 +0200472#define MV88E6XXX_FLAG_SERDES BIT_ULL(MV88E6XXX_CAP_SERDES)
Vivien Didelot09cb7df2016-08-15 17:19:01 -0400473
Vivien Didelot6dc10bb2016-09-29 12:21:55 -0400474#define MV88E6XXX_FLAG_G1_ATU_FID BIT_ULL(MV88E6XXX_CAP_G1_ATU_FID)
475#define MV88E6XXX_FLAG_G1_VTU_FID BIT_ULL(MV88E6XXX_CAP_G1_VTU_FID)
476
Andrew Lunnd6b10232016-09-21 01:40:32 +0200477#define MV88E6XXX_FLAG_GLOBAL2 BIT_ULL(MV88E6XXX_CAP_GLOBAL2)
Andrew Lunndc30c352016-10-16 19:56:49 +0200478#define MV88E6XXX_FLAG_G2_INT BIT_ULL(MV88E6XXX_CAP_G2_INT)
Andrew Lunnd6b10232016-09-21 01:40:32 +0200479#define MV88E6XXX_FLAG_G2_MGMT_EN_2X BIT_ULL(MV88E6XXX_CAP_G2_MGMT_EN_2X)
480#define MV88E6XXX_FLAG_G2_MGMT_EN_0X BIT_ULL(MV88E6XXX_CAP_G2_MGMT_EN_0X)
481#define MV88E6XXX_FLAG_G2_IRL_CMD BIT_ULL(MV88E6XXX_CAP_G2_IRL_CMD)
482#define MV88E6XXX_FLAG_G2_IRL_DATA BIT_ULL(MV88E6XXX_CAP_G2_IRL_DATA)
483#define MV88E6XXX_FLAG_G2_PVT_ADDR BIT_ULL(MV88E6XXX_CAP_G2_PVT_ADDR)
484#define MV88E6XXX_FLAG_G2_PVT_DATA BIT_ULL(MV88E6XXX_CAP_G2_PVT_DATA)
Andrew Lunnd6b10232016-09-21 01:40:32 +0200485#define MV88E6XXX_FLAG_G2_POT BIT_ULL(MV88E6XXX_CAP_G2_POT)
Vivien Didelota0ffff22016-08-15 17:18:58 -0400486
Andrew Lunnd6b10232016-09-21 01:40:32 +0200487#define MV88E6XXX_FLAG_PPU BIT_ULL(MV88E6XXX_CAP_PPU)
488#define MV88E6XXX_FLAG_PPU_ACTIVE BIT_ULL(MV88E6XXX_CAP_PPU_ACTIVE)
489#define MV88E6XXX_FLAG_STU BIT_ULL(MV88E6XXX_CAP_STU)
490#define MV88E6XXX_FLAG_TEMP BIT_ULL(MV88E6XXX_CAP_TEMP)
491#define MV88E6XXX_FLAG_TEMP_LIMIT BIT_ULL(MV88E6XXX_CAP_TEMP_LIMIT)
492#define MV88E6XXX_FLAG_VTU BIT_ULL(MV88E6XXX_CAP_VTU)
Vivien Didelot8c9983a2016-05-09 13:22:39 -0400493
Vivien Didelot8ec61c72016-07-18 20:45:37 -0400494/* Ingress Rate Limit unit */
495#define MV88E6XXX_FLAGS_IRL \
496 (MV88E6XXX_FLAG_G2_IRL_CMD | \
497 MV88E6XXX_FLAG_G2_IRL_DATA)
498
Vivien Didelota0ffff22016-08-15 17:18:58 -0400499/* Multi-chip Addressing Mode */
500#define MV88E6XXX_FLAGS_MULTI_CHIP \
501 (MV88E6XXX_FLAG_SMI_CMD | \
502 MV88E6XXX_FLAG_SMI_DATA)
503
Vivien Didelot63ed8802016-07-18 20:45:35 -0400504/* Cross-chip Port VLAN Table */
505#define MV88E6XXX_FLAGS_PVT \
506 (MV88E6XXX_FLAG_G2_PVT_ADDR | \
507 MV88E6XXX_FLAG_G2_PVT_DATA)
508
Vivien Didelot09cb7df2016-08-15 17:19:01 -0400509/* Fiber/SERDES Registers at SMI address F, page 1 */
510#define MV88E6XXX_FLAGS_SERDES \
511 (MV88E6XXX_FLAG_PHY_PAGE | \
512 MV88E6XXX_FLAG_SERDES)
513
Vivien Didelot8c9983a2016-05-09 13:22:39 -0400514#define MV88E6XXX_FLAGS_FAMILY_6095 \
Vivien Didelot97299342016-07-18 20:45:30 -0400515 (MV88E6XXX_FLAG_GLOBAL2 | \
Vivien Didelot47395ed2016-07-18 20:45:33 -0400516 MV88E6XXX_FLAG_G2_MGMT_EN_0X | \
Vivien Didelot2672f822016-05-09 13:22:48 -0400517 MV88E6XXX_FLAG_PPU | \
Vivien Didelota0ffff22016-08-15 17:18:58 -0400518 MV88E6XXX_FLAG_VTU | \
519 MV88E6XXX_FLAGS_MULTI_CHIP)
Vivien Didelot8c9983a2016-05-09 13:22:39 -0400520
521#define MV88E6XXX_FLAGS_FAMILY_6097 \
Vivien Didelot6dc10bb2016-09-29 12:21:55 -0400522 (MV88E6XXX_FLAG_G1_ATU_FID | \
523 MV88E6XXX_FLAG_G1_VTU_FID | \
524 MV88E6XXX_FLAG_GLOBAL2 | \
Vivien Didelot47395ed2016-07-18 20:45:33 -0400525 MV88E6XXX_FLAG_G2_MGMT_EN_2X | \
526 MV88E6XXX_FLAG_G2_MGMT_EN_0X | \
Vivien Didelot9bda8892016-07-18 20:45:36 -0400527 MV88E6XXX_FLAG_G2_POT | \
Vivien Didelot2672f822016-05-09 13:22:48 -0400528 MV88E6XXX_FLAG_PPU | \
Vivien Didelotcb9b9022016-05-10 15:44:29 -0400529 MV88E6XXX_FLAG_STU | \
Vivien Didelot63ed8802016-07-18 20:45:35 -0400530 MV88E6XXX_FLAG_VTU | \
Vivien Didelot8ec61c72016-07-18 20:45:37 -0400531 MV88E6XXX_FLAGS_IRL | \
Vivien Didelota0ffff22016-08-15 17:18:58 -0400532 MV88E6XXX_FLAGS_MULTI_CHIP | \
Vivien Didelot63ed8802016-07-18 20:45:35 -0400533 MV88E6XXX_FLAGS_PVT)
Vivien Didelotb5058d72016-05-09 13:22:38 -0400534
Vivien Didelot6594f612016-05-09 13:22:42 -0400535#define MV88E6XXX_FLAGS_FAMILY_6165 \
Vivien Didelot6dc10bb2016-09-29 12:21:55 -0400536 (MV88E6XXX_FLAG_G1_ATU_FID | \
537 MV88E6XXX_FLAG_G1_VTU_FID | \
538 MV88E6XXX_FLAG_GLOBAL2 | \
Andrew Lunndc30c352016-10-16 19:56:49 +0200539 MV88E6XXX_FLAG_G2_INT | \
Vivien Didelot47395ed2016-07-18 20:45:33 -0400540 MV88E6XXX_FLAG_G2_MGMT_EN_2X | \
541 MV88E6XXX_FLAG_G2_MGMT_EN_0X | \
Vivien Didelot9bda8892016-07-18 20:45:36 -0400542 MV88E6XXX_FLAG_G2_POT | \
Vivien Didelot914b32f2016-06-20 13:14:11 -0400543 MV88E6XXX_FLAG_STU | \
Vivien Didelotcb9b9022016-05-10 15:44:29 -0400544 MV88E6XXX_FLAG_TEMP | \
Vivien Didelot63ed8802016-07-18 20:45:35 -0400545 MV88E6XXX_FLAG_VTU | \
Vivien Didelot8ec61c72016-07-18 20:45:37 -0400546 MV88E6XXX_FLAGS_IRL | \
Vivien Didelota0ffff22016-08-15 17:18:58 -0400547 MV88E6XXX_FLAGS_MULTI_CHIP | \
Vivien Didelot63ed8802016-07-18 20:45:35 -0400548 MV88E6XXX_FLAGS_PVT)
Vivien Didelotb5058d72016-05-09 13:22:38 -0400549
Vivien Didelot8c9983a2016-05-09 13:22:39 -0400550#define MV88E6XXX_FLAGS_FAMILY_6185 \
Vivien Didelot97299342016-07-18 20:45:30 -0400551 (MV88E6XXX_FLAG_GLOBAL2 | \
Andrew Lunndc30c352016-10-16 19:56:49 +0200552 MV88E6XXX_FLAG_G2_INT | \
Vivien Didelot47395ed2016-07-18 20:45:33 -0400553 MV88E6XXX_FLAG_G2_MGMT_EN_0X | \
Vivien Didelota0ffff22016-08-15 17:18:58 -0400554 MV88E6XXX_FLAGS_MULTI_CHIP | \
Vivien Didelot2672f822016-05-09 13:22:48 -0400555 MV88E6XXX_FLAG_PPU | \
Vivien Didelot54d77b52016-05-09 13:22:47 -0400556 MV88E6XXX_FLAG_VTU)
Vivien Didelotb5058d72016-05-09 13:22:38 -0400557
Vivien Didelot6d5834a2016-05-09 13:22:40 -0400558#define MV88E6XXX_FLAGS_FAMILY_6320 \
Andrew Lunn2bbb33b2016-08-22 16:01:02 +0200559 (MV88E6XXX_FLAG_EDSA | \
560 MV88E6XXX_FLAG_EEE | \
Vivien Didelot97299342016-07-18 20:45:30 -0400561 MV88E6XXX_FLAG_GLOBAL2 | \
Vivien Didelot47395ed2016-07-18 20:45:33 -0400562 MV88E6XXX_FLAG_G2_MGMT_EN_2X | \
563 MV88E6XXX_FLAG_G2_MGMT_EN_0X | \
Vivien Didelot9bda8892016-07-18 20:45:36 -0400564 MV88E6XXX_FLAG_G2_POT | \
Vivien Didelot552238b2016-05-09 13:22:49 -0400565 MV88E6XXX_FLAG_PPU_ACTIVE | \
Vivien Didelot6594f612016-05-09 13:22:42 -0400566 MV88E6XXX_FLAG_TEMP | \
Vivien Didelot936f2342016-05-09 13:22:46 -0400567 MV88E6XXX_FLAG_TEMP_LIMIT | \
Vivien Didelot63ed8802016-07-18 20:45:35 -0400568 MV88E6XXX_FLAG_VTU | \
Vivien Didelot8ec61c72016-07-18 20:45:37 -0400569 MV88E6XXX_FLAGS_IRL | \
Vivien Didelota0ffff22016-08-15 17:18:58 -0400570 MV88E6XXX_FLAGS_MULTI_CHIP | \
Vivien Didelotb3469dd2016-09-29 12:22:00 -0400571 MV88E6XXX_FLAGS_PVT)
Vivien Didelotb5058d72016-05-09 13:22:38 -0400572
Vivien Didelot6d5834a2016-05-09 13:22:40 -0400573#define MV88E6XXX_FLAGS_FAMILY_6351 \
Andrew Lunn2bbb33b2016-08-22 16:01:02 +0200574 (MV88E6XXX_FLAG_EDSA | \
Vivien Didelot6dc10bb2016-09-29 12:21:55 -0400575 MV88E6XXX_FLAG_G1_ATU_FID | \
576 MV88E6XXX_FLAG_G1_VTU_FID | \
Andrew Lunn2bbb33b2016-08-22 16:01:02 +0200577 MV88E6XXX_FLAG_GLOBAL2 | \
Andrew Lunndc30c352016-10-16 19:56:49 +0200578 MV88E6XXX_FLAG_G2_INT | \
Vivien Didelot47395ed2016-07-18 20:45:33 -0400579 MV88E6XXX_FLAG_G2_MGMT_EN_2X | \
580 MV88E6XXX_FLAG_G2_MGMT_EN_0X | \
Vivien Didelot9bda8892016-07-18 20:45:36 -0400581 MV88E6XXX_FLAG_G2_POT | \
Vivien Didelot552238b2016-05-09 13:22:49 -0400582 MV88E6XXX_FLAG_PPU_ACTIVE | \
Vivien Didelotcb9b9022016-05-10 15:44:29 -0400583 MV88E6XXX_FLAG_STU | \
Vivien Didelot936f2342016-05-09 13:22:46 -0400584 MV88E6XXX_FLAG_TEMP | \
Vivien Didelot63ed8802016-07-18 20:45:35 -0400585 MV88E6XXX_FLAG_VTU | \
Vivien Didelot8ec61c72016-07-18 20:45:37 -0400586 MV88E6XXX_FLAGS_IRL | \
Vivien Didelota0ffff22016-08-15 17:18:58 -0400587 MV88E6XXX_FLAGS_MULTI_CHIP | \
Vivien Didelotb3469dd2016-09-29 12:22:00 -0400588 MV88E6XXX_FLAGS_PVT)
Vivien Didelotb5058d72016-05-09 13:22:38 -0400589
Vivien Didelot6d5834a2016-05-09 13:22:40 -0400590#define MV88E6XXX_FLAGS_FAMILY_6352 \
Andrew Lunn2bbb33b2016-08-22 16:01:02 +0200591 (MV88E6XXX_FLAG_EDSA | \
592 MV88E6XXX_FLAG_EEE | \
Vivien Didelot6dc10bb2016-09-29 12:21:55 -0400593 MV88E6XXX_FLAG_G1_ATU_FID | \
594 MV88E6XXX_FLAG_G1_VTU_FID | \
Vivien Didelot97299342016-07-18 20:45:30 -0400595 MV88E6XXX_FLAG_GLOBAL2 | \
Andrew Lunndc30c352016-10-16 19:56:49 +0200596 MV88E6XXX_FLAG_G2_INT | \
Vivien Didelot47395ed2016-07-18 20:45:33 -0400597 MV88E6XXX_FLAG_G2_MGMT_EN_2X | \
598 MV88E6XXX_FLAG_G2_MGMT_EN_0X | \
Vivien Didelot9bda8892016-07-18 20:45:36 -0400599 MV88E6XXX_FLAG_G2_POT | \
Vivien Didelot552238b2016-05-09 13:22:49 -0400600 MV88E6XXX_FLAG_PPU_ACTIVE | \
Vivien Didelotcb9b9022016-05-10 15:44:29 -0400601 MV88E6XXX_FLAG_STU | \
Vivien Didelot6594f612016-05-09 13:22:42 -0400602 MV88E6XXX_FLAG_TEMP | \
Vivien Didelot936f2342016-05-09 13:22:46 -0400603 MV88E6XXX_FLAG_TEMP_LIMIT | \
Vivien Didelot63ed8802016-07-18 20:45:35 -0400604 MV88E6XXX_FLAG_VTU | \
Vivien Didelot8ec61c72016-07-18 20:45:37 -0400605 MV88E6XXX_FLAGS_IRL | \
Vivien Didelota0ffff22016-08-15 17:18:58 -0400606 MV88E6XXX_FLAGS_MULTI_CHIP | \
Vivien Didelot57c67cf2016-08-15 17:18:59 -0400607 MV88E6XXX_FLAGS_PVT | \
Vivien Didelotb3469dd2016-09-29 12:22:00 -0400608 MV88E6XXX_FLAGS_SERDES)
609
610struct mv88e6xxx_ops;
Vivien Didelotb5058d72016-05-09 13:22:38 -0400611
Vivien Didelotf6271e62016-04-17 13:23:59 -0400612struct mv88e6xxx_info {
Vivien Didelot22356472016-04-17 13:24:00 -0400613 enum mv88e6xxx_family family;
Vivien Didelotf6271e62016-04-17 13:23:59 -0400614 u16 prod_num;
615 const char *name;
Vivien Didelotcd5a2c82016-04-17 13:24:02 -0400616 unsigned int num_databases;
Vivien Didelot009a2b92016-04-17 13:24:01 -0400617 unsigned int num_ports;
Vivien Didelot9dddd472016-06-20 13:14:10 -0400618 unsigned int port_base_addr;
Vivien Didelota935c052016-09-29 12:21:53 -0400619 unsigned int global1_addr;
Vivien Didelotacddbd22016-07-18 20:45:39 -0400620 unsigned int age_time_coeff;
Andrew Lunndc30c352016-10-16 19:56:49 +0200621 unsigned int g1_irqs;
Andrew Lunnd6b10232016-09-21 01:40:32 +0200622 unsigned long long flags;
Vivien Didelotb3469dd2016-09-29 12:22:00 -0400623 const struct mv88e6xxx_ops *ops;
Vivien Didelotb9b37712015-10-30 19:39:48 -0400624};
625
Vivien Didelotfd231c82015-08-10 09:09:50 -0400626struct mv88e6xxx_atu_entry {
627 u16 fid;
628 u8 state;
629 bool trunk;
630 u16 portv_trunkid;
631 u8 mac[ETH_ALEN];
632};
633
Vivien Didelotb4e47c02016-09-29 12:21:58 -0400634struct mv88e6xxx_vtu_entry {
Vivien Didelotb8fee952015-08-13 12:52:19 -0400635 u16 vid;
636 u16 fid;
Vivien Didelotb8fee952015-08-13 12:52:19 -0400637 u8 sid;
638 bool valid;
639 u8 data[DSA_MAX_PORTS];
640};
641
Vivien Didelotc08026a2016-09-29 12:21:59 -0400642struct mv88e6xxx_bus_ops;
Vivien Didelot914b32f2016-06-20 13:14:11 -0400643
Vivien Didelotd715fa62016-02-12 12:09:38 -0500644struct mv88e6xxx_priv_port {
Vivien Didelota6692752016-02-12 12:09:39 -0500645 struct net_device *bridge_dev;
Vivien Didelotd715fa62016-02-12 12:09:38 -0500646};
647
Andrew Lunndc30c352016-10-16 19:56:49 +0200648struct mv88e6xxx_irq {
649 u16 masked;
650 struct irq_chip chip;
651 struct irq_domain *domain;
652 unsigned int nirqs;
653};
654
Vivien Didelotfad09c72016-06-21 12:28:20 -0400655struct mv88e6xxx_chip {
Vivien Didelotf6271e62016-04-17 13:23:59 -0400656 const struct mv88e6xxx_info *info;
657
Andrew Lunn7543a6d2016-04-13 02:40:40 +0200658 /* The dsa_switch this private structure is related to */
659 struct dsa_switch *ds;
660
Andrew Lunn158bc062016-04-28 21:24:06 -0400661 /* The device this structure is associated to */
662 struct device *dev;
663
Vivien Didelot9f8b3ee2016-06-20 13:14:05 -0400664 /* This mutex protects the access to the switch registers */
665 struct mutex reg_lock;
Lennert Buytenhek91da11f2008-10-07 13:44:02 +0000666
Andrew Lunna77d43f2016-04-13 02:40:42 +0200667 /* The MII bus and the address on the bus that is used to
668 * communication with the switch
669 */
Vivien Didelotc08026a2016-09-29 12:21:59 -0400670 const struct mv88e6xxx_bus_ops *smi_ops;
Andrew Lunna77d43f2016-04-13 02:40:42 +0200671 struct mii_bus *bus;
672 int sw_addr;
673
Barry Grussling3675c8d2013-01-08 16:05:53 +0000674 /* Handles automatic disabling and re-enabling of the PHY
Lennert Buytenhek2e5f0322008-10-07 13:45:18 +0000675 * polling unit.
676 */
Vivien Didelotc08026a2016-09-29 12:21:59 -0400677 const struct mv88e6xxx_bus_ops *phy_ops;
Lennert Buytenhek2e5f0322008-10-07 13:45:18 +0000678 struct mutex ppu_mutex;
679 int ppu_disabled;
680 struct work_struct ppu_work;
681 struct timer_list ppu_timer;
Lennert Buytenhek2e5f0322008-10-07 13:45:18 +0000682
Barry Grussling3675c8d2013-01-08 16:05:53 +0000683 /* This mutex serialises access to the statistics unit.
Lennert Buytenhek91da11f2008-10-07 13:44:02 +0000684 * Hold this mutex over snapshot + dump sequences.
685 */
686 struct mutex stats_mutex;
Peter Korsgaardec80bfc2011-04-05 03:03:56 +0000687
Vivien Didelotd715fa62016-02-12 12:09:38 -0500688 struct mv88e6xxx_priv_port ports[DSA_MAX_PORTS];
689
Andrew Lunn52638f72016-05-10 23:27:22 +0200690 /* A switch may have a GPIO line tied to its reset pin. Parse
691 * this from the device tree, and use it before performing
692 * switch soft reset.
693 */
694 struct gpio_desc *reset;
Andrew Lunnf8cd8752016-05-10 23:27:25 +0200695
696 /* set to size of eeprom if supported by the switch */
697 int eeprom_len;
Andrew Lunnb516d452016-06-04 21:17:06 +0200698
699 /* Device node for the MDIO bus */
700 struct device_node *mdio_np;
701
702 /* And the MDIO bus itself */
703 struct mii_bus *mdio_bus;
Andrew Lunndc30c352016-10-16 19:56:49 +0200704
705 /* There can be two interrupt controllers, which are chained
706 * off a GPIO as interrupt source
707 */
708 struct mv88e6xxx_irq g1_irq;
709 struct mv88e6xxx_irq g2_irq;
710 int irq;
Lennert Buytenhek91da11f2008-10-07 13:44:02 +0000711};
712
Vivien Didelotc08026a2016-09-29 12:21:59 -0400713struct mv88e6xxx_bus_ops {
Vivien Didelotfad09c72016-06-21 12:28:20 -0400714 int (*read)(struct mv88e6xxx_chip *chip, int addr, int reg, u16 *val);
715 int (*write)(struct mv88e6xxx_chip *chip, int addr, int reg, u16 val);
Vivien Didelot914b32f2016-06-20 13:14:11 -0400716};
717
Vivien Didelotb3469dd2016-09-29 12:22:00 -0400718struct mv88e6xxx_ops {
Vivien Didelotee4dc2e72016-09-29 12:22:02 -0400719 int (*get_eeprom)(struct mv88e6xxx_chip *chip,
720 struct ethtool_eeprom *eeprom, u8 *data);
721 int (*set_eeprom)(struct mv88e6xxx_chip *chip,
722 struct ethtool_eeprom *eeprom, u8 *data);
723
Vivien Didelotb073d4e2016-09-29 12:22:01 -0400724 int (*set_switch_mac)(struct mv88e6xxx_chip *chip, u8 *addr);
725
Vivien Didelotb3469dd2016-09-29 12:22:00 -0400726 int (*phy_read)(struct mv88e6xxx_chip *chip, int addr, int reg,
727 u16 *val);
728 int (*phy_write)(struct mv88e6xxx_chip *chip, int addr, int reg,
729 u16 val);
Vivien Didelot08ef7f12016-11-04 03:23:32 +0100730
Vivien Didelota0a0f622016-11-04 03:23:34 +0100731 /* RGMII Receive/Transmit Timing Control
732 * Add delay on PHY_INTERFACE_MODE_RGMII_*ID, no delay otherwise.
733 */
734 int (*port_set_rgmii_delay)(struct mv88e6xxx_chip *chip, int port,
735 phy_interface_t mode);
736
Vivien Didelot08ef7f12016-11-04 03:23:32 +0100737#define LINK_FORCED_DOWN 0
738#define LINK_FORCED_UP 1
739#define LINK_UNFORCED -2
740
741 /* Port's MAC link state
742 * Use LINK_FORCED_UP or LINK_FORCED_DOWN to force link up or down,
743 * or LINK_UNFORCED for normal link detection.
744 */
745 int (*port_set_link)(struct mv88e6xxx_chip *chip, int port, int link);
Vivien Didelot7f1ae072016-11-04 03:23:33 +0100746
747#define DUPLEX_UNFORCED -2
748
749 /* Port's MAC duplex mode
750 *
751 * Use DUPLEX_HALF or DUPLEX_FULL to force half or full duplex,
752 * or DUPLEX_UNFORCED for normal duplex detection.
753 */
754 int (*port_set_duplex)(struct mv88e6xxx_chip *chip, int port, int dup);
Vivien Didelotb3469dd2016-09-29 12:22:00 -0400755};
756
Andrew Lunnf5e2ed02015-12-23 13:23:17 +0100757enum stat_type {
758 BANK0,
759 BANK1,
760 PORT,
761};
762
Lennert Buytenhek91da11f2008-10-07 13:44:02 +0000763struct mv88e6xxx_hw_stat {
764 char string[ETH_GSTRING_LEN];
765 int sizeof_stat;
766 int reg;
Andrew Lunnf5e2ed02015-12-23 13:23:17 +0100767 enum stat_type type;
Lennert Buytenhek91da11f2008-10-07 13:44:02 +0000768};
769
Vivien Didelotfad09c72016-06-21 12:28:20 -0400770static inline bool mv88e6xxx_has(struct mv88e6xxx_chip *chip,
Vivien Didelotb5058d72016-05-09 13:22:38 -0400771 unsigned long flags)
772{
Vivien Didelotfad09c72016-06-21 12:28:20 -0400773 return (chip->info->flags & flags) == flags;
Vivien Didelotb5058d72016-05-09 13:22:38 -0400774}
775
Vivien Didelotde333762016-09-29 12:21:56 -0400776static inline unsigned int mv88e6xxx_num_databases(struct mv88e6xxx_chip *chip)
777{
778 return chip->info->num_databases;
779}
780
Vivien Didelot370b4ff2016-09-29 12:21:57 -0400781static inline unsigned int mv88e6xxx_num_ports(struct mv88e6xxx_chip *chip)
782{
783 return chip->info->num_ports;
784}
785
Vivien Didelotec561272016-09-02 14:45:33 -0400786int mv88e6xxx_read(struct mv88e6xxx_chip *chip, int addr, int reg, u16 *val);
787int mv88e6xxx_write(struct mv88e6xxx_chip *chip, int addr, int reg, u16 val);
788int mv88e6xxx_update(struct mv88e6xxx_chip *chip, int addr, int reg,
789 u16 update);
790int mv88e6xxx_wait(struct mv88e6xxx_chip *chip, int addr, int reg, u16 mask);
791
Lennert Buytenhek91da11f2008-10-07 13:44:02 +0000792#endif