Commit 3a611e26 authored by Geert Uytterhoeven's avatar Geert Uytterhoeven Committed by David S. Miller

net/smsc911x: Add minimal runtime PM support

Add minimal runtime PM support (enable on probe, disable on remove), to
ensure proper operation with a parent device that uses runtime PM.

This is needed on systems where the external bus controller module of
the SoC is contained in a PM domain and/or has a gateable functional
clock. In such cases, before accessing any device connected to the
external bus, the PM domain must be powered up, and/or the functional
clock must be enabled, which is typically handled through runtime PM by
the bus controller driver.

An example of this is the kzm9g development board, where an smsc9220
Ethernet controller is connected to the Bus State Controller (BSC) of a
Renesas sh73a0 SoC.
Signed-off-by: default avatarGeert Uytterhoeven <geert+renesas@glider.be>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 4f037215
...@@ -59,6 +59,8 @@ ...@@ -59,6 +59,8 @@
#include <linux/of_device.h> #include <linux/of_device.h>
#include <linux/of_gpio.h> #include <linux/of_gpio.h>
#include <linux/of_net.h> #include <linux/of_net.h>
#include <linux/pm_runtime.h>
#include "smsc911x.h" #include "smsc911x.h"
#define SMSC_CHIPNAME "smsc911x" #define SMSC_CHIPNAME "smsc911x"
...@@ -2338,6 +2340,9 @@ static int smsc911x_drv_remove(struct platform_device *pdev) ...@@ -2338,6 +2340,9 @@ static int smsc911x_drv_remove(struct platform_device *pdev)
free_netdev(dev); free_netdev(dev);
pm_runtime_put(&pdev->dev);
pm_runtime_disable(&pdev->dev);
return 0; return 0;
} }
...@@ -2491,6 +2496,9 @@ static int smsc911x_drv_probe(struct platform_device *pdev) ...@@ -2491,6 +2496,9 @@ static int smsc911x_drv_probe(struct platform_device *pdev)
if (pdata->config.shift) if (pdata->config.shift)
pdata->ops = &shifted_smsc911x_ops; pdata->ops = &shifted_smsc911x_ops;
pm_runtime_enable(&pdev->dev);
pm_runtime_get_sync(&pdev->dev);
retval = smsc911x_init(dev); retval = smsc911x_init(dev);
if (retval < 0) if (retval < 0)
goto out_disable_resources; goto out_disable_resources;
...@@ -2572,6 +2580,8 @@ static int smsc911x_drv_probe(struct platform_device *pdev) ...@@ -2572,6 +2580,8 @@ static int smsc911x_drv_probe(struct platform_device *pdev)
out_free_irq: out_free_irq:
free_irq(dev->irq, dev); free_irq(dev->irq, dev);
out_disable_resources: out_disable_resources:
pm_runtime_put(&pdev->dev);
pm_runtime_disable(&pdev->dev);
(void)smsc911x_disable_resources(pdev); (void)smsc911x_disable_resources(pdev);
out_enable_resources_fail: out_enable_resources_fail:
smsc911x_free_resources(pdev); smsc911x_free_resources(pdev);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment