diff options
| author | Jan Beulich <JBeulich@suse.com> | 2012-11-07 11:46:08 -0500 |
|---|---|---|
| committer | H. Peter Anvin <hpa@linux.intel.com> | 2012-11-14 11:49:34 -0500 |
| commit | 5d6d578c170bb280db5d4779f666e456f4f82ec5 (patch) | |
| tree | 188f5a32ff431bbc72a3d3466fa82f562f6f110a | |
| parent | 89d16665d388837b30972081d97b814be26d68a2 (diff) | |
x86, efi: Check table header length in efi_bgrt_init()
Header length should be validated for all ACPI tables before accessing
any non-header field.
Signed-off-by: Jan Beulich <jbeulich@suse.com>
Link: http://lkml.kernel.org/r/509A9E6002000078000A7079@nat28.tlf.novell.com
Acked-by: Matt Fleming <matt.fleming@intel.com>
Signed-off-by: H. Peter Anvin <hpa@linux.intel.com>
| -rw-r--r-- | arch/x86/platform/efi/efi-bgrt.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/arch/x86/platform/efi/efi-bgrt.c b/arch/x86/platform/efi/efi-bgrt.c index f6a0c1b8e518..d9c1b95af17c 100644 --- a/arch/x86/platform/efi/efi-bgrt.c +++ b/arch/x86/platform/efi/efi-bgrt.c | |||
| @@ -39,6 +39,8 @@ void efi_bgrt_init(void) | |||
| 39 | if (ACPI_FAILURE(status)) | 39 | if (ACPI_FAILURE(status)) |
| 40 | return; | 40 | return; |
| 41 | 41 | ||
| 42 | if (bgrt_tab->header.length < sizeof(*bgrt_tab)) | ||
| 43 | return; | ||
| 42 | if (bgrt_tab->version != 1) | 44 | if (bgrt_tab->version != 1) |
| 43 | return; | 45 | return; |
| 44 | if (bgrt_tab->image_type != 0 || !bgrt_tab->image_address) | 46 | if (bgrt_tab->image_type != 0 || !bgrt_tab->image_address) |
