Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 03246800 authored by Thayumanavar Sachithanantham's avatar Thayumanavar Sachithanantham Committed by Linus Torvalds
Browse files

[PATCH] cs5535_gpio.c: call cdev_del() during module_exit to unmap kobject...

[PATCH] cs5535_gpio.c: call cdev_del() during module_exit to unmap kobject references and other cleanups

During module unloading, cdev_del() must be called to unmap cdev related
kobject references and other cleanups(such as inode->i_cdev being set to
NULL) which prevents the OOPS upon subsequent loading, usage and unloading
of modules(as seen in the mail thread
http://marc.theaimsgroup.com/?l=linux-kernel&m=114533640609018&w=2

).

Also, remove unneeded test of gpio_base.

Signed-off-by: default avatarThayumanavar Sachithanantham <thayumk@gmail.com>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent c16c556e
Loading
Loading
Loading
Loading
+3 −2
Original line number Original line Diff line number Diff line
@@ -241,8 +241,9 @@ static int __init cs5535_gpio_init(void)
static void __exit cs5535_gpio_cleanup(void)
static void __exit cs5535_gpio_cleanup(void)
{
{
	dev_t dev_id = MKDEV(major, 0);
	dev_t dev_id = MKDEV(major, 0);

	cdev_del(&cs5535_gpio_cdev);
	unregister_chrdev_region(dev_id, CS5535_GPIO_COUNT);
	unregister_chrdev_region(dev_id, CS5535_GPIO_COUNT);
	if (gpio_base != 0)
	release_region(gpio_base, CS5535_GPIO_SIZE);
	release_region(gpio_base, CS5535_GPIO_SIZE);
}
}