global: Move remaining CONFIG_SYS_* to CFG_SYS_*
[platform/kernel/u-boot.git] / drivers / net / ksz9477.c
1 // SPDX-License-Identifier: GPL-2.0+
2 /*
3  * (C) Copyright 2020
4  * Tim Harvey, Gateworks Corporation
5  */
6
7 #include <dm.h>
8 #include <dm/device_compat.h>
9 #include <dm/device-internal.h>
10 #include <dm/lists.h>
11 #include <eth_phy.h>
12 #include <linux/delay.h>
13 #include <miiphy.h>
14 #include <i2c.h>
15 #include <net/dsa.h>
16
17 #include <asm-generic/gpio.h>
18
19 /* Global registers */
20
21 /* Chip ID */
22 #define REG_CHIP_ID0__1                 0x0000
23
24 /* Operation control */
25 #define REG_SW_OPERATION                0x0300
26 #define SW_RESET                        BIT(1)
27 #define SW_START                        BIT(0)
28
29 /* Port Specific Registers */
30 #define PORT_CTRL_ADDR(port, addr) ((addr) | (((port) + 1) << 12))
31
32 /* Port Control */
33 #define REG_PORT_XMII_CTRL_1            0x0301
34 #define PORT_MII_NOT_1GBIT              BIT(6)
35 #define PORT_MII_SEL_EDGE               BIT(5)
36 #define PORT_RGMII_ID_IG_ENABLE         BIT(4)
37 #define PORT_RGMII_ID_EG_ENABLE         BIT(3)
38 #define PORT_MII_MAC_MODE               BIT(2)
39 #define PORT_MII_SEL_M                  0x3
40 #define PORT_RGMII_SEL                  0x0
41 #define PORT_RMII_SEL                   0x1
42 #define PORT_GMII_SEL                   0x2
43 #define PORT_MII_SEL                    0x3
44
45 /* Port MSTP State Register */
46 #define REG_PORT_MSTP_STATE             0x0b04
47 #define PORT_TX_ENABLE                  BIT(2)
48 #define PORT_RX_ENABLE                  BIT(1)
49 #define PORT_LEARN_DISABLE              BIT(0)
50
51 /* MMD */
52 #define REG_PORT_PHY_MMD_SETUP          0x011A
53 #define PORT_MMD_OP_MODE_M              0x3
54 #define PORT_MMD_OP_MODE_S              14
55 #define PORT_MMD_OP_INDEX               0
56 #define PORT_MMD_OP_DATA_NO_INCR        1
57 #define PORT_MMD_OP_DATA_INCR_RW        2
58 #define PORT_MMD_OP_DATA_INCR_W         3
59 #define PORT_MMD_DEVICE_ID_M            0x1F
60 #define MMD_SETUP(mode, dev)            (((u16)(mode) << PORT_MMD_OP_MODE_S) | (dev))
61 #define REG_PORT_PHY_MMD_INDEX_DATA     0x011C
62
63 struct ksz_dsa_priv {
64         struct udevice *dev;
65         int active_port;
66 };
67
68 static inline int ksz_read8(struct udevice *dev, u32 reg, u8 *val)
69 {
70         int ret = dm_i2c_read(dev, reg, val, 1);
71
72         dev_dbg(dev, "%s 0x%04x<<0x%02x\n", __func__, reg, *val);
73
74         return ret;
75 }
76
77 static inline int ksz_pread8(struct udevice *dev, int port, int reg, u8 *val)
78 {
79         return ksz_read8(dev, PORT_CTRL_ADDR(port, reg), val);
80 }
81
82 static inline int ksz_write8(struct udevice *dev, u32 reg, u8 val)
83 {
84         dev_dbg(dev, "%s 0x%04x>>0x%02x\n", __func__, reg, val);
85         return dm_i2c_write(dev, reg, &val, 1);
86 }
87
88 static inline int ksz_pwrite8(struct udevice *dev, int port, int reg, u8 val)
89 {
90         return ksz_write8(dev, PORT_CTRL_ADDR(port, reg), val);
91 }
92
93 static inline int ksz_write16(struct udevice *dev, u32 reg, u16 val)
94 {
95         u8 buf[2];
96
97         buf[1] = val & 0xff;
98         buf[0] = val >> 8;
99         dev_dbg(dev, "%s 0x%04x>>0x%04x\n", __func__, reg, val);
100
101         return dm_i2c_write(dev, reg, buf, 2);
102 }
103
104 static inline int ksz_pwrite16(struct udevice *dev, int port, int reg, u16 val)
105 {
106         return ksz_write16(dev, PORT_CTRL_ADDR(port, reg), val);
107 }
108
109 static inline int ksz_read16(struct udevice *dev, u32 reg, u16 *val)
110 {
111         u8 buf[2];
112         int ret;
113
114         ret = dm_i2c_read(dev, reg, buf, 2);
115         *val = (buf[0] << 8) | buf[1];
116         dev_dbg(dev, "%s 0x%04x<<0x%04x\n", __func__, reg, *val);
117
118         return ret;
119 }
120
121 static inline int ksz_pread16(struct udevice *dev, int port, int reg, u16 *val)
122 {
123         return ksz_read16(dev, PORT_CTRL_ADDR(port, reg), val);
124 }
125
126 static inline int ksz_read32(struct udevice *dev, u32 reg, u32 *val)
127 {
128         return dm_i2c_read(dev, reg, (u8 *)val, 4);
129 }
130
131 static inline int ksz_pread32(struct udevice *dev, int port, int reg, u32 *val)
132 {
133         return ksz_read32(dev, PORT_CTRL_ADDR(port, reg), val);
134 }
135
136 static inline int ksz_write32(struct udevice *dev, u32 reg, u32 val)
137 {
138         u8 buf[4];
139
140         buf[3] = val & 0xff;
141         buf[2] = (val >> 24) & 0xff;
142         buf[1] = (val >> 16) & 0xff;
143         buf[0] = (val >> 8) & 0xff;
144         dev_dbg(dev, "%s 0x%04x>>0x%04x\n", __func__, reg, val);
145
146         return dm_i2c_write(dev, reg, buf, 4);
147 }
148
149 static inline int ksz_pwrite32(struct udevice *dev, int port, int reg, u32 val)
150 {
151         return ksz_write32(dev, PORT_CTRL_ADDR(port, reg), val);
152 }
153
154 static __maybe_unused void ksz_port_mmd_read(struct udevice *dev, int port,
155                                              u8 addr, u16 reg, u16 *val)
156 {
157         ksz_pwrite16(dev, port, REG_PORT_PHY_MMD_SETUP, MMD_SETUP(PORT_MMD_OP_INDEX, addr));
158         ksz_pwrite16(dev, port, REG_PORT_PHY_MMD_INDEX_DATA, reg);
159         ksz_pwrite16(dev, port, REG_PORT_PHY_MMD_SETUP, MMD_SETUP(PORT_MMD_OP_DATA_NO_INCR, addr));
160         ksz_pread16(dev, port, REG_PORT_PHY_MMD_INDEX_DATA, val);
161         dev_dbg(dev, "%s  P%d 0x%02x:0x%04x<<0x%04x\n", __func__, port + 1, addr, reg, *val);
162 }
163
164 static void ksz_port_mmd_write(struct udevice *dev, int port, u8 addr, u16 reg, u16 val)
165 {
166         dev_dbg(dev, "%s P%d 0x%02x:0x%04x>>0x%04x\n", __func__, port + 1, addr, addr, val);
167         ksz_pwrite16(dev, port, REG_PORT_PHY_MMD_SETUP, MMD_SETUP(PORT_MMD_OP_INDEX, addr));
168         ksz_pwrite16(dev, port, REG_PORT_PHY_MMD_INDEX_DATA, addr);
169         ksz_pwrite16(dev, port, REG_PORT_PHY_MMD_SETUP, MMD_SETUP(PORT_MMD_OP_DATA_NO_INCR, addr));
170         ksz_pwrite16(dev, port, REG_PORT_PHY_MMD_INDEX_DATA, val);
171 }
172
173 /* Apply PHY settings to address errata listed in KSZ9477, KSZ9897, KSZ9896, KSZ9567
174  * Silicon Errata and Data Sheet Clarification documents
175  */
176 static void ksz_phy_errata_setup(struct udevice *dev, int port)
177 {
178         dev_dbg(dev, "%s P%d\n", __func__, port + 1);
179
180         /* Register settings are needed to improve PHY receive performance */
181         ksz_port_mmd_write(dev, port, 0x01, 0x6f, 0xdd0b);
182         ksz_port_mmd_write(dev, port, 0x01, 0x8f, 0x6032);
183         ksz_port_mmd_write(dev, port, 0x01, 0x9d, 0x248c);
184         ksz_port_mmd_write(dev, port, 0x01, 0x75, 0x0060);
185         ksz_port_mmd_write(dev, port, 0x01, 0xd3, 0x7777);
186         ksz_port_mmd_write(dev, port, 0x1c, 0x06, 0x3008);
187         ksz_port_mmd_write(dev, port, 0x1c, 0x08, 0x2001);
188
189         /* Transmit waveform amplitude can be improved (1000BASE-T, 100BASE-TX, 10BASE-Te) */
190         ksz_port_mmd_write(dev, port, 0x1c, 0x04, 0x00d0);
191
192         /* Energy Efficient Ethernet (EEE) feature select must be manually disabled */
193         ksz_port_mmd_write(dev, port, 0x07, 0x3c, 0x0000);
194
195         /* Register settings are required to meet data sheet supply current specifications */
196         ksz_port_mmd_write(dev, port, 0x1c, 0x13, 0x6eff);
197         ksz_port_mmd_write(dev, port, 0x1c, 0x14, 0xe6ff);
198         ksz_port_mmd_write(dev, port, 0x1c, 0x15, 0x6eff);
199         ksz_port_mmd_write(dev, port, 0x1c, 0x16, 0xe6ff);
200         ksz_port_mmd_write(dev, port, 0x1c, 0x17, 0x00ff);
201         ksz_port_mmd_write(dev, port, 0x1c, 0x18, 0x43ff);
202         ksz_port_mmd_write(dev, port, 0x1c, 0x19, 0xc3ff);
203         ksz_port_mmd_write(dev, port, 0x1c, 0x1a, 0x6fff);
204         ksz_port_mmd_write(dev, port, 0x1c, 0x1b, 0x07ff);
205         ksz_port_mmd_write(dev, port, 0x1c, 0x1c, 0x0fff);
206         ksz_port_mmd_write(dev, port, 0x1c, 0x1d, 0xe7ff);
207         ksz_port_mmd_write(dev, port, 0x1c, 0x1e, 0xefff);
208         ksz_port_mmd_write(dev, port, 0x1c, 0x20, 0xeeee);
209 }
210
211 /*
212  * mii bus driver
213  */
214 #define KSZ_MDIO_CHILD_DRV_NAME "ksz_mdio"
215
216 struct ksz_mdio_priv {
217         struct ksz_dsa_priv *ksz;
218 };
219
220 static int dm_ksz_mdio_read(struct udevice *dev, int addr, int devad, int reg)
221 {
222         struct ksz_mdio_priv *priv = dev_get_priv(dev);
223         struct ksz_dsa_priv *ksz = priv->ksz;
224         u16 val = 0xffff;
225
226         ksz_pread16(ksz->dev, addr, 0x100 + (reg << 1), &val);
227         dev_dbg(ksz->dev, "%s P%d reg=0x%04x:0x%04x<<0x%04x\n", __func__,
228                 addr + 1, reg, 0x100 + (reg << 1), val);
229
230         return val;
231 };
232
233 static int dm_ksz_mdio_write(struct udevice *dev, int addr, int devad, int reg, u16 val)
234 {
235         struct ksz_mdio_priv *priv = dev_get_priv(dev);
236         struct ksz_dsa_priv *ksz = priv->ksz;
237
238         dev_dbg(ksz->dev, "%s P%d reg=0x%04x:%04x>>0x%04x\n",
239                 __func__, addr + 1, reg, 0x100 + (reg << 1), val);
240         ksz_pwrite16(ksz->dev, addr, 0x100 + (reg << 1), val);
241
242         return 0;
243 }
244
245 static const struct mdio_ops ksz_mdio_ops = {
246         .read = dm_ksz_mdio_read,
247         .write = dm_ksz_mdio_write,
248 };
249
250 static int ksz_mdio_bind(struct udevice *dev)
251 {
252         char name[16];
253         static int num_devices;
254
255         dev_dbg(dev, "%s\n", __func__);
256         sprintf(name, "ksz-mdio-%d", num_devices++);
257         device_set_name(dev, name);
258
259         return 0;
260 }
261
262 static int ksz_mdio_probe(struct udevice *dev)
263 {
264         struct ksz_mdio_priv *priv = dev_get_priv(dev);
265
266         dev_dbg(dev, "%s\n", __func__);
267         priv->ksz = dev_get_parent_priv(dev->parent);
268
269         return 0;
270 }
271
272 static const struct udevice_id ksz_mdio_ids[] = {
273         { .compatible = "microchip,ksz-mdio" },
274         { }
275 };
276
277 U_BOOT_DRIVER(ksz_mdio) = {
278         .name           = KSZ_MDIO_CHILD_DRV_NAME,
279         .id             = UCLASS_MDIO,
280         .of_match       = ksz_mdio_ids,
281         .bind           = ksz_mdio_bind,
282         .probe          = ksz_mdio_probe,
283         .ops            = &ksz_mdio_ops,
284         .priv_auto      = sizeof(struct ksz_mdio_priv),
285         .plat_auto      = sizeof(struct mdio_perdev_priv),
286 };
287
288 static int ksz_port_setup(struct udevice *dev, int port,
289                           phy_interface_t interface)
290 {
291         struct dsa_pdata *pdata = dev_get_uclass_plat(dev);
292         u8 data8;
293
294         dev_dbg(dev, "%s P%d %s\n", __func__, port + 1,
295                 (port == pdata->cpu_port) ? "cpu" : "");
296
297         if (port != pdata->cpu_port) {
298                 /* phy port: config errata and leds */
299                 ksz_phy_errata_setup(dev, port);
300         } else {
301                 /* cpu port: configure MAC interface mode */
302                 ksz_pread8(dev, port, REG_PORT_XMII_CTRL_1, &data8);
303                 dev_dbg(dev, "%s P%d cpu interface %s\n", __func__, port + 1,
304                         phy_string_for_interface(interface));
305                 switch (interface) {
306                 case PHY_INTERFACE_MODE_MII:
307                         data8 &= ~PORT_MII_SEL_M;
308                         data8 |= PORT_MII_SEL;
309                         data8 |= PORT_MII_NOT_1GBIT;
310                         break;
311                 case PHY_INTERFACE_MODE_RMII:
312                         data8 &= ~PORT_MII_SEL_M;
313                         data8 |= PORT_RMII_SEL;
314                         data8 |= PORT_MII_NOT_1GBIT;
315                         break;
316                 case PHY_INTERFACE_MODE_GMII:
317                         data8 &= ~PORT_MII_SEL_M;
318                         data8 |= PORT_GMII_SEL;
319                         data8 &= ~PORT_MII_NOT_1GBIT;
320                         break;
321                 default:
322                         data8 &= ~PORT_MII_SEL_M;
323                         data8 |= PORT_RGMII_SEL;
324                         data8 &= ~PORT_MII_NOT_1GBIT;
325                         data8 &= ~PORT_RGMII_ID_IG_ENABLE;
326                         data8 &= ~PORT_RGMII_ID_EG_ENABLE;
327                         if (interface == PHY_INTERFACE_MODE_RGMII_ID ||
328                             interface == PHY_INTERFACE_MODE_RGMII_RXID)
329                                 data8 |= PORT_RGMII_ID_IG_ENABLE;
330                         if (interface == PHY_INTERFACE_MODE_RGMII_ID ||
331                             interface == PHY_INTERFACE_MODE_RGMII_TXID)
332                                 data8 |= PORT_RGMII_ID_EG_ENABLE;
333                         break;
334                 }
335                 ksz_write8(dev, PORT_CTRL_ADDR(port, REG_PORT_XMII_CTRL_1), data8);
336         }
337
338         return 0;
339 }
340
341 static int ksz_port_enable(struct udevice *dev, int port, struct phy_device *phy)
342 {
343         struct dsa_pdata *pdata = dev_get_uclass_plat(dev);
344         struct ksz_dsa_priv *priv = dev_get_priv(dev);
345         int supported = PHY_GBIT_FEATURES;
346         u8 data8;
347         int ret;
348
349         dev_dbg(dev, "%s P%d 0x%x %s\n", __func__, port + 1, phy->phy_id,
350                 phy_string_for_interface(phy->interface));
351
352         /* setup this port */
353         ret = ksz_port_setup(dev, port, phy->interface);
354         if (ret) {
355                 dev_err(dev, "port setup failed: %d\n", ret);
356                 return ret;
357         }
358
359         /* enable port forwarding for this port */
360         ksz_pread8(priv->dev, port, REG_PORT_MSTP_STATE, &data8);
361         data8 &= ~(PORT_TX_ENABLE | PORT_RX_ENABLE | PORT_LEARN_DISABLE);
362         data8 |= (PORT_TX_ENABLE | PORT_RX_ENABLE);
363         ksz_pwrite8(priv->dev, port, REG_PORT_MSTP_STATE, data8);
364
365         /* if cpu master we are done */
366         if (port == pdata->cpu_port)
367                 return 0;
368
369         /* configure phy */
370         phy->supported &= supported;
371         phy->advertising &= supported;
372         ret = phy_config(phy);
373         if (ret)
374                 return ret;
375
376         ret = phy_startup(phy);
377         if (ret)
378                 return ret;
379
380         /* start switch */
381         ksz_read8(priv->dev, REG_SW_OPERATION, &data8);
382         data8 |= SW_START;
383         ksz_write8(priv->dev, REG_SW_OPERATION, data8);
384
385         /* keep track of current enabled non-cpu port */
386         priv->active_port = port;
387
388         return 0;
389 }
390
391 static void ksz_port_disable(struct udevice *dev, int port, struct phy_device *phy)
392 {
393         struct dsa_pdata *pdata = dev_get_uclass_plat(dev);
394         struct ksz_dsa_priv *priv = dev_get_priv(dev);
395         u8 data8;
396
397         dev_dbg(dev, "%s P%d 0x%x\n", __func__, port + 1, phy->phy_id);
398
399         /* can't disable CPU port without re-configuring/re-starting switch */
400         if (port == pdata->cpu_port)
401                 return;
402
403         /* disable port */
404         ksz_pread8(priv->dev, port, REG_PORT_MSTP_STATE, &data8);
405         data8 &= ~(PORT_TX_ENABLE | PORT_RX_ENABLE | PORT_LEARN_DISABLE);
406         data8 |= PORT_LEARN_DISABLE;
407         ksz_pwrite8(priv->dev, port, REG_PORT_MSTP_STATE, data8);
408
409         /*
410          * we don't call phy_shutdown here to avoid waiting next time we use
411          * the port, but the downside is that remote side will think we're
412          * actively processing traffic although we are not.
413          */
414 }
415
416 static int ksz_xmit(struct udevice *dev, int port, void *packet, int length)
417 {
418         dev_dbg(dev, "%s P%d %d\n", __func__, port + 1, length);
419
420         return 0;
421 }
422
423 static int ksz_recv(struct udevice *dev, int *port, void *packet, int length)
424 {
425         struct ksz_dsa_priv *priv = dev_get_priv(dev);
426
427         dev_dbg(dev, "%s P%d %d\n", __func__, priv->active_port + 1, length);
428         *port = priv->active_port;
429
430         return 0;
431 };
432
433 static const struct dsa_ops ksz_dsa_ops = {
434         .port_enable = ksz_port_enable,
435         .port_disable = ksz_port_disable,
436         .xmit = ksz_xmit,
437         .rcv = ksz_recv,
438 };
439
440 static int ksz_probe_mdio(struct udevice *dev)
441 {
442         ofnode node, mdios;
443         int ret;
444
445         mdios = dev_read_subnode(dev, "mdios");
446         if (ofnode_valid(mdios)) {
447                 ofnode_for_each_subnode(node, mdios) {
448                         const char *name = ofnode_get_name(node);
449                         struct udevice *pdev;
450
451                         ret = device_bind_driver_to_node(dev,
452                                                          KSZ_MDIO_CHILD_DRV_NAME,
453                                                          name, node, &pdev);
454                         if (ret)
455                                 dev_err(dev, "failed to probe %s: %d\n", name, ret);
456                 }
457         }
458
459         return 0;
460 }
461
462 /*
463  * I2C driver
464  */
465 static int ksz_i2c_probe(struct udevice *dev)
466 {
467         struct dsa_pdata *pdata = dev_get_uclass_plat(dev);
468         struct ksz_dsa_priv *priv = dev_get_priv(dev);
469         struct udevice *master = dsa_get_master(dev);
470         int i, ret;
471         u8 data8;
472         u32 id;
473
474         if (!master)
475                 return -ENODEV;
476
477         dev_dbg(dev, "%s %s master:%s\n", __func__, dev->name, master->name);
478         dev_set_parent_priv(dev, priv);
479
480         ret = i2c_set_chip_offset_len(dev, 2);
481         if (ret) {
482                 printf("i2c_set_chip_offset_len failed: %d\n", ret);
483                 return ret;
484         }
485
486         /* default config */
487         priv->dev = dev;
488
489         /* chip level reset */
490         ksz_read8(priv->dev, REG_SW_OPERATION, &data8);
491         data8 |= SW_RESET;
492         ksz_write8(priv->dev, REG_SW_OPERATION, data8);
493
494         /* read chip id */
495         ret = ksz_read32(dev, REG_CHIP_ID0__1, &id);
496         if (ret)
497                 return ret;
498         id = __swab32(id);
499         dev_dbg(dev, "%s id=0x%08x\n", __func__, id);
500         switch (id & 0xffffff00) {
501         case 0x00947700:
502                 puts("KSZ9477S: ");
503                 break;
504         case 0x00956700:
505                 puts("KSZ9567R: ");
506                 break;
507         case 0x00989700:
508                 puts("KSZ9897S: ");
509                 break;
510         default:
511                 dev_err(dev, "invalid chip id: 0x%08x\n", id);
512                 return -EINVAL;
513         }
514
515         /* probe mdio bus */
516         ret = ksz_probe_mdio(dev);
517         if (ret)
518                 return ret;
519
520         /* disable ports by default */
521         for (i = 0; i < pdata->num_ports; i++) {
522                 ksz_pread8(priv->dev, i, REG_PORT_MSTP_STATE, &data8);
523                 data8 &= ~(PORT_TX_ENABLE | PORT_RX_ENABLE | PORT_LEARN_DISABLE);
524                 ksz_pwrite8(priv->dev, i, REG_PORT_MSTP_STATE, data8);
525         }
526
527         dsa_set_tagging(dev, 0, 0);
528
529         return 0;
530 };
531
532 static const struct udevice_id ksz_i2c_ids[] = {
533         { .compatible = "microchip,ksz9897" },
534         { .compatible = "microchip,ksz9477" },
535         { .compatible = "microchip,ksz9567" },
536         { }
537 };
538
539 U_BOOT_DRIVER(ksz) = {
540         .name           = "ksz-switch",
541         .id             = UCLASS_DSA,
542         .of_match       = ksz_i2c_ids,
543         .probe          = ksz_i2c_probe,
544         .ops            = &ksz_dsa_ops,
545         .priv_auto      = sizeof(struct ksz_dsa_priv),
546 };