gpiolib: fix sysfs when cdev is not selected
In gpiochip_setup_dev() the call to gpiolib_cdev_register() indirectly
calls device_add().  This is still required for the sysfs even when
CONFIG_GPIO_CDEV is not selected in the build.
Replace the stubbed functions in gpiolib-cdev.h with macros in gpiolib.c
that perform the required device_add() and device_del() when
CONFIG_GPIO_CDEV is not selected.
Fixes: d143493c01 (gpiolib: make cdev a build option)
Reported-by: Nicolas Schichan <nschichan@freebox.fr>
Signed-off-by: Kent Gibson <warthog618@gmail.com>
Tested-by: Nicolas Schichan <nschichan@freebox.fr>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
			
			
This commit is contained in:
		
							parent
							
								
									560b6ac37a
								
							
						
					
					
						commit
						1f5eb8b17f
					
				| @ -7,22 +7,7 @@ | ||||
| 
 | ||||
| struct gpio_device; | ||||
| 
 | ||||
| #ifdef CONFIG_GPIO_CDEV | ||||
| 
 | ||||
| int gpiolib_cdev_register(struct gpio_device *gdev, dev_t devt); | ||||
| void gpiolib_cdev_unregister(struct gpio_device *gdev); | ||||
| 
 | ||||
| #else | ||||
| 
 | ||||
| static inline int gpiolib_cdev_register(struct gpio_device *gdev, dev_t devt) | ||||
| { | ||||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| static inline void gpiolib_cdev_unregister(struct gpio_device *gdev) | ||||
| { | ||||
| } | ||||
| 
 | ||||
| #endif /* CONFIG_GPIO_CDEV */ | ||||
| 
 | ||||
| #endif /* GPIOLIB_CDEV_H */ | ||||
|  | ||||
| @ -480,11 +480,23 @@ static void gpiodevice_release(struct device *dev) | ||||
| 	kfree(gdev); | ||||
| } | ||||
| 
 | ||||
| #ifdef CONFIG_GPIO_CDEV | ||||
| #define gcdev_register(gdev, devt)	gpiolib_cdev_register((gdev), (devt)) | ||||
| #define gcdev_unregister(gdev)		gpiolib_cdev_unregister((gdev)) | ||||
| #else | ||||
| /*
 | ||||
|  * gpiolib_cdev_register() indirectly calls device_add(), which is still | ||||
|  * required even when cdev is not selected. | ||||
|  */ | ||||
| #define gcdev_register(gdev, devt)	device_add(&(gdev)->dev) | ||||
| #define gcdev_unregister(gdev)		device_del(&(gdev)->dev) | ||||
| #endif | ||||
| 
 | ||||
| static int gpiochip_setup_dev(struct gpio_device *gdev) | ||||
| { | ||||
| 	int ret; | ||||
| 
 | ||||
| 	ret = gpiolib_cdev_register(gdev, gpio_devt); | ||||
| 	ret = gcdev_register(gdev, gpio_devt); | ||||
| 	if (ret) | ||||
| 		return ret; | ||||
| 
 | ||||
| @ -500,7 +512,7 @@ static int gpiochip_setup_dev(struct gpio_device *gdev) | ||||
| 	return 0; | ||||
| 
 | ||||
| err_remove_device: | ||||
| 	gpiolib_cdev_unregister(gdev); | ||||
| 	gcdev_unregister(gdev); | ||||
| 	return ret; | ||||
| } | ||||
| 
 | ||||
| @ -825,7 +837,7 @@ void gpiochip_remove(struct gpio_chip *gc) | ||||
| 	 * be removed, else it will be dangling until the last user is | ||||
| 	 * gone. | ||||
| 	 */ | ||||
| 	gpiolib_cdev_unregister(gdev); | ||||
| 	gcdev_unregister(gdev); | ||||
| 	put_device(&gdev->dev); | ||||
| } | ||||
| EXPORT_SYMBOL_GPL(gpiochip_remove); | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user