xref: /openbmc/u-boot/drivers/net/gmac_rockchip.c (revision c40b6df87fc0193a7184ada9f53aaf57cdec0cdf)
1 // SPDX-License-Identifier: GPL-2.0+
2 /*
3  * (C) Copyright 2015 Sjoerd Simons <sjoerd.simons@collabora.co.uk>
4  *
5  * Rockchip GMAC ethernet IP driver for U-Boot
6  */
7 
8 #include <common.h>
9 #include <dm.h>
10 #include <clk.h>
11 #include <phy.h>
12 #include <syscon.h>
13 #include <asm/io.h>
14 #include <asm/arch/periph.h>
15 #include <asm/arch/clock.h>
16 #include <asm/arch/hardware.h>
17 #include <asm/arch/grf_rk322x.h>
18 #include <asm/arch/grf_rk3288.h>
19 #include <asm/arch/grf_rk3328.h>
20 #include <asm/arch/grf_rk3368.h>
21 #include <asm/arch/grf_rk3399.h>
22 #include <asm/arch/grf_rv1108.h>
23 #include <dm/pinctrl.h>
24 #include <dt-bindings/clock/rk3288-cru.h>
25 #include "designware.h"
26 
27 DECLARE_GLOBAL_DATA_PTR;
28 #define DELAY_ENABLE(soc, tx, rx) \
29 	(((tx) ? soc##_TXCLK_DLY_ENA_GMAC_ENABLE : soc##_TXCLK_DLY_ENA_GMAC_DISABLE) | \
30 	((rx) ? soc##_RXCLK_DLY_ENA_GMAC_ENABLE : soc##_RXCLK_DLY_ENA_GMAC_DISABLE))
31 
32 /*
33  * Platform data for the gmac
34  *
35  * dw_eth_pdata: Required platform data for designware driver (must be first)
36  */
37 struct gmac_rockchip_platdata {
38 	struct dw_eth_pdata dw_eth_pdata;
39 	bool clock_input;
40 	int tx_delay;
41 	int rx_delay;
42 };
43 
44 struct rk_gmac_ops {
45 	int (*fix_mac_speed)(struct dw_eth_dev *priv);
46 	void (*set_to_rmii)(struct gmac_rockchip_platdata *pdata);
47 	void (*set_to_rgmii)(struct gmac_rockchip_platdata *pdata);
48 };
49 
50 
51 static int gmac_rockchip_ofdata_to_platdata(struct udevice *dev)
52 {
53 	struct gmac_rockchip_platdata *pdata = dev_get_platdata(dev);
54 	const char *string;
55 
56 	string = dev_read_string(dev, "clock_in_out");
57 	if (!strcmp(string, "input"))
58 		pdata->clock_input = true;
59 	else
60 		pdata->clock_input = false;
61 
62 	/* Check the new naming-style first... */
63 	pdata->tx_delay = dev_read_u32_default(dev, "tx_delay", -ENOENT);
64 	pdata->rx_delay = dev_read_u32_default(dev, "rx_delay", -ENOENT);
65 
66 	/* ... and fall back to the old naming style or default, if necessary */
67 	if (pdata->tx_delay == -ENOENT)
68 		pdata->tx_delay = dev_read_u32_default(dev, "tx-delay", 0x30);
69 	if (pdata->rx_delay == -ENOENT)
70 		pdata->rx_delay = dev_read_u32_default(dev, "rx-delay", 0x10);
71 
72 	return designware_eth_ofdata_to_platdata(dev);
73 }
74 
75 static int rk3228_gmac_fix_mac_speed(struct dw_eth_dev *priv)
76 {
77 	struct rk322x_grf *grf;
78 	int clk;
79 	enum {
80 		RK3228_GMAC_CLK_SEL_SHIFT = 8,
81 		RK3228_GMAC_CLK_SEL_MASK  = GENMASK(9, 8),
82 		RK3228_GMAC_CLK_SEL_125M  = 0 << 8,
83 		RK3228_GMAC_CLK_SEL_25M   = 3 << 8,
84 		RK3228_GMAC_CLK_SEL_2_5M  = 2 << 8,
85 	};
86 
87 	switch (priv->phydev->speed) {
88 	case 10:
89 		clk = RK3228_GMAC_CLK_SEL_2_5M;
90 		break;
91 	case 100:
92 		clk = RK3228_GMAC_CLK_SEL_25M;
93 		break;
94 	case 1000:
95 		clk = RK3228_GMAC_CLK_SEL_125M;
96 		break;
97 	default:
98 		debug("Unknown phy speed: %d\n", priv->phydev->speed);
99 		return -EINVAL;
100 	}
101 
102 	grf = syscon_get_first_range(ROCKCHIP_SYSCON_GRF);
103 	rk_clrsetreg(&grf->mac_con[1], RK3228_GMAC_CLK_SEL_MASK, clk);
104 
105 	return 0;
106 }
107 
108 static int rk3288_gmac_fix_mac_speed(struct dw_eth_dev *priv)
109 {
110 	struct rk3288_grf *grf;
111 	int clk;
112 
113 	switch (priv->phydev->speed) {
114 	case 10:
115 		clk = RK3288_GMAC_CLK_SEL_2_5M;
116 		break;
117 	case 100:
118 		clk = RK3288_GMAC_CLK_SEL_25M;
119 		break;
120 	case 1000:
121 		clk = RK3288_GMAC_CLK_SEL_125M;
122 		break;
123 	default:
124 		debug("Unknown phy speed: %d\n", priv->phydev->speed);
125 		return -EINVAL;
126 	}
127 
128 	grf = syscon_get_first_range(ROCKCHIP_SYSCON_GRF);
129 	rk_clrsetreg(&grf->soc_con1, RK3288_GMAC_CLK_SEL_MASK, clk);
130 
131 	return 0;
132 }
133 
134 static int rk3328_gmac_fix_mac_speed(struct dw_eth_dev *priv)
135 {
136 	struct rk3328_grf_regs *grf;
137 	int clk;
138 	enum {
139 		RK3328_GMAC_CLK_SEL_SHIFT = 11,
140 		RK3328_GMAC_CLK_SEL_MASK  = GENMASK(12, 11),
141 		RK3328_GMAC_CLK_SEL_125M  = 0 << 11,
142 		RK3328_GMAC_CLK_SEL_25M   = 3 << 11,
143 		RK3328_GMAC_CLK_SEL_2_5M  = 2 << 11,
144 	};
145 
146 	switch (priv->phydev->speed) {
147 	case 10:
148 		clk = RK3328_GMAC_CLK_SEL_2_5M;
149 		break;
150 	case 100:
151 		clk = RK3328_GMAC_CLK_SEL_25M;
152 		break;
153 	case 1000:
154 		clk = RK3328_GMAC_CLK_SEL_125M;
155 		break;
156 	default:
157 		debug("Unknown phy speed: %d\n", priv->phydev->speed);
158 		return -EINVAL;
159 	}
160 
161 	grf = syscon_get_first_range(ROCKCHIP_SYSCON_GRF);
162 	rk_clrsetreg(&grf->mac_con[1], RK3328_GMAC_CLK_SEL_MASK, clk);
163 
164 	return 0;
165 }
166 
167 static int rk3368_gmac_fix_mac_speed(struct dw_eth_dev *priv)
168 {
169 	struct rk3368_grf *grf;
170 	int clk;
171 	enum {
172 		RK3368_GMAC_CLK_SEL_2_5M = 2 << 4,
173 		RK3368_GMAC_CLK_SEL_25M = 3 << 4,
174 		RK3368_GMAC_CLK_SEL_125M = 0 << 4,
175 		RK3368_GMAC_CLK_SEL_MASK = GENMASK(5, 4),
176 	};
177 
178 	switch (priv->phydev->speed) {
179 	case 10:
180 		clk = RK3368_GMAC_CLK_SEL_2_5M;
181 		break;
182 	case 100:
183 		clk = RK3368_GMAC_CLK_SEL_25M;
184 		break;
185 	case 1000:
186 		clk = RK3368_GMAC_CLK_SEL_125M;
187 		break;
188 	default:
189 		debug("Unknown phy speed: %d\n", priv->phydev->speed);
190 		return -EINVAL;
191 	}
192 
193 	grf = syscon_get_first_range(ROCKCHIP_SYSCON_GRF);
194 	rk_clrsetreg(&grf->soc_con15, RK3368_GMAC_CLK_SEL_MASK, clk);
195 
196 	return 0;
197 }
198 
199 static int rk3399_gmac_fix_mac_speed(struct dw_eth_dev *priv)
200 {
201 	struct rk3399_grf_regs *grf;
202 	int clk;
203 
204 	switch (priv->phydev->speed) {
205 	case 10:
206 		clk = RK3399_GMAC_CLK_SEL_2_5M;
207 		break;
208 	case 100:
209 		clk = RK3399_GMAC_CLK_SEL_25M;
210 		break;
211 	case 1000:
212 		clk = RK3399_GMAC_CLK_SEL_125M;
213 		break;
214 	default:
215 		debug("Unknown phy speed: %d\n", priv->phydev->speed);
216 		return -EINVAL;
217 	}
218 
219 	grf = syscon_get_first_range(ROCKCHIP_SYSCON_GRF);
220 	rk_clrsetreg(&grf->soc_con5, RK3399_GMAC_CLK_SEL_MASK, clk);
221 
222 	return 0;
223 }
224 
225 static int rv1108_set_rmii_speed(struct dw_eth_dev *priv)
226 {
227 	struct rv1108_grf *grf;
228 	int clk, speed;
229 	enum {
230 		RV1108_GMAC_SPEED_MASK		= BIT(2),
231 		RV1108_GMAC_SPEED_10M		= 0 << 2,
232 		RV1108_GMAC_SPEED_100M		= 1 << 2,
233 		RV1108_GMAC_CLK_SEL_MASK	= BIT(7),
234 		RV1108_GMAC_CLK_SEL_2_5M	= 0 << 7,
235 		RV1108_GMAC_CLK_SEL_25M		= 1 << 7,
236 	};
237 
238 	switch (priv->phydev->speed) {
239 	case 10:
240 		clk = RV1108_GMAC_CLK_SEL_2_5M;
241 		speed = RV1108_GMAC_SPEED_10M;
242 		break;
243 	case 100:
244 		clk = RV1108_GMAC_CLK_SEL_25M;
245 		speed = RV1108_GMAC_SPEED_100M;
246 		break;
247 	default:
248 		debug("Unknown phy speed: %d\n", priv->phydev->speed);
249 		return -EINVAL;
250 	}
251 
252 	grf = syscon_get_first_range(ROCKCHIP_SYSCON_GRF);
253 	rk_clrsetreg(&grf->gmac_con0,
254 		     RV1108_GMAC_CLK_SEL_MASK | RV1108_GMAC_SPEED_MASK,
255 		     clk | speed);
256 
257 	return 0;
258 }
259 
260 static void rk3228_gmac_set_to_rgmii(struct gmac_rockchip_platdata *pdata)
261 {
262 	struct rk322x_grf *grf;
263 	enum {
264 		RK3228_RMII_MODE_SHIFT = 10,
265 		RK3228_RMII_MODE_MASK  = BIT(10),
266 
267 		RK3228_GMAC_PHY_INTF_SEL_SHIFT = 4,
268 		RK3228_GMAC_PHY_INTF_SEL_MASK  = GENMASK(6, 4),
269 		RK3228_GMAC_PHY_INTF_SEL_RGMII = BIT(4),
270 
271 		RK3228_RXCLK_DLY_ENA_GMAC_MASK = BIT(1),
272 		RK3228_RXCLK_DLY_ENA_GMAC_DISABLE = 0,
273 		RK3228_RXCLK_DLY_ENA_GMAC_ENABLE = BIT(1),
274 
275 		RK3228_TXCLK_DLY_ENA_GMAC_MASK = BIT(0),
276 		RK3228_TXCLK_DLY_ENA_GMAC_DISABLE = 0,
277 		RK3228_TXCLK_DLY_ENA_GMAC_ENABLE = BIT(0),
278 	};
279 	enum {
280 		RK3228_CLK_RX_DL_CFG_GMAC_SHIFT = 0x7,
281 		RK3228_CLK_RX_DL_CFG_GMAC_MASK = GENMASK(13, 7),
282 
283 		RK3228_CLK_TX_DL_CFG_GMAC_SHIFT = 0x0,
284 		RK3228_CLK_TX_DL_CFG_GMAC_MASK = GENMASK(6, 0),
285 	};
286 
287 	grf = syscon_get_first_range(ROCKCHIP_SYSCON_GRF);
288 	rk_clrsetreg(&grf->mac_con[1],
289 		     RK3228_RMII_MODE_MASK |
290 		     RK3228_GMAC_PHY_INTF_SEL_MASK |
291 		     RK3228_RXCLK_DLY_ENA_GMAC_MASK |
292 		     RK3228_TXCLK_DLY_ENA_GMAC_MASK,
293 		     RK3228_GMAC_PHY_INTF_SEL_RGMII |
294 		     DELAY_ENABLE(RK3228, pdata->tx_delay, pdata->rx_delay));
295 
296 	rk_clrsetreg(&grf->mac_con[0],
297 		     RK3228_CLK_RX_DL_CFG_GMAC_MASK |
298 		     RK3228_CLK_TX_DL_CFG_GMAC_MASK,
299 		     pdata->rx_delay << RK3228_CLK_RX_DL_CFG_GMAC_SHIFT |
300 		     pdata->tx_delay << RK3228_CLK_TX_DL_CFG_GMAC_SHIFT);
301 }
302 
303 static void rk3288_gmac_set_to_rgmii(struct gmac_rockchip_platdata *pdata)
304 {
305 	struct rk3288_grf *grf;
306 
307 	grf = syscon_get_first_range(ROCKCHIP_SYSCON_GRF);
308 	rk_clrsetreg(&grf->soc_con1,
309 		     RK3288_RMII_MODE_MASK | RK3288_GMAC_PHY_INTF_SEL_MASK,
310 		     RK3288_GMAC_PHY_INTF_SEL_RGMII);
311 
312 	rk_clrsetreg(&grf->soc_con3,
313 		     RK3288_RXCLK_DLY_ENA_GMAC_MASK |
314 		     RK3288_TXCLK_DLY_ENA_GMAC_MASK |
315 		     RK3288_CLK_RX_DL_CFG_GMAC_MASK |
316 		     RK3288_CLK_TX_DL_CFG_GMAC_MASK,
317 		     DELAY_ENABLE(RK3288, pdata->rx_delay, pdata->tx_delay) |
318 		     pdata->rx_delay << RK3288_CLK_RX_DL_CFG_GMAC_SHIFT |
319 		     pdata->tx_delay << RK3288_CLK_TX_DL_CFG_GMAC_SHIFT);
320 }
321 
322 static void rk3328_gmac_set_to_rgmii(struct gmac_rockchip_platdata *pdata)
323 {
324 	struct rk3328_grf_regs *grf;
325 	enum {
326 		RK3328_RMII_MODE_SHIFT = 9,
327 		RK3328_RMII_MODE_MASK  = BIT(9),
328 
329 		RK3328_GMAC_PHY_INTF_SEL_SHIFT = 4,
330 		RK3328_GMAC_PHY_INTF_SEL_MASK  = GENMASK(6, 4),
331 		RK3328_GMAC_PHY_INTF_SEL_RGMII = BIT(4),
332 
333 		RK3328_RXCLK_DLY_ENA_GMAC_MASK = BIT(1),
334 		RK3328_RXCLK_DLY_ENA_GMAC_DISABLE = 0,
335 		RK3328_RXCLK_DLY_ENA_GMAC_ENABLE = BIT(1),
336 
337 		RK3328_TXCLK_DLY_ENA_GMAC_MASK = BIT(0),
338 		RK3328_TXCLK_DLY_ENA_GMAC_DISABLE = 0,
339 		RK3328_TXCLK_DLY_ENA_GMAC_ENABLE = BIT(0),
340 	};
341 	enum {
342 		RK3328_CLK_RX_DL_CFG_GMAC_SHIFT = 0x7,
343 		RK3328_CLK_RX_DL_CFG_GMAC_MASK = GENMASK(13, 7),
344 
345 		RK3328_CLK_TX_DL_CFG_GMAC_SHIFT = 0x0,
346 		RK3328_CLK_TX_DL_CFG_GMAC_MASK = GENMASK(6, 0),
347 	};
348 
349 	grf = syscon_get_first_range(ROCKCHIP_SYSCON_GRF);
350 	rk_clrsetreg(&grf->mac_con[1],
351 		     RK3328_RMII_MODE_MASK |
352 		     RK3328_GMAC_PHY_INTF_SEL_MASK |
353 		     RK3328_RXCLK_DLY_ENA_GMAC_MASK |
354 		     RK3328_TXCLK_DLY_ENA_GMAC_MASK,
355 		     RK3328_GMAC_PHY_INTF_SEL_RGMII |
356 		     DELAY_ENABLE(RK3328, pdata->tx_delay, pdata->rx_delay));
357 
358 	rk_clrsetreg(&grf->mac_con[0],
359 		     RK3328_CLK_RX_DL_CFG_GMAC_MASK |
360 		     RK3328_CLK_TX_DL_CFG_GMAC_MASK,
361 		     pdata->rx_delay << RK3328_CLK_RX_DL_CFG_GMAC_SHIFT |
362 		     pdata->tx_delay << RK3328_CLK_TX_DL_CFG_GMAC_SHIFT);
363 }
364 
365 static void rk3368_gmac_set_to_rgmii(struct gmac_rockchip_platdata *pdata)
366 {
367 	struct rk3368_grf *grf;
368 	enum {
369 		RK3368_GMAC_PHY_INTF_SEL_RGMII = 1 << 9,
370 		RK3368_GMAC_PHY_INTF_SEL_MASK = GENMASK(11, 9),
371 		RK3368_RMII_MODE_MASK  = BIT(6),
372 		RK3368_RMII_MODE       = BIT(6),
373 	};
374 	enum {
375 		RK3368_RXCLK_DLY_ENA_GMAC_MASK = BIT(15),
376 		RK3368_RXCLK_DLY_ENA_GMAC_DISABLE = 0,
377 		RK3368_RXCLK_DLY_ENA_GMAC_ENABLE = BIT(15),
378 		RK3368_TXCLK_DLY_ENA_GMAC_MASK = BIT(7),
379 		RK3368_TXCLK_DLY_ENA_GMAC_DISABLE = 0,
380 		RK3368_TXCLK_DLY_ENA_GMAC_ENABLE = BIT(7),
381 		RK3368_CLK_RX_DL_CFG_GMAC_SHIFT = 8,
382 		RK3368_CLK_RX_DL_CFG_GMAC_MASK = GENMASK(14, 8),
383 		RK3368_CLK_TX_DL_CFG_GMAC_SHIFT = 0,
384 		RK3368_CLK_TX_DL_CFG_GMAC_MASK = GENMASK(6, 0),
385 	};
386 
387 	grf = syscon_get_first_range(ROCKCHIP_SYSCON_GRF);
388 	rk_clrsetreg(&grf->soc_con15,
389 		     RK3368_RMII_MODE_MASK | RK3368_GMAC_PHY_INTF_SEL_MASK,
390 		     RK3368_GMAC_PHY_INTF_SEL_RGMII);
391 
392 	rk_clrsetreg(&grf->soc_con16,
393 		     RK3368_RXCLK_DLY_ENA_GMAC_MASK |
394 		     RK3368_TXCLK_DLY_ENA_GMAC_MASK |
395 		     RK3368_CLK_RX_DL_CFG_GMAC_MASK |
396 		     RK3368_CLK_TX_DL_CFG_GMAC_MASK,
397 		     DELAY_ENABLE(RK3368, pdata->tx_delay, pdata->rx_delay) |
398 		     pdata->rx_delay << RK3368_CLK_RX_DL_CFG_GMAC_SHIFT |
399 		     pdata->tx_delay << RK3368_CLK_TX_DL_CFG_GMAC_SHIFT);
400 }
401 
402 static void rk3399_gmac_set_to_rgmii(struct gmac_rockchip_platdata *pdata)
403 {
404 	struct rk3399_grf_regs *grf;
405 
406 	grf = syscon_get_first_range(ROCKCHIP_SYSCON_GRF);
407 
408 	rk_clrsetreg(&grf->soc_con5,
409 		     RK3399_GMAC_PHY_INTF_SEL_MASK,
410 		     RK3399_GMAC_PHY_INTF_SEL_RGMII);
411 
412 	rk_clrsetreg(&grf->soc_con6,
413 		     RK3399_RXCLK_DLY_ENA_GMAC_MASK |
414 		     RK3399_TXCLK_DLY_ENA_GMAC_MASK |
415 		     RK3399_CLK_RX_DL_CFG_GMAC_MASK |
416 		     RK3399_CLK_TX_DL_CFG_GMAC_MASK,
417 		     DELAY_ENABLE(RK3399, pdata->tx_delay, pdata->rx_delay) |
418 		     pdata->rx_delay << RK3399_CLK_RX_DL_CFG_GMAC_SHIFT |
419 		     pdata->tx_delay << RK3399_CLK_TX_DL_CFG_GMAC_SHIFT);
420 }
421 
422 static void rv1108_gmac_set_to_rmii(struct gmac_rockchip_platdata *pdata)
423 {
424 	struct rv1108_grf *grf;
425 
426 	enum {
427 		RV1108_GMAC_PHY_INTF_SEL_MASK  = GENMASK(6, 4),
428 		RV1108_GMAC_PHY_INTF_SEL_RMII  = 4 << 4,
429 	};
430 
431 	grf = syscon_get_first_range(ROCKCHIP_SYSCON_GRF);
432 	rk_clrsetreg(&grf->gmac_con0,
433 		     RV1108_GMAC_PHY_INTF_SEL_MASK,
434 		     RV1108_GMAC_PHY_INTF_SEL_RMII);
435 }
436 
437 static int gmac_rockchip_probe(struct udevice *dev)
438 {
439 	struct gmac_rockchip_platdata *pdata = dev_get_platdata(dev);
440 	struct rk_gmac_ops *ops =
441 		(struct rk_gmac_ops *)dev_get_driver_data(dev);
442 	struct dw_eth_pdata *dw_pdata = dev_get_platdata(dev);
443 	struct eth_pdata *eth_pdata = &dw_pdata->eth_pdata;
444 	struct clk clk;
445 	ulong rate;
446 	int ret;
447 
448 	ret = clk_get_by_index(dev, 0, &clk);
449 	if (ret)
450 		return ret;
451 
452 	switch (eth_pdata->phy_interface) {
453 	case PHY_INTERFACE_MODE_RGMII:
454 		/* Set to RGMII mode */
455 		if (ops->set_to_rgmii)
456 			ops->set_to_rgmii(pdata);
457 		else
458 			return -EPERM;
459 
460 		/*
461 		 * If the gmac clock is from internal pll, need to set and
462 		 * check the return value for gmac clock at RGMII mode. If
463 		 * the gmac clock is from external source, the clock rate
464 		 * is not set, because of it is bypassed.
465 		 */
466 
467 		if (!pdata->clock_input) {
468 			rate = clk_set_rate(&clk, 125000000);
469 			if (rate != 125000000)
470 				return -EINVAL;
471 		}
472 		break;
473 
474 	case PHY_INTERFACE_MODE_RGMII_ID:
475 		/* Set to RGMII mode */
476 		if (ops->set_to_rgmii) {
477 			pdata->tx_delay = 0;
478 			pdata->rx_delay = 0;
479 			ops->set_to_rgmii(pdata);
480 		} else
481 			return -EPERM;
482 
483 		if (!pdata->clock_input) {
484 			rate = clk_set_rate(&clk, 125000000);
485 			if (rate != 125000000)
486 				return -EINVAL;
487 		}
488 		break;
489 
490 	case PHY_INTERFACE_MODE_RMII:
491 		/* Set to RMII mode */
492 		if (ops->set_to_rmii)
493 			ops->set_to_rmii(pdata);
494 		else
495 			return -EPERM;
496 
497 		if (!pdata->clock_input) {
498 			rate = clk_set_rate(&clk, 50000000);
499 			if (rate != 50000000)
500 				return -EINVAL;
501 		}
502 		break;
503 
504 	case PHY_INTERFACE_MODE_RGMII_RXID:
505 		 /* Set to RGMII_RXID mode */
506 		if (ops->set_to_rgmii) {
507 			pdata->tx_delay = 0;
508 			ops->set_to_rgmii(pdata);
509 		} else
510 			return -EPERM;
511 
512 		if (!pdata->clock_input) {
513 			rate = clk_set_rate(&clk, 125000000);
514 			if (rate != 125000000)
515 				return -EINVAL;
516 		}
517 		break;
518 
519 	case PHY_INTERFACE_MODE_RGMII_TXID:
520 		/* Set to RGMII_TXID mode */
521 		if (ops->set_to_rgmii) {
522 			pdata->rx_delay = 0;
523 			ops->set_to_rgmii(pdata);
524 		} else
525 			return -EPERM;
526 
527 		if (!pdata->clock_input) {
528 			rate = clk_set_rate(&clk, 125000000);
529 			if (rate != 125000000)
530 				return -EINVAL;
531 		}
532 		break;
533 
534 	default:
535 		debug("NO interface defined!\n");
536 		return -ENXIO;
537 	}
538 
539 	return designware_eth_probe(dev);
540 }
541 
542 static int gmac_rockchip_eth_start(struct udevice *dev)
543 {
544 	struct eth_pdata *pdata = dev_get_platdata(dev);
545 	struct dw_eth_dev *priv = dev_get_priv(dev);
546 	struct rk_gmac_ops *ops =
547 		(struct rk_gmac_ops *)dev_get_driver_data(dev);
548 	int ret;
549 
550 	ret = designware_eth_init(priv, pdata->enetaddr);
551 	if (ret)
552 		return ret;
553 	ret = ops->fix_mac_speed(priv);
554 	if (ret)
555 		return ret;
556 	ret = designware_eth_enable(priv);
557 	if (ret)
558 		return ret;
559 
560 	return 0;
561 }
562 
563 const struct eth_ops gmac_rockchip_eth_ops = {
564 	.start			= gmac_rockchip_eth_start,
565 	.send			= designware_eth_send,
566 	.recv			= designware_eth_recv,
567 	.free_pkt		= designware_eth_free_pkt,
568 	.stop			= designware_eth_stop,
569 	.write_hwaddr		= designware_eth_write_hwaddr,
570 };
571 
572 const struct rk_gmac_ops rk3228_gmac_ops = {
573 	.fix_mac_speed = rk3228_gmac_fix_mac_speed,
574 	.set_to_rgmii = rk3228_gmac_set_to_rgmii,
575 };
576 
577 const struct rk_gmac_ops rk3288_gmac_ops = {
578 	.fix_mac_speed = rk3288_gmac_fix_mac_speed,
579 	.set_to_rgmii = rk3288_gmac_set_to_rgmii,
580 };
581 
582 const struct rk_gmac_ops rk3328_gmac_ops = {
583 	.fix_mac_speed = rk3328_gmac_fix_mac_speed,
584 	.set_to_rgmii = rk3328_gmac_set_to_rgmii,
585 };
586 
587 const struct rk_gmac_ops rk3368_gmac_ops = {
588 	.fix_mac_speed = rk3368_gmac_fix_mac_speed,
589 	.set_to_rgmii = rk3368_gmac_set_to_rgmii,
590 };
591 
592 const struct rk_gmac_ops rk3399_gmac_ops = {
593 	.fix_mac_speed = rk3399_gmac_fix_mac_speed,
594 	.set_to_rgmii = rk3399_gmac_set_to_rgmii,
595 };
596 
597 const struct rk_gmac_ops rv1108_gmac_ops = {
598 	.fix_mac_speed = rv1108_set_rmii_speed,
599 	.set_to_rmii = rv1108_gmac_set_to_rmii,
600 };
601 
602 static const struct udevice_id rockchip_gmac_ids[] = {
603 	{ .compatible = "rockchip,rk3228-gmac",
604 	  .data = (ulong)&rk3228_gmac_ops },
605 	{ .compatible = "rockchip,rk3288-gmac",
606 	  .data = (ulong)&rk3288_gmac_ops },
607 	{ .compatible = "rockchip,rk3328-gmac",
608 	  .data = (ulong)&rk3328_gmac_ops },
609 	{ .compatible = "rockchip,rk3368-gmac",
610 	  .data = (ulong)&rk3368_gmac_ops },
611 	{ .compatible = "rockchip,rk3399-gmac",
612 	  .data = (ulong)&rk3399_gmac_ops },
613 	{ .compatible = "rockchip,rv1108-gmac",
614 	  .data = (ulong)&rv1108_gmac_ops },
615 	{ }
616 };
617 
618 U_BOOT_DRIVER(eth_gmac_rockchip) = {
619 	.name	= "gmac_rockchip",
620 	.id	= UCLASS_ETH,
621 	.of_match = rockchip_gmac_ids,
622 	.ofdata_to_platdata = gmac_rockchip_ofdata_to_platdata,
623 	.probe	= gmac_rockchip_probe,
624 	.ops	= &gmac_rockchip_eth_ops,
625 	.priv_auto_alloc_size = sizeof(struct dw_eth_dev),
626 	.platdata_auto_alloc_size = sizeof(struct gmac_rockchip_platdata),
627 	.flags = DM_FLAG_ALLOC_PRIV_DMA,
628 };
629