ssb: unregister gpios before unloading ssb
This patch unregisters the gpio chip before ssb gets unloaded. Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
Родитель
c50ae9470e
Коммит
600485edae
|
@ -174,3 +174,15 @@ int ssb_gpio_init(struct ssb_bus *bus)
|
||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int ssb_gpio_unregister(struct ssb_bus *bus)
|
||||||
|
{
|
||||||
|
if (ssb_chipco_available(&bus->chipco) ||
|
||||||
|
ssb_extif_available(&bus->extif)) {
|
||||||
|
return gpiochip_remove(&bus->gpio);
|
||||||
|
} else {
|
||||||
|
SSB_WARN_ON(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
|
@ -443,6 +443,15 @@ static void ssb_devices_unregister(struct ssb_bus *bus)
|
||||||
|
|
||||||
void ssb_bus_unregister(struct ssb_bus *bus)
|
void ssb_bus_unregister(struct ssb_bus *bus)
|
||||||
{
|
{
|
||||||
|
int err;
|
||||||
|
|
||||||
|
err = ssb_gpio_unregister(bus);
|
||||||
|
if (err == -EBUSY)
|
||||||
|
ssb_dprintk(KERN_ERR PFX "Some GPIOs are still in use.\n");
|
||||||
|
else if (err)
|
||||||
|
ssb_dprintk(KERN_ERR PFX
|
||||||
|
"Can not unregister GPIO driver: %i\n", err);
|
||||||
|
|
||||||
ssb_buses_lock();
|
ssb_buses_lock();
|
||||||
ssb_devices_unregister(bus);
|
ssb_devices_unregister(bus);
|
||||||
list_del(&bus->list);
|
list_del(&bus->list);
|
||||||
|
|
|
@ -252,11 +252,16 @@ static inline void ssb_extif_init(struct ssb_extif *extif)
|
||||||
|
|
||||||
#ifdef CONFIG_SSB_DRIVER_GPIO
|
#ifdef CONFIG_SSB_DRIVER_GPIO
|
||||||
extern int ssb_gpio_init(struct ssb_bus *bus);
|
extern int ssb_gpio_init(struct ssb_bus *bus);
|
||||||
|
extern int ssb_gpio_unregister(struct ssb_bus *bus);
|
||||||
#else /* CONFIG_SSB_DRIVER_GPIO */
|
#else /* CONFIG_SSB_DRIVER_GPIO */
|
||||||
static inline int ssb_gpio_init(struct ssb_bus *bus)
|
static inline int ssb_gpio_init(struct ssb_bus *bus)
|
||||||
{
|
{
|
||||||
return -ENOTSUPP;
|
return -ENOTSUPP;
|
||||||
}
|
}
|
||||||
|
static inline int ssb_gpio_unregister(struct ssb_bus *bus)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
#endif /* CONFIG_SSB_DRIVER_GPIO */
|
#endif /* CONFIG_SSB_DRIVER_GPIO */
|
||||||
|
|
||||||
#endif /* LINUX_SSB_PRIVATE_H_ */
|
#endif /* LINUX_SSB_PRIVATE_H_ */
|
||||||
|
|
Загрузка…
Ссылка в новой задаче