[ubsan] Don't suggest casting to unsigned for unsigned unary minus overflow.
llvm-svn: 171273
This commit is contained in:
parent
f584977df2
commit
d6cd3203f6
|
|
@ -1,7 +1,12 @@
|
|||
// RUN: %clang -fsanitize=signed-integer-overflow %s -o %t && %t 2>&1 | FileCheck %s
|
||||
// RUN: %clang -fsanitize=signed-integer-overflow %s -o %t && %t 2>&1 | FileCheck %s --check-prefix=CHECKS
|
||||
// RUN: %clang -fsanitize=unsigned-integer-overflow %s -o %t && %t 2>&1 | FileCheck %s --check-prefix=CHECKU
|
||||
|
||||
int main() {
|
||||
// CHECKS-NOT: runtime error
|
||||
// CHECKU: negate-overflow.cpp:[[@LINE+2]]:3: runtime error: negation of 2147483648 cannot be represented in type 'unsigned int'
|
||||
// CHECKU-NOT: cast to an unsigned
|
||||
-unsigned(-0x7fffffff - 1); // ok
|
||||
// CHECK: negate-overflow.cpp:6:10: runtime error: negation of -2147483648 cannot be represented in type 'int'; cast to an unsigned type to negate this value to itself
|
||||
// CHECKS: negate-overflow.cpp:[[@LINE+2]]:10: runtime error: negation of -2147483648 cannot be represented in type 'int'; cast to an unsigned type to negate this value to itself
|
||||
// CHECKU-NOT: runtime error
|
||||
return -(-0x7fffffff - 1);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -103,10 +103,15 @@ void __ubsan::__ubsan_handle_mul_overflow_abort(OverflowData *Data,
|
|||
|
||||
void __ubsan::__ubsan_handle_negate_overflow(OverflowData *Data,
|
||||
ValueHandle OldVal) {
|
||||
Diag(Data->Loc, DL_Error,
|
||||
"negation of %0 cannot be represented in type %1; "
|
||||
"cast to an unsigned type to negate this value to itself")
|
||||
<< Value(Data->Type, OldVal) << Data->Type;
|
||||
if (Data->Type.isSignedIntegerTy())
|
||||
Diag(Loc, DL_Error,
|
||||
"negation of %0 cannot be represented in type %1; "
|
||||
"cast to an unsigned type to negate this value to itself")
|
||||
<< Value(Data->Type, OldVal) << Data->Type;
|
||||
else
|
||||
Diag(Loc, DL_Error,
|
||||
"negation of %0 cannot be represented in type %1")
|
||||
<< Value(Data->Type, OldVal) << Data->Type;
|
||||
}
|
||||
void __ubsan::__ubsan_handle_negate_overflow_abort(OverflowData *Data,
|
||||
ValueHandle OldVal) {
|
||||
|
|
|
|||
Loading…
Reference in New Issue