[Patch v1] netlogic/platform_net: Catch failure to register NETLOGIC_XLR_NET device.

2016-07-11 Thread Arvind Yadav
This driver Kconfig is depend on CPU_XLR. If default Kconfig
NETLOGIC_XLR_NET value are used with CPU_XLR then you end up
with a resource. This causes __request_resource to return a
conflict which then returns an -EBUSY error code. The  driver
netlogic/platform_net.c assumes that the platfom_device_register
will always succeed.

Catch this failure during xlr_net_init. Driver should not ignore
return value of platform_device_register.

Signed-off-by: Arvind Yadav 
---
 drivers/staging/netlogic/platform_net.c | 26 +-
 1 file changed, 17 insertions(+), 9 deletions(-)

diff --git a/drivers/staging/netlogic/platform_net.c 
b/drivers/staging/netlogic/platform_net.c
index abf4c71..d8ce50d 100644
--- a/drivers/staging/netlogic/platform_net.c
+++ b/drivers/staging/netlogic/platform_net.c
@@ -130,9 +130,10 @@ static struct platform_device *gmac_controller2_init(void 
*gmac0_addr)
return _net_dev1;
 }
 
-static void xls_gmac_init(void)
+static int xls_gmac_init(void)
 {
int mac;
+   int ret;
struct platform_device *xlr_net_dev1;
void __iomem *gmac0_addr = ioremap(CPHYSADDR(
nlm_mmio_base(NETLOGIC_IO_GMAC_0_OFFSET)), 0xfff);
@@ -171,7 +172,7 @@ static void xls_gmac_init(void)
 
xlr_resource_init(_net0_res[0], xlr_gmac_offsets[0],
  xlr_gmac_irqs[0]);
-   platform_device_register(_net_dev0);
+   ret = platform_device_register(_net_dev0);
 
/* second block is XAUI, not supported yet */
break;
@@ -187,14 +188,20 @@ static void xls_gmac_init(void)
xlr_gmac_irqs[mac]);
}
xlr_net_dev0.num_resources = 8;
-   platform_device_register(_net_dev0);
+   ret = platform_device_register(_net_dev0);
 
xlr_net_dev1 = gmac_controller2_init(gmac0_addr);
-   platform_device_register(xlr_net_dev1);
+   if (ret == 0) {
+   ret = platform_device_register(xlr_net_dev1);
+   if (ret)
+   platform_driver_unregister(_net_dev0);
+   }
+
}
+   return ret;
 }
 
-static void xlr_gmac_init(void)
+static int xlr_gmac_init(void)
 {
int mac;
 
@@ -228,17 +235,18 @@ static void xlr_gmac_init(void)
xlr_net_dev0.num_resources = 8;
xlr_net_dev0.resource = xlr_net0_res;
 
-   platform_device_register(_net_dev0);
+   return platform_device_register(_net_dev0);
 }
 
 static int __init xlr_net_init(void)
 {
+   int ret;
if (nlm_chip_is_xls())
-   xls_gmac_init();
+   ret = xls_gmac_init();
else
-   xlr_gmac_init();
+   ret = xlr_gmac_init();
 
-   return 0;
+   return ret;
 }
 
 arch_initcall(xlr_net_init);
-- 
1.9.1



[Patch v1] netlogic/platform_net: Catch failure to register NETLOGIC_XLR_NET device.

2016-07-11 Thread Arvind Yadav
This driver Kconfig is depend on CPU_XLR. If default Kconfig
NETLOGIC_XLR_NET value are used with CPU_XLR then you end up
with a resource. This causes __request_resource to return a
conflict which then returns an -EBUSY error code. The  driver
netlogic/platform_net.c assumes that the platfom_device_register
will always succeed.

Catch this failure during xlr_net_init. Driver should not ignore
return value of platform_device_register.

Signed-off-by: Arvind Yadav 
---
 drivers/staging/netlogic/platform_net.c | 26 +-
 1 file changed, 17 insertions(+), 9 deletions(-)

diff --git a/drivers/staging/netlogic/platform_net.c 
b/drivers/staging/netlogic/platform_net.c
index abf4c71..d8ce50d 100644
--- a/drivers/staging/netlogic/platform_net.c
+++ b/drivers/staging/netlogic/platform_net.c
@@ -130,9 +130,10 @@ static struct platform_device *gmac_controller2_init(void 
*gmac0_addr)
return _net_dev1;
 }
 
-static void xls_gmac_init(void)
+static int xls_gmac_init(void)
 {
int mac;
+   int ret;
struct platform_device *xlr_net_dev1;
void __iomem *gmac0_addr = ioremap(CPHYSADDR(
nlm_mmio_base(NETLOGIC_IO_GMAC_0_OFFSET)), 0xfff);
@@ -171,7 +172,7 @@ static void xls_gmac_init(void)
 
xlr_resource_init(_net0_res[0], xlr_gmac_offsets[0],
  xlr_gmac_irqs[0]);
-   platform_device_register(_net_dev0);
+   ret = platform_device_register(_net_dev0);
 
/* second block is XAUI, not supported yet */
break;
@@ -187,14 +188,20 @@ static void xls_gmac_init(void)
xlr_gmac_irqs[mac]);
}
xlr_net_dev0.num_resources = 8;
-   platform_device_register(_net_dev0);
+   ret = platform_device_register(_net_dev0);
 
xlr_net_dev1 = gmac_controller2_init(gmac0_addr);
-   platform_device_register(xlr_net_dev1);
+   if (ret == 0) {
+   ret = platform_device_register(xlr_net_dev1);
+   if (ret)
+   platform_driver_unregister(_net_dev0);
+   }
+
}
+   return ret;
 }
 
-static void xlr_gmac_init(void)
+static int xlr_gmac_init(void)
 {
int mac;
 
@@ -228,17 +235,18 @@ static void xlr_gmac_init(void)
xlr_net_dev0.num_resources = 8;
xlr_net_dev0.resource = xlr_net0_res;
 
-   platform_device_register(_net_dev0);
+   return platform_device_register(_net_dev0);
 }
 
 static int __init xlr_net_init(void)
 {
+   int ret;
if (nlm_chip_is_xls())
-   xls_gmac_init();
+   ret = xls_gmac_init();
else
-   xlr_gmac_init();
+   ret = xlr_gmac_init();
 
-   return 0;
+   return ret;
 }
 
 arch_initcall(xlr_net_init);
-- 
1.9.1