]> git.kernelconcepts.de Git - karo-tx-uboot.git/commitdiff
dm: reset: Allow reset_walk() to return
authorSimon Glass <sjg@chromium.org>
Mon, 6 Jul 2015 18:54:27 +0000 (12:54 -0600)
committerLothar Waßmann <LW@KARO-electronics.de>
Wed, 9 Sep 2015 11:48:55 +0000 (13:48 +0200)
Add a new reset_walk_halt() function to cause a reset and then halt on
failure. The reset_walk() function returns an error code.

This is needed for testing since otherwise U-Boot will halt in the middle
of a test.

Signed-off-by: Simon Glass <sjg@chromium.org>
drivers/misc/reset-uclass.c
include/reset.h

index ba277570c56731f001e2576a314e725e1c0e636c..fdb5c6fcff34fd7aa46d25f7feadd220addacf15 100644 (file)
@@ -25,23 +25,34 @@ int reset_request(struct udevice *dev, enum reset_t type)
        return ops->request(dev, type);
 }
 
-void reset_walk(enum reset_t type)
+int reset_walk(enum reset_t type)
 {
        struct udevice *dev;
-       int ret = 0;
+       int ret = -ENOSYS;
 
        while (ret != -EINPROGRESS && type < RESET_COUNT) {
                for (uclass_first_device(UCLASS_RESET, &dev);
-               dev;
-               uclass_next_device(&dev)) {
+                    dev;
+                    uclass_next_device(&dev)) {
                        ret = reset_request(dev, type);
                        if (ret == -EINPROGRESS)
                                break;
                }
+               type++;
        }
 
+       return ret;
+}
+
+void reset_walk_halt(enum reset_t type)
+{
+       int ret;
+
+       ret = reset_walk(type);
+
        /* Wait for the reset to take effect */
-       mdelay(100);
+       if (ret == -EINPROGRESS)
+               mdelay(100);
 
        /* Still no reset? Give up */
        printf("Reset not supported on this platform\n");
@@ -53,7 +64,15 @@ void reset_walk(enum reset_t type)
  */
 void reset_cpu(ulong addr)
 {
-       reset_walk(RESET_WARM);
+       reset_walk_halt(RESET_WARM);
+}
+
+
+int do_reset(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
+{
+       reset_walk_halt(RESET_WARM);
+
+       return 0;
 }
 
 UCLASS_DRIVER(reset) = {
index d29e108eecbbfd118278d01a51b68dd4eea608ad..383761eb1fb0d972108c9731f1176b8f88c533f7 100644 (file)
@@ -51,8 +51,17 @@ int reset_request(struct udevice *dev, enum reset_t type);
  * If this function fails to reset, it will display a message and halt
  *
  * @type:      Reset type to request
+ * @return -EINPROGRESS if a reset is in progress, -ENOSYS if not available
  */
-void reset_walk(enum reset_t type);
+int reset_walk(enum reset_t type);
+
+/**
+ * reset_walk_halt() - try to reset, otherwise halt
+ *
+ * This calls reset_walk(). If it returns, indicating that reset is not
+ * supported, it prints a message and halts.
+ */
+void reset_walk_halt(enum reset_t type);
 
 /**
  * reset_cpu() - calls reset_walk(RESET_WARM)