Re: [PATCH 2/5] drivers: bus: omap_l3: Convert to use devm_request_and_ioremap()

From: Alexander Shiyan
Date: Tue Mar 04 2014 - 04:13:01 EST


ÐÑÐÑÐÐÐ, 4 ÐÐÑÑÐ 2014, 11:01 +02:00 ÐÑ Peter Ujfalusi <peter.ujfalusi@xxxxxx>:
> We can then remove the iounmap() calls from probe and remove.
> Since the driver requests the resources via index we can do the mem resource
> request within a for loop.
>
> Signed-off-by: Peter Ujfalusi <peter.ujfalusi@xxxxxx>
> Reviewed-by: Santosh Shilimkar <santosh.shilimkar@ti>
> ---

> + /* Get mem resources */
> + for (i = 0; i < 3; i++) {
> + struct resource *res = platform_get_resource(pdev,
> + IORESOURCE_MEM, i);
> + if (!res) {
> + dev_err(&pdev->dev, "couldn't find resource %d\n", i);
> + return -ENODEV;
> + }

No need to check "res". devm_request_and_ioremap() do all for us.

> - l3->l3_base[2] = ioremap(res->start, resource_size(res));
> - if (!l3->l3_base[2]) {
> - dev_err(&pdev->dev, "ioremap failed\n");
> - ret = -ENOMEM;
> - goto err2;
> + l3->l3_base[i] = devm_request_and_ioremap(&pdev->dev, res);
> + if (!l3->l3_base[i]) {

if (IS_ERR(l3->l3_base[i]))

> + dev_err(&pdev->dev, "ioremap %d failed\n", i);

Unnecessary.

> + return -ENOMEM;

return PTR_ERR(l3->l3_base[i]);

---
N‹§²æ¸›yú²X¬¶ÇvØ–)Þ{.nlj·¥Š{±‘êX§¶›¡Ü}©ž²ÆzÚj:+v‰¨¾«‘êZ+€Êzf£¢·hšˆ§~†­†Ûÿû®w¥¢¸?™¨è&¢)ßf”ùy§m…á«a¶Úÿ 0¶ìå