]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
cmd: improve coninfo output formatting
authorHeinrich Schuchardt <heinrich.schuchardt@canonical.com>
Sat, 28 Jan 2023 00:11:56 +0000 (01:11 +0100)
committerHeinrich Schuchardt <heinrich.schuchardt@canonical.com>
Fri, 10 Feb 2023 12:05:39 +0000 (13:05 +0100)
Device name are typically longer than 8 characters. This leads to ragged
output.
Only the I and O bit of the device flags are of interest for the user.
Writing a hexadecimal number is just confusing.

Before the patch the output looked like this:

    => coninfo
    List of available devices:
    pl011@9000000 00000007 IO stdin stdout stderr
    serial   00000003 IO
    usbkbd   00000001 I.

With the patch the output looks like this:

    => coninfo
    List of available devices
    |-- pl011@9000000 (IO)
    |   |-- stdin
    |   |-- stdout
    |   |-- stderr
    |-- serial (IO)
    |-- usbkbd (I)

Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt@canonical.com>
Reviewed-by: Simon Glass <sjg@chromium.org>
cmd/console.c

index 9a1db83c7c3854a968988c0bf5f250689434b7e1..620a961cdefbaa3f188b9761c49b01ac0357b712 100644 (file)
@@ -22,23 +22,21 @@ static int do_coninfo(struct cmd_tbl *cmd, int flag, int argc,
 
        /* Scan for valid output and input devices */
 
-       puts ("List of available devices:\n");
+       puts("List of available devices\n");
 
        list_for_each(pos, list) {
                dev = list_entry(pos, struct stdio_dev, list);
 
-               printf ("%-8s %08x %c%c ",
-                       dev->name,
-                       dev->flags,
-                       (dev->flags & DEV_FLAGS_INPUT) ? 'I' : '.',
-                       (dev->flags & DEV_FLAGS_OUTPUT) ? 'O' : '.');
+               printf("|-- %s (%s%s)\n",
+                      dev->name,
+                      (dev->flags & DEV_FLAGS_INPUT) ? "I" : "",
+                      (dev->flags & DEV_FLAGS_OUTPUT) ? "O" : "");
 
                for (l = 0; l < MAX_FILES; l++) {
                        if (stdio_devices[l] == dev) {
-                               printf ("%s ", stdio_names[l]);
+                               printf("|   |-- %s\n", stdio_names[l]);
                        }
                }
-               putc ('\n');
        }
        return 0;
 }