* [PATCH] drivers/i2c: Correct use of request_region/request_mem_region
@ 2009-08-09 13:06 Julia Lawall
2009-09-12 16:04 ` Jean Delvare
0 siblings, 1 reply; 2+ messages in thread
From: Julia Lawall @ 2009-08-09 13:06 UTC (permalink / raw)
To: Vitaly Wool, linux-i2c-u79uwXL29TY76Z2rM5mHXA,
linux-kernel-u79uwXL29TY76Z2rM5mHXA,
kernel-janitors-u79uwXL29TY76Z2rM5mHXA
From: Julia Lawall <julia-dAYI7NvHqcQ@public.gmane.org>
request_mem_region should be used when ioremap is used subsequently.
release_region is then correspondingly replaced by release_mem_region.
The semantic patch that fixes this problem is as follows:
(http://coccinelle.lip6.fr/)
// <smpl>
@r@
expression start,E;
@@
- request_region
+ request_mem_region
(start,...)
... when != request_mem_region(start,...)
when != start = E
ioremap(start,...)
@@
expression r.start;
@@
- release_region
+ release_mem_region
(start,...)
// </smpl>
Signed-off-by: Julia Lawall <julia-dAYI7NvHqcQ@public.gmane.org>
---
drivers/i2c/busses/i2c-pnx.c | 7 ++++---
1 files changed, 4 insertions(+), 3 deletions(-)
diff --git a/drivers/i2c/busses/i2c-pnx.c b/drivers/i2c/busses/i2c-pnx.c
index ec15cff..6ff6c20 100644
--- a/drivers/i2c/busses/i2c-pnx.c
+++ b/drivers/i2c/busses/i2c-pnx.c
@@ -586,7 +586,8 @@ static int __devinit i2c_pnx_probe(struct platform_device *pdev)
alg_data->mif.timer.data = (unsigned long)i2c_pnx->adapter;
/* Register I/O resource */
- if (!request_region(alg_data->base, I2C_PNX_REGION_SIZE, pdev->name)) {
+ if (!request_mem_region(alg_data->base, I2C_PNX_REGION_SIZE,
+ pdev->name)) {
dev_err(&pdev->dev,
"I/O region 0x%08x for I2C already in use.\n",
alg_data->base);
@@ -650,7 +651,7 @@ out_clock:
out_unmap:
iounmap((void *)alg_data->ioaddr);
out_release:
- release_region(alg_data->base, I2C_PNX_REGION_SIZE);
+ release_mem_region(alg_data->base, I2C_PNX_REGION_SIZE);
out_drvdata:
platform_set_drvdata(pdev, NULL);
out:
@@ -667,7 +668,7 @@ static int __devexit i2c_pnx_remove(struct platform_device *pdev)
i2c_del_adapter(adap);
i2c_pnx->set_clock_stop(pdev);
iounmap((void *)alg_data->ioaddr);
- release_region(alg_data->base, I2C_PNX_REGION_SIZE);
+ release_mem_region(alg_data->base, I2C_PNX_REGION_SIZE);
platform_set_drvdata(pdev, NULL);
return 0;
^ permalink raw reply related [flat|nested] 2+ messages in thread* Re: [PATCH] drivers/i2c: Correct use of request_region/request_mem_region
2009-08-09 13:06 [PATCH] drivers/i2c: Correct use of request_region/request_mem_region Julia Lawall
@ 2009-09-12 16:04 ` Jean Delvare
0 siblings, 0 replies; 2+ messages in thread
From: Jean Delvare @ 2009-09-12 16:04 UTC (permalink / raw)
To: Vitaly Wool; +Cc: Julia Lawall, linux-i2c, linux-kernel, kernel-janitors
On Sun, 9 Aug 2009 15:06:43 +0200 (CEST), Julia Lawall wrote:
> From: Julia Lawall <julia@diku.dk>
>
> request_mem_region should be used when ioremap is used subsequently.
> release_region is then correspondingly replaced by release_mem_region.
> (...)
> Signed-off-by: Julia Lawall <julia@diku.dk>
>
> ---
> drivers/i2c/busses/i2c-pnx.c | 7 ++++---
> 1 files changed, 4 insertions(+), 3 deletions(-)
>
> diff --git a/drivers/i2c/busses/i2c-pnx.c b/drivers/i2c/busses/i2c-pnx.c
> index ec15cff..6ff6c20 100644
> --- a/drivers/i2c/busses/i2c-pnx.c
> +++ b/drivers/i2c/busses/i2c-pnx.c
> @@ -586,7 +586,8 @@ static int __devinit i2c_pnx_probe(struct platform_device *pdev)
> alg_data->mif.timer.data = (unsigned long)i2c_pnx->adapter;
>
> /* Register I/O resource */
> - if (!request_region(alg_data->base, I2C_PNX_REGION_SIZE, pdev->name)) {
> + if (!request_mem_region(alg_data->base, I2C_PNX_REGION_SIZE,
> + pdev->name)) {
> dev_err(&pdev->dev,
> "I/O region 0x%08x for I2C already in use.\n",
> alg_data->base);
> @@ -650,7 +651,7 @@ out_clock:
> out_unmap:
> iounmap((void *)alg_data->ioaddr);
> out_release:
> - release_region(alg_data->base, I2C_PNX_REGION_SIZE);
> + release_mem_region(alg_data->base, I2C_PNX_REGION_SIZE);
> out_drvdata:
> platform_set_drvdata(pdev, NULL);
> out:
> @@ -667,7 +668,7 @@ static int __devexit i2c_pnx_remove(struct platform_device *pdev)
> i2c_del_adapter(adap);
> i2c_pnx->set_clock_stop(pdev);
> iounmap((void *)alg_data->ioaddr);
> - release_region(alg_data->base, I2C_PNX_REGION_SIZE);
> + release_mem_region(alg_data->base, I2C_PNX_REGION_SIZE);
> platform_set_drvdata(pdev, NULL);
>
> return 0;
Vitaly, can you please ack this change?
--
Jean Delvare
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2009-09-12 16:04 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-08-09 13:06 [PATCH] drivers/i2c: Correct use of request_region/request_mem_region Julia Lawall
2009-09-12 16:04 ` Jean Delvare
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).