From: Simon Glass Date: Sun, 23 Jun 2024 20:30:21 +0000 (-0600) Subject: dm: core: Enhance comments on bind_drivers_pass() X-Git-Tag: v2025.01-rc5-pxa1908~431^2~10 X-Git-Url: http://git.dujemihanovic.xyz/posts?a=commitdiff_plain;h=cb44201c7182f9367e7e0dd1b009a85e26fc1a83;p=u-boot.git dm: core: Enhance comments on bind_drivers_pass() This part of driver model is a little subtle, so add some more comments to promote better understanding. Signed-off-by: Simon Glass --- diff --git a/drivers/core/lists.c b/drivers/core/lists.c index bd0ab4f16c..c7be504b6f 100644 --- a/drivers/core/lists.c +++ b/drivers/core/lists.c @@ -8,6 +8,7 @@ #define LOG_CATEGORY LOGC_DM +#include #include #include #include @@ -50,6 +51,21 @@ struct uclass_driver *lists_uclass_lookup(enum uclass_id id) return NULL; } +/** + * bind_drivers_pass() - Perform a pass of driver binding + * + * Work through the driver_info records binding a driver for each one. If the + * binding fails, continue binding others, but return the error. + * + * For OF_PLATDATA we must bind parent devices before their children. So only + * children of bound parents are bound on each call to this function. When a + * child is left unbound, -EAGAIN is returned, indicating that this function + * should be called again + * + * @parent: Parent device to use when binding each child device + * Return: 0 if OK, -EAGAIN if unbound children exist, -ENOENT if there is no + * driver for one of the devices, other -ve on other error + */ static int bind_drivers_pass(struct udevice *parent, bool pre_reloc_only) { struct driver_info *info =