summaryrefslogtreecommitdiffstats
path: root/drivers/net/ethernet/actions/owl-emac.h
blob: 9eb0d1a302420a637c16a361c27b9fa7658e1496 (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
271
272
273
274
275
276
277
278
279
280
/* SPDX-License-Identifier: GPL-2.0-or-later */
/*
 * Actions Semi Owl SoCs Ethernet MAC driver
 *
 * Copyright (c) 2012 Actions Semi Inc.
 * Copyright (c) 2021 Cristian Ciocaltea <cristian.ciocaltea@gmail.com>
 */

#ifndef __OWL_EMAC_H__
#define __OWL_EMAC_H__

#define OWL_EMAC_DRVNAME			"owl-emac"

#define OWL_EMAC_POLL_DELAY_USEC		5
#define OWL_EMAC_MDIO_POLL_TIMEOUT_USEC		1000
#define OWL_EMAC_RESET_POLL_TIMEOUT_USEC	2000
#define OWL_EMAC_TX_TIMEOUT			(2 * HZ)

#define OWL_EMAC_MTU_MIN			ETH_MIN_MTU
#define OWL_EMAC_MTU_MAX			ETH_DATA_LEN
#define OWL_EMAC_RX_FRAME_MAX_LEN		(ETH_FRAME_LEN + ETH_FCS_LEN)
#define OWL_EMAC_SKB_ALIGN			4
#define OWL_EMAC_SKB_RESERVE			18

#define OWL_EMAC_MAX_MULTICAST_ADDRS		14
#define OWL_EMAC_SETUP_FRAME_LEN		192

#define OWL_EMAC_RX_RING_SIZE			64
#define OWL_EMAC_TX_RING_SIZE			32

/* Bus mode register */
#define OWL_EMAC_REG_MAC_CSR0			0x0000
#define OWL_EMAC_BIT_MAC_CSR0_SWR		BIT(0)	/* Software reset */

/* Transmit/receive poll demand registers */
#define OWL_EMAC_REG_MAC_CSR1			0x0008
#define OWL_EMAC_VAL_MAC_CSR1_TPD		0x01
#define OWL_EMAC_REG_MAC_CSR2			0x0010
#define OWL_EMAC_VAL_MAC_CSR2_RPD		0x01

/* Receive/transmit descriptor list base address registers */
#define OWL_EMAC_REG_MAC_CSR3			0x0018
#define OWL_EMAC_REG_MAC_CSR4			0x0020

/* Status register */
#define OWL_EMAC_REG_MAC_CSR5			0x0028
#define OWL_EMAC_MSK_MAC_CSR5_TS		GENMASK(22, 20)	/* Transmit process state */
#define OWL_EMAC_OFF_MAC_CSR5_TS		20
#define OWL_EMAC_VAL_MAC_CSR5_TS_DATA		0x03	/* Transferring data HOST -> FIFO */
#define OWL_EMAC_VAL_MAC_CSR5_TS_CDES		0x07	/* Closing transmit descriptor */
#define OWL_EMAC_MSK_MAC_CSR5_RS		GENMASK(19, 17)	/* Receive process state */
#define OWL_EMAC_OFF_MAC_CSR5_RS		17
#define OWL_EMAC_VAL_MAC_CSR5_RS_FDES		0x01	/* Fetching receive descriptor */
#define OWL_EMAC_VAL_MAC_CSR5_RS_CDES		0x05	/* Closing receive descriptor */
#define OWL_EMAC_VAL_MAC_CSR5_RS_DATA		0x07	/* Transferring data FIFO -> HOST */
#define OWL_EMAC_BIT_MAC_CSR5_NIS		BIT(16)	/* Normal interrupt summary */
#define OWL_EMAC_BIT_MAC_CSR5_AIS		BIT(15)	/* Abnormal interrupt summary */
#define OWL_EMAC_BIT_MAC_CSR5_ERI		BIT(14)	/* Early receive interrupt */
#define OWL_EMAC_BIT_MAC_CSR5_GTE		BIT(11)	/* General-purpose timer expiration */
#define OWL_EMAC_BIT_MAC_CSR5_ETI		BIT(10)	/* Early transmit interrupt */
#define OWL_EMAC_BIT_MAC_CSR5_RPS		BIT(8)	/* Receive process stopped */
#define OWL_EMAC_BIT_MAC_CSR5_RU		BIT(7)	/* Receive buffer unavailable */
#define OWL_EMAC_BIT_MAC_CSR5_RI		BIT(6)	/* Receive interrupt */
#define OWL_EMAC_BIT_MAC_CSR5_UNF		BIT(5)	/* Transmit underflow */
#define OWL_EMAC_BIT_MAC_CSR5_LCIS		BIT(4)	/* Link change status */
#define OWL_EMAC_BIT_MAC_CSR5_LCIQ		BIT(3)	/* Link change interrupt */
#define OWL_EMAC_BIT_MAC_CSR5_TU		BIT(2)	/* Transmit buffer unavailable */
#define OWL_EMAC_BIT_MAC_CSR5_TPS		BIT(1)	/* Transmit process stopped */
#define OWL_EMAC_BIT_MAC_CSR5_TI		BIT(0)	/* Transmit interrupt */

/* Operation mode register */
#define OWL_EMAC_REG_MAC_CSR6			0x0030
#define OWL_EMAC_BIT_MAC_CSR6_RA		BIT(30)	/* Receive all */
#define OWL_EMAC_BIT_MAC_CSR6_TTM		BIT(22)	/* Transmit threshold mode */
#define OWL_EMAC_BIT_MAC_CSR6_SF		BIT(21)	/* Store and forward */
#define OWL_EMAC_MSK_MAC_CSR6_SPEED		GENMASK(17, 16)	/* Eth speed selection */
#define OWL_EMAC_OFF_MAC_CSR6_SPEED		16
#define OWL_EMAC_VAL_MAC_CSR6_SPEED_100M	0x00
#define OWL_EMAC_VAL_MAC_CSR6_SPEED_10M		0x02
#define OWL_EMAC_BIT_MAC_CSR6_ST		BIT(13)	/* Start/stop transmit command */
#define OWL_EMAC_BIT_MAC_CSR6_LP		BIT(10)	/* Loopback mode */
#define OWL_EMAC_BIT_MAC_CSR6_FD		BIT(9)	/* Full duplex mode */
#define OWL_EMAC_BIT_MAC_CSR6_PM		BIT(7)	/* Pass all multicast */
#define OWL_EMAC_BIT_MAC_CSR6_PR		BIT(6)	/* Promiscuous mode */
#define OWL_EMAC_BIT_MAC_CSR6_IF		BIT(4)	/* Inverse filtering */
#define OWL_EMAC_BIT_MAC_CSR6_PB		BIT(3)	/* Pass bad frames */
#define OWL_EMAC_BIT_MAC_CSR6_HO		BIT(2)	/* Hash only filtering mode */
#define OWL_EMAC_BIT_MAC_CSR6_SR		BIT(1)	/* Start/stop receive command */
#define OWL_EMAC_BIT_MAC_CSR6_HP		BIT(0)	/* Hash/perfect receive filtering mode */
#define OWL_EMAC_MSK_MAC_CSR6_STSR	       (OWL_EMAC_BIT_MAC_CSR6_ST | \
						OWL_EMAC_BIT_MAC_CSR6_SR)

/* Interrupt enable register */
#define OWL_EMAC_REG_MAC_CSR7			0x0038
#define OWL_EMAC_BIT_MAC_CSR7_NIE		BIT(16)	/* Normal interrupt summary enable */
#define OWL_EMAC_BIT_MAC_CSR7_AIE		BIT(15)	/* Abnormal interrupt summary enable */
#define OWL_EMAC_BIT_MAC_CSR7_ERE		BIT(14)	/* Early receive interrupt enable */
#define OWL_EMAC_BIT_MAC_CSR7_GTE		BIT(11)	/* General-purpose timer overflow */
#define OWL_EMAC_BIT_MAC_CSR7_ETE		BIT(10)	/* Early transmit interrupt enable */
#define OWL_EMAC_BIT_MAC_CSR7_RSE		BIT(8)	/* Receive stopped enable */
#define OWL_EMAC_BIT_MAC_CSR7_RUE		BIT(7)	/* Receive buffer unavailable enable */
#define OWL_EMAC_BIT_MAC_CSR7_RIE		BIT(6)	/* Receive interrupt enable */
#define OWL_EMAC_BIT_MAC_CSR7_UNE		BIT(5)	/* Underflow interrupt enable */
#define OWL_EMAC_BIT_MAC_CSR7_TUE		BIT(2)	/* Transmit buffer unavailable enable */
#define OWL_EMAC_BIT_MAC_CSR7_TSE		BIT(1)	/* Transmit stopped enable */
#define OWL_EMAC_BIT_MAC_CSR7_TIE		BIT(0)	/* Transmit interrupt enable */
#define OWL_EMAC_BIT_MAC_CSR7_ALL_NOT_TUE      (OWL_EMAC_BIT_MAC_CSR7_ERE | \
						OWL_EMAC_BIT_MAC_CSR7_GTE | \
						OWL_EMAC_BIT_MAC_CSR7_ETE | \
						OWL_EMAC_BIT_MAC_CSR7_RSE | \
						OWL_EMAC_BIT_MAC_CSR7_RUE | \
						OWL_EMAC_BIT_MAC_CSR7_RIE | \
						OWL_EMAC_BIT_MAC_CSR7_UNE | \
						OWL_EMAC_BIT_MAC_CSR7_TSE | \
						OWL_EMAC_BIT_MAC_CSR7_TIE)

/* Missed frames and overflow counter register */
#define OWL_EMAC_REG_MAC_CSR8			0x0040
/* MII management and serial ROM register */
#define OWL_EMAC_REG_MAC_CSR9			0x0048

/* MII serial management register */
#define OWL_EMAC_REG_MAC_CSR10			0x0050
#define OWL_EMAC_BIT_MAC_CSR10_SB		BIT(31)	/* Start transfer or busy */
#define OWL_EMAC_MSK_MAC_CSR10_CLKDIV		GENMASK(30, 28)	/* Clock divider */
#define OWL_EMAC_OFF_MAC_CSR10_CLKDIV		28
#define OWL_EMAC_VAL_MAC_CSR10_CLKDIV_128	0x04
#define OWL_EMAC_VAL_MAC_CSR10_OPCODE_WR	0x01	/* Register write command */
#define OWL_EMAC_OFF_MAC_CSR10_OPCODE		26	/* Operation mode */
#define OWL_EMAC_VAL_MAC_CSR10_OPCODE_DCG	0x00	/* Disable clock generation */
#define OWL_EMAC_VAL_MAC_CSR10_OPCODE_WR	0x01	/* Register write command */
#define OWL_EMAC_VAL_MAC_CSR10_OPCODE_RD	0x02	/* Register read command */
#define OWL_EMAC_VAL_MAC_CSR10_OPCODE_CDS	0x03	/* Clock divider set */
#define OWL_EMAC_MSK_MAC_CSR10_PHYADD		GENMASK(25, 21)	/* Physical layer address */
#define OWL_EMAC_OFF_MAC_CSR10_PHYADD		21
#define OWL_EMAC_MSK_MAC_CSR10_REGADD		GENMASK(20, 16)	/* Register address */
#define OWL_EMAC_OFF_MAC_CSR10_REGADD		16
#define OWL_EMAC_MSK_MAC_CSR10_DATA		GENMASK(15, 0)	/* Register data */

/* General-purpose timer and interrupt mitigation control register */
#define OWL_EMAC_REG_MAC_CSR11			0x0058
#define OWL_EMAC_OFF_MAC_CSR11_TT		27	/* Transmit timer */
#define OWL_EMAC_OFF_MAC_CSR11_NTP		24	/* No. of transmit packets */
#define OWL_EMAC_OFF_MAC_CSR11_RT		20	/* Receive timer */
#define OWL_EMAC_OFF_MAC_CSR11_NRP		17	/* No. of receive packets */

/* MAC address low/high registers */
#define OWL_EMAC_REG_MAC_CSR16			0x0080
#define OWL_EMAC_REG_MAC_CSR17			0x0088

/* Pause time & cache thresholds register */
#define OWL_EMAC_REG_MAC_CSR18			0x0090
#define OWL_EMAC_OFF_MAC_CSR18_CPTL		24	/* Cache pause threshold level */
#define OWL_EMAC_OFF_MAC_CSR18_CRTL		16	/* Cache restart threshold level */
#define OWL_EMAC_OFF_MAC_CSR18_PQT		0	/* Flow control pause quanta time */

/* FIFO pause & restart threshold register */
#define OWL_EMAC_REG_MAC_CSR19			0x0098
#define OWL_EMAC_OFF_MAC_CSR19_FPTL		16	/* FIFO pause threshold level */
#define OWL_EMAC_OFF_MAC_CSR19_FRTL		0	/* FIFO restart threshold level */

/* Flow control setup & status register */
#define OWL_EMAC_REG_MAC_CSR20			0x00A0
#define OWL_EMAC_BIT_MAC_CSR20_FCE		BIT(31)	/* Flow Control Enable */
#define OWL_EMAC_BIT_MAC_CSR20_TUE		BIT(30)	/* Transmit Un-pause frames Enable */
#define OWL_EMAC_BIT_MAC_CSR20_TPE		BIT(29)	/* Transmit Pause frames Enable */
#define OWL_EMAC_BIT_MAC_CSR20_RPE		BIT(28)	/* Receive Pause frames Enable */
#define OWL_EMAC_BIT_MAC_CSR20_BPE		BIT(27)	/* Back pressure (half-duplex) Enable */

/* MII control register */
#define OWL_EMAC_REG_MAC_CTRL			0x00B0
#define OWL_EMAC_BIT_MAC_CTRL_RRSB		BIT(8)	/* RMII_REFCLK select bit */
#define OWL_EMAC_OFF_MAC_CTRL_SSDC		4	/* SMII SYNC delay cycle */
#define OWL_EMAC_BIT_MAC_CTRL_RCPS		BIT(1)	/* REF_CLK phase select */
#define OWL_EMAC_BIT_MAC_CTRL_RSIS		BIT(0)	/* RMII/SMII interface select */

/* Receive descriptor status field */
#define OWL_EMAC_BIT_RDES0_OWN			BIT(31)	/* Ownership bit */
#define OWL_EMAC_BIT_RDES0_FF			BIT(30)	/* Filtering fail */
#define OWL_EMAC_MSK_RDES0_FL			GENMASK(29, 16)	/* Frame length */
#define OWL_EMAC_OFF_RDES0_FL			16
#define OWL_EMAC_BIT_RDES0_ES			BIT(15)	/* Error summary */
#define OWL_EMAC_BIT_RDES0_DE			BIT(14)	/* Descriptor error */
#define OWL_EMAC_BIT_RDES0_RF			BIT(11)	/* Runt frame */
#define OWL_EMAC_BIT_RDES0_MF			BIT(10)	/* Multicast frame */
#define OWL_EMAC_BIT_RDES0_FS			BIT(9)	/* First descriptor */
#define OWL_EMAC_BIT_RDES0_LS			BIT(8)	/* Last descriptor */
#define OWL_EMAC_BIT_RDES0_TL			BIT(7)	/* Frame too long */
#define OWL_EMAC_BIT_RDES0_CS			BIT(6)	/* Collision seen */
#define OWL_EMAC_BIT_RDES0_FT			BIT(5)	/* Frame type */
#define OWL_EMAC_BIT_RDES0_RE			BIT(3)	/* Report on MII error */
#define OWL_EMAC_BIT_RDES0_DB			BIT(2)	/* Dribbling bit */
#define OWL_EMAC_BIT_RDES0_CE			BIT(1)	/* CRC error */
#define OWL_EMAC_BIT_RDES0_ZERO			BIT(0)	/* Legal frame length indicator */

/* Receive descriptor control and count field */
#define OWL_EMAC_BIT_RDES1_RER			BIT(25)	/* Receive end of ring */
#define OWL_EMAC_MSK_RDES1_RBS1			GENMASK(10, 0) /* Buffer 1 size */

/* Transmit descriptor status field */
#define OWL_EMAC_BIT_TDES0_OWN			BIT(31)	/* Ownership bit */
#define OWL_EMAC_BIT_TDES0_ES			BIT(15)	/* Error summary */
#define OWL_EMAC_BIT_TDES0_LO			BIT(11)	/* Loss of carrier */
#define OWL_EMAC_BIT_TDES0_NC			BIT(10)	/* No carrier */
#define OWL_EMAC_BIT_TDES0_LC			BIT(9)	/* Late collision */
#define OWL_EMAC_BIT_TDES0_EC			BIT(8)	/* Excessive collisions */
#define OWL_EMAC_MSK_TDES0_CC			GENMASK(6, 3) /* Collision count */
#define OWL_EMAC_BIT_TDES0_UF			BIT(1)	/* Underflow error */
#define OWL_EMAC_BIT_TDES0_DE			BIT(0)	/* Deferred */

/* Transmit descriptor control and count field */
#define OWL_EMAC_BIT_TDES1_IC			BIT(31)	/* Interrupt on completion */
#define OWL_EMAC_BIT_TDES1_LS			BIT(30)	/* Last descriptor */
#define OWL_EMAC_BIT_TDES1_FS			BIT(29)	/* First descriptor */
#define OWL_EMAC_BIT_TDES1_FT1			BIT(28)	/* Filtering type */
#define OWL_EMAC_BIT_TDES1_SET			BIT(27)	/* Setup packet */
#define OWL_EMAC_BIT_TDES1_AC			BIT(26)	/* Add CRC disable */
#define OWL_EMAC_BIT_TDES1_TER			BIT(25)	/* Transmit end of ring */
#define OWL_EMAC_BIT_TDES1_DPD			BIT(23)	/* Disabled padding */
#define OWL_EMAC_BIT_TDES1_FT0			BIT(22)	/* Filtering type */
#define OWL_EMAC_MSK_TDES1_TBS1			GENMASK(10, 0) /* Buffer 1 size */

static const char *const owl_emac_clk_names[] = { "eth", "rmii" };
#define OWL_EMAC_NCLKS ARRAY_SIZE(owl_emac_clk_names)

enum owl_emac_clk_map {
	OWL_EMAC_CLK_ETH = 0,
	OWL_EMAC_CLK_RMII
};

struct owl_emac_addr_list {
	u8 addrs[OWL_EMAC_MAX_MULTICAST_ADDRS][ETH_ALEN];
	int count;
};

/* TX/RX descriptors */
struct owl_emac_ring_desc {
	u32 status;
	u32 control;
	u32 buf_addr;
	u32 reserved;		/* 2nd buffer address is not used */
};

struct owl_emac_ring {
	struct owl_emac_ring_desc *descs;
	dma_addr_t descs_dma;
	struct sk_buff **skbs;
	dma_addr_t *skbs_dma;
	unsigned int size;
	unsigned int head;
	unsigned int tail;
};

struct owl_emac_priv {
	struct net_device *netdev;
	void __iomem *base;

	struct clk_bulk_data clks[OWL_EMAC_NCLKS];
	struct reset_control *reset;

	struct owl_emac_ring rx_ring;
	struct owl_emac_ring tx_ring;

	struct mii_bus *mii;
	struct napi_struct napi;

	phy_interface_t phy_mode;
	unsigned int link;
	int speed;
	int duplex;
	int pause;
	struct owl_emac_addr_list mcaddr_list;

	struct work_struct mac_reset_task;

	u32 msg_enable;		/* Debug message level */
	spinlock_t lock;	/* Sync concurrent ring access */
};

#endif /* __OWL_EMAC_H__ */