cmd: improve coninfo output formatting
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>
This commit is contained in:
@@ -22,23 +22,21 @@ static int do_coninfo(struct cmd_tbl *cmd, int flag, int argc,
|
|||||||
|
|
||||||
/* Scan for valid output and input devices */
|
/* Scan for valid output and input devices */
|
||||||
|
|
||||||
puts ("List of available devices:\n");
|
puts("List of available devices\n");
|
||||||
|
|
||||||
list_for_each(pos, list) {
|
list_for_each(pos, list) {
|
||||||
dev = list_entry(pos, struct stdio_dev, list);
|
dev = list_entry(pos, struct stdio_dev, list);
|
||||||
|
|
||||||
printf ("%-8s %08x %c%c ",
|
printf("|-- %s (%s%s)\n",
|
||||||
dev->name,
|
dev->name,
|
||||||
dev->flags,
|
(dev->flags & DEV_FLAGS_INPUT) ? "I" : "",
|
||||||
(dev->flags & DEV_FLAGS_INPUT) ? 'I' : '.',
|
(dev->flags & DEV_FLAGS_OUTPUT) ? "O" : "");
|
||||||
(dev->flags & DEV_FLAGS_OUTPUT) ? 'O' : '.');
|
|
||||||
|
|
||||||
for (l = 0; l < MAX_FILES; l++) {
|
for (l = 0; l < MAX_FILES; l++) {
|
||||||
if (stdio_devices[l] == dev) {
|
if (stdio_devices[l] == dev) {
|
||||||
printf ("%s ", stdio_names[l]);
|
printf("| |-- %s\n", stdio_names[l]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
putc ('\n');
|
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user