/** @file\r
MADT table parser\r
\r
- Copyright (c) 2016 - 2019, ARM Limited. All rights reserved.\r
+ Copyright (c) 2016 - 2020, ARM Limited. All rights reserved.\r
SPDX-License-Identifier: BSD-2-Clause-Patent\r
\r
@par Reference(s):\r
return;\r
}\r
\r
- // Make sure forward progress is made.\r
- if (*MadtInterruptControllerLength < 2) {\r
+ // Validate Interrupt Controller Structure length\r
+ if ((*MadtInterruptControllerLength == 0) ||\r
+ ((Offset + (*MadtInterruptControllerLength)) > AcpiTableLength)) {\r
IncrementErrorCount ();\r
Print (\r
- L"ERROR: Structure length is too small: " \\r
- L"MadtInterruptControllerLength = %d. " \\r
- L"MadtInterruptControllerType = %d. MADT parsing aborted.\n",\r
+ L"ERROR: Invalid Interrupt Controller Structure length. " \\r
+ L"Length = %d. Offset = %d. AcpiTableLength = %d.\n",\r
*MadtInterruptControllerLength,\r
- *MadtInterruptControllerType\r
- );\r
- return;\r
- }\r
-\r
- // Make sure the MADT structure lies inside the table\r
- if ((Offset + *MadtInterruptControllerLength) > AcpiTableLength) {\r
- IncrementErrorCount ();\r
- Print (\r
- L"ERROR: Invalid MADT structure length. " \\r
- L"MadtInterruptControllerLength = %d. " \\r
- L"RemainingTableBufferLength = %d. MADT parsing aborted.\n",\r
- *MadtInterruptControllerLength,\r
- AcpiTableLength - Offset\r
+ Offset,\r
+ AcpiTableLength\r
);\r
return;\r
}\r