diff options
author | Simon Glass <sjg@chromium.org> | 2015-11-08 23:47:52 -0700 |
---|---|---|
committer | Simon Glass <sjg@chromium.org> | 2015-11-19 20:27:51 -0700 |
commit | 7aeac5bc8c5903b8d27188a21b39f0b2c4bd13c1 (patch) | |
tree | d2bc124ba0ef8028c5e183e8112b317b30621f43 | |
parent | 45bfa47e123cdb0df8e273e3f0c84907c7394f6a (diff) | |
download | talos-obmc-uboot-7aeac5bc8c5903b8d27188a21b39f0b2c4bd13c1.tar.gz talos-obmc-uboot-7aeac5bc8c5903b8d27188a21b39f0b2c4bd13c1.zip |
dm: core: Add safe device iteration macros
Add iteration macros which support unbinding a device within the loop.
Signed-off-by: Simon Glass <sjg@chromium.org>
-rw-r--r-- | include/dm/device.h | 12 | ||||
-rw-r--r-- | include/dm/uclass.h | 15 |
2 files changed, 27 insertions, 0 deletions
diff --git a/include/dm/device.h b/include/dm/device.h index 28ba4ca404..7fb99356be 100644 --- a/include/dm/device.h +++ b/include/dm/device.h @@ -509,6 +509,18 @@ static inline bool device_is_on_pci_bus(struct udevice *dev) return device_get_uclass_id(dev->parent) == UCLASS_PCI; } +/** + * device_foreach_child_safe() - iterate through child devices safely + * + * This allows the @pos child to be removed in the loop if required. + * + * @pos: struct udevice * for the current device + * @next: struct udevice * for the next device + * @parent: parent device to scan + */ +#define device_foreach_child_safe(pos, next, parent) \ + list_for_each_entry_safe(pos, next, &parent->child_head, sibling_node) + /* device resource management */ typedef void (*dr_release_t)(struct udevice *dev, void *res); typedef int (*dr_match_t)(struct udevice *dev, void *res, void *match_data); diff --git a/include/dm/uclass.h b/include/dm/uclass.h index d214b88734..bfbd27afd6 100644 --- a/include/dm/uclass.h +++ b/include/dm/uclass.h @@ -243,4 +243,19 @@ int uclass_resolve_seq(struct udevice *dev); #define uclass_foreach_dev(pos, uc) \ list_for_each_entry(pos, &uc->dev_head, uclass_node) +/** + * uclass_foreach_dev_safe() - Helper function to safely iteration through devs + * + * This creates a for() loop which works through the available devices in + * a uclass in order from start to end. Inside the loop, it is safe to remove + * @pos if required. + * + * @pos: struct udevice * to hold the current device. Set to NULL when there + * are no more devices. + * @next: struct udevice * to hold the next next + * @uc: uclass to scan + */ +#define uclass_foreach_dev_safe(pos, next, uc) \ + list_for_each_entry_safe(pos, next, &uc->dev_head, uclass_node) + #endif |