mirror of
https://github.com/smaeul/u-boot.git
synced 2025-10-24 09:38:18 +01:00
These two are not worth having separate inline functions as they are really simple, so drop them. Also changed 'type' parameter of fsp_get_next_hob() from u16 to uint. Suggested-by: Simon Glass <sjg@chromium.org> Signed-off-by: Bin Meng <bmeng.cn@gmail.com> Acked-by: Simon Glass <sjg@chromium.org>
66 lines
1.3 KiB
C
66 lines
1.3 KiB
C
/*
|
|
* Copyright (C) 2014, Bin Meng <bmeng.cn@gmail.com>
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0+
|
|
*/
|
|
|
|
#include <common.h>
|
|
#include <command.h>
|
|
#include <linux/compiler.h>
|
|
#include <asm/arch/fsp/fsp_support.h>
|
|
|
|
DECLARE_GLOBAL_DATA_PTR;
|
|
|
|
static char *hob_type[] = {
|
|
"reserved",
|
|
"Hand-off",
|
|
"Memory Allocation",
|
|
"Resource Descriptor",
|
|
"GUID Extension",
|
|
"Firmware Volume",
|
|
"CPU",
|
|
"Memory Pool",
|
|
"reserved",
|
|
"Firmware Volume 2",
|
|
"Load PEIM Unused",
|
|
"UEFI Capsule",
|
|
};
|
|
|
|
int do_hob(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
|
|
{
|
|
const struct hob_header *hdr;
|
|
uint type;
|
|
char *desc;
|
|
int i = 0;
|
|
|
|
hdr = gd->arch.hob_list;
|
|
|
|
printf("HOB list address: 0x%08x\n\n", (unsigned int)hdr);
|
|
|
|
printf("No. | Address | Type | Length in Bytes\n");
|
|
printf("----|----------|---------------------|----------------\n");
|
|
while (!end_of_hob(hdr)) {
|
|
printf("%-3d | %08x | ", i, (unsigned int)hdr);
|
|
type = hdr->type;
|
|
if (type == HOB_TYPE_UNUSED)
|
|
desc = "*Unused*";
|
|
else if (type == HOB_TYPE_EOH)
|
|
desc = "*END OF HOB*";
|
|
else if (type >= 0 && type <= ARRAY_SIZE(hob_type))
|
|
desc = hob_type[type];
|
|
else
|
|
desc = "*Invalid Type*";
|
|
printf("%-19s | %-15d\n", desc, hdr->len);
|
|
hdr = get_next_hob(hdr);
|
|
i++;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
U_BOOT_CMD(
|
|
hob, 1, 1, do_hob,
|
|
"print Firmware Support Package (FSP) Hand-Off Block information",
|
|
""
|
|
);
|