regulator: core: remove sysfs entry properly in regulator_put
With changes introduced by commit 222cc7b (regulator: core: Allow
multiple requests of a single supply mapping) on create_regulator,
regulator_put needs a corresponding update on sysfs entry removing.
Also regulator->dev still needs to get assigned in create_regulator,
otherwise, sysfs_remove_link call in regulator_put will get bypassed.
Reported-by: Fabio Estevam <festevam@gmail.com>
Tested-by: Dong Aisheng <dong.aisheng@linaro.org>
Signed-off-by: Shawn Guo <shawn.guo@linaro.org>
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
	
	
This commit is contained in:
		
					parent
					
						
							
								e113d792d5
							
						
					
				
			
			
				commit
				
					
						e2c98eaf92
					
				
			
		
					 1 changed files with 3 additions and 4 deletions
				
			
		|  | @ -1063,6 +1063,8 @@ static struct regulator *create_regulator(struct regulator_dev *rdev, | |||
| 	list_add(®ulator->list, &rdev->consumer_list); | ||||
| 
 | ||||
| 	if (dev) { | ||||
| 		regulator->dev = dev; | ||||
| 
 | ||||
| 		/* Add a link to the device sysfs entry */ | ||||
| 		size = scnprintf(buf, REG_STR_SIZE, "%s-%s", | ||||
| 				 dev->kobj.name, supply_name); | ||||
|  | @ -1359,11 +1361,8 @@ void regulator_put(struct regulator *regulator) | |||
| 	debugfs_remove_recursive(regulator->debugfs); | ||||
| 
 | ||||
| 	/* remove any sysfs entries */ | ||||
| 	if (regulator->dev) { | ||||
| 	if (regulator->dev) | ||||
| 		sysfs_remove_link(&rdev->dev.kobj, regulator->supply_name); | ||||
| 		device_remove_file(regulator->dev, ®ulator->dev_attr); | ||||
| 		kfree(regulator->dev_attr.attr.name); | ||||
| 	} | ||||
| 	kfree(regulator->supply_name); | ||||
| 	list_del(®ulator->list); | ||||
| 	kfree(regulator); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Shawn Guo
				Shawn Guo