Files
clang-p2996/clang/test/Analysis/addrspace-null.c
Vince Bridgers fe8b2236ef [analyzer] Fix "RhsLoc and LhsLoc bitwidth must be same"
clang: <root>/clang/lib/StaticAnalyzer/Core/SimpleSValBuilder.cpp:727:
void assertEqualBitWidths(clang::ento::ProgramStateRef,
  clang::ento::Loc, clang::ento::Loc): Assertion `RhsBitwidth ==
  LhsBitwidth && "RhsLoc and LhsLoc bitwidth must be same!"'

This change adjusts the bitwidth of the smaller operand for an evalBinOp
as a result of a comparison operation. This can occur in the specific
case represented by the test cases for a target with different pointer
sizes.

Reviewed By: NoQ

Differential Revision: https://reviews.llvm.org/D122513
2022-03-29 17:08:19 -05:00

48 lines
1.1 KiB
C

// RUN: %clang_analyze_cc1 -triple amdgcn-unknown-unknown \
// RUN: -analyze -analyzer-checker=core -DAMDGCN_TRIPLE \
// RUN: -analyze -analyzer-checker=debug.ExprInspection \
// RUN: -Wno-implicit-int -Wno-int-conversion -verify %s
//
// RUN: %clang_analyze_cc1 -triple amdgcn-unknown-unknown \
// RUN: -analyze -analyzer-checker=core -DDEFAULT_TRIPLE \
// RUN: -analyze -analyzer-checker=debug.ExprInspection \
// RUN: -Wno-implicit-int -Wno-int-conversion -verify %s
// From https://llvm.org/docs/AMDGPUUsage.html#address-spaces,
// select address space 3 (local), since the pointer size is
// different than Generic.
// expected-no-diagnostics
#define DEVICE __attribute__((address_space(3)))
#if defined(AMDGCN_TRIPLE)
// this crashes
int fn1() {
int val = 0;
DEVICE int *dptr = val;
return dptr == (void *)0;
}
// does not crash
int fn2() {
int val = 0;
DEVICE int *dptr = val;
return dptr == (DEVICE void *)0;
}
// this crashes
int fn3() {
int val = 0;
int *dptr = val;
return dptr == (DEVICE void *)0;
}
#endif
// does not crash
int fn4() {
int val = 0;
int *dptr = val;
return dptr == (void *)0;
}