mirror of
				https://xff.cz/git/u-boot/
				synced 2025-10-31 18:35:42 +01:00 
			
		
		
		
	dm: core: Switch uclass_*_device_err to use uclass_*_device_check
The _err variant iterators use the simple iterators without suffix as basis. However, there is no user that uclass_next_device_err for iteration, many users of uclass_first_device_err use it to get the first and (assumed) only device of an uclass, and a couple that use uclass_next_device_err to get the device following a known device in the uclass list. While there are some truly singleton device classes in which more than one device cannot exist these are quite rare, and most classes can have multiple devices even if it is not the case on the SoC's EVB. In a later patch the simple iterators will be updated to not stop on error and return next device instead. With this in many cases the code that expects the first device or an error if it fails to probe may get the next device instead. Use the _check iterators as the basis of _err iterators to preserve the old behavior. Signed-off-by: Michal Suchanek <msuchanek@suse.de> Reviewed-by: Simon Glass <sjg@chromium.org>
This commit is contained in:
		
				
					committed by
					
						 Simon Glass
						Simon Glass
					
				
			
			
				
	
			
			
			
						parent
						
							801f71194c
						
					
				
				
					commit
					e44d7e73fe
				
			| @@ -586,19 +586,6 @@ int uclass_first_device(enum uclass_id id, struct udevice **devp) | ||||
| 	return uclass_get_device_tail(dev, ret, devp); | ||||
| } | ||||
|  | ||||
| int uclass_first_device_err(enum uclass_id id, struct udevice **devp) | ||||
| { | ||||
| 	int ret; | ||||
|  | ||||
| 	ret = uclass_first_device(id, devp); | ||||
| 	if (ret) | ||||
| 		return ret; | ||||
| 	else if (!*devp) | ||||
| 		return -ENODEV; | ||||
|  | ||||
| 	return 0; | ||||
| } | ||||
|  | ||||
| int uclass_next_device(struct udevice **devp) | ||||
| { | ||||
| 	struct udevice *dev = *devp; | ||||
| @@ -611,11 +598,24 @@ int uclass_next_device(struct udevice **devp) | ||||
| 	return uclass_get_device_tail(dev, ret, devp); | ||||
| } | ||||
|  | ||||
| int uclass_first_device_err(enum uclass_id id, struct udevice **devp) | ||||
| { | ||||
| 	int ret; | ||||
|  | ||||
| 	ret = uclass_first_device_check(id, devp); | ||||
| 	if (ret) | ||||
| 		return ret; | ||||
| 	else if (!*devp) | ||||
| 		return -ENODEV; | ||||
|  | ||||
| 	return 0; | ||||
| } | ||||
|  | ||||
| int uclass_next_device_err(struct udevice **devp) | ||||
| { | ||||
| 	int ret; | ||||
|  | ||||
| 	ret = uclass_next_device(devp); | ||||
| 	ret = uclass_next_device_check(devp); | ||||
| 	if (ret) | ||||
| 		return ret; | ||||
| 	else if (!*devp) | ||||
|   | ||||
| @@ -332,17 +332,6 @@ int uclass_get_device_by_driver(enum uclass_id id, const struct driver *drv, | ||||
|  */ | ||||
| int uclass_first_device(enum uclass_id id, struct udevice **devp); | ||||
|  | ||||
| /** | ||||
|  * uclass_first_device_err() - Get the first device in a uclass | ||||
|  * | ||||
|  * The device returned is probed if necessary, and ready for use | ||||
|  * | ||||
|  * @id: Uclass ID to look up | ||||
|  * @devp: Returns pointer to the first device in that uclass, or NULL if none | ||||
|  * Return: 0 if found, -ENODEV if not found, other -ve on error | ||||
|  */ | ||||
| int uclass_first_device_err(enum uclass_id id, struct udevice **devp); | ||||
|  | ||||
| /** | ||||
|  * uclass_next_device() - Get the next device in a uclass | ||||
|  * | ||||
| @@ -358,6 +347,17 @@ int uclass_first_device_err(enum uclass_id id, struct udevice **devp); | ||||
|  */ | ||||
| int uclass_next_device(struct udevice **devp); | ||||
|  | ||||
| /** | ||||
|  * uclass_first_device_err() - Get the first device in a uclass | ||||
|  * | ||||
|  * The device returned is probed if necessary, and ready for use | ||||
|  * | ||||
|  * @id: Uclass ID to look up | ||||
|  * @devp: Returns pointer to the first device in that uclass, or NULL if none | ||||
|  * Return: 0 if found, -ENODEV if not found, other -ve on error | ||||
|  */ | ||||
| int uclass_first_device_err(enum uclass_id id, struct udevice **devp); | ||||
|  | ||||
| /** | ||||
|  * uclass_next_device_err() - Get the next device in a uclass | ||||
|  * | ||||
|   | ||||
		Reference in New Issue
	
	Block a user