summaryrefslogtreecommitdiffstats
path: root/drivers/core
diff options
context:
space:
mode:
authorMasahiro Yamada <yamada.masahiro@socionext.com>2015-07-25 21:52:34 +0900
committerSimon Glass <sjg@chromium.org>2015-08-06 07:44:29 -0600
commitaed1a4dd88e94001b811b297c1ff734c3f8d22d9 (patch)
treede57a73634e7d1b673be8379d6893eaf62d03ee6 /drivers/core
parentf33017716e5c430d84366ecc4476ba2b655f3fef (diff)
downloadtalos-obmc-uboot-aed1a4dd88e94001b811b297c1ff734c3f8d22d9.tar.gz
talos-obmc-uboot-aed1a4dd88e94001b811b297c1ff734c3f8d22d9.zip
dm: add DM_FLAG_BOUND flag
Currently, we only have DM_FLAG_ACTIVATED to indicate the device status, but we still cannot know in which stage is in progress, binding or probing. This commit introduces a new flag, DM_FLAG_BOUND, which is set when the device is really bound, and cleared when it is unbound. Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com> Acked-by: Simon Glass <sjg@chromium.org>
Diffstat (limited to 'drivers/core')
-rw-r--r--drivers/core/device-remove.c3
-rw-r--r--drivers/core/device.c2
2 files changed, 5 insertions, 0 deletions
diff --git a/drivers/core/device-remove.c b/drivers/core/device-remove.c
index 6b87f865e4..45d6543067 100644
--- a/drivers/core/device-remove.c
+++ b/drivers/core/device-remove.c
@@ -61,6 +61,9 @@ int device_unbind(struct udevice *dev)
if (dev->flags & DM_FLAG_ACTIVATED)
return -EINVAL;
+ if (!(dev->flags & DM_FLAG_BOUND))
+ return -EINVAL;
+
drv = dev->driver;
assert(drv);
diff --git a/drivers/core/device.c b/drivers/core/device.c
index d65717ddc7..bf6f2716da 100644
--- a/drivers/core/device.c
+++ b/drivers/core/device.c
@@ -132,6 +132,8 @@ int device_bind(struct udevice *parent, const struct driver *drv,
dm_dbg("Bound device %s to %s\n", dev->name, parent->name);
*devp = dev;
+ dev->flags |= DM_FLAG_BOUND;
+
return 0;
fail_child_post_bind:
OpenPOWER on IntegriCloud