dm: core: Add a function to count the children of a device
authorLokesh Vutla <lokeshvutla@ti.com>
Wed, 4 Sep 2019 10:31:26 +0000 (16:01 +0530)
committerTom Rini <trini@konsulko.com>
Fri, 11 Oct 2019 14:07:33 +0000 (10:07 -0400)
Add a function to count the available children of a device.

Signed-off-by: Lokesh Vutla <lokeshvutla@ti.com>
drivers/core/device.c
include/dm/device.h
test/dm/bus.c

index 84f0f0fbf0e87b450f33752706577b51e92c05f7..ce66c72e5ec9c194320ec783e340b8c00ceb52ff 100644 (file)
@@ -568,6 +568,17 @@ int device_get_child(struct udevice *parent, int index, struct udevice **devp)
        return -ENODEV;
 }
 
+int device_get_child_count(struct udevice *parent)
+{
+       struct udevice *dev;
+       int count = 0;
+
+       list_for_each_entry(dev, &parent->child_head, sibling_node)
+               count++;
+
+       return count;
+}
+
 int device_find_child_by_seq(struct udevice *parent, int seq_or_req_seq,
                             bool find_req_seq, struct udevice **devp)
 {
index d1210429e9230788afe4c59af7d418b2f6d21352..defda0aebcb66102513f4cad3ba4313e239c9376 100644 (file)
@@ -404,6 +404,15 @@ const char *dev_get_uclass_name(const struct udevice *dev);
  */
 int device_get_child(struct udevice *parent, int index, struct udevice **devp);
 
+/**
+ * device_get_child_count() - Get the available child count of a device
+ *
+ * Returns the number of children to a device.
+ *
+ * @parent:    Parent device to check
+ */
+int device_get_child_count(struct udevice *parent);
+
 /**
  * device_find_child_by_seq() - Find a child device based on a sequence
  *
index 93f3acd4308e97691a45e1594db2c7d7ea43afb8..1ad45adb6059c7a574c2d5775f8b7b36e0ad3f7c 100644 (file)
@@ -8,6 +8,7 @@
 #include <os.h>
 #endif
 #include <dm.h>
+#include <dm/device.h>
 #include <dm/device-internal.h>
 #include <dm/test.h>
 #include <dm/uclass-internal.h>
@@ -371,7 +372,6 @@ static int test_bus_parent_platdata(struct unit_test_state *uts)
 {
        struct dm_test_parent_platdata *plat;
        struct udevice *bus, *dev;
-       int child_count;
 
        /* Check that the bus has no children */
        ut_assertok(uclass_find_device(UCLASS_TEST_BUS, 0, &bus));
@@ -380,7 +380,7 @@ static int test_bus_parent_platdata(struct unit_test_state *uts)
 
        ut_assertok(uclass_get_device(UCLASS_TEST_BUS, 0, &bus));
 
-       for (device_find_first_child(bus, &dev), child_count = 0;
+       for (device_find_first_child(bus, &dev);
             dev;
             device_find_next_child(&dev)) {
                /* Check that platform data is allocated */
@@ -399,22 +399,20 @@ static int test_bus_parent_platdata(struct unit_test_state *uts)
                ut_asserteq_ptr(plat, dev_get_parent_platdata(dev));
                ut_asserteq(1, plat->count);
                ut_assertok(device_probe(dev));
-               child_count++;
        }
-       ut_asserteq(3, child_count);
+       ut_asserteq(3, device_get_child_count(bus));
 
        /* Removing the bus should also have no effect (it is still bound) */
        device_remove(bus, DM_REMOVE_NORMAL);
-       for (device_find_first_child(bus, &dev), child_count = 0;
+       for (device_find_first_child(bus, &dev);
             dev;
             device_find_next_child(&dev)) {
                /* Check that platform data is allocated */
                plat = dev_get_parent_platdata(dev);
                ut_assert(plat != NULL);
                ut_asserteq(1, plat->count);
-               child_count++;
        }
-       ut_asserteq(3, child_count);
+       ut_asserteq(3, device_get_child_count(bus));
 
        /* Unbind all the children */
        do {
@@ -425,16 +423,15 @@ static int test_bus_parent_platdata(struct unit_test_state *uts)
 
        /* Now the child platdata should be removed and re-added */
        device_probe(bus);
-       for (device_find_first_child(bus, &dev), child_count = 0;
+       for (device_find_first_child(bus, &dev);
             dev;
             device_find_next_child(&dev)) {
                /* Check that platform data is allocated */
                plat = dev_get_parent_platdata(dev);
                ut_assert(plat != NULL);
                ut_asserteq(0, plat->count);
-               child_count++;
        }
-       ut_asserteq(3, child_count);
+       ut_asserteq(3, device_get_child_count(bus));
 
        return 0;
 }
@@ -480,19 +477,17 @@ static int dm_test_bus_child_post_bind(struct unit_test_state *uts)
 {
        struct dm_test_parent_platdata *plat;
        struct udevice *bus, *dev;
-       int child_count;
 
        ut_assertok(uclass_get_device(UCLASS_TEST_BUS, 0, &bus));
-       for (device_find_first_child(bus, &dev), child_count = 0;
+       for (device_find_first_child(bus, &dev);
             dev;
             device_find_next_child(&dev)) {
                /* Check that platform data is allocated */
                plat = dev_get_parent_platdata(dev);
                ut_assert(plat != NULL);
                ut_asserteq(1, plat->bind_flag);
-               child_count++;
        }
-       ut_asserteq(3, child_count);
+       ut_asserteq(3, device_get_child_count(bus));
 
        return 0;
 }
@@ -503,19 +498,17 @@ static int dm_test_bus_child_post_bind_uclass(struct unit_test_state *uts)
 {
        struct dm_test_parent_platdata *plat;
        struct udevice *bus, *dev;
-       int child_count;
 
        ut_assertok(uclass_get_device(UCLASS_TEST_BUS, 0, &bus));
-       for (device_find_first_child(bus, &dev), child_count = 0;
+       for (device_find_first_child(bus, &dev);
             dev;
             device_find_next_child(&dev)) {
                /* Check that platform data is allocated */
                plat = dev_get_parent_platdata(dev);
                ut_assert(plat != NULL);
                ut_asserteq(2, plat->uclass_bind_flag);
-               child_count++;
        }
-       ut_asserteq(3, child_count);
+       ut_asserteq(3, device_get_child_count(bus));
 
        return 0;
 }
@@ -529,14 +522,13 @@ DM_TEST(dm_test_bus_child_post_bind_uclass,
 static int dm_test_bus_child_pre_probe_uclass(struct unit_test_state *uts)
 {
        struct udevice *bus, *dev;
-       int child_count;
 
        /*
         * See testfdt_drv_probe() which effectively checks that the uclass
         * flag is set before that method is called
         */
        ut_assertok(uclass_get_device(UCLASS_TEST_BUS, 0, &bus));
-       for (device_find_first_child(bus, &dev), child_count = 0;
+       for (device_find_first_child(bus, &dev);
             dev;
             device_find_next_child(&dev)) {
                struct dm_test_priv *priv = dev_get_priv(dev);
@@ -549,9 +541,8 @@ static int dm_test_bus_child_pre_probe_uclass(struct unit_test_state *uts)
                ut_assert(priv != NULL);
                ut_asserteq(1, priv->uclass_flag);
                ut_asserteq(1, priv->uclass_total);
-               child_count++;
        }
-       ut_asserteq(3, child_count);
+       ut_asserteq(3, device_get_child_count(bus));
 
        return 0;
 }
@@ -565,14 +556,13 @@ DM_TEST(dm_test_bus_child_pre_probe_uclass,
 static int dm_test_bus_child_post_probe_uclass(struct unit_test_state *uts)
 {
        struct udevice *bus, *dev;
-       int child_count;
 
        /*
         * See testfdt_drv_probe() which effectively initializes that
         * the uclass postp flag is set to a value
         */
        ut_assertok(uclass_get_device(UCLASS_TEST_BUS, 0, &bus));
-       for (device_find_first_child(bus, &dev), child_count = 0;
+       for (device_find_first_child(bus, &dev);
             dev;
             device_find_next_child(&dev)) {
                struct dm_test_priv *priv = dev_get_priv(dev);
@@ -584,9 +574,8 @@ static int dm_test_bus_child_post_probe_uclass(struct unit_test_state *uts)
                priv = dev_get_priv(dev);
                ut_assert(priv != NULL);
                ut_asserteq(0, priv->uclass_postp);
-               child_count++;
        }
-       ut_asserteq(3, child_count);
+       ut_asserteq(3, device_get_child_count(bus));
 
        return 0;
 }