mirror of
https://github.com/u-boot/u-boot.git
synced 2025-05-08 19:11:53 +00:00
cmd: dm: Fixed/Added DM driver listing subcommands
Renamed dm "drivers" subcommand to "compat" (as it listed compatibility strings) and prevent it from segfaulting when drivers have no of_match populated. Added a new "drivers" subcommand to dump a list of all known DM drivers and for each, their uclass id, uclass driver and names of attached devices. Added a new "static" subcommand to dump a list of DM drivers with statically defined platform data. Signed-off-by: Niel Fourie <lusus@denx.de> Cc: Simon Glass <sjg@chromium.org> Cc: Sean Anderson <seanga2@gmail.com> Reviewed-by: Simon Glass <sjg@chromium.org>
This commit is contained in:
parent
2280fa56a0
commit
2e48836895
4 changed files with 101 additions and 4 deletions
|
@ -97,7 +97,7 @@ void dm_dump_uclass(void)
|
|||
}
|
||||
}
|
||||
|
||||
void dm_dump_drivers(void)
|
||||
void dm_dump_driver_compat(void)
|
||||
{
|
||||
struct driver *d = ll_entry_start(struct driver, driver);
|
||||
const int n_ents = ll_entry_count(struct driver, driver);
|
||||
|
@ -120,3 +120,56 @@ void dm_dump_drivers(void)
|
|||
printf("%-20.20s %s\n", "", match->compatible);
|
||||
}
|
||||
}
|
||||
|
||||
void dm_dump_drivers(void)
|
||||
{
|
||||
struct driver *d = ll_entry_start(struct driver, driver);
|
||||
const int n_ents = ll_entry_count(struct driver, driver);
|
||||
struct driver *entry;
|
||||
struct udevice *udev;
|
||||
struct uclass *uc;
|
||||
int i;
|
||||
|
||||
puts("Driver uid uclass Devices\n");
|
||||
puts("----------------------------------------------------------\n");
|
||||
|
||||
for (entry = d; entry < d + n_ents; entry++) {
|
||||
uclass_get(entry->id, &uc);
|
||||
|
||||
printf("%-25.25s %-3.3d %-20.20s ", entry->name, entry->id,
|
||||
uc ? uc->uc_drv->name : "<no uclass>");
|
||||
|
||||
if (!uc) {
|
||||
puts("\n");
|
||||
continue;
|
||||
}
|
||||
|
||||
i = 0;
|
||||
uclass_foreach_dev(udev, uc) {
|
||||
if (udev->driver != entry)
|
||||
continue;
|
||||
if (i)
|
||||
printf("%-51.51s", "");
|
||||
|
||||
printf("%-25.25s\n", udev->name);
|
||||
i++;
|
||||
}
|
||||
if (!i)
|
||||
puts("<none>\n");
|
||||
}
|
||||
}
|
||||
|
||||
void dm_dump_static_driver_info(void)
|
||||
{
|
||||
struct driver_info *drv = ll_entry_start(struct driver_info,
|
||||
driver_info);
|
||||
const int n_ents = ll_entry_count(struct driver_info, driver_info);
|
||||
struct driver_info *entry;
|
||||
|
||||
puts("Driver Address\n");
|
||||
puts("---------------------------------\n");
|
||||
for (entry = drv; entry != drv + n_ents; entry++) {
|
||||
printf("%-25.25s @%08lx\n", entry->name,
|
||||
(ulong)map_to_sysmem(entry->platdata));
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue