aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net
diff options
context:
space:
mode:
authorFabio Estevam <fabio.estevam@freescale.com>2013-05-26 23:48:29 -0400
committerDavid S. Miller <davem@davemloft.net>2013-05-28 01:29:54 -0400
commitf4e9f3d2fdb141d920c9fd7bd5ea7db348f6d3be (patch)
tree91de00d3ac2b93c126eb0abe5f29254f694445ed /drivers/net
parent3904dcc4a7af8e28e45a8d123cef3f7653847a51 (diff)
fec: Place the phy regulator in the private structure
Instead of using a local reg_phy structure, let's put it inside the private structure, so that we are able to have access to the regulator structure even when we are outside fec_probe(). This is in preparation for controlling the FEC PHY regulator in the suspend and resume functions. Signed-off-by: Fabio Estevam <fabio.estevam@freescale.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net')
-rw-r--r--drivers/net/ethernet/freescale/fec.h1
-rw-r--r--drivers/net/ethernet/freescale/fec_main.c7
2 files changed, 4 insertions, 4 deletions
diff --git a/drivers/net/ethernet/freescale/fec.h b/drivers/net/ethernet/freescale/fec.h
index 9ce5b7185fda..b11cdbcc04ff 100644
--- a/drivers/net/ethernet/freescale/fec.h
+++ b/drivers/net/ethernet/freescale/fec.h
@@ -272,6 +272,7 @@ struct fec_enet_private {
272 int hwts_tx_en; 272 int hwts_tx_en;
273 struct timer_list time_keep; 273 struct timer_list time_keep;
274 struct fec_enet_delayed_work delay_work; 274 struct fec_enet_delayed_work delay_work;
275 struct regulator *reg_phy;
275}; 276};
276 277
277void fec_ptp_init(struct net_device *ndev, struct platform_device *pdev); 278void fec_ptp_init(struct net_device *ndev, struct platform_device *pdev);
diff --git a/drivers/net/ethernet/freescale/fec_main.c b/drivers/net/ethernet/freescale/fec_main.c
index 0936b26b5e1e..57ac7c3453d6 100644
--- a/drivers/net/ethernet/freescale/fec_main.c
+++ b/drivers/net/ethernet/freescale/fec_main.c
@@ -1840,7 +1840,6 @@ fec_probe(struct platform_device *pdev)
1840 struct resource *r; 1840 struct resource *r;
1841 const struct of_device_id *of_id; 1841 const struct of_device_id *of_id;
1842 static int dev_id; 1842 static int dev_id;
1843 struct regulator *reg_phy;
1844 1843
1845 of_id = of_match_device(fec_dt_ids, &pdev->dev); 1844 of_id = of_match_device(fec_dt_ids, &pdev->dev);
1846 if (of_id) 1845 if (of_id)
@@ -1919,9 +1918,9 @@ fec_probe(struct platform_device *pdev)
1919 clk_prepare_enable(fep->clk_enet_out); 1918 clk_prepare_enable(fep->clk_enet_out);
1920 clk_prepare_enable(fep->clk_ptp); 1919 clk_prepare_enable(fep->clk_ptp);
1921 1920
1922 reg_phy = devm_regulator_get(&pdev->dev, "phy"); 1921 fep->reg_phy = devm_regulator_get(&pdev->dev, "phy");
1923 if (!IS_ERR(reg_phy)) { 1922 if (!IS_ERR(fep->reg_phy)) {
1924 ret = regulator_enable(reg_phy); 1923 ret = regulator_enable(fep->reg_phy);
1925 if (ret) { 1924 if (ret) {
1926 dev_err(&pdev->dev, 1925 dev_err(&pdev->dev,
1927 "Failed to enable phy regulator: %d\n", ret); 1926 "Failed to enable phy regulator: %d\n", ret);