From: Pavel Holica Date: Wed, 6 Nov 2013 22:24:16 +0000 (+0100) Subject: acpi-fpdt: break on zero or negative length read X-Git-Tag: v209~1576 X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=f576cd2092bc40f9998415cdc3caf10035d4743a acpi-fpdt: break on zero or negative length read https://bugzilla.redhat.com/show_bug.cgi?id=1027478 --- diff --git a/src/shared/acpi-fpdt.c b/src/shared/acpi-fpdt.c index 75648b4d8..7bae47f85 100644 --- a/src/shared/acpi-fpdt.c +++ b/src/shared/acpi-fpdt.c @@ -109,6 +109,8 @@ int acpi_get_boot_usec(usec_t *loader_start, usec_t *loader_exit) { for (rec = (struct acpi_fpdt_header *)(buf + sizeof(struct acpi_table_header)); (char *)rec < buf + l; rec = (struct acpi_fpdt_header *)((char *)rec + rec->length)) { + if (rec->length <= 0) + break; if (rec->type != ACPI_FPDT_TYPE_BOOT) continue; if (rec->length != sizeof(struct acpi_fpdt_header))