summaryrefslogtreecommitdiff
path: root/drivers/net/ethernet/sunplus/spl2sw_define.h
blob: acc6c1228ebc747977cfc893c1aa421df0f41206 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
/* SPDX-License-Identifier: GPL-2.0 */
/* Copyright Sunplus Technology Co., Ltd.
 *       All rights reserved.
 */

#ifndef __SPL2SW_DEFINE_H__
#define __SPL2SW_DEFINE_H__

#define MAX_NETDEV_NUM			2	/* Maximum # of net-device */

/* Interrupt status */
#define MAC_INT_DAISY_MODE_CHG		BIT(31) /* Daisy Mode Change             */
#define MAC_INT_IP_CHKSUM_ERR		BIT(23) /* IP Checksum Append Error      */
#define MAC_INT_WDOG_TIMER1_EXP		BIT(22) /* Watchdog Timer1 Expired       */
#define MAC_INT_WDOG_TIMER0_EXP		BIT(21) /* Watchdog Timer0 Expired       */
#define MAC_INT_INTRUDER_ALERT		BIT(20) /* Atruder Alert                 */
#define MAC_INT_PORT_ST_CHG		BIT(19) /* Port Status Change            */
#define MAC_INT_BC_STORM		BIT(18) /* Broad Cast Storm              */
#define MAC_INT_MUST_DROP_LAN		BIT(17) /* Global Queue Exhausted        */
#define MAC_INT_GLOBAL_QUE_FULL		BIT(16) /* Global Queue Full             */
#define MAC_INT_TX_SOC_PAUSE_ON		BIT(15) /* Soc Port TX Pause On          */
#define MAC_INT_RX_SOC_QUE_FULL		BIT(14) /* Soc Port Out Queue Full       */
#define MAC_INT_TX_LAN1_QUE_FULL	BIT(9)  /* Port 1 Out Queue Full         */
#define MAC_INT_TX_LAN0_QUE_FULL	BIT(8)  /* Port 0 Out Queue Full         */
#define MAC_INT_RX_L_DESCF		BIT(7)  /* Low Priority Descriptor Full  */
#define MAC_INT_RX_H_DESCF		BIT(6)  /* High Priority Descriptor Full */
#define MAC_INT_RX_DONE_L		BIT(5)  /* RX Low Priority Done          */
#define MAC_INT_RX_DONE_H		BIT(4)  /* RX High Priority Done         */
#define MAC_INT_TX_DONE_L		BIT(3)  /* TX Low Priority Done          */
#define MAC_INT_TX_DONE_H		BIT(2)  /* TX High Priority Done         */
#define MAC_INT_TX_DES_ERR		BIT(1)  /* TX Descriptor Error           */
#define MAC_INT_RX_DES_ERR		BIT(0)  /* Rx Descriptor Error           */

#define MAC_INT_RX			(MAC_INT_RX_DONE_H | MAC_INT_RX_DONE_L | \
					MAC_INT_RX_DES_ERR)
#define MAC_INT_TX			(MAC_INT_TX_DONE_L | MAC_INT_TX_DONE_H | \
					MAC_INT_TX_DES_ERR)
#define MAC_INT_MASK_DEF		(MAC_INT_DAISY_MODE_CHG | MAC_INT_IP_CHKSUM_ERR | \
					MAC_INT_WDOG_TIMER1_EXP | MAC_INT_WDOG_TIMER0_EXP | \
					MAC_INT_INTRUDER_ALERT | MAC_INT_PORT_ST_CHG | \
					MAC_INT_BC_STORM | MAC_INT_MUST_DROP_LAN | \
					MAC_INT_GLOBAL_QUE_FULL | MAC_INT_TX_SOC_PAUSE_ON | \
					MAC_INT_RX_SOC_QUE_FULL | MAC_INT_TX_LAN1_QUE_FULL | \
					MAC_INT_TX_LAN0_QUE_FULL | MAC_INT_RX_L_DESCF | \
					MAC_INT_RX_H_DESCF)

/* Address table search */
#define MAC_ADDR_LOOKUP_IDLE		BIT(2)
#define MAC_SEARCH_NEXT_ADDR		BIT(1)
#define MAC_BEGIN_SEARCH_ADDR		BIT(0)

/* Address table status */
#define MAC_HASH_LOOKUP_ADDR		GENMASK(31, 22)
#define MAC_R_PORT_MAP			GENMASK(13, 12)
#define MAC_R_CPU_PORT			GENMASK(11, 10)
#define MAC_R_VID			GENMASK(9, 7)
#define MAC_R_AGE			GENMASK(6, 4)
#define MAC_R_PROXY			BIT(3)
#define MAC_R_MC_INGRESS		BIT(2)
#define MAC_AT_TABLE_END		BIT(1)
#define MAC_AT_DATA_READY		BIT(0)

/* Wt mac ad0 */
#define MAC_W_PORT_MAP			GENMASK(13, 12)
#define MAC_W_LAN_PORT_1		BIT(13)
#define MAC_W_LAN_PORT_0		BIT(12)
#define MAC_W_CPU_PORT			GENMASK(11, 10)
#define MAC_W_CPU_PORT_1		BIT(11)
#define MAC_W_CPU_PORT_0		BIT(10)
#define MAC_W_VID			GENMASK(9, 7)
#define MAC_W_AGE			GENMASK(6, 4)
#define MAC_W_PROXY			BIT(3)
#define MAC_W_MC_INGRESS		BIT(2)
#define MAC_W_MAC_DONE			BIT(1)
#define MAC_W_MAC_CMD			BIT(0)

/* W mac 15_0 bus */
#define MAC_W_MAC_15_0			GENMASK(15, 0)

/* W mac 47_16 bus */
#define MAC_W_MAC_47_16			GENMASK(31, 0)

/* PVID config 0 */
#define MAC_P1_PVID			GENMASK(6, 4)
#define MAC_P0_PVID			GENMASK(2, 0)

/* VLAN member config 0 */
#define MAC_VLAN_MEMSET_3		GENMASK(27, 24)
#define MAC_VLAN_MEMSET_2		GENMASK(19, 16)
#define MAC_VLAN_MEMSET_1		GENMASK(11, 8)
#define MAC_VLAN_MEMSET_0		GENMASK(3, 0)

/* VLAN member config 1 */
#define MAC_VLAN_MEMSET_5		GENMASK(11, 8)
#define MAC_VLAN_MEMSET_4		GENMASK(3, 0)

/* Port ability */
#define MAC_PORT_ABILITY_LINK_ST	GENMASK(25, 24)

/* CPU control */
#define MAC_EN_SOC1_AGING		BIT(15)
#define MAC_EN_SOC0_AGING		BIT(14)
#define MAC_DIS_LRN_SOC1		BIT(13)
#define MAC_DIS_LRN_SOC0		BIT(12)
#define MAC_EN_CRC_SOC1			BIT(9)
#define MAC_EN_CRC_SOC0			BIT(8)
#define MAC_DIS_SOC1_CPU		BIT(7)
#define MAC_DIS_SOC0_CPU		BIT(6)
#define MAC_DIS_BC2CPU_P1		BIT(5)
#define MAC_DIS_BC2CPU_P0		BIT(4)
#define MAC_DIS_MC2CPU			GENMASK(3, 2)
#define MAC_DIS_MC2CPU_P1		BIT(3)
#define MAC_DIS_MC2CPU_P0		BIT(2)
#define MAC_DIS_UN2CPU			GENMASK(1, 0)

/* Port control 0 */
#define MAC_DIS_PORT			GENMASK(25, 24)
#define MAC_DIS_PORT1			BIT(25)
#define MAC_DIS_PORT0			BIT(24)
#define MAC_DIS_RMC2CPU_P1		BIT(17)
#define MAC_DIS_RMC2CPU_P0		BIT(16)
#define MAC_EN_FLOW_CTL_P1		BIT(9)
#define MAC_EN_FLOW_CTL_P0		BIT(8)
#define MAC_EN_BACK_PRESS_P1		BIT(1)
#define MAC_EN_BACK_PRESS_P0		BIT(0)

/* Port control 1 */
#define MAC_DIS_SA_LRN_P1		BIT(9)
#define MAC_DIS_SA_LRN_P0		BIT(8)

/* Port control 2 */
#define MAC_EN_AGING_P1			BIT(9)
#define MAC_EN_AGING_P0			BIT(8)

/* Switch Global control */
#define MAC_RMC_TB_FAULT_RULE		GENMASK(26, 25)
#define MAC_LED_FLASH_TIME		GENMASK(24, 23)
#define MAC_BC_STORM_PREV		GENMASK(5, 4)

/* LED port 0 */
#define MAC_LED_ACT_HI			BIT(28)

/* PHY control register 0  */
#define MAC_CPU_PHY_WT_DATA		GENMASK(31, 16)
#define MAC_CPU_PHY_CMD			GENMASK(14, 13)
#define MAC_CPU_PHY_REG_ADDR		GENMASK(12, 8)
#define MAC_CPU_PHY_ADDR		GENMASK(4, 0)

/* PHY control register 1 */
#define MAC_CPU_PHY_RD_DATA		GENMASK(31, 16)
#define MAC_PHY_RD_RDY			BIT(1)
#define MAC_PHY_WT_DONE			BIT(0)

/* MAC force mode */
#define MAC_EXT_PHY1_ADDR		GENMASK(28, 24)
#define MAC_EXT_PHY0_ADDR		GENMASK(20, 16)
#define MAC_FORCE_RMII_LINK		GENMASK(9, 8)
#define MAC_FORCE_RMII_EN_1		BIT(7)
#define MAC_FORCE_RMII_EN_0		BIT(6)
#define MAC_FORCE_RMII_FC		GENMASK(5, 4)
#define MAC_FORCE_RMII_DPX		GENMASK(3, 2)
#define MAC_FORCE_RMII_SPD		GENMASK(1, 0)

/* CPU transmit trigger */
#define MAC_TRIG_L_SOC0			BIT(1)
#define MAC_TRIG_H_SOC0			BIT(0)

/* Config descriptor queue */
#define TX_DESC_NUM			16	/* # of descriptors in TX queue   */
#define MAC_GUARD_DESC_NUM		2	/* # of descriptors of gap      0 */
#define RX_QUEUE0_DESC_NUM		16	/* # of descriptors in RX queue 0 */
#define RX_QUEUE1_DESC_NUM		16	/* # of descriptors in RX queue 1 */
#define TX_DESC_QUEUE_NUM		1	/* # of TX queue                  */
#define RX_DESC_QUEUE_NUM		2	/* # of RX queue                  */

#define MAC_RX_LEN_MAX			2047	/* Size of RX buffer       */

/* Tx descriptor */
/* cmd1 */
#define TXD_OWN				BIT(31)
#define TXD_ERR_CODE			GENMASK(29, 26)
#define TXD_SOP				BIT(25)		/* start of a packet */
#define TXD_EOP				BIT(24)		/* end of a packet */
#define TXD_VLAN			GENMASK(17, 12)
#define TXD_PKT_LEN			GENMASK(10, 0)	/* packet length */
/* cmd2 */
#define TXD_EOR				BIT(31)		/* end of ring */
#define TXD_BUF_LEN2			GENMASK(22, 12)
#define TXD_BUF_LEN1			GENMASK(10, 0)

/* Rx descriptor */
/* cmd1 */
#define RXD_OWN				BIT(31)
#define RXD_ERR_CODE			GENMASK(29, 26)
#define RXD_TCP_UDP_CHKSUM		BIT(23)
#define RXD_PROXY			BIT(22)
#define RXD_PROTOCOL			GENMASK(21, 20)
#define RXD_VLAN_TAG			BIT(19)
#define RXD_IP_CHKSUM			BIT(18)
#define RXD_ROUTE_TYPE			GENMASK(17, 16)
#define RXD_PKT_SP			GENMASK(14, 12)	/* packet source port */
#define RXD_PKT_LEN			GENMASK(10, 0)	/* packet length */
/* cmd2 */
#define RXD_EOR				BIT(31)		/* end of ring */
#define RXD_BUF_LEN2			GENMASK(22, 12)
#define RXD_BUF_LEN1			GENMASK(10, 0)

/* structure of descriptor */
struct spl2sw_mac_desc {
	u32 cmd1;
	u32 cmd2;
	u32 addr1;
	u32 addr2;
};

struct spl2sw_skb_info {
	struct sk_buff *skb;
	u32 mapping;
	u32 len;
};

struct spl2sw_common {
	void __iomem *l2sw_reg_base;

	struct platform_device *pdev;
	struct reset_control *rstc;
	struct clk *clk;

	void *desc_base;
	dma_addr_t desc_dma;
	s32 desc_size;
	struct spl2sw_mac_desc *rx_desc[RX_DESC_QUEUE_NUM];
	struct spl2sw_skb_info *rx_skb_info[RX_DESC_QUEUE_NUM];
	u32 rx_pos[RX_DESC_QUEUE_NUM];
	u32 rx_desc_num[RX_DESC_QUEUE_NUM];
	u32 rx_desc_buff_size;

	struct spl2sw_mac_desc *tx_desc;
	struct spl2sw_skb_info tx_temp_skb_info[TX_DESC_NUM];
	u32 tx_done_pos;
	u32 tx_pos;
	u32 tx_desc_full;

	struct net_device *ndev[MAX_NETDEV_NUM];
	struct mii_bus *mii_bus;

	struct napi_struct rx_napi;
	struct napi_struct tx_napi;

	spinlock_t tx_lock;		/* spinlock for accessing tx buffer */
	spinlock_t mdio_lock;		/* spinlock for mdio commands */
	spinlock_t int_mask_lock;	/* spinlock for accessing int mask reg. */

	u8 enable;
};

struct spl2sw_mac {
	struct net_device *ndev;
	struct spl2sw_common *comm;

	u8 mac_addr[ETH_ALEN];
	phy_interface_t phy_mode;
	struct device_node *phy_node;

	u8 lan_port;
	u8 to_vlan;
	u8 vlan_id;
};

#endif