aboutsummaryrefslogtreecommitdiff
path: root/hw/acpi/ghes.c
diff options
context:
space:
mode:
authorDongjiu Geng <gengdongjiu@huawei.com>2020-07-27 16:12:10 +0100
committerPeter Maydell <peter.maydell@linaro.org>2020-07-27 16:12:10 +0100
commit4bf7c0cb09a59314aca261291e3a20a24c7dd3b3 (patch)
tree6117bfdb425cd85dc699f6623f566d197bd395d2 /hw/acpi/ghes.c
parent4215d3413272ad6d1c6c9d0234450b602e46a74c (diff)
downloadqemu-4bf7c0cb09a59314aca261291e3a20a24c7dd3b3.zip
qemu-4bf7c0cb09a59314aca261291e3a20a24c7dd3b3.tar.gz
qemu-4bf7c0cb09a59314aca261291e3a20a24c7dd3b3.tar.bz2
ACPI: Assert that we don't run out of the preallocated memory
data_length is a constant value, so we use assert instead of condition check. Signed-off-by: Dongjiu Geng <gengdongjiu@huawei.com> Message-id: 20200622113146.33421-1-gengdongjiu@huawei.com Reviewed-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Diffstat (limited to 'hw/acpi/ghes.c')
-rw-r--r--hw/acpi/ghes.c12
1 files changed, 4 insertions, 8 deletions
diff --git a/hw/acpi/ghes.c b/hw/acpi/ghes.c
index b363bc3..f0ee9f5 100644
--- a/hw/acpi/ghes.c
+++ b/hw/acpi/ghes.c
@@ -204,16 +204,12 @@ static int acpi_ghes_record_mem_error(uint64_t error_block_address,
/* This is the length if adding a new generic error data entry*/
data_length = ACPI_GHES_DATA_LENGTH + ACPI_GHES_MEM_CPER_LENGTH;
-
/*
- * Check whether it will run out of the preallocated memory if adding a new
- * generic error data entry
+ * It should not run out of the preallocated memory if adding a new generic
+ * error data entry
*/
- if ((data_length + ACPI_GHES_GESB_SIZE) > ACPI_GHES_MAX_RAW_DATA_LENGTH) {
- error_report("Not enough memory to record new CPER!!!");
- g_array_free(block, true);
- return -1;
- }
+ assert((data_length + ACPI_GHES_GESB_SIZE) <=
+ ACPI_GHES_MAX_RAW_DATA_LENGTH);
/* Build the new generic error status block header */
acpi_ghes_generic_error_status(block, ACPI_GEBS_UNCORRECTABLE,