Returning a non-zero value in a platform driver's remove callback only
results in an error message ("remove callback returned a non-zero value.
This will be ignored.", see platform_remove()), and then the device is
removed anyhow.
As there was just a WARN_ON triggered, return 0 to drop the follow up
warning. The latter output is hardly relevant after the big WARN splat.
This is a preparation for making platform remove callbacks return void.
Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Signed-off-by: Bartosz Golaszewski <brgl@bgdev.pl>
 
        gpiochip_remove(&priv->gpio_chip);
 
-       if (is_module())
-               return 0;
-
        /* REVISIT no support yet for deregistering all the IRQs */
-       WARN_ON(1);
-       return -EIO;
+       WARN_ON(!is_module());
+       return 0;
 }
 
 static const struct of_device_id twl_gpio_match[] = {