aboutsummaryrefslogtreecommitdiff
path: root/util/cbfstool/cbfstool.c
diff options
context:
space:
mode:
authorStefan Reinauer <reinauer@chromium.org>2013-02-04 15:39:13 -0800
committerStefan Reinauer <stefan.reinauer@coreboot.org>2013-02-05 22:43:23 +0100
commit543a6824580331373a2d77694c23905dc7ca48a7 (patch)
tree5c66c2db8f91aef83e5ee9174ab19afe0dc81ed8 /util/cbfstool/cbfstool.c
parentc13e4bf3e16080993fb42399327501201c4f9f13 (diff)
cbfstool: support parsing UEFI firmware volumes
This removes the hack implemented in http://review.coreboot.org/#/c/2280 (and should make using 64bit Tiano easier, but that's not yet supported) Change-Id: Ie30129c4102dfbd41584177f39057b31f5a937fd Signed-off-by: Stefan Reinauer <reinauer@google.com> Reviewed-on: http://review.coreboot.org/2281 Tested-by: build bot (Jenkins) Reviewed-by: Patrick Georgi <patrick@georgi-clan.de> Reviewed-by: Stefan Reinauer <stefan.reinauer@coreboot.org>
Diffstat (limited to 'util/cbfstool/cbfstool.c')
-rw-r--r--util/cbfstool/cbfstool.c14
1 files changed, 13 insertions, 1 deletions
diff --git a/util/cbfstool/cbfstool.c b/util/cbfstool/cbfstool.c
index 3881628e26..97fd88d316 100644
--- a/util/cbfstool/cbfstool.c
+++ b/util/cbfstool/cbfstool.c
@@ -138,8 +138,20 @@ static int cbfstool_convert_mkstage(struct buffer *buffer, uint32_t *offset) {
static int cbfstool_convert_mkpayload(struct buffer *buffer, uint32_t *offset) {
struct buffer output;
- if (parse_elf_to_payload(buffer, &output, param.algo) != 0)
+ int ret;
+ /* per default, try and see if payload is an ELF binary */
+ ret = parse_elf_to_payload(buffer, &output, param.algo);
+
+ /* If it's not an ELF, see if it's a UEFI FV */
+ if (ret != 0)
+ ret = parse_fv_to_payload(buffer, &output, param.algo);
+
+ /* Not a supported payload type */
+ if (ret != 0) {
+ ERROR("Not a supported payload type (ELF / FV).\n");
return -1;
+ }
+
buffer_delete(buffer);
// direct assign, no dupe.
memcpy(buffer, &output, sizeof(*buffer));