diff options
author | Jiang Liu <liuj97@gmail.com> | 2012-02-15 00:01:44 +0800 |
---|---|---|
committer | Len Brown <len.brown@intel.com> | 2012-03-30 04:01:26 -0400 |
commit | 37d2a3622d249d83413c92a1cd9e94b5237d0fcc (patch) | |
tree | 81456457d095b0615dd1664b12c880fe8859e449 /drivers/acpi | |
parent | 15afae604651d4e17652d2ffb56f5e36f991cfef (diff) | |
download | op-kernel-dev-37d2a3622d249d83413c92a1cd9e94b5237d0fcc.zip op-kernel-dev-37d2a3622d249d83413c92a1cd9e94b5237d0fcc.tar.gz |
CPER failed to handle generic error records with multiple sections
The function apei_estatus_print() and apei_estatus_check() forget to move ahead
the gdata pointer when dealing with multiple generic error data sections.
Signed-off-by: Jiang Liu <jiang.liu@huawei.com>
Signed-off-by: Len Brown <len.brown@intel.com>
Diffstat (limited to 'drivers/acpi')
-rw-r--r-- | drivers/acpi/apei/cper.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/acpi/apei/cper.c b/drivers/acpi/apei/cper.c index 5d41894..e6defd8 100644 --- a/drivers/acpi/apei/cper.c +++ b/drivers/acpi/apei/cper.c @@ -362,6 +362,7 @@ void apei_estatus_print(const char *pfx, gedata_len = gdata->error_data_length; apei_estatus_print_section(pfx, gdata, sec_no); data_len -= gedata_len + sizeof(*gdata); + gdata = (void *)(gdata + 1) + gedata_len; sec_no++; } } @@ -396,6 +397,7 @@ int apei_estatus_check(const struct acpi_hest_generic_status *estatus) if (gedata_len > data_len - sizeof(*gdata)) return -EINVAL; data_len -= gedata_len + sizeof(*gdata); + gdata = (void *)(gdata + 1) + gedata_len; } if (data_len) return -EINVAL; |