Specifically: - Disable int128 tests on Windows, as MSVC cl.exe does not support int128, so we might not have been able to build the runtime with int128 support. - XFAIL the vptr tests as we lack Microsoft ABI support. - XFAIL enum.cpp as UBSan fails to add the correct instrumentation code for some reason. - Modify certain tests that build executables multiple times to use unique names for each executable. This works around a race condition observed on Windows. - Implement IsAccessibleMemoryRange for Windows to fix the last misaligned.cpp test. - Introduce a substitution for testing crashes on Windows using KillTheDoctor. Differential Revision: http://reviews.llvm.org/D10864 llvm-svn: 241303
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 '{{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'|__int128 not supported}}
|
|
#endif
|
|
}
|