summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlexander Graf <agraf@suse.de>2016-08-19 01:23:30 +0200
committerAlexander Graf <agraf@suse.de>2016-10-19 09:01:52 +0200
commitaba5e9194b98988162e5bd026dbcb6627a53efe5 (patch)
treee3680dfb93276f1d5711e9cf4098f93a965ad943
parente663b350f1699312281ddd1439dda6b5fc86598d (diff)
downloadu-boot-aba5e9194b98988162e5bd026dbcb6627a53efe5.tar.gz
efi_loader: Fix efi_install_configuration_table
So far we were only installing the FDT table and didn't have space to store any other. Hence nobody realized that our efi table allocation was broken in that it didn't set the indicator for the number of tables plus one. This patch fixes it, allowing code to allocate new efi tables. Signed-off-by: Alexander Graf <agraf@suse.de> Reviewed-by: Simon Glass <sjg@chromium.org>
-rw-r--r--lib/efi_loader/efi_boottime.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/lib/efi_loader/efi_boottime.c b/lib/efi_loader/efi_boottime.c
index 51961d2060..17f1927465 100644
--- a/lib/efi_loader/efi_boottime.c
+++ b/lib/efi_loader/efi_boottime.c
@@ -395,7 +395,7 @@ efi_status_t efi_install_configuration_table(const efi_guid_t *guid, void *table
/* Add a new entry */
memcpy(&efi_conf_table[i].guid, guid, sizeof(*guid));
efi_conf_table[i].table = table;
- systab.nr_tables = i;
+ systab.nr_tables = i + 1;
return EFI_SUCCESS;
}