On 12/18/18 6:05 AM, AKASHI Takahiro wrote: > "dh" command prints all the uefi handles used in the system. > => efishell dh > (T.B.D.) > 0: (protocol info not available) > 1: (protocol info not available) > 2: (protocol info not available) > 3: (protocol info not available) > 4: (protocol info not available) > 5: (protocol info not available) > 6: (protocol info not available) > 7: (protocol info not available) > 8: (protocol info not available) > 9: (protocol info not available) > 10: (protocol info not available) > 11: (protocol info not available) > 12: (protocol info not available) > 13: (protocol info not available) > 14: (protocol info not available) > 15: (protocol info not available) > > Signed-off-by: AKASHI Takahiro <takahiro.aka...@linaro.org> > --- > cmd/efishell.c | 33 ++++++++++++++++++++++++++++++++- > 1 file changed, 32 insertions(+), 1 deletion(-) > > diff --git a/cmd/efishell.c b/cmd/efishell.c > index 5a81a627d616..47ad77606062 100644 > --- a/cmd/efishell.c > +++ b/cmd/efishell.c > @@ -511,6 +511,33 @@ static int do_efi_show_memmap(int argc, char * const > argv[]) > return CMD_RET_SUCCESS; > } > > +static char *efi_get_proto_info(efi_handle_t handle) > +{ > + return strdup("(protocol info not available)"); Shouldn't this enumerate all protocol GUIDs installed on the handles by calling ProtocolsPerHandle()?
Also instances of installed drivers identifiable by the driver binding protocol might be interesting. Best regards Heinrich > +} > + > +static int do_efi_show_handles(int argc, char * const argv[]) > +{ > + efi_handle_t *handles = NULL, *handle; > + char *info; > + int i; > + > + handles = efi_get_handles_by_proto(NULL); > + if (!handles) > + return CMD_RET_SUCCESS; > + > + for (handle = handles, i = 0; *handle; handle++, i++) { > + /* TODO: depends on protocols */ > + info = efi_get_proto_info(*handle); > + printf("%d: %s\n", i, info ?: ""); > + free(info); > + } > + > + free(handles); > + > + return CMD_RET_SUCCESS; > +} > + > static int do_efi_boot_add(int argc, char * const argv[]) > { > int id; > @@ -900,6 +927,8 @@ static int do_efishell(cmd_tbl_t *cmdtp, int flag, > return do_efi_show_images(argc, argv); > else if (!strcmp(command, "memmap")) > return do_efi_show_memmap(argc, argv); > + else if (!strcmp(command, "dh")) > + return do_efi_show_handles(argc, argv); > else > return CMD_RET_USAGE; > } > @@ -929,7 +958,9 @@ static char efishell_help_text[] = > "efishell images\n" > " - show loaded images\n" > "efishell memmap\n" > - " - show uefi memory map\n"; > + " - show uefi memory map\n" > + "efishell dh\n" > + " - show uefi handles\n"; > #endif > > U_BOOT_CMD( > _______________________________________________ U-Boot mailing list U-Boot@lists.denx.de https://lists.denx.de/listinfo/u-boot