Commit 68bc74fe authored by Sekhar Nori's avatar Sekhar Nori Committed by David S. Miller

net: davinci_emac: fix oops caused by uninitialized ndev->dev

Commit e1943128 (drivers: net:
davinci_cpdma: Convert kzalloc() to devm_kzalloc()) triggered
a bug in emac_probe() wherein dev member of net_device is used
for devres allocations even before it is initialized.

This patch fixes that by using the struct device in platform_device
instead.

While at it, use &pdev->dev consistently for console messages instead
of using ndev->dev for just one case and remove an unnecessary line
continuation.
Reported-by: default avatarKevin Hilman <khilman@linaro.org>
Helped-by: default avatarGeorge Cherian <george.cherian@ti.com>
Signed-off-by: default avatarSekhar Nori <nsekhar@ti.com>
Acked-by: default avatarMugunthan V N <mugunthanvnm@ti.com>
Tested-by: default avatarLad, Prabhakar <prabhakar.csengg@gmail.com>
Tested-by: default avatarKevin Hilman <khilman@linaro.org>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent cb421c28
...@@ -1865,7 +1865,6 @@ static int davinci_emac_probe(struct platform_device *pdev) ...@@ -1865,7 +1865,6 @@ static int davinci_emac_probe(struct platform_device *pdev)
struct emac_priv *priv; struct emac_priv *priv;
unsigned long hw_ram_addr; unsigned long hw_ram_addr;
struct emac_platform_data *pdata; struct emac_platform_data *pdata;
struct device *emac_dev;
struct cpdma_params dma_params; struct cpdma_params dma_params;
struct clk *emac_clk; struct clk *emac_clk;
unsigned long emac_bus_frequency; unsigned long emac_bus_frequency;
...@@ -1911,7 +1910,6 @@ static int davinci_emac_probe(struct platform_device *pdev) ...@@ -1911,7 +1910,6 @@ static int davinci_emac_probe(struct platform_device *pdev)
priv->coal_intvl = 0; priv->coal_intvl = 0;
priv->bus_freq_mhz = (u32)(emac_bus_frequency / 1000000); priv->bus_freq_mhz = (u32)(emac_bus_frequency / 1000000);
emac_dev = &ndev->dev;
/* Get EMAC platform data */ /* Get EMAC platform data */
res = platform_get_resource(pdev, IORESOURCE_MEM, 0); res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
priv->emac_base_phys = res->start + pdata->ctrl_reg_offset; priv->emac_base_phys = res->start + pdata->ctrl_reg_offset;
...@@ -1930,7 +1928,7 @@ static int davinci_emac_probe(struct platform_device *pdev) ...@@ -1930,7 +1928,7 @@ static int davinci_emac_probe(struct platform_device *pdev)
hw_ram_addr = (u32 __force)res->start + pdata->ctrl_ram_offset; hw_ram_addr = (u32 __force)res->start + pdata->ctrl_ram_offset;
memset(&dma_params, 0, sizeof(dma_params)); memset(&dma_params, 0, sizeof(dma_params));
dma_params.dev = emac_dev; dma_params.dev = &pdev->dev;
dma_params.dmaregs = priv->emac_base; dma_params.dmaregs = priv->emac_base;
dma_params.rxthresh = priv->emac_base + 0x120; dma_params.rxthresh = priv->emac_base + 0x120;
dma_params.rxfree = priv->emac_base + 0x140; dma_params.rxfree = priv->emac_base + 0x140;
...@@ -1994,7 +1992,7 @@ static int davinci_emac_probe(struct platform_device *pdev) ...@@ -1994,7 +1992,7 @@ static int davinci_emac_probe(struct platform_device *pdev)
if (netif_msg_probe(priv)) { if (netif_msg_probe(priv)) {
dev_notice(emac_dev, "DaVinci EMAC Probe found device "\ dev_notice(&pdev->dev, "DaVinci EMAC Probe found device "
"(regs: %p, irq: %d)\n", "(regs: %p, irq: %d)\n",
(void *)priv->emac_base_phys, ndev->irq); (void *)priv->emac_base_phys, ndev->irq);
} }
......
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