For this patch, a simple search was performed for patterns where there are two types (usually an LHS and an RHS) which are structurally the same, and there is some result type which is resolved as either one of them (typically LHS for consistency). We change those cases to resolve as the common sugared type between those two, utilizing the new infrastructure created for this purpose. Signed-off-by: Matheus Izvekov <mizvekov@gmail.com> Differential Revision: https://reviews.llvm.org/D111509
33 lines
1.3 KiB
C++
33 lines
1.3 KiB
C++
// RUN: %clangxx -DADD_I32 -fsanitize=signed-integer-overflow %s -o %t1 && %run %t1 2>&1 | FileCheck %s --check-prefix=CHECK-ADD_I32
|
|
// RUN: %clangxx -DADD_I64 -fsanitize=signed-integer-overflow %s -o %t2 && %run %t2 2>&1 | FileCheck %s --check-prefix=CHECK-ADD_I64
|
|
// RUN: %clangxx -DADD_I128 -fsanitize=signed-integer-overflow %s -o %t3 && %run %t3 2>&1 | FileCheck %s --check-prefix=CHECK-ADD_I128
|
|
|
|
#include <stdint.h>
|
|
#include <stdio.h>
|
|
|
|
int main() {
|
|
// These promote to 'int'.
|
|
(void)(int8_t(0x7f) + int8_t(0x7f));
|
|
(void)(int16_t(0x3fff) + int16_t(0x4000));
|
|
|
|
#ifdef ADD_I32
|
|
int32_t k = 0x12345678;
|
|
k += 0x789abcde;
|
|
// CHECK-ADD_I32: add-overflow.cpp:[[@LINE-1]]:5: runtime error: signed integer overflow: 305419896 + 2023406814 cannot be represented in type 'int'
|
|
#endif
|
|
|
|
#ifdef ADD_I64
|
|
(void)(int64_t(8000000000000000000ll) + int64_t(2000000000000000000ll));
|
|
// CHECK-ADD_I64: 8000000000000000000 + 2000000000000000000 cannot be represented in type '{{int64_t|long( long)?}}'
|
|
#endif
|
|
|
|
#ifdef ADD_I128
|
|
# if defined(__SIZEOF_INT128__) && !defined(_WIN32)
|
|
(void)((__int128_t(1) << 126) + (__int128_t(1) << 126));
|
|
# else
|
|
puts("__int128 not supported");
|
|
# endif
|
|
// CHECK-ADD_I128: {{0x40000000000000000000000000000000 \+ 0x40000000000000000000000000000000 cannot be represented in type '__int128_t'|__int128 not supported}}
|
|
#endif
|
|
}
|