blob: 856c6e50565fff2aa1ae46597caf6e5dead7ca8e [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 Lunn52638f72016-05-10 23:27:22 +020016#include <linux/gpio/consumer.h>
Vivien Didelot194fea72015-08-10 09:09:47 -040017
Andrew Lunn80c46272015-06-20 18:42:30 +020018#ifndef UINT64_MAX
19#define UINT64_MAX (u64)(~((u64)0))
20#endif
21
Andrew Lunncca8b132015-04-02 04:06:39 +020022#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
Guenter Roeckb2eb0662015-04-02 04:06:30 +020032
Patrick Uiterwijk13a7ebb2016-03-30 01:39:41 +000033/* Fiber/SERDES Registers are located at SMI address F, page 1 */
34#define REG_FIBER_SERDES 0x0f
35#define PAGE_FIBER_SERDES 0x01
36
Lennert Buytenhek91da11f2008-10-07 13:44:02 +000037#define REG_PORT(p) (0x10 + (p))
Andrew Lunncca8b132015-04-02 04:06:39 +020038#define PORT_STATUS 0x00
39#define PORT_STATUS_PAUSE_EN BIT(15)
40#define PORT_STATUS_MY_PAUSE BIT(14)
41#define PORT_STATUS_HD_FLOW BIT(13)
42#define PORT_STATUS_PHY_DETECT BIT(12)
43#define PORT_STATUS_LINK BIT(11)
44#define PORT_STATUS_DUPLEX BIT(10)
45#define PORT_STATUS_SPEED_MASK 0x0300
46#define PORT_STATUS_SPEED_10 0x0000
47#define PORT_STATUS_SPEED_100 0x0100
48#define PORT_STATUS_SPEED_1000 0x0200
49#define PORT_STATUS_EEE BIT(6) /* 6352 */
50#define PORT_STATUS_AM_DIS BIT(6) /* 6165 */
51#define PORT_STATUS_MGMII BIT(6) /* 6185 */
52#define PORT_STATUS_TX_PAUSED BIT(5)
53#define PORT_STATUS_FLOW_CTRL BIT(4)
Patrick Uiterwijk13a7ebb2016-03-30 01:39:41 +000054#define PORT_STATUS_CMODE_MASK 0x0f
55#define PORT_STATUS_CMODE_100BASE_X 0x8
56#define PORT_STATUS_CMODE_1000BASE_X 0x9
57#define PORT_STATUS_CMODE_SGMII 0xa
Andrew Lunncca8b132015-04-02 04:06:39 +020058#define PORT_PCS_CTRL 0x01
Andrew Lunne7e72ac2015-08-31 15:56:51 +020059#define PORT_PCS_CTRL_RGMII_DELAY_RXCLK BIT(15)
60#define PORT_PCS_CTRL_RGMII_DELAY_TXCLK BIT(14)
Andrew Lunn54d792f2015-05-06 01:09:47 +020061#define PORT_PCS_CTRL_FC BIT(7)
62#define PORT_PCS_CTRL_FORCE_FC BIT(6)
63#define PORT_PCS_CTRL_LINK_UP BIT(5)
64#define PORT_PCS_CTRL_FORCE_LINK BIT(4)
65#define PORT_PCS_CTRL_DUPLEX_FULL BIT(3)
66#define PORT_PCS_CTRL_FORCE_DUPLEX BIT(2)
67#define PORT_PCS_CTRL_10 0x00
68#define PORT_PCS_CTRL_100 0x01
69#define PORT_PCS_CTRL_1000 0x02
70#define PORT_PCS_CTRL_UNFORCED 0x03
71#define PORT_PAUSE_CTRL 0x02
Andrew Lunncca8b132015-04-02 04:06:39 +020072#define PORT_SWITCH_ID 0x03
Vivien Didelotf6271e62016-04-17 13:23:59 -040073#define PORT_SWITCH_ID_PROD_NUM_6085 0x04a
74#define PORT_SWITCH_ID_PROD_NUM_6095 0x095
75#define PORT_SWITCH_ID_PROD_NUM_6131 0x106
76#define PORT_SWITCH_ID_PROD_NUM_6320 0x115
77#define PORT_SWITCH_ID_PROD_NUM_6123 0x121
78#define PORT_SWITCH_ID_PROD_NUM_6161 0x161
79#define PORT_SWITCH_ID_PROD_NUM_6165 0x165
80#define PORT_SWITCH_ID_PROD_NUM_6171 0x171
81#define PORT_SWITCH_ID_PROD_NUM_6172 0x172
82#define PORT_SWITCH_ID_PROD_NUM_6175 0x175
83#define PORT_SWITCH_ID_PROD_NUM_6176 0x176
84#define PORT_SWITCH_ID_PROD_NUM_6185 0x1a7
85#define PORT_SWITCH_ID_PROD_NUM_6240 0x240
86#define PORT_SWITCH_ID_PROD_NUM_6321 0x310
87#define PORT_SWITCH_ID_PROD_NUM_6352 0x352
88#define PORT_SWITCH_ID_PROD_NUM_6350 0x371
89#define PORT_SWITCH_ID_PROD_NUM_6351 0x375
Andrew Lunncca8b132015-04-02 04:06:39 +020090#define PORT_CONTROL 0x04
Andrew Lunn54d792f2015-05-06 01:09:47 +020091#define PORT_CONTROL_USE_CORE_TAG BIT(15)
92#define PORT_CONTROL_DROP_ON_LOCK BIT(14)
93#define PORT_CONTROL_EGRESS_UNMODIFIED (0x0 << 12)
94#define PORT_CONTROL_EGRESS_UNTAGGED (0x1 << 12)
95#define PORT_CONTROL_EGRESS_TAGGED (0x2 << 12)
96#define PORT_CONTROL_EGRESS_ADD_TAG (0x3 << 12)
97#define PORT_CONTROL_HEADER BIT(11)
98#define PORT_CONTROL_IGMP_MLD_SNOOP BIT(10)
99#define PORT_CONTROL_DOUBLE_TAG BIT(9)
100#define PORT_CONTROL_FRAME_MODE_NORMAL (0x0 << 8)
101#define PORT_CONTROL_FRAME_MODE_DSA (0x1 << 8)
102#define PORT_CONTROL_FRAME_MODE_PROVIDER (0x2 << 8)
103#define PORT_CONTROL_FRAME_ETHER_TYPE_DSA (0x3 << 8)
104#define PORT_CONTROL_DSA_TAG BIT(8)
105#define PORT_CONTROL_VLAN_TUNNEL BIT(7)
106#define PORT_CONTROL_TAG_IF_BOTH BIT(6)
107#define PORT_CONTROL_USE_IP BIT(5)
108#define PORT_CONTROL_USE_TAG BIT(4)
109#define PORT_CONTROL_FORWARD_UNKNOWN_MC BIT(3)
110#define PORT_CONTROL_FORWARD_UNKNOWN BIT(2)
Andrew Lunncca8b132015-04-02 04:06:39 +0200111#define PORT_CONTROL_STATE_MASK 0x03
112#define PORT_CONTROL_STATE_DISABLED 0x00
113#define PORT_CONTROL_STATE_BLOCKING 0x01
114#define PORT_CONTROL_STATE_LEARNING 0x02
115#define PORT_CONTROL_STATE_FORWARDING 0x03
116#define PORT_CONTROL_1 0x05
Vivien Didelot2db9ce12016-02-26 13:16:04 -0500117#define PORT_CONTROL_1_FID_11_4_MASK (0xff << 0)
Andrew Lunncca8b132015-04-02 04:06:39 +0200118#define PORT_BASE_VLAN 0x06
Vivien Didelot2db9ce12016-02-26 13:16:04 -0500119#define PORT_BASE_VLAN_FID_3_0_MASK (0xf << 12)
Andrew Lunncca8b132015-04-02 04:06:39 +0200120#define PORT_DEFAULT_VLAN 0x07
Vivien Didelotb8fee952015-08-13 12:52:19 -0400121#define PORT_DEFAULT_VLAN_MASK 0xfff
Andrew Lunncca8b132015-04-02 04:06:39 +0200122#define PORT_CONTROL_2 0x08
Andrew Lunn54d792f2015-05-06 01:09:47 +0200123#define PORT_CONTROL_2_IGNORE_FCS BIT(15)
124#define PORT_CONTROL_2_VTU_PRI_OVERRIDE BIT(14)
125#define PORT_CONTROL_2_SA_PRIO_OVERRIDE BIT(13)
126#define PORT_CONTROL_2_DA_PRIO_OVERRIDE BIT(12)
127#define PORT_CONTROL_2_JUMBO_1522 (0x00 << 12)
128#define PORT_CONTROL_2_JUMBO_2048 (0x01 << 12)
129#define PORT_CONTROL_2_JUMBO_10240 (0x02 << 12)
Vivien Didelot8efdda42015-08-13 12:52:23 -0400130#define PORT_CONTROL_2_8021Q_MASK (0x03 << 10)
131#define PORT_CONTROL_2_8021Q_DISABLED (0x00 << 10)
132#define PORT_CONTROL_2_8021Q_FALLBACK (0x01 << 10)
133#define PORT_CONTROL_2_8021Q_CHECK (0x02 << 10)
134#define PORT_CONTROL_2_8021Q_SECURE (0x03 << 10)
Andrew Lunn54d792f2015-05-06 01:09:47 +0200135#define PORT_CONTROL_2_DISCARD_TAGGED BIT(9)
136#define PORT_CONTROL_2_DISCARD_UNTAGGED BIT(8)
137#define PORT_CONTROL_2_MAP_DA BIT(7)
138#define PORT_CONTROL_2_DEFAULT_FORWARD BIT(6)
139#define PORT_CONTROL_2_FORWARD_UNKNOWN BIT(6)
140#define PORT_CONTROL_2_EGRESS_MONITOR BIT(5)
141#define PORT_CONTROL_2_INGRESS_MONITOR BIT(4)
Andrew Lunncca8b132015-04-02 04:06:39 +0200142#define PORT_RATE_CONTROL 0x09
143#define PORT_RATE_CONTROL_2 0x0a
144#define PORT_ASSOC_VECTOR 0x0b
Andrew Lunn4c7ea3c2015-11-03 10:52:36 -0500145#define PORT_ASSOC_VECTOR_HOLD_AT_1 BIT(15)
146#define PORT_ASSOC_VECTOR_INT_AGE_OUT BIT(14)
147#define PORT_ASSOC_VECTOR_LOCKED_PORT BIT(13)
148#define PORT_ASSOC_VECTOR_IGNORE_WRONG BIT(12)
149#define PORT_ASSOC_VECTOR_REFRESH_LOCKED BIT(11)
Andrew Lunn54d792f2015-05-06 01:09:47 +0200150#define PORT_ATU_CONTROL 0x0c
151#define PORT_PRI_OVERRIDE 0x0d
152#define PORT_ETH_TYPE 0x0f
Andrew Lunncca8b132015-04-02 04:06:39 +0200153#define PORT_IN_DISCARD_LO 0x10
154#define PORT_IN_DISCARD_HI 0x11
155#define PORT_IN_FILTERED 0x12
156#define PORT_OUT_FILTERED 0x13
Andrew Lunn54d792f2015-05-06 01:09:47 +0200157#define PORT_TAG_REGMAP_0123 0x18
158#define PORT_TAG_REGMAP_4567 0x19
Andrew Lunncca8b132015-04-02 04:06:39 +0200159
Lennert Buytenhek91da11f2008-10-07 13:44:02 +0000160#define REG_GLOBAL 0x1b
Andrew Lunncca8b132015-04-02 04:06:39 +0200161#define GLOBAL_STATUS 0x00
162#define GLOBAL_STATUS_PPU_STATE BIT(15) /* 6351 and 6171 */
163/* Two bits for 6165, 6185 etc */
164#define GLOBAL_STATUS_PPU_MASK (0x3 << 14)
165#define GLOBAL_STATUS_PPU_DISABLED_RST (0x0 << 14)
166#define GLOBAL_STATUS_PPU_INITIALIZING (0x1 << 14)
167#define GLOBAL_STATUS_PPU_DISABLED (0x2 << 14)
168#define GLOBAL_STATUS_PPU_POLLING (0x3 << 14)
169#define GLOBAL_MAC_01 0x01
170#define GLOBAL_MAC_23 0x02
171#define GLOBAL_MAC_45 0x03
Vivien Didelota08df0f2015-08-10 09:09:46 -0400172#define GLOBAL_ATU_FID 0x01 /* 6097 6165 6351 6352 */
Vivien Didelotb8fee952015-08-13 12:52:19 -0400173#define GLOBAL_VTU_FID 0x02 /* 6097 6165 6351 6352 */
174#define GLOBAL_VTU_FID_MASK 0xfff
175#define GLOBAL_VTU_SID 0x03 /* 6097 6165 6351 6352 */
176#define GLOBAL_VTU_SID_MASK 0x3f
Andrew Lunncca8b132015-04-02 04:06:39 +0200177#define GLOBAL_CONTROL 0x04
178#define GLOBAL_CONTROL_SW_RESET BIT(15)
179#define GLOBAL_CONTROL_PPU_ENABLE BIT(14)
180#define GLOBAL_CONTROL_DISCARD_EXCESS BIT(13) /* 6352 */
181#define GLOBAL_CONTROL_SCHED_PRIO BIT(11) /* 6152 */
182#define GLOBAL_CONTROL_MAX_FRAME_1632 BIT(10) /* 6152 */
Andrew Lunn54d792f2015-05-06 01:09:47 +0200183#define GLOBAL_CONTROL_RELOAD_EEPROM BIT(9) /* 6152 */
Andrew Lunncca8b132015-04-02 04:06:39 +0200184#define GLOBAL_CONTROL_DEVICE_EN BIT(7)
185#define GLOBAL_CONTROL_STATS_DONE_EN BIT(6)
186#define GLOBAL_CONTROL_VTU_PROBLEM_EN BIT(5)
187#define GLOBAL_CONTROL_VTU_DONE_EN BIT(4)
188#define GLOBAL_CONTROL_ATU_PROBLEM_EN BIT(3)
189#define GLOBAL_CONTROL_ATU_DONE_EN BIT(2)
190#define GLOBAL_CONTROL_TCAM_EN BIT(1)
191#define GLOBAL_CONTROL_EEPROM_DONE_EN BIT(0)
192#define GLOBAL_VTU_OP 0x05
Vivien Didelot6b17e862015-08-13 12:52:18 -0400193#define GLOBAL_VTU_OP_BUSY BIT(15)
194#define GLOBAL_VTU_OP_FLUSH_ALL ((0x01 << 12) | GLOBAL_VTU_OP_BUSY)
Vivien Didelot7dad08d2015-08-13 12:52:21 -0400195#define GLOBAL_VTU_OP_VTU_LOAD_PURGE ((0x03 << 12) | GLOBAL_VTU_OP_BUSY)
Vivien Didelotb8fee952015-08-13 12:52:19 -0400196#define GLOBAL_VTU_OP_VTU_GET_NEXT ((0x04 << 12) | GLOBAL_VTU_OP_BUSY)
Vivien Didelot0d3b33e2015-08-13 12:52:22 -0400197#define GLOBAL_VTU_OP_STU_LOAD_PURGE ((0x05 << 12) | GLOBAL_VTU_OP_BUSY)
198#define GLOBAL_VTU_OP_STU_GET_NEXT ((0x06 << 12) | GLOBAL_VTU_OP_BUSY)
Andrew Lunncca8b132015-04-02 04:06:39 +0200199#define GLOBAL_VTU_VID 0x06
Vivien Didelotb8fee952015-08-13 12:52:19 -0400200#define GLOBAL_VTU_VID_MASK 0xfff
201#define GLOBAL_VTU_VID_VALID BIT(12)
Andrew Lunncca8b132015-04-02 04:06:39 +0200202#define GLOBAL_VTU_DATA_0_3 0x07
203#define GLOBAL_VTU_DATA_4_7 0x08
204#define GLOBAL_VTU_DATA_8_11 0x09
Vivien Didelotb8fee952015-08-13 12:52:19 -0400205#define GLOBAL_VTU_STU_DATA_MASK 0x03
206#define GLOBAL_VTU_DATA_MEMBER_TAG_UNMODIFIED 0x00
207#define GLOBAL_VTU_DATA_MEMBER_TAG_UNTAGGED 0x01
208#define GLOBAL_VTU_DATA_MEMBER_TAG_TAGGED 0x02
209#define GLOBAL_VTU_DATA_MEMBER_TAG_NON_MEMBER 0x03
Vivien Didelot0d3b33e2015-08-13 12:52:22 -0400210#define GLOBAL_STU_DATA_PORT_STATE_DISABLED 0x00
211#define GLOBAL_STU_DATA_PORT_STATE_BLOCKING 0x01
212#define GLOBAL_STU_DATA_PORT_STATE_LEARNING 0x02
213#define GLOBAL_STU_DATA_PORT_STATE_FORWARDING 0x03
Andrew Lunncca8b132015-04-02 04:06:39 +0200214#define GLOBAL_ATU_CONTROL 0x0a
Andrew Lunn54d792f2015-05-06 01:09:47 +0200215#define GLOBAL_ATU_CONTROL_LEARN2ALL BIT(3)
Andrew Lunncca8b132015-04-02 04:06:39 +0200216#define GLOBAL_ATU_OP 0x0b
217#define GLOBAL_ATU_OP_BUSY BIT(15)
218#define GLOBAL_ATU_OP_NOP (0 << 12)
Vivien Didelot7fb5e752015-09-04 14:34:12 -0400219#define GLOBAL_ATU_OP_FLUSH_MOVE_ALL ((1 << 12) | GLOBAL_ATU_OP_BUSY)
220#define GLOBAL_ATU_OP_FLUSH_MOVE_NON_STATIC ((2 << 12) | GLOBAL_ATU_OP_BUSY)
Andrew Lunncca8b132015-04-02 04:06:39 +0200221#define GLOBAL_ATU_OP_LOAD_DB ((3 << 12) | GLOBAL_ATU_OP_BUSY)
222#define GLOBAL_ATU_OP_GET_NEXT_DB ((4 << 12) | GLOBAL_ATU_OP_BUSY)
Vivien Didelot7fb5e752015-09-04 14:34:12 -0400223#define GLOBAL_ATU_OP_FLUSH_MOVE_ALL_DB ((5 << 12) | GLOBAL_ATU_OP_BUSY)
224#define GLOBAL_ATU_OP_FLUSH_MOVE_NON_STATIC_DB ((6 << 12) | GLOBAL_ATU_OP_BUSY)
Andrew Lunncca8b132015-04-02 04:06:39 +0200225#define GLOBAL_ATU_OP_GET_CLR_VIOLATION ((7 << 12) | GLOBAL_ATU_OP_BUSY)
226#define GLOBAL_ATU_DATA 0x0c
Andrew Lunn8a0a2652015-06-20 18:42:29 +0200227#define GLOBAL_ATU_DATA_TRUNK BIT(15)
Vivien Didelotfd231c82015-08-10 09:09:50 -0400228#define GLOBAL_ATU_DATA_TRUNK_ID_MASK 0x00f0
229#define GLOBAL_ATU_DATA_TRUNK_ID_SHIFT 4
Andrew Lunn8a0a2652015-06-20 18:42:29 +0200230#define GLOBAL_ATU_DATA_PORT_VECTOR_MASK 0x3ff0
231#define GLOBAL_ATU_DATA_PORT_VECTOR_SHIFT 4
Andrew Lunncca8b132015-04-02 04:06:39 +0200232#define GLOBAL_ATU_DATA_STATE_MASK 0x0f
233#define GLOBAL_ATU_DATA_STATE_UNUSED 0x00
234#define GLOBAL_ATU_DATA_STATE_UC_MGMT 0x0d
235#define GLOBAL_ATU_DATA_STATE_UC_STATIC 0x0e
236#define GLOBAL_ATU_DATA_STATE_UC_PRIO_OVER 0x0f
237#define GLOBAL_ATU_DATA_STATE_MC_NONE_RATE 0x05
238#define GLOBAL_ATU_DATA_STATE_MC_STATIC 0x07
239#define GLOBAL_ATU_DATA_STATE_MC_MGMT 0x0e
240#define GLOBAL_ATU_DATA_STATE_MC_PRIO_OVER 0x0f
241#define GLOBAL_ATU_MAC_01 0x0d
242#define GLOBAL_ATU_MAC_23 0x0e
243#define GLOBAL_ATU_MAC_45 0x0f
244#define GLOBAL_IP_PRI_0 0x10
245#define GLOBAL_IP_PRI_1 0x11
246#define GLOBAL_IP_PRI_2 0x12
247#define GLOBAL_IP_PRI_3 0x13
248#define GLOBAL_IP_PRI_4 0x14
249#define GLOBAL_IP_PRI_5 0x15
250#define GLOBAL_IP_PRI_6 0x16
251#define GLOBAL_IP_PRI_7 0x17
252#define GLOBAL_IEEE_PRI 0x18
253#define GLOBAL_CORE_TAG_TYPE 0x19
254#define GLOBAL_MONITOR_CONTROL 0x1a
Andrew Lunn15966a22015-05-06 01:09:49 +0200255#define GLOBAL_MONITOR_CONTROL_INGRESS_SHIFT 12
256#define GLOBAL_MONITOR_CONTROL_EGRESS_SHIFT 8
257#define GLOBAL_MONITOR_CONTROL_ARP_SHIFT 4
258#define GLOBAL_MONITOR_CONTROL_MIRROR_SHIFT 0
259#define GLOBAL_MONITOR_CONTROL_ARP_DISABLED (0xf0)
Andrew Lunncca8b132015-04-02 04:06:39 +0200260#define GLOBAL_CONTROL_2 0x1c
Andrew Lunn15966a22015-05-06 01:09:49 +0200261#define GLOBAL_CONTROL_2_NO_CASCADE 0xe000
262#define GLOBAL_CONTROL_2_MULTIPLE_CASCADE 0xf000
263
Andrew Lunncca8b132015-04-02 04:06:39 +0200264#define GLOBAL_STATS_OP 0x1d
265#define GLOBAL_STATS_OP_BUSY BIT(15)
266#define GLOBAL_STATS_OP_NOP (0 << 12)
267#define GLOBAL_STATS_OP_FLUSH_ALL ((1 << 12) | GLOBAL_STATS_OP_BUSY)
268#define GLOBAL_STATS_OP_FLUSH_PORT ((2 << 12) | GLOBAL_STATS_OP_BUSY)
269#define GLOBAL_STATS_OP_READ_CAPTURED ((4 << 12) | GLOBAL_STATS_OP_BUSY)
270#define GLOBAL_STATS_OP_CAPTURE_PORT ((5 << 12) | GLOBAL_STATS_OP_BUSY)
271#define GLOBAL_STATS_OP_HIST_RX ((1 << 10) | GLOBAL_STATS_OP_BUSY)
272#define GLOBAL_STATS_OP_HIST_TX ((2 << 10) | GLOBAL_STATS_OP_BUSY)
273#define GLOBAL_STATS_OP_HIST_RX_TX ((3 << 10) | GLOBAL_STATS_OP_BUSY)
Andrew Lunnf5e2ed02015-12-23 13:23:17 +0100274#define GLOBAL_STATS_OP_BANK_1 BIT(9)
Andrew Lunncca8b132015-04-02 04:06:39 +0200275#define GLOBAL_STATS_COUNTER_32 0x1e
276#define GLOBAL_STATS_COUNTER_01 0x1f
277
Lennert Buytenhek91da11f2008-10-07 13:44:02 +0000278#define REG_GLOBAL2 0x1c
Andrew Lunncca8b132015-04-02 04:06:39 +0200279#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
Andrew Lunn54d792f2015-05-06 01:09:47 +0200285#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)
Andrew Lunncca8b132015-04-02 04:06:39 +0200290#define GLOBAL2_DEVICE_MAPPING 0x06
Andrew Lunn54d792f2015-05-06 01:09:47 +0200291#define GLOBAL2_DEVICE_MAPPING_UPDATE BIT(15)
292#define GLOBAL2_DEVICE_MAPPING_TARGET_SHIFT 8
Andrew Lunnd35bd872015-06-20 18:42:32 +0200293#define GLOBAL2_DEVICE_MAPPING_PORT_MASK 0x0f
Andrew Lunncca8b132015-04-02 04:06:39 +0200294#define GLOBAL2_TRUNK_MASK 0x07
Andrew Lunn54d792f2015-05-06 01:09:47 +0200295#define GLOBAL2_TRUNK_MASK_UPDATE BIT(15)
296#define GLOBAL2_TRUNK_MASK_NUM_SHIFT 12
Andrew Lunncca8b132015-04-02 04:06:39 +0200297#define GLOBAL2_TRUNK_MAPPING 0x08
Andrew Lunn54d792f2015-05-06 01:09:47 +0200298#define GLOBAL2_TRUNK_MAPPING_UPDATE BIT(15)
299#define GLOBAL2_TRUNK_MAPPING_ID_SHIFT 11
Andrew Lunncca8b132015-04-02 04:06:39 +0200300#define GLOBAL2_INGRESS_OP 0x09
301#define GLOBAL2_INGRESS_DATA 0x0a
302#define GLOBAL2_PVT_ADDR 0x0b
303#define GLOBAL2_PVT_DATA 0x0c
304#define GLOBAL2_SWITCH_MAC 0x0d
305#define GLOBAL2_SWITCH_MAC_BUSY BIT(15)
306#define GLOBAL2_ATU_STATS 0x0e
307#define GLOBAL2_PRIO_OVERRIDE 0x0f
Andrew Lunn15966a22015-05-06 01:09:49 +0200308#define GLOBAL2_PRIO_OVERRIDE_FORCE_SNOOP BIT(7)
309#define GLOBAL2_PRIO_OVERRIDE_SNOOP_SHIFT 4
310#define GLOBAL2_PRIO_OVERRIDE_FORCE_ARP BIT(3)
311#define GLOBAL2_PRIO_OVERRIDE_ARP_SHIFT 0
Andrew Lunncca8b132015-04-02 04:06:39 +0200312#define GLOBAL2_EEPROM_OP 0x14
Andrew Lunn966bce32015-08-08 17:04:50 +0200313#define GLOBAL2_EEPROM_OP_BUSY BIT(15)
314#define GLOBAL2_EEPROM_OP_WRITE ((3 << 12) | GLOBAL2_EEPROM_OP_BUSY)
315#define GLOBAL2_EEPROM_OP_READ ((4 << 12) | GLOBAL2_EEPROM_OP_BUSY)
316#define GLOBAL2_EEPROM_OP_LOAD BIT(11)
317#define GLOBAL2_EEPROM_OP_WRITE_EN BIT(10)
318#define GLOBAL2_EEPROM_OP_ADDR_MASK 0xff
Andrew Lunncca8b132015-04-02 04:06:39 +0200319#define GLOBAL2_EEPROM_DATA 0x15
320#define GLOBAL2_PTP_AVB_OP 0x16
321#define GLOBAL2_PTP_AVB_DATA 0x17
322#define GLOBAL2_SMI_OP 0x18
323#define GLOBAL2_SMI_OP_BUSY BIT(15)
324#define GLOBAL2_SMI_OP_CLAUSE_22 BIT(12)
325#define GLOBAL2_SMI_OP_22_WRITE ((1 << 10) | GLOBAL2_SMI_OP_BUSY | \
326 GLOBAL2_SMI_OP_CLAUSE_22)
327#define GLOBAL2_SMI_OP_22_READ ((2 << 10) | GLOBAL2_SMI_OP_BUSY | \
328 GLOBAL2_SMI_OP_CLAUSE_22)
329#define GLOBAL2_SMI_OP_45_WRITE_ADDR ((0 << 10) | GLOBAL2_SMI_OP_BUSY)
330#define GLOBAL2_SMI_OP_45_WRITE_DATA ((1 << 10) | GLOBAL2_SMI_OP_BUSY)
331#define GLOBAL2_SMI_OP_45_READ_DATA ((2 << 10) | GLOBAL2_SMI_OP_BUSY)
332#define GLOBAL2_SMI_DATA 0x19
333#define GLOBAL2_SCRATCH_MISC 0x1a
Andrew Lunn56d95e22015-06-20 18:42:33 +0200334#define GLOBAL2_SCRATCH_BUSY BIT(15)
335#define GLOBAL2_SCRATCH_REGISTER_SHIFT 8
336#define GLOBAL2_SCRATCH_VALUE_MASK 0xff
Andrew Lunncca8b132015-04-02 04:06:39 +0200337#define GLOBAL2_WDOG_CONTROL 0x1b
338#define GLOBAL2_QOS_WEIGHT 0x1c
339#define GLOBAL2_MISC 0x1d
Guenter Roeckdefb05b2015-03-26 18:36:38 -0700340
Vivien Didelot3285f9e2016-02-26 13:16:03 -0500341#define MV88E6XXX_N_FID 4096
342
Vivien Didelotf81ec902016-05-09 13:22:58 -0400343/* List of supported models */
344enum mv88e6xxx_model {
345 MV88E6085,
346 MV88E6095,
347 MV88E6123,
348 MV88E6131,
349 MV88E6161,
350 MV88E6165,
351 MV88E6171,
352 MV88E6172,
353 MV88E6175,
354 MV88E6176,
355 MV88E6185,
356 MV88E6240,
357 MV88E6320,
358 MV88E6321,
359 MV88E6350,
360 MV88E6351,
361 MV88E6352,
362};
363
Vivien Didelot22356472016-04-17 13:24:00 -0400364enum mv88e6xxx_family {
365 MV88E6XXX_FAMILY_NONE,
366 MV88E6XXX_FAMILY_6065, /* 6031 6035 6061 6065 */
367 MV88E6XXX_FAMILY_6095, /* 6092 6095 */
368 MV88E6XXX_FAMILY_6097, /* 6046 6085 6096 6097 */
369 MV88E6XXX_FAMILY_6165, /* 6123 6161 6165 */
370 MV88E6XXX_FAMILY_6185, /* 6108 6121 6122 6131 6152 6155 6182 6185 */
371 MV88E6XXX_FAMILY_6320, /* 6320 6321 */
372 MV88E6XXX_FAMILY_6351, /* 6171 6175 6350 6351 */
373 MV88E6XXX_FAMILY_6352, /* 6172 6176 6240 6352 */
374};
375
Vivien Didelot8c9983a2016-05-09 13:22:39 -0400376enum mv88e6xxx_cap {
Vivien Didelot2672f822016-05-09 13:22:48 -0400377 /* Address Translation Unit.
378 * The ATU is used to lookup and learn MAC addresses. See GLOBAL_ATU_OP.
379 */
380 MV88E6XXX_CAP_ATU,
381
Vivien Didelotaadbdb82016-05-09 13:22:44 -0400382 /* Energy Efficient Ethernet.
383 */
384 MV88E6XXX_CAP_EEE,
385
Vivien Didelotd24645b2016-05-09 13:22:41 -0400386 /* EEPROM Command and Data registers.
387 * See GLOBAL2_EEPROM_OP and GLOBAL2_EEPROM_DATA.
388 */
389 MV88E6XXX_CAP_EEPROM,
390
Vivien Didelot914b32f2016-06-20 13:14:11 -0400391 /* Multi-chip Addressing Mode.
392 * Some chips require an indirect SMI access when their SMI device
393 * address is not zero. See SMI_CMD and SMI_DATA.
394 */
395 MV88E6XXX_CAP_MULTI_CHIP,
396
Vivien Didelot936f2342016-05-09 13:22:46 -0400397 /* Port State Filtering for 802.1D Spanning Tree.
398 * See PORT_CONTROL_STATE_* values in the PORT_CONTROL register.
399 */
400 MV88E6XXX_CAP_PORTSTATE,
401
Vivien Didelot8c9983a2016-05-09 13:22:39 -0400402 /* PHY Polling Unit.
403 * See GLOBAL_CONTROL_PPU_ENABLE and GLOBAL_STATUS_PPU_POLLING.
404 */
405 MV88E6XXX_CAP_PPU,
Vivien Didelot552238b2016-05-09 13:22:49 -0400406 MV88E6XXX_CAP_PPU_ACTIVE,
Vivien Didelot6d5834a2016-05-09 13:22:40 -0400407
408 /* SMI PHY Command and Data registers.
409 * This requires an indirect access to PHY registers through
410 * GLOBAL2_SMI_OP, otherwise direct access to PHY registers is done.
411 */
412 MV88E6XXX_CAP_SMI_PHY,
Vivien Didelot6594f612016-05-09 13:22:42 -0400413
Vivien Didelotcb9b9022016-05-10 15:44:29 -0400414 /* Per VLAN Spanning Tree Unit (STU).
415 * The Port State database, if present, is accessed through VTU
416 * operations and dedicated SID registers. See GLOBAL_VTU_SID.
417 */
418 MV88E6XXX_CAP_STU,
419
Vivien Didelot1d13a062016-05-09 13:22:43 -0400420 /* Switch MAC/WoL/WoF register.
421 * This requires an indirect access to set the switch MAC address
422 * through GLOBAL2_SWITCH_MAC, otherwise GLOBAL_MAC_01, GLOBAL_MAC_23,
423 * and GLOBAL_MAC_45 are used with a direct access.
424 */
425 MV88E6XXX_CAP_SWITCH_MAC_WOL_WOF,
426
Vivien Didelot6594f612016-05-09 13:22:42 -0400427 /* Internal temperature sensor.
428 * Available from any enabled port's PHY register 26, page 6.
429 */
430 MV88E6XXX_CAP_TEMP,
431 MV88E6XXX_CAP_TEMP_LIMIT,
Vivien Didelot936f2342016-05-09 13:22:46 -0400432
433 /* In-chip Port Based VLANs.
434 * Each port VLANTable register (see PORT_BASE_VLAN) is used to restrict
435 * the output (or egress) ports to which it is allowed to send frames.
436 */
437 MV88E6XXX_CAP_VLANTABLE,
Vivien Didelot54d77b52016-05-09 13:22:47 -0400438
439 /* VLAN Table Unit.
440 * The VTU is used to program 802.1Q VLANs. See GLOBAL_VTU_OP.
441 */
442 MV88E6XXX_CAP_VTU,
Vivien Didelot8c9983a2016-05-09 13:22:39 -0400443};
Vivien Didelotb5058d72016-05-09 13:22:38 -0400444
Vivien Didelot8c9983a2016-05-09 13:22:39 -0400445/* Bitmask of capabilities */
Vivien Didelot2672f822016-05-09 13:22:48 -0400446#define MV88E6XXX_FLAG_ATU BIT(MV88E6XXX_CAP_ATU)
Vivien Didelotaadbdb82016-05-09 13:22:44 -0400447#define MV88E6XXX_FLAG_EEE BIT(MV88E6XXX_CAP_EEE)
Vivien Didelotd24645b2016-05-09 13:22:41 -0400448#define MV88E6XXX_FLAG_EEPROM BIT(MV88E6XXX_CAP_EEPROM)
Vivien Didelot914b32f2016-06-20 13:14:11 -0400449#define MV88E6XXX_FLAG_MULTI_CHIP BIT(MV88E6XXX_CAP_MULTI_CHIP)
Vivien Didelot936f2342016-05-09 13:22:46 -0400450#define MV88E6XXX_FLAG_PORTSTATE BIT(MV88E6XXX_CAP_PORTSTATE)
Vivien Didelot8c9983a2016-05-09 13:22:39 -0400451#define MV88E6XXX_FLAG_PPU BIT(MV88E6XXX_CAP_PPU)
Vivien Didelot552238b2016-05-09 13:22:49 -0400452#define MV88E6XXX_FLAG_PPU_ACTIVE BIT(MV88E6XXX_CAP_PPU_ACTIVE)
Vivien Didelot6d5834a2016-05-09 13:22:40 -0400453#define MV88E6XXX_FLAG_SMI_PHY BIT(MV88E6XXX_CAP_SMI_PHY)
Vivien Didelotcb9b9022016-05-10 15:44:29 -0400454#define MV88E6XXX_FLAG_STU BIT(MV88E6XXX_CAP_STU)
Vivien Didelot1d13a062016-05-09 13:22:43 -0400455#define MV88E6XXX_FLAG_SWITCH_MAC BIT(MV88E6XXX_CAP_SWITCH_MAC_WOL_WOF)
Vivien Didelot6594f612016-05-09 13:22:42 -0400456#define MV88E6XXX_FLAG_TEMP BIT(MV88E6XXX_CAP_TEMP)
457#define MV88E6XXX_FLAG_TEMP_LIMIT BIT(MV88E6XXX_CAP_TEMP_LIMIT)
Vivien Didelot936f2342016-05-09 13:22:46 -0400458#define MV88E6XXX_FLAG_VLANTABLE BIT(MV88E6XXX_CAP_VLANTABLE)
Vivien Didelot54d77b52016-05-09 13:22:47 -0400459#define MV88E6XXX_FLAG_VTU BIT(MV88E6XXX_CAP_VTU)
Vivien Didelot8c9983a2016-05-09 13:22:39 -0400460
461#define MV88E6XXX_FLAGS_FAMILY_6095 \
Vivien Didelot2672f822016-05-09 13:22:48 -0400462 (MV88E6XXX_FLAG_ATU | \
Vivien Didelot914b32f2016-06-20 13:14:11 -0400463 MV88E6XXX_FLAG_MULTI_CHIP | \
Vivien Didelot2672f822016-05-09 13:22:48 -0400464 MV88E6XXX_FLAG_PPU | \
Vivien Didelot54d77b52016-05-09 13:22:47 -0400465 MV88E6XXX_FLAG_VLANTABLE | \
466 MV88E6XXX_FLAG_VTU)
Vivien Didelot8c9983a2016-05-09 13:22:39 -0400467
468#define MV88E6XXX_FLAGS_FAMILY_6097 \
Vivien Didelot2672f822016-05-09 13:22:48 -0400469 (MV88E6XXX_FLAG_ATU | \
Vivien Didelot914b32f2016-06-20 13:14:11 -0400470 MV88E6XXX_FLAG_MULTI_CHIP | \
Vivien Didelot2672f822016-05-09 13:22:48 -0400471 MV88E6XXX_FLAG_PPU | \
Vivien Didelotcb9b9022016-05-10 15:44:29 -0400472 MV88E6XXX_FLAG_STU | \
Vivien Didelot54d77b52016-05-09 13:22:47 -0400473 MV88E6XXX_FLAG_VLANTABLE | \
474 MV88E6XXX_FLAG_VTU)
Vivien Didelotb5058d72016-05-09 13:22:38 -0400475
Vivien Didelot6594f612016-05-09 13:22:42 -0400476#define MV88E6XXX_FLAGS_FAMILY_6165 \
Vivien Didelot914b32f2016-06-20 13:14:11 -0400477 (MV88E6XXX_FLAG_MULTI_CHIP | \
478 MV88E6XXX_FLAG_STU | \
Vivien Didelotcb9b9022016-05-10 15:44:29 -0400479 MV88E6XXX_FLAG_SWITCH_MAC | \
480 MV88E6XXX_FLAG_TEMP | \
481 MV88E6XXX_FLAG_VTU)
Vivien Didelotb5058d72016-05-09 13:22:38 -0400482
Vivien Didelot8c9983a2016-05-09 13:22:39 -0400483#define MV88E6XXX_FLAGS_FAMILY_6185 \
Vivien Didelot2672f822016-05-09 13:22:48 -0400484 (MV88E6XXX_FLAG_ATU | \
Vivien Didelot914b32f2016-06-20 13:14:11 -0400485 MV88E6XXX_FLAG_MULTI_CHIP | \
Vivien Didelot2672f822016-05-09 13:22:48 -0400486 MV88E6XXX_FLAG_PPU | \
Vivien Didelot54d77b52016-05-09 13:22:47 -0400487 MV88E6XXX_FLAG_VLANTABLE | \
488 MV88E6XXX_FLAG_VTU)
Vivien Didelotb5058d72016-05-09 13:22:38 -0400489
Vivien Didelot6d5834a2016-05-09 13:22:40 -0400490#define MV88E6XXX_FLAGS_FAMILY_6320 \
Vivien Didelot2672f822016-05-09 13:22:48 -0400491 (MV88E6XXX_FLAG_ATU | \
492 MV88E6XXX_FLAG_EEE | \
Vivien Didelotaadbdb82016-05-09 13:22:44 -0400493 MV88E6XXX_FLAG_EEPROM | \
Vivien Didelot914b32f2016-06-20 13:14:11 -0400494 MV88E6XXX_FLAG_MULTI_CHIP | \
Vivien Didelot936f2342016-05-09 13:22:46 -0400495 MV88E6XXX_FLAG_PORTSTATE | \
Vivien Didelot552238b2016-05-09 13:22:49 -0400496 MV88E6XXX_FLAG_PPU_ACTIVE | \
Vivien Didelot6594f612016-05-09 13:22:42 -0400497 MV88E6XXX_FLAG_SMI_PHY | \
Vivien Didelot1d13a062016-05-09 13:22:43 -0400498 MV88E6XXX_FLAG_SWITCH_MAC | \
Vivien Didelot6594f612016-05-09 13:22:42 -0400499 MV88E6XXX_FLAG_TEMP | \
Vivien Didelot936f2342016-05-09 13:22:46 -0400500 MV88E6XXX_FLAG_TEMP_LIMIT | \
Vivien Didelot54d77b52016-05-09 13:22:47 -0400501 MV88E6XXX_FLAG_VLANTABLE | \
502 MV88E6XXX_FLAG_VTU)
Vivien Didelotb5058d72016-05-09 13:22:38 -0400503
Vivien Didelot6d5834a2016-05-09 13:22:40 -0400504#define MV88E6XXX_FLAGS_FAMILY_6351 \
Vivien Didelot2672f822016-05-09 13:22:48 -0400505 (MV88E6XXX_FLAG_ATU | \
Vivien Didelot914b32f2016-06-20 13:14:11 -0400506 MV88E6XXX_FLAG_MULTI_CHIP | \
Vivien Didelot2672f822016-05-09 13:22:48 -0400507 MV88E6XXX_FLAG_PORTSTATE | \
Vivien Didelot552238b2016-05-09 13:22:49 -0400508 MV88E6XXX_FLAG_PPU_ACTIVE | \
Vivien Didelot936f2342016-05-09 13:22:46 -0400509 MV88E6XXX_FLAG_SMI_PHY | \
Vivien Didelotcb9b9022016-05-10 15:44:29 -0400510 MV88E6XXX_FLAG_STU | \
Vivien Didelot1d13a062016-05-09 13:22:43 -0400511 MV88E6XXX_FLAG_SWITCH_MAC | \
Vivien Didelot936f2342016-05-09 13:22:46 -0400512 MV88E6XXX_FLAG_TEMP | \
Vivien Didelot54d77b52016-05-09 13:22:47 -0400513 MV88E6XXX_FLAG_VLANTABLE | \
514 MV88E6XXX_FLAG_VTU)
Vivien Didelotb5058d72016-05-09 13:22:38 -0400515
Vivien Didelot6d5834a2016-05-09 13:22:40 -0400516#define MV88E6XXX_FLAGS_FAMILY_6352 \
Vivien Didelot2672f822016-05-09 13:22:48 -0400517 (MV88E6XXX_FLAG_ATU | \
518 MV88E6XXX_FLAG_EEE | \
Vivien Didelotaadbdb82016-05-09 13:22:44 -0400519 MV88E6XXX_FLAG_EEPROM | \
Vivien Didelot914b32f2016-06-20 13:14:11 -0400520 MV88E6XXX_FLAG_MULTI_CHIP | \
Vivien Didelot936f2342016-05-09 13:22:46 -0400521 MV88E6XXX_FLAG_PORTSTATE | \
Vivien Didelot552238b2016-05-09 13:22:49 -0400522 MV88E6XXX_FLAG_PPU_ACTIVE | \
Vivien Didelot936f2342016-05-09 13:22:46 -0400523 MV88E6XXX_FLAG_SMI_PHY | \
Vivien Didelotcb9b9022016-05-10 15:44:29 -0400524 MV88E6XXX_FLAG_STU | \
Vivien Didelot1d13a062016-05-09 13:22:43 -0400525 MV88E6XXX_FLAG_SWITCH_MAC | \
Vivien Didelot6594f612016-05-09 13:22:42 -0400526 MV88E6XXX_FLAG_TEMP | \
Vivien Didelot936f2342016-05-09 13:22:46 -0400527 MV88E6XXX_FLAG_TEMP_LIMIT | \
Vivien Didelot54d77b52016-05-09 13:22:47 -0400528 MV88E6XXX_FLAG_VLANTABLE | \
529 MV88E6XXX_FLAG_VTU)
Vivien Didelotb5058d72016-05-09 13:22:38 -0400530
Vivien Didelotf6271e62016-04-17 13:23:59 -0400531struct mv88e6xxx_info {
Vivien Didelot22356472016-04-17 13:24:00 -0400532 enum mv88e6xxx_family family;
Vivien Didelotf6271e62016-04-17 13:23:59 -0400533 u16 prod_num;
534 const char *name;
Vivien Didelotcd5a2c82016-04-17 13:24:02 -0400535 unsigned int num_databases;
Vivien Didelot009a2b92016-04-17 13:24:01 -0400536 unsigned int num_ports;
Vivien Didelot9dddd472016-06-20 13:14:10 -0400537 unsigned int port_base_addr;
Vivien Didelotb5058d72016-05-09 13:22:38 -0400538 unsigned long flags;
Vivien Didelotb9b37712015-10-30 19:39:48 -0400539};
540
Vivien Didelotfd231c82015-08-10 09:09:50 -0400541struct mv88e6xxx_atu_entry {
542 u16 fid;
543 u8 state;
544 bool trunk;
545 u16 portv_trunkid;
546 u8 mac[ETH_ALEN];
547};
548
Vivien Didelotb8fee952015-08-13 12:52:19 -0400549struct mv88e6xxx_vtu_stu_entry {
550 /* VTU only */
551 u16 vid;
552 u16 fid;
553
554 /* VTU and STU */
555 u8 sid;
556 bool valid;
557 u8 data[DSA_MAX_PORTS];
558};
559
Vivien Didelot914b32f2016-06-20 13:14:11 -0400560struct mv88e6xxx_ops;
561
Vivien Didelotd715fa62016-02-12 12:09:38 -0500562struct mv88e6xxx_priv_port {
Vivien Didelota6692752016-02-12 12:09:39 -0500563 struct net_device *bridge_dev;
Vivien Didelotd715fa62016-02-12 12:09:38 -0500564};
565
Lennert Buytenhek91da11f2008-10-07 13:44:02 +0000566struct mv88e6xxx_priv_state {
Vivien Didelotf6271e62016-04-17 13:23:59 -0400567 const struct mv88e6xxx_info *info;
568
Andrew Lunn7543a6d2016-04-13 02:40:40 +0200569 /* The dsa_switch this private structure is related to */
570 struct dsa_switch *ds;
571
Andrew Lunn158bc062016-04-28 21:24:06 -0400572 /* The device this structure is associated to */
573 struct device *dev;
574
Vivien Didelot9f8b3ee2016-06-20 13:14:05 -0400575 /* This mutex protects the access to the switch registers */
576 struct mutex reg_lock;
Lennert Buytenhek91da11f2008-10-07 13:44:02 +0000577
Andrew Lunna77d43f2016-04-13 02:40:42 +0200578 /* The MII bus and the address on the bus that is used to
579 * communication with the switch
580 */
Vivien Didelot914b32f2016-06-20 13:14:11 -0400581 const struct mv88e6xxx_ops *smi_ops;
Andrew Lunna77d43f2016-04-13 02:40:42 +0200582 struct mii_bus *bus;
583 int sw_addr;
584
Barry Grussling3675c8d2013-01-08 16:05:53 +0000585 /* Handles automatic disabling and re-enabling of the PHY
Lennert Buytenhek2e5f0322008-10-07 13:45:18 +0000586 * polling unit.
587 */
588 struct mutex ppu_mutex;
589 int ppu_disabled;
590 struct work_struct ppu_work;
591 struct timer_list ppu_timer;
Lennert Buytenhek2e5f0322008-10-07 13:45:18 +0000592
Barry Grussling3675c8d2013-01-08 16:05:53 +0000593 /* This mutex serialises access to the statistics unit.
Lennert Buytenhek91da11f2008-10-07 13:44:02 +0000594 * Hold this mutex over snapshot + dump sequences.
595 */
596 struct mutex stats_mutex;
Peter Korsgaardec80bfc2011-04-05 03:03:56 +0000597
Guenter Roeck3ad50cc2014-10-29 10:44:56 -0700598 /* This mutex serializes phy access for chips with
599 * indirect phy addressing. It is unused for chips
600 * with direct phy access.
601 */
602 struct mutex phy_mutex;
603
Guenter Roeck33b43df2014-10-29 10:45:03 -0700604 /* This mutex serializes eeprom access for chips with
605 * eeprom support.
606 */
607 struct mutex eeprom_mutex;
608
Vivien Didelotd715fa62016-02-12 12:09:38 -0500609 struct mv88e6xxx_priv_port ports[DSA_MAX_PORTS];
610
Andrew Lunn52638f72016-05-10 23:27:22 +0200611 /* A switch may have a GPIO line tied to its reset pin. Parse
612 * this from the device tree, and use it before performing
613 * switch soft reset.
614 */
615 struct gpio_desc *reset;
Andrew Lunnf8cd8752016-05-10 23:27:25 +0200616
617 /* set to size of eeprom if supported by the switch */
618 int eeprom_len;
Andrew Lunnb516d452016-06-04 21:17:06 +0200619
620 /* Device node for the MDIO bus */
621 struct device_node *mdio_np;
622
623 /* And the MDIO bus itself */
624 struct mii_bus *mdio_bus;
Lennert Buytenhek91da11f2008-10-07 13:44:02 +0000625};
626
Vivien Didelot914b32f2016-06-20 13:14:11 -0400627struct mv88e6xxx_ops {
628 int (*read)(struct mv88e6xxx_priv_state *ps,
629 int addr, int reg, u16 *val);
630 int (*write)(struct mv88e6xxx_priv_state *ps,
631 int addr, int reg, u16 val);
632};
633
Andrew Lunnf5e2ed02015-12-23 13:23:17 +0100634enum stat_type {
635 BANK0,
636 BANK1,
637 PORT,
638};
639
Lennert Buytenhek91da11f2008-10-07 13:44:02 +0000640struct mv88e6xxx_hw_stat {
641 char string[ETH_GSTRING_LEN];
642 int sizeof_stat;
643 int reg;
Andrew Lunnf5e2ed02015-12-23 13:23:17 +0100644 enum stat_type type;
Lennert Buytenhek91da11f2008-10-07 13:44:02 +0000645};
646
Vivien Didelotb5058d72016-05-09 13:22:38 -0400647static inline bool mv88e6xxx_has(struct mv88e6xxx_priv_state *ps,
648 unsigned long flags)
649{
650 return (ps->info->flags & flags) == flags;
651}
652
Lennert Buytenhek91da11f2008-10-07 13:44:02 +0000653#endif