On 6 September 2015 at 10:15, Heyi Guo <[email protected]> wrote:
> The code has a simple bug on calculating aligned page table address.
> We need to add alignment - 1 to allocated address first and then mask
> the unaligned bits.
>

Nice find!

> Contributed-under: TianoCore Contribution Agreement 1.0
> Signed-off-by: Heyi Guo <[email protected]>
> Cc: Leif Lindholm <[email protected]>
> Cc: Ard Biesheuvel <[email protected]>
> ---
>  ArmPkg/Library/ArmLib/AArch64/AArch64Mmu.c | 4 ++--
>  1 file changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/ArmPkg/Library/ArmLib/AArch64/AArch64Mmu.c 
> b/ArmPkg/Library/ArmLib/AArch64/AArch64Mmu.c
> index 3d58d5d..4db4bbe 100644
> --- a/ArmPkg/Library/ArmLib/AArch64/AArch64Mmu.c
> +++ b/ArmPkg/Library/ArmLib/AArch64/AArch64Mmu.c
> @@ -381,7 +381,7 @@ GetBlockEntryListFromAddress (
>          if (TranslationTable == NULL) {
>            return NULL;
>          }
> -        TranslationTable = (UINT64*)((UINTN)TranslationTable & 
> TT_ADDRESS_MASK_DESCRIPTION_TABLE);
> +        TranslationTable = (UINT64*)(((UINTN)TranslationTable + 
> TT_ALIGNMENT_DESCRIPTION_TABLE - 1) & TT_ADDRESS_MASK_DESCRIPTION_TABLE);
>

Could we do (TranslationTable | (TT_ALIGNMENT_DESCRIPTION_TABLE - 1))
+ 1 instead of using two different symbolic constants?

>          // Populate the newly created lower level table
>          SubTableBlockEntry = TranslationTable;
> @@ -409,7 +409,7 @@ GetBlockEntryListFromAddress (
>          if (TranslationTable == NULL) {
>            return NULL;
>          }
> -        TranslationTable = (UINT64*)((UINTN)TranslationTable & 
> TT_ADDRESS_MASK_DESCRIPTION_TABLE);
> +        TranslationTable = (UINT64*)(((UINTN)TranslationTable + 
> TT_ALIGNMENT_DESCRIPTION_TABLE - 1) & TT_ADDRESS_MASK_DESCRIPTION_TABLE);
>
>          ZeroMem (TranslationTable, TT_ENTRY_COUNT * sizeof(UINT64));
>

I think you missed another instance at line 625

So what is hidden from view by all these symbolic constants is that we
are aligning the return value of AllocatePages() to 4 KB, which is
rather pointless, and is actually resulting in every allocation to
waste 4 KB. But that also means the buggy rounding code never produces
incorrect values, making the severity of this bug low.

So instead, could we get a comprehensive patch that:
- replaces all three instances with a call to a static function that
does the allocation and the rounding
- apply the rounding only if the alignment exceeds 4 KB
- fix the rounding logic.

Thanks,
Ard.
_______________________________________________
edk2-devel mailing list
[email protected]
https://lists.01.org/mailman/listinfo/edk2-devel

Reply via email to