Adding detection of out-of-bound pre-bound memory read to AES-XTS tests. #2286
+187
−63
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Issues:
Addresses #V1681992550
Description of changes:
This change hardens the tests introduced in #2227 Fix out-of-bound (OOB) input read in AES-XTS Decrypt in AVX-512 implementation.
It adds a memory page preceding the input and output buffer that is protected against read and write in order to detect any under-read, in which case a segfault occurs.
The suspected code that can potentially cause a "pre-bound" OOB is the cipher-stealing section in Encrypt
crypto/fipsmodule/aes/asm/aesni-xts-avx512.pl#L1809-L1810
and decrypt
crypto/fipsmodule/aes/asm/aesni-xts-avx512.pl#2572-L2573.
Testing:
The efficacy of the added test was shown by changing the decrypt cipher-stealing code for example to:
With this change, a segmentation fault occurs in the test vector of input length 17 bytes (1 AES block + 1 byte); which is the smallest test vector that requires cipher stealing. At the changed line:
$input
points at byte 16, i.e. past the first block$length
= 1, after l.2429$input + $length - 18
=$input -17
, which points at byte "-1", i.e. the byte right before byte 0 of the input, i.e. an underread, this causes a segfault at this vector.Another test changes the location of the written output
Similar tests in the encrypt path gave the same result of segfaulting when trying to read before the input beginning.
Call-outs:
N/A
By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license and the ISC license.