Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit f1a26a06 authored by Florian Fainelli's avatar Florian Fainelli Committed by David S. Miller
Browse files

net: dsa: update dsa_of_{probe, remove} to use a device pointer



In preparation for allowing a different mechanism to register DSA switch
devices and driver, update dsa_of_probe and dsa_of_remove to take a
struct device pointer since neither of these two functions uses the
struct platform_device pointer.

Signed-off-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 49612729
Loading
Loading
Loading
Loading
+12 −12
Original line number Diff line number Diff line
@@ -563,9 +563,9 @@ static void dsa_of_free_platform_data(struct dsa_platform_data *pd)
	kfree(pd->chip);
}

static int dsa_of_probe(struct platform_device *pdev)
static int dsa_of_probe(struct device *dev)
{
	struct device_node *np = pdev->dev.of_node;
	struct device_node *np = dev->of_node;
	struct device_node *child, *mdio, *ethernet, *port, *link;
	struct mii_bus *mdio_bus;
	struct platform_device *ethernet_dev;
@@ -597,7 +597,7 @@ static int dsa_of_probe(struct platform_device *pdev)
	if (!pd)
		return -ENOMEM;

	pdev->dev.platform_data = pd;
	dev->platform_data = pd;
	pd->netdev = &ethernet_dev->dev;
	pd->nr_chips = of_get_available_child_count(np);
	if (pd->nr_chips > DSA_MAX_SWITCHES)
@@ -670,27 +670,27 @@ out_free_chip:
	dsa_of_free_platform_data(pd);
out_free:
	kfree(pd);
	pdev->dev.platform_data = NULL;
	dev->platform_data = NULL;
	return ret;
}

static void dsa_of_remove(struct platform_device *pdev)
static void dsa_of_remove(struct device *dev)
{
	struct dsa_platform_data *pd = pdev->dev.platform_data;
	struct dsa_platform_data *pd = dev->platform_data;

	if (!pdev->dev.of_node)
	if (!dev->of_node)
		return;

	dsa_of_free_platform_data(pd);
	kfree(pd);
}
#else
static inline int dsa_of_probe(struct platform_device *pdev)
static inline int dsa_of_probe(struct device *dev)
{
	return 0;
}

static inline void dsa_of_remove(struct platform_device *pdev)
static inline void dsa_of_remove(struct device *dev)
{
}
#endif
@@ -706,7 +706,7 @@ static int dsa_probe(struct platform_device *pdev)
		       dsa_driver_version);

	if (pdev->dev.of_node) {
		ret = dsa_of_probe(pdev);
		ret = dsa_of_probe(&pdev->dev);
		if (ret)
			return ret;

@@ -777,7 +777,7 @@ static int dsa_probe(struct platform_device *pdev)
	return 0;

out:
	dsa_of_remove(pdev);
	dsa_of_remove(&pdev->dev);

	return ret;
}
@@ -799,7 +799,7 @@ static int dsa_remove(struct platform_device *pdev)
			dsa_switch_destroy(ds);
	}

	dsa_of_remove(pdev);
	dsa_of_remove(&pdev->dev);

	return 0;
}