summaryrefslogtreecommitdiffstats
path: root/BaseTools/Source/Python/Common/DscClassObject.py
diff options
context:
space:
mode:
authorLaszlo Ersek <lersek@redhat.com>2018-02-15 14:47:11 +0100
committerLaszlo Ersek <lersek@redhat.com>2018-02-21 11:57:33 +0100
commit41bfaffd13094d9042110091e6c37adf20c4032c (patch)
treed73cd00cf9ace8fdb7945bac50894637f36c2246 /BaseTools/Source/Python/Common/DscClassObject.py
parent54c7728a04658b09ea1a50b9e35e838fde166003 (diff)
downloadedk2-41bfaffd13094d9042110091e6c37adf20c4032c.tar.gz
edk2-41bfaffd13094d9042110091e6c37adf20c4032c.tar.bz2
edk2-41bfaffd13094d9042110091e6c37adf20c4032c.zip
MdePkg/BaseSafeIntLib: fix undefined behavior in SafeInt64Add()
The addition in the assignment SignedResult = Augend + Addend; is performed with unchecked INT64 operands. According to ISO C, if the mathematical result of signed integer addition cannot be represented in the result type, the behavior is undefined. (Refer to ISO C99 6.5p5. 6.2.5p9 only exempts unsigned integers, and 6.3.1.3p3 does not apply because it treats the conversion of integers that have been successfully evaluated first.) Replace the after-the-fact result checking with checks on the operands, and only perform the addition if it is safe. Cc: Bret Barkelew <Bret.Barkelew@microsoft.com> Cc: Liming Gao <liming.gao@intel.com> Cc: Michael D Kinney <michael.d.kinney@intel.com> Cc: Sean Brogan <sean.brogan@microsoft.com> Contributed-under: TianoCore Contribution Agreement 1.1 Signed-off-by: Laszlo Ersek <lersek@redhat.com> Reviewed-by: Ard Biesheuvel <ard.biesheuvel@linaro.org> Tested-by: Michael D Kinney <michael.d.kinney@intel.com>
Diffstat (limited to 'BaseTools/Source/Python/Common/DscClassObject.py')
0 files changed, 0 insertions, 0 deletions