dsa.c 21.2 KB
Newer Older
1 2
/*
 * net/dsa/dsa.c - Hardware switch handling
3
 * Copyright (c) 2008-2009 Marvell Semiconductor
4
 * Copyright (c) 2013 Florian Fainelli <florian@openwrt.org>
5 6 7 8 9 10 11
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 */

12
#include <linux/device.h>
13 14
#include <linux/list.h>
#include <linux/platform_device.h>
15
#include <linux/slab.h>
16
#include <linux/module.h>
17 18 19
#include <linux/of.h>
#include <linux/of_mdio.h>
#include <linux/of_platform.h>
20
#include <linux/of_net.h>
21
#include <linux/of_gpio.h>
22
#include <linux/netdevice.h>
23
#include <linux/sysfs.h>
24
#include <linux/phy_fixed.h>
25
#include <linux/gpio/consumer.h>
26
#include <net/dsa.h>
27 28
#include "dsa_priv.h"

29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
static struct sk_buff *dsa_slave_notag_xmit(struct sk_buff *skb,
					    struct net_device *dev)
{
	/* Just return the original SKB */
	return skb;
}

static const struct dsa_device_ops none_ops = {
	.xmit	= dsa_slave_notag_xmit,
	.rcv	= NULL,
};

const struct dsa_device_ops *dsa_device_ops[DSA_TAG_LAST] = {
#ifdef CONFIG_NET_DSA_TAG_DSA
	[DSA_TAG_PROTO_DSA] = &dsa_netdev_ops,
#endif
#ifdef CONFIG_NET_DSA_TAG_EDSA
	[DSA_TAG_PROTO_EDSA] = &edsa_netdev_ops,
#endif
#ifdef CONFIG_NET_DSA_TAG_TRAILER
	[DSA_TAG_PROTO_TRAILER] = &trailer_netdev_ops,
#endif
#ifdef CONFIG_NET_DSA_TAG_BRCM
	[DSA_TAG_PROTO_BRCM] = &brcm_netdev_ops,
53 54 55
#endif
#ifdef CONFIG_NET_DSA_TAG_QCA
	[DSA_TAG_PROTO_QCA] = &qca_netdev_ops,
56 57 58
#endif
#ifdef CONFIG_NET_DSA_TAG_MTK
	[DSA_TAG_PROTO_MTK] = &mtk_netdev_ops,
59 60 61
#endif
	[DSA_TAG_PROTO_NONE] = &none_ops,
};
62 63 64 65 66

/* switch driver registration ***********************************************/
static DEFINE_MUTEX(dsa_switch_drivers_mutex);
static LIST_HEAD(dsa_switch_drivers);

67
void register_switch_driver(struct dsa_switch_driver *drv)
68 69
{
	mutex_lock(&dsa_switch_drivers_mutex);
70
	list_add_tail(&drv->list, &dsa_switch_drivers);
71 72
	mutex_unlock(&dsa_switch_drivers_mutex);
}
73
EXPORT_SYMBOL_GPL(register_switch_driver);
74

75
void unregister_switch_driver(struct dsa_switch_driver *drv)
76 77
{
	mutex_lock(&dsa_switch_drivers_mutex);
78
	list_del_init(&drv->list);
79 80
	mutex_unlock(&dsa_switch_drivers_mutex);
}
81
EXPORT_SYMBOL_GPL(unregister_switch_driver);
82

83
static const struct dsa_switch_ops *
84
dsa_switch_probe(struct device *parent, struct device *host_dev, int sw_addr,
V
Vivien Didelot 已提交
85
		 const char **_name, void **priv)
86
{
87
	const struct dsa_switch_ops *ret;
88
	struct list_head *list;
V
Vivien Didelot 已提交
89
	const char *name;
90 91 92 93 94 95

	ret = NULL;
	name = NULL;

	mutex_lock(&dsa_switch_drivers_mutex);
	list_for_each(list, &dsa_switch_drivers) {
96
		const struct dsa_switch_ops *ops;
97
		struct dsa_switch_driver *drv;
98

99 100
		drv = list_entry(list, struct dsa_switch_driver, list);
		ops = drv->ops;
101

102
		name = ops->probe(parent, host_dev, sw_addr, priv);
103
		if (name != NULL) {
104
			ret = ops;
105 106 107 108 109 110 111 112 113 114 115
			break;
		}
	}
	mutex_unlock(&dsa_switch_drivers_mutex);

	*_name = name;

	return ret;
}

/* basic switch operations **************************************************/
116
int dsa_cpu_dsa_setup(struct dsa_switch *ds, struct device *dev,
117
		      struct dsa_port *dport, int port)
118
{
119
	struct device_node *port_dn = dport->dn;
120
	struct phy_device *phydev;
121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137
	int ret, mode;

	if (of_phy_is_fixed_link(port_dn)) {
		ret = of_phy_register_fixed_link(port_dn);
		if (ret) {
			dev_err(dev, "failed to register fixed PHY\n");
			return ret;
		}
		phydev = of_phy_find_device(port_dn);

		mode = of_get_phy_mode(port_dn);
		if (mode < 0)
			mode = PHY_INTERFACE_MODE_NA;
		phydev->interface = mode;

		genphy_config_init(phydev);
		genphy_read_status(phydev);
138 139
		if (ds->ops->adjust_link)
			ds->ops->adjust_link(ds, port, phydev);
140 141

		put_device(&phydev->mdio.dev);
142 143 144 145 146 147 148
	}

	return 0;
}

static int dsa_cpu_dsa_setups(struct dsa_switch *ds, struct device *dev)
{
149
	struct dsa_port *dport;
150
	int ret, port;
151

152
	for (port = 0; port < ds->num_ports; port++) {
153 154 155
		if (!(dsa_is_cpu_port(ds, port) || dsa_is_dsa_port(ds, port)))
			continue;

156 157
		dport = &ds->ports[port];
		ret = dsa_cpu_dsa_setup(ds, dev, dport, port);
158 159
		if (ret)
			return ret;
160 161 162 163
	}
	return 0;
}

164 165 166 167 168 169 170 171 172 173 174 175 176 177
const struct dsa_device_ops *dsa_resolve_tag_protocol(int tag_protocol)
{
	const struct dsa_device_ops *ops;

	if (tag_protocol >= DSA_TAG_LAST)
		return ERR_PTR(-EINVAL);
	ops = dsa_device_ops[tag_protocol];

	if (!ops)
		return ERR_PTR(-ENOPROTOOPT);

	return ops;
}

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
int dsa_cpu_port_ethtool_setup(struct dsa_switch *ds)
{
	struct net_device *master;
	struct ethtool_ops *cpu_ops;

	master = ds->dst->master_netdev;
	if (ds->master_netdev)
		master = ds->master_netdev;

	cpu_ops = devm_kzalloc(ds->dev, sizeof(*cpu_ops), GFP_KERNEL);
	if (!cpu_ops)
		return -ENOMEM;

	memcpy(&ds->dst->master_ethtool_ops, master->ethtool_ops,
	       sizeof(struct ethtool_ops));
	ds->dst->master_orig_ethtool_ops = master->ethtool_ops;
	memcpy(cpu_ops, &ds->dst->master_ethtool_ops,
	       sizeof(struct ethtool_ops));
	dsa_cpu_port_ethtool_init(cpu_ops);
	master->ethtool_ops = cpu_ops;

	return 0;
}

void dsa_cpu_port_ethtool_restore(struct dsa_switch *ds)
{
	struct net_device *master;

	master = ds->dst->master_netdev;
	if (ds->master_netdev)
		master = ds->master_netdev;

	master->ethtool_ops = ds->dst->master_orig_ethtool_ops;
}

213
static int dsa_switch_setup_one(struct dsa_switch *ds, struct device *parent)
214
{
215
	const struct dsa_switch_ops *ops = ds->ops;
216
	struct dsa_switch_tree *dst = ds->dst;
A
Andrew Lunn 已提交
217
	struct dsa_chip_data *cd = ds->cd;
218
	bool valid_name_found = false;
219 220
	int index = ds->index;
	int i, ret;
221 222 223 224

	/*
	 * Validate supplied switch configuration.
	 */
225
	for (i = 0; i < ds->num_ports; i++) {
226 227
		char *name;

A
Andrew Lunn 已提交
228
		name = cd->port_names[i];
229 230 231 232
		if (name == NULL)
			continue;

		if (!strcmp(name, "cpu")) {
233
			if (dst->cpu_switch) {
234 235
				netdev_err(dst->master_netdev,
					   "multiple cpu ports?!\n");
236
				return -EINVAL;
237
			}
238
			dst->cpu_switch = ds;
239
			dst->cpu_port = i;
240
			ds->cpu_port_mask |= 1 << i;
241 242
		} else if (!strcmp(name, "dsa")) {
			ds->dsa_port_mask |= 1 << i;
243
		} else {
244
			ds->enabled_port_mask |= 1 << i;
245
		}
246
		valid_name_found = true;
247 248
	}

249
	if (!valid_name_found && i == ds->num_ports)
250
		return -EINVAL;
251

252 253 254
	/* Make the built-in MII bus mask match the number of ports,
	 * switch drivers can override this later
	 */
255
	ds->phys_mii_mask = ds->enabled_port_mask;
256

257
	/*
258 259 260
	 * If the CPU connects to this switch, set the switch tree
	 * tagging protocol to the preferred tagging format of this
	 * switch.
261
	 */
262
	if (dst->cpu_switch == ds) {
263 264
		enum dsa_tag_protocol tag_protocol;

265
		tag_protocol = ops->get_tag_protocol(ds);
266
		dst->tag_ops = dsa_resolve_tag_protocol(tag_protocol);
267 268
		if (IS_ERR(dst->tag_ops))
			return PTR_ERR(dst->tag_ops);
269

270
		dst->rcv = dst->tag_ops->rcv;
271
	}
272

273 274
	memcpy(ds->rtable, cd->rtable, sizeof(ds->rtable));

275 276 277
	/*
	 * Do basic register setup.
	 */
278
	ret = ops->setup(ds);
279
	if (ret < 0)
280
		return ret;
281

V
Vivien Didelot 已提交
282 283 284 285
	ret = dsa_switch_register_notifier(ds);
	if (ret)
		return ret;

286 287 288
	if (ops->set_addr) {
		ret = ops->set_addr(ds, dst->master_netdev->dev_addr);
		if (ret < 0)
289
			return ret;
290
	}
291

292
	if (!ds->slave_mii_bus && ops->phy_read) {
A
Andrew Lunn 已提交
293
		ds->slave_mii_bus = devm_mdiobus_alloc(parent);
294 295
		if (!ds->slave_mii_bus)
			return -ENOMEM;
A
Andrew Lunn 已提交
296
		dsa_slave_mii_bus_init(ds);
297

A
Andrew Lunn 已提交
298 299
		ret = mdiobus_register(ds->slave_mii_bus);
		if (ret < 0)
300
			return ret;
A
Andrew Lunn 已提交
301
	}
302 303 304 305

	/*
	 * Create network devices for physical switch ports.
	 */
306
	for (i = 0; i < ds->num_ports; i++) {
307 308
		ds->ports[i].dn = cd->port_dn[i];

309
		if (!(ds->enabled_port_mask & (1 << i)))
310 311
			continue;

A
Andrew Lunn 已提交
312
		ret = dsa_slave_create(ds, parent, i, cd->port_names[i]);
313
		if (ret < 0)
R
Russell King 已提交
314
			netdev_err(dst->master_netdev, "[%d]: can't create dsa slave device for port %d(%s): %d\n",
A
Andrew Lunn 已提交
315
				   index, i, cd->port_names[i], ret);
316 317
	}

318
	/* Perform configuration of the CPU and DSA ports */
319
	ret = dsa_cpu_dsa_setups(ds, parent);
320
	if (ret < 0)
321 322 323
		netdev_err(dst->master_netdev, "[%d] : can't configure CPU and DSA ports\n",
			   index);

324 325 326 327
	ret = dsa_cpu_port_ethtool_setup(ds);
	if (ret)
		return ret;

328
	return 0;
329 330 331 332 333 334
}

static struct dsa_switch *
dsa_switch_setup(struct dsa_switch_tree *dst, int index,
		 struct device *parent, struct device *host_dev)
{
A
Andrew Lunn 已提交
335
	struct dsa_chip_data *cd = dst->pd->chip + index;
336
	const struct dsa_switch_ops *ops;
337 338
	struct dsa_switch *ds;
	int ret;
V
Vivien Didelot 已提交
339
	const char *name;
340
	void *priv;
341 342 343 344

	/*
	 * Probe for switch model.
	 */
345 346
	ops = dsa_switch_probe(parent, host_dev, cd->sw_addr, &name, &priv);
	if (!ops) {
347 348 349 350 351 352 353 354 355 356 357
		netdev_err(dst->master_netdev, "[%d]: could not detect attached switch\n",
			   index);
		return ERR_PTR(-EINVAL);
	}
	netdev_info(dst->master_netdev, "[%d]: detected a %s switch\n",
		    index, name);


	/*
	 * Allocate and initialise switch state.
	 */
358 359
	ds = dsa_switch_alloc(parent, DSA_MAX_PORTS);
	if (!ds)
360
		return ERR_PTR(-ENOMEM);
361 362 363

	ds->dst = dst;
	ds->index = index;
A
Andrew Lunn 已提交
364
	ds->cd = cd;
365
	ds->ops = ops;
366
	ds->priv = priv;
367 368 369

	ret = dsa_switch_setup_one(ds, parent);
	if (ret)
370
		return ERR_PTR(ret);
371 372

	return ds;
373 374
}

375
void dsa_cpu_dsa_destroy(struct dsa_port *port)
376
{
377 378
	struct device_node *port_dn = port->dn;

379 380
	if (of_phy_is_fixed_link(port_dn))
		of_phy_deregister_fixed_link(port_dn);
381 382 383 384
}

static void dsa_switch_destroy(struct dsa_switch *ds)
{
385 386
	int port;

387
	/* Destroy network devices for physical switch ports. */
388
	for (port = 0; port < ds->num_ports; port++) {
389
		if (!(ds->enabled_port_mask & (1 << port)))
390 391
			continue;

392
		if (!ds->ports[port].netdev)
393 394
			continue;

395
		dsa_slave_destroy(ds->ports[port].netdev);
396 397
	}

398
	/* Disable configuration of the CPU and DSA ports */
399
	for (port = 0; port < ds->num_ports; port++) {
400 401
		if (!(dsa_is_cpu_port(ds, port) || dsa_is_dsa_port(ds, port)))
			continue;
402
		dsa_cpu_dsa_destroy(&ds->ports[port]);
403 404 405 406

		/* Clearing a bit which is not set does no harm */
		ds->cpu_port_mask |= ~(1 << port);
		ds->dsa_port_mask |= ~(1 << port);
407 408
	}

409
	if (ds->slave_mii_bus && ds->ops->phy_read)
A
Andrew Lunn 已提交
410
		mdiobus_unregister(ds->slave_mii_bus);
V
Vivien Didelot 已提交
411 412

	dsa_switch_unregister_notifier(ds);
413 414
}

415
#ifdef CONFIG_PM_SLEEP
416
int dsa_switch_suspend(struct dsa_switch *ds)
417 418 419 420
{
	int i, ret = 0;

	/* Suspend slave network devices */
421
	for (i = 0; i < ds->num_ports; i++) {
422
		if (!dsa_is_port_initialized(ds, i))
423 424
			continue;

425
		ret = dsa_slave_suspend(ds->ports[i].netdev);
426 427 428 429
		if (ret)
			return ret;
	}

430 431
	if (ds->ops->suspend)
		ret = ds->ops->suspend(ds);
432 433 434

	return ret;
}
435
EXPORT_SYMBOL_GPL(dsa_switch_suspend);
436

437
int dsa_switch_resume(struct dsa_switch *ds)
438 439 440
{
	int i, ret = 0;

441 442
	if (ds->ops->resume)
		ret = ds->ops->resume(ds);
443 444 445 446 447

	if (ret)
		return ret;

	/* Resume slave network devices */
448
	for (i = 0; i < ds->num_ports; i++) {
449
		if (!dsa_is_port_initialized(ds, i))
450 451
			continue;

452
		ret = dsa_slave_resume(ds->ports[i].netdev);
453 454 455 456 457 458
		if (ret)
			return ret;
	}

	return 0;
}
459
EXPORT_SYMBOL_GPL(dsa_switch_resume);
460
#endif
461

462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480
/* platform driver init and cleanup *****************************************/
static int dev_is_class(struct device *dev, void *class)
{
	if (dev->class != NULL && !strcmp(dev->class->name, class))
		return 1;

	return 0;
}

static struct device *dev_find_class(struct device *parent, char *class)
{
	if (dev_is_class(parent, class)) {
		get_device(parent);
		return parent;
	}

	return device_find_child(parent, class, dev_is_class);
}

481
struct mii_bus *dsa_host_dev_to_mii_bus(struct device *dev)
482 483 484 485 486 487 488 489 490 491 492 493 494 495 496
{
	struct device *d;

	d = dev_find_class(dev, "mdio_bus");
	if (d != NULL) {
		struct mii_bus *bus;

		bus = to_mii_bus(d);
		put_device(d);

		return bus;
	}

	return NULL;
}
497
EXPORT_SYMBOL_GPL(dsa_host_dev_to_mii_bus);
498

499
struct net_device *dsa_dev_to_net_device(struct device *dev)
500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515
{
	struct device *d;

	d = dev_find_class(dev, "net");
	if (d != NULL) {
		struct net_device *nd;

		nd = to_net_dev(d);
		dev_hold(nd);
		put_device(d);

		return nd;
	}

	return NULL;
}
516
EXPORT_SYMBOL_GPL(dsa_dev_to_net_device);
517

518 519 520
#ifdef CONFIG_OF
static int dsa_of_setup_routing_table(struct dsa_platform_data *pd,
					struct dsa_chip_data *cd,
521
					int chip_index, int port_index,
522 523 524 525 526 527 528 529 530 531 532 533 534 535 536
					struct device_node *link)
{
	const __be32 *reg;
	int link_sw_addr;
	struct device_node *parent_sw;
	int len;

	parent_sw = of_get_parent(link);
	if (!parent_sw)
		return -EINVAL;

	reg = of_get_property(parent_sw, "reg", &len);
	if (!reg || (len != sizeof(*reg) * 2))
		return -EINVAL;

537 538 539 540
	/*
	 * Get the destination switch number from the second field of its 'reg'
	 * property, i.e. for "reg = <0x19 1>" sw_addr is '1'.
	 */
541 542 543 544 545
	link_sw_addr = be32_to_cpup(reg + 1);

	if (link_sw_addr >= pd->nr_chips)
		return -EINVAL;

546
	cd->rtable[link_sw_addr] = port_index;
547 548 549 550

	return 0;
}

551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575
static int dsa_of_probe_links(struct dsa_platform_data *pd,
			      struct dsa_chip_data *cd,
			      int chip_index, int port_index,
			      struct device_node *port,
			      const char *port_name)
{
	struct device_node *link;
	int link_index;
	int ret;

	for (link_index = 0;; link_index++) {
		link = of_parse_phandle(port, "link", link_index);
		if (!link)
			break;

		if (!strcmp(port_name, "dsa") && pd->nr_chips > 1) {
			ret = dsa_of_setup_routing_table(pd, cd, chip_index,
							 port_index, link);
			if (ret)
				return ret;
		}
	}
	return 0;
}

576 577 578 579 580 581 582
static void dsa_of_free_platform_data(struct dsa_platform_data *pd)
{
	int i;
	int port_index;

	for (i = 0; i < pd->nr_chips; i++) {
		port_index = 0;
583
		while (port_index < DSA_MAX_PORTS) {
584
			kfree(pd->chip[i].port_names[port_index]);
585 586
			port_index++;
		}
587 588 589 590

		/* Drop our reference to the MDIO bus device */
		if (pd->chip[i].host_dev)
			put_device(pd->chip[i].host_dev);
591 592 593 594
	}
	kfree(pd->chip);
}

595
static int dsa_of_probe(struct device *dev)
596
{
597
	struct device_node *np = dev->of_node;
598
	struct device_node *child, *mdio, *ethernet, *port;
A
Andrew Lunn 已提交
599
	struct mii_bus *mdio_bus, *mdio_bus_switch;
600
	struct net_device *ethernet_dev;
601 602 603 604 605
	struct dsa_platform_data *pd;
	struct dsa_chip_data *cd;
	const char *port_name;
	int chip_index, port_index;
	const unsigned int *sw_addr, *port_reg;
606
	u32 eeprom_len;
607
	int ret;
608 609 610 611 612 613 614

	mdio = of_parse_phandle(np, "dsa,mii-bus", 0);
	if (!mdio)
		return -EINVAL;

	mdio_bus = of_mdio_find_bus(mdio);
	if (!mdio_bus)
615
		return -EPROBE_DEFER;
616 617

	ethernet = of_parse_phandle(np, "dsa,ethernet", 0);
618 619 620 621
	if (!ethernet) {
		ret = -EINVAL;
		goto out_put_mdio;
	}
622

623
	ethernet_dev = of_find_net_device_by_node(ethernet);
624 625 626 627
	if (!ethernet_dev) {
		ret = -EPROBE_DEFER;
		goto out_put_mdio;
	}
628 629

	pd = kzalloc(sizeof(*pd), GFP_KERNEL);
630 631
	if (!pd) {
		ret = -ENOMEM;
R
Russell King 已提交
632
		goto out_put_ethernet;
633
	}
634

635
	dev->platform_data = pd;
636
	pd->of_netdev = ethernet_dev;
637
	pd->nr_chips = of_get_available_child_count(np);
638 639 640
	if (pd->nr_chips > DSA_MAX_SWITCHES)
		pd->nr_chips = DSA_MAX_SWITCHES;

641 642
	pd->chip = kcalloc(pd->nr_chips, sizeof(struct dsa_chip_data),
			   GFP_KERNEL);
643 644 645 646 647
	if (!pd->chip) {
		ret = -ENOMEM;
		goto out_free;
	}

648
	chip_index = -1;
649
	for_each_available_child_of_node(np, child) {
650 651
		int i;

652
		chip_index++;
653 654
		cd = &pd->chip[chip_index];

655
		cd->of_node = child;
656

657 658 659 660
		/* Initialize the routing table */
		for (i = 0; i < DSA_MAX_SWITCHES; ++i)
			cd->rtable[i] = DSA_RTABLE_NONE;

661 662
		/* When assigning the host device, increment its refcount */
		cd->host_dev = get_device(&mdio_bus->dev);
663 664 665 666 667 668

		sw_addr = of_get_property(child, "reg", NULL);
		if (!sw_addr)
			continue;

		cd->sw_addr = be32_to_cpup(sw_addr);
669
		if (cd->sw_addr >= PHY_MAX_ADDR)
670 671
			continue;

672
		if (!of_property_read_u32(child, "eeprom-length", &eeprom_len))
673 674
			cd->eeprom_len = eeprom_len;

A
Andrew Lunn 已提交
675 676 677 678 679 680 681
		mdio = of_parse_phandle(child, "mii-bus", 0);
		if (mdio) {
			mdio_bus_switch = of_mdio_find_bus(mdio);
			if (!mdio_bus_switch) {
				ret = -EPROBE_DEFER;
				goto out_free_chip;
			}
682 683 684 685 686 687

			/* Drop the mdio_bus device ref, replacing the host
			 * device with the mdio_bus_switch device, keeping
			 * the refcount from of_mdio_find_bus() above.
			 */
			put_device(cd->host_dev);
A
Andrew Lunn 已提交
688 689 690
			cd->host_dev = &mdio_bus_switch->dev;
		}

691 692 693 694 695 696
		for_each_available_child_of_node(child, port) {
			port_reg = of_get_property(port, "reg", NULL);
			if (!port_reg)
				continue;

			port_index = be32_to_cpup(port_reg);
697 698
			if (port_index >= DSA_MAX_PORTS)
				break;
699 700 701 702 703

			port_name = of_get_property(port, "label", NULL);
			if (!port_name)
				continue;

704 705
			cd->port_dn[port_index] = port;

706 707 708 709 710 711 712
			cd->port_names[port_index] = kstrdup(port_name,
					GFP_KERNEL);
			if (!cd->port_names[port_index]) {
				ret = -ENOMEM;
				goto out_free_chip;
			}

713 714 715 716
			ret = dsa_of_probe_links(pd, cd, chip_index,
						 port_index, port, port_name);
			if (ret)
				goto out_free_chip;
717 718 719 720

		}
	}

721 722 723 724
	/* The individual chips hold their own refcount on the mdio bus,
	 * so drop ours */
	put_device(&mdio_bus->dev);

725 726 727
	return 0;

out_free_chip:
728
	dsa_of_free_platform_data(pd);
729 730
out_free:
	kfree(pd);
731
	dev->platform_data = NULL;
R
Russell King 已提交
732 733
out_put_ethernet:
	put_device(&ethernet_dev->dev);
734 735
out_put_mdio:
	put_device(&mdio_bus->dev);
736 737 738
	return ret;
}

739
static void dsa_of_remove(struct device *dev)
740
{
741
	struct dsa_platform_data *pd = dev->platform_data;
742

743
	if (!dev->of_node)
744 745
		return;

746
	dsa_of_free_platform_data(pd);
R
Russell King 已提交
747
	put_device(&pd->of_netdev->dev);
748 749 750
	kfree(pd);
}
#else
751
static inline int dsa_of_probe(struct device *dev)
752 753 754 755
{
	return 0;
}

756
static inline void dsa_of_remove(struct device *dev)
757 758 759 760
{
}
#endif

761 762
static int dsa_setup_dst(struct dsa_switch_tree *dst, struct net_device *dev,
			 struct device *parent, struct dsa_platform_data *pd)
763 764
{
	int i;
765
	unsigned configured = 0;
766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781

	dst->pd = pd;
	dst->master_netdev = dev;
	dst->cpu_port = -1;

	for (i = 0; i < pd->nr_chips; i++) {
		struct dsa_switch *ds;

		ds = dsa_switch_setup(dst, i, parent, pd->chip[i].host_dev);
		if (IS_ERR(ds)) {
			netdev_err(dev, "[%d]: couldn't create dsa switch instance (error %ld)\n",
				   i, PTR_ERR(ds));
			continue;
		}

		dst->ds[i] = ds;
782 783

		++configured;
784 785
	}

786 787 788 789 790 791
	/*
	 * If no switch was found, exit cleanly
	 */
	if (!configured)
		return -EPROBE_DEFER;

792 793 794 795 796 797 798 799
	/*
	 * If we use a tagging format that doesn't have an ethertype
	 * field, make sure that all packets from this point on get
	 * sent to the tag format's receive function.
	 */
	wmb();
	dev->dsa_ptr = (void *)dst;

800
	return 0;
801 802
}

803 804 805 806
static int dsa_probe(struct platform_device *pdev)
{
	struct dsa_platform_data *pd = pdev->dev.platform_data;
	struct net_device *dev;
807
	struct dsa_switch_tree *dst;
808
	int ret;
809

810
	if (pdev->dev.of_node) {
811
		ret = dsa_of_probe(&pdev->dev);
812 813 814 815 816 817
		if (ret)
			return ret;

		pd = pdev->dev.platform_data;
	}

818
	if (pd == NULL || (pd->netdev == NULL && pd->of_netdev == NULL))
819 820
		return -EINVAL;

821 822 823 824
	if (pd->of_netdev) {
		dev = pd->of_netdev;
		dev_hold(dev);
	} else {
825
		dev = dsa_dev_to_net_device(pd->netdev);
826
	}
827
	if (dev == NULL) {
828
		ret = -EPROBE_DEFER;
829 830
		goto out;
	}
831 832 833

	if (dev->dsa_ptr != NULL) {
		dev_put(dev);
834 835
		ret = -EEXIST;
		goto out;
836 837
	}

838
	dst = devm_kzalloc(&pdev->dev, sizeof(*dst), GFP_KERNEL);
839
	if (dst == NULL) {
840
		dev_put(dev);
841 842
		ret = -ENOMEM;
		goto out;
843 844
	}

845 846
	platform_set_drvdata(pdev, dst);

847
	ret = dsa_setup_dst(dst, dev, &pdev->dev, pd);
848 849
	if (ret) {
		dev_put(dev);
850
		goto out;
851
	}
852 853

	return 0;
854 855

out:
856
	dsa_of_remove(&pdev->dev);
857 858

	return ret;
859 860
}

861
static void dsa_remove_dst(struct dsa_switch_tree *dst)
862
{
863
	int i;
864

865 866 867 868 869 870 871 872
	dst->master_netdev->dsa_ptr = NULL;

	/* If we used a tagging format that doesn't have an ethertype
	 * field, make sure that all packets from this point get sent
	 * without the tag and go through the regular receive path.
	 */
	wmb();

873 874 875
	for (i = 0; i < dst->pd->nr_chips; i++) {
		struct dsa_switch *ds = dst->ds[i];

876
		if (ds)
877 878
			dsa_switch_destroy(ds);
	}
879

880
	dsa_cpu_port_ethtool_restore(dst->cpu_switch);
881

882
	dev_put(dst->master_netdev);
883 884 885 886 887
}

static int dsa_remove(struct platform_device *pdev)
{
	struct dsa_switch_tree *dst = platform_get_drvdata(pdev);
888

889
	dsa_remove_dst(dst);
890
	dsa_of_remove(&pdev->dev);
891

892 893 894 895 896 897 898
	return 0;
}

static void dsa_shutdown(struct platform_device *pdev)
{
}

899 900 901 902 903 904 905 906 907 908
static int dsa_switch_rcv(struct sk_buff *skb, struct net_device *dev,
			  struct packet_type *pt, struct net_device *orig_dev)
{
	struct dsa_switch_tree *dst = dev->dsa_ptr;

	if (unlikely(dst == NULL)) {
		kfree_skb(skb);
		return 0;
	}

909
	return dst->rcv(skb, dev, pt, orig_dev);
910 911
}

912
static struct packet_type dsa_pack_type __read_mostly = {
913 914 915 916
	.type	= cpu_to_be16(ETH_P_XDSA),
	.func	= dsa_switch_rcv,
};

917 918 919 920 921 922 923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951 952
#ifdef CONFIG_PM_SLEEP
static int dsa_suspend(struct device *d)
{
	struct platform_device *pdev = to_platform_device(d);
	struct dsa_switch_tree *dst = platform_get_drvdata(pdev);
	int i, ret = 0;

	for (i = 0; i < dst->pd->nr_chips; i++) {
		struct dsa_switch *ds = dst->ds[i];

		if (ds != NULL)
			ret = dsa_switch_suspend(ds);
	}

	return ret;
}

static int dsa_resume(struct device *d)
{
	struct platform_device *pdev = to_platform_device(d);
	struct dsa_switch_tree *dst = platform_get_drvdata(pdev);
	int i, ret = 0;

	for (i = 0; i < dst->pd->nr_chips; i++) {
		struct dsa_switch *ds = dst->ds[i];

		if (ds != NULL)
			ret = dsa_switch_resume(ds);
	}

	return ret;
}
#endif

static SIMPLE_DEV_PM_OPS(dsa_pm_ops, dsa_suspend, dsa_resume);

953 954 955 956 957 958
static const struct of_device_id dsa_of_match_table[] = {
	{ .compatible = "marvell,dsa", },
	{}
};
MODULE_DEVICE_TABLE(of, dsa_of_match_table);

959 960 961 962 963 964
static struct platform_driver dsa_driver = {
	.probe		= dsa_probe,
	.remove		= dsa_remove,
	.shutdown	= dsa_shutdown,
	.driver = {
		.name	= "dsa",
965
		.of_match_table = dsa_of_match_table,
966
		.pm	= &dsa_pm_ops,
967 968 969 970 971
	},
};

static int __init dsa_init_module(void)
{
B
Ben Hutchings 已提交
972 973
	int rc;

974 975 976
	rc = dsa_slave_register_notifier();
	if (rc)
		return rc;
977

B
Ben Hutchings 已提交
978 979 980 981
	rc = platform_driver_register(&dsa_driver);
	if (rc)
		return rc;

982 983
	dev_add_pack(&dsa_pack_type);

B
Ben Hutchings 已提交
984
	return 0;
985 986 987 988 989
}
module_init(dsa_init_module);

static void __exit dsa_cleanup_module(void)
{
990
	dsa_slave_unregister_notifier();
991
	dev_remove_pack(&dsa_pack_type);
992 993 994 995
	platform_driver_unregister(&dsa_driver);
}
module_exit(dsa_cleanup_module);

996
MODULE_AUTHOR("Lennert Buytenhek <buytenh@wantstofly.org>");
997 998 999
MODULE_DESCRIPTION("Driver for Distributed Switch Architecture switch chips");
MODULE_LICENSE("GPL");
MODULE_ALIAS("platform:dsa");