Commit 460d47db authored by Russell King's avatar Russell King

DMA-API: usb: musb: use platform_device_register_full() to avoid directly messing with dma masks

Use platform_device_register_full() for those drivers which can, to
avoid messing directly with DMA masks.  This can only be done when
the driver does not need to access the allocated musb platform device
from within its callbacks, which may be called during the musb
device probing.
Signed-off-by: default avatarRussell King <rmk+kernel@arm.linux.org.uk>
parent 27c1789c
...@@ -89,7 +89,6 @@ struct am35x_glue { ...@@ -89,7 +89,6 @@ struct am35x_glue {
struct clk *phy_clk; struct clk *phy_clk;
struct clk *clk; struct clk *clk;
}; };
#define glue_to_musb(g) platform_get_drvdata(g->musb)
/* /*
* am35x_musb_enable - enable interrupts * am35x_musb_enable - enable interrupts
...@@ -452,14 +451,18 @@ static const struct musb_platform_ops am35x_ops = { ...@@ -452,14 +451,18 @@ static const struct musb_platform_ops am35x_ops = {
.set_vbus = am35x_musb_set_vbus, .set_vbus = am35x_musb_set_vbus,
}; };
static u64 am35x_dmamask = DMA_BIT_MASK(32); static const struct platform_device_info am35x_dev_info = {
.name = "musb-hdrc",
.id = PLATFORM_DEVID_AUTO,
.dma_mask = DMA_BIT_MASK(32),
};
static int am35x_probe(struct platform_device *pdev) static int am35x_probe(struct platform_device *pdev)
{ {
struct musb_hdrc_platform_data *pdata = dev_get_platdata(&pdev->dev); struct musb_hdrc_platform_data *pdata = dev_get_platdata(&pdev->dev);
struct platform_device *musb; struct platform_device *musb;
struct am35x_glue *glue; struct am35x_glue *glue;
struct platform_device_info pinfo;
struct clk *phy_clk; struct clk *phy_clk;
struct clk *clk; struct clk *clk;
...@@ -471,12 +474,6 @@ static int am35x_probe(struct platform_device *pdev) ...@@ -471,12 +474,6 @@ static int am35x_probe(struct platform_device *pdev)
goto err0; goto err0;
} }
musb = platform_device_alloc("musb-hdrc", PLATFORM_DEVID_AUTO);
if (!musb) {
dev_err(&pdev->dev, "failed to allocate musb device\n");
goto err1;
}
phy_clk = clk_get(&pdev->dev, "fck"); phy_clk = clk_get(&pdev->dev, "fck");
if (IS_ERR(phy_clk)) { if (IS_ERR(phy_clk)) {
dev_err(&pdev->dev, "failed to get PHY clock\n"); dev_err(&pdev->dev, "failed to get PHY clock\n");
...@@ -503,12 +500,7 @@ static int am35x_probe(struct platform_device *pdev) ...@@ -503,12 +500,7 @@ static int am35x_probe(struct platform_device *pdev)
goto err6; goto err6;
} }
musb->dev.parent = &pdev->dev;
musb->dev.dma_mask = &am35x_dmamask;
musb->dev.coherent_dma_mask = am35x_dmamask;
glue->dev = &pdev->dev; glue->dev = &pdev->dev;
glue->musb = musb;
glue->phy_clk = phy_clk; glue->phy_clk = phy_clk;
glue->clk = clk; glue->clk = clk;
...@@ -516,22 +508,17 @@ static int am35x_probe(struct platform_device *pdev) ...@@ -516,22 +508,17 @@ static int am35x_probe(struct platform_device *pdev)
platform_set_drvdata(pdev, glue); platform_set_drvdata(pdev, glue);
ret = platform_device_add_resources(musb, pdev->resource, pinfo = am35x_dev_info;
pdev->num_resources); pinfo.parent = &pdev->dev;
if (ret) { pinfo.res = pdev->resource;
dev_err(&pdev->dev, "failed to add resources\n"); pinfo.num_res = pdev->num_resources;
goto err7; pinfo.data = pdata;
} pinfo.size_data = sizeof(*pdata);
ret = platform_device_add_data(musb, pdata, sizeof(*pdata)); glue->musb = musb = platform_device_register_full(&pinfo);
if (ret) { if (IS_ERR(musb)) {
dev_err(&pdev->dev, "failed to add platform_data\n"); ret = PTR_ERR(musb);
goto err7; dev_err(&pdev->dev, "failed to register musb device: %d\n", ret);
}
ret = platform_device_add(musb);
if (ret) {
dev_err(&pdev->dev, "failed to register musb device\n");
goto err7; goto err7;
} }
...@@ -550,9 +537,6 @@ static int am35x_probe(struct platform_device *pdev) ...@@ -550,9 +537,6 @@ static int am35x_probe(struct platform_device *pdev)
clk_put(phy_clk); clk_put(phy_clk);
err3: err3:
platform_device_put(musb);
err1:
kfree(glue); kfree(glue);
err0: err0:
......
...@@ -472,7 +472,11 @@ static const struct musb_platform_ops da8xx_ops = { ...@@ -472,7 +472,11 @@ static const struct musb_platform_ops da8xx_ops = {
.set_vbus = da8xx_musb_set_vbus, .set_vbus = da8xx_musb_set_vbus,
}; };
static u64 da8xx_dmamask = DMA_BIT_MASK(32); static const struct platform_device_info da8xx_dev_info = {
.name = "musb-hdrc",
.id = PLATFORM_DEVID_AUTO,
.dma_mask = DMA_BIT_MASK(32),
};
static int da8xx_probe(struct platform_device *pdev) static int da8xx_probe(struct platform_device *pdev)
{ {
...@@ -480,7 +484,7 @@ static int da8xx_probe(struct platform_device *pdev) ...@@ -480,7 +484,7 @@ static int da8xx_probe(struct platform_device *pdev)
struct musb_hdrc_platform_data *pdata = dev_get_platdata(&pdev->dev); struct musb_hdrc_platform_data *pdata = dev_get_platdata(&pdev->dev);
struct platform_device *musb; struct platform_device *musb;
struct da8xx_glue *glue; struct da8xx_glue *glue;
struct platform_device_info pinfo;
struct clk *clk; struct clk *clk;
int ret = -ENOMEM; int ret = -ENOMEM;
...@@ -491,12 +495,6 @@ static int da8xx_probe(struct platform_device *pdev) ...@@ -491,12 +495,6 @@ static int da8xx_probe(struct platform_device *pdev)
goto err0; goto err0;
} }
musb = platform_device_alloc("musb-hdrc", PLATFORM_DEVID_AUTO);
if (!musb) {
dev_err(&pdev->dev, "failed to allocate musb device\n");
goto err1;
}
clk = clk_get(&pdev->dev, "usb20"); clk = clk_get(&pdev->dev, "usb20");
if (IS_ERR(clk)) { if (IS_ERR(clk)) {
dev_err(&pdev->dev, "failed to get clock\n"); dev_err(&pdev->dev, "failed to get clock\n");
...@@ -510,12 +508,7 @@ static int da8xx_probe(struct platform_device *pdev) ...@@ -510,12 +508,7 @@ static int da8xx_probe(struct platform_device *pdev)
goto err4; goto err4;
} }
musb->dev.parent = &pdev->dev;
musb->dev.dma_mask = &da8xx_dmamask;
musb->dev.coherent_dma_mask = da8xx_dmamask;
glue->dev = &pdev->dev; glue->dev = &pdev->dev;
glue->musb = musb;
glue->clk = clk; glue->clk = clk;
pdata->platform_ops = &da8xx_ops; pdata->platform_ops = &da8xx_ops;
...@@ -535,22 +528,17 @@ static int da8xx_probe(struct platform_device *pdev) ...@@ -535,22 +528,17 @@ static int da8xx_probe(struct platform_device *pdev)
musb_resources[1].end = pdev->resource[1].end; musb_resources[1].end = pdev->resource[1].end;
musb_resources[1].flags = pdev->resource[1].flags; musb_resources[1].flags = pdev->resource[1].flags;
ret = platform_device_add_resources(musb, musb_resources, pinfo = da8xx_dev_info;
ARRAY_SIZE(musb_resources)); pinfo.parent = &pdev->dev;
if (ret) { pinfo.res = musb_resources;
dev_err(&pdev->dev, "failed to add resources\n"); pinfo.num_res = ARRAY_SIZE(musb_resources);
goto err5; pinfo.data = pdata;
} pinfo.size_data = sizeof(*pdata);
ret = platform_device_add_data(musb, pdata, sizeof(*pdata)); glue->musb = musb = platform_device_register_full(&pinfo);
if (ret) { if (IS_ERR(musb)) {
dev_err(&pdev->dev, "failed to add platform_data\n"); ret = PTR_ERR(musb);
goto err5; dev_err(&pdev->dev, "failed to register musb device: %d\n", ret);
}
ret = platform_device_add(musb);
if (ret) {
dev_err(&pdev->dev, "failed to register musb device\n");
goto err5; goto err5;
} }
...@@ -563,9 +551,6 @@ static int da8xx_probe(struct platform_device *pdev) ...@@ -563,9 +551,6 @@ static int da8xx_probe(struct platform_device *pdev)
clk_put(clk); clk_put(clk);
err3: err3:
platform_device_put(musb);
err1:
kfree(glue); kfree(glue);
err0: err0:
......
...@@ -505,7 +505,11 @@ static const struct musb_platform_ops davinci_ops = { ...@@ -505,7 +505,11 @@ static const struct musb_platform_ops davinci_ops = {
.set_vbus = davinci_musb_set_vbus, .set_vbus = davinci_musb_set_vbus,
}; };
static u64 davinci_dmamask = DMA_BIT_MASK(32); static const struct platform_device_info davinci_dev_info = {
.name = "musb-hdrc",
.id = PLATFORM_DEVID_AUTO,
.dma_mask = DMA_BIT_MASK(32),
};
static int davinci_probe(struct platform_device *pdev) static int davinci_probe(struct platform_device *pdev)
{ {
...@@ -513,6 +517,7 @@ static int davinci_probe(struct platform_device *pdev) ...@@ -513,6 +517,7 @@ static int davinci_probe(struct platform_device *pdev)
struct musb_hdrc_platform_data *pdata = dev_get_platdata(&pdev->dev); struct musb_hdrc_platform_data *pdata = dev_get_platdata(&pdev->dev);
struct platform_device *musb; struct platform_device *musb;
struct davinci_glue *glue; struct davinci_glue *glue;
struct platform_device_info pinfo;
struct clk *clk; struct clk *clk;
int ret = -ENOMEM; int ret = -ENOMEM;
...@@ -523,12 +528,6 @@ static int davinci_probe(struct platform_device *pdev) ...@@ -523,12 +528,6 @@ static int davinci_probe(struct platform_device *pdev)
goto err0; goto err0;
} }
musb = platform_device_alloc("musb-hdrc", PLATFORM_DEVID_AUTO);
if (!musb) {
dev_err(&pdev->dev, "failed to allocate musb device\n");
goto err1;
}
clk = clk_get(&pdev->dev, "usb"); clk = clk_get(&pdev->dev, "usb");
if (IS_ERR(clk)) { if (IS_ERR(clk)) {
dev_err(&pdev->dev, "failed to get clock\n"); dev_err(&pdev->dev, "failed to get clock\n");
...@@ -542,12 +541,7 @@ static int davinci_probe(struct platform_device *pdev) ...@@ -542,12 +541,7 @@ static int davinci_probe(struct platform_device *pdev)
goto err4; goto err4;
} }
musb->dev.parent = &pdev->dev;
musb->dev.dma_mask = &davinci_dmamask;
musb->dev.coherent_dma_mask = davinci_dmamask;
glue->dev = &pdev->dev; glue->dev = &pdev->dev;
glue->musb = musb;
glue->clk = clk; glue->clk = clk;
pdata->platform_ops = &davinci_ops; pdata->platform_ops = &davinci_ops;
...@@ -567,22 +561,17 @@ static int davinci_probe(struct platform_device *pdev) ...@@ -567,22 +561,17 @@ static int davinci_probe(struct platform_device *pdev)
musb_resources[1].end = pdev->resource[1].end; musb_resources[1].end = pdev->resource[1].end;
musb_resources[1].flags = pdev->resource[1].flags; musb_resources[1].flags = pdev->resource[1].flags;
ret = platform_device_add_resources(musb, musb_resources, pinfo = davinci_dev_info;
ARRAY_SIZE(musb_resources)); pinfo.parent = &pdev->dev;
if (ret) { pinfo.res = musb_resources;
dev_err(&pdev->dev, "failed to add resources\n"); pinfo.num_res = ARRAY_SIZE(musb_resources);
goto err5; pinfo.data = pdata;
} pinfo.size_data = sizeof(*pdata);
ret = platform_device_add_data(musb, pdata, sizeof(*pdata)); glue->musb = musb = platform_device_register_full(&pinfo);
if (ret) { if (IS_ERR(musb)) {
dev_err(&pdev->dev, "failed to add platform_data\n"); ret = PTR_ERR(musb);
goto err5; dev_err(&pdev->dev, "failed to register musb device: %d\n", ret);
}
ret = platform_device_add(musb);
if (ret) {
dev_err(&pdev->dev, "failed to register musb device\n");
goto err5; goto err5;
} }
...@@ -595,9 +584,6 @@ static int davinci_probe(struct platform_device *pdev) ...@@ -595,9 +584,6 @@ static int davinci_probe(struct platform_device *pdev)
clk_put(clk); clk_put(clk);
err3: err3:
platform_device_put(musb);
err1:
kfree(glue); kfree(glue);
err0: err0:
......
...@@ -1152,7 +1152,11 @@ static const struct musb_platform_ops tusb_ops = { ...@@ -1152,7 +1152,11 @@ static const struct musb_platform_ops tusb_ops = {
.set_vbus = tusb_musb_set_vbus, .set_vbus = tusb_musb_set_vbus,
}; };
static u64 tusb_dmamask = DMA_BIT_MASK(32); static const struct platform_device_info tusb_dev_info = {
.name = "musb-hdrc",
.id = PLATFORM_DEVID_AUTO,
.dma_mask = DMA_BIT_MASK(32),
};
static int tusb_probe(struct platform_device *pdev) static int tusb_probe(struct platform_device *pdev)
{ {
...@@ -1160,7 +1164,7 @@ static int tusb_probe(struct platform_device *pdev) ...@@ -1160,7 +1164,7 @@ static int tusb_probe(struct platform_device *pdev)
struct musb_hdrc_platform_data *pdata = dev_get_platdata(&pdev->dev); struct musb_hdrc_platform_data *pdata = dev_get_platdata(&pdev->dev);
struct platform_device *musb; struct platform_device *musb;
struct tusb6010_glue *glue; struct tusb6010_glue *glue;
struct platform_device_info pinfo;
int ret = -ENOMEM; int ret = -ENOMEM;
glue = kzalloc(sizeof(*glue), GFP_KERNEL); glue = kzalloc(sizeof(*glue), GFP_KERNEL);
...@@ -1169,18 +1173,7 @@ static int tusb_probe(struct platform_device *pdev) ...@@ -1169,18 +1173,7 @@ static int tusb_probe(struct platform_device *pdev)
goto err0; goto err0;
} }
musb = platform_device_alloc("musb-hdrc", PLATFORM_DEVID_AUTO);
if (!musb) {
dev_err(&pdev->dev, "failed to allocate musb device\n");
goto err1;
}
musb->dev.parent = &pdev->dev;
musb->dev.dma_mask = &tusb_dmamask;
musb->dev.coherent_dma_mask = tusb_dmamask;
glue->dev = &pdev->dev; glue->dev = &pdev->dev;
glue->musb = musb;
pdata->platform_ops = &tusb_ops; pdata->platform_ops = &tusb_ops;
...@@ -1204,31 +1197,23 @@ static int tusb_probe(struct platform_device *pdev) ...@@ -1204,31 +1197,23 @@ static int tusb_probe(struct platform_device *pdev)
musb_resources[2].end = pdev->resource[2].end; musb_resources[2].end = pdev->resource[2].end;
musb_resources[2].flags = pdev->resource[2].flags; musb_resources[2].flags = pdev->resource[2].flags;
ret = platform_device_add_resources(musb, musb_resources, pinfo = tusb_dev_info;
ARRAY_SIZE(musb_resources)); pinfo.parent = &pdev->dev;
if (ret) { pinfo.res = musb_resources;
dev_err(&pdev->dev, "failed to add resources\n"); pinfo.num_res = ARRAY_SIZE(musb_resources);
goto err3; pinfo.data = pdata;
} pinfo.size_data = sizeof(*pdata);
ret = platform_device_add_data(musb, pdata, sizeof(*pdata)); glue->musb = musb = platform_device_register_full(&pinfo);
if (ret) { if (IS_ERR(musb)) {
dev_err(&pdev->dev, "failed to add platform_data\n"); ret = PTR_ERR(musb);
goto err3; dev_err(&pdev->dev, "failed to register musb device: %d\n", ret);
}
ret = platform_device_add(musb);
if (ret) {
dev_err(&pdev->dev, "failed to register musb device\n");
goto err3; goto err3;
} }
return 0; return 0;
err3: err3:
platform_device_put(musb);
err1:
kfree(glue); kfree(glue);
err0: err0:
......
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