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>
This commit is contained in:
Dongjiu Geng 2020-07-27 16:12:10 +01:00 committed by Peter Maydell
parent 4215d34132
commit 4bf7c0cb09

View File

@ -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*/ /* This is the length if adding a new generic error data entry*/
data_length = ACPI_GHES_DATA_LENGTH + ACPI_GHES_MEM_CPER_LENGTH; 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 * It should not run out of the preallocated memory if adding a new generic
* generic error data entry * error data entry
*/ */
if ((data_length + ACPI_GHES_GESB_SIZE) > ACPI_GHES_MAX_RAW_DATA_LENGTH) { assert((data_length + ACPI_GHES_GESB_SIZE) <=
error_report("Not enough memory to record new CPER!!!"); ACPI_GHES_MAX_RAW_DATA_LENGTH);
g_array_free(block, true);
return -1;
}
/* Build the new generic error status block header */ /* Build the new generic error status block header */
acpi_ghes_generic_error_status(block, ACPI_GEBS_UNCORRECTABLE, acpi_ghes_generic_error_status(block, ACPI_GEBS_UNCORRECTABLE,