case BO_Shl: {
if (Info.getLangOpts().OpenCL)
// OpenCL 6.3j: shift values are effectively % word size of LHS.
- RHS &= APSInt(llvm::APInt(LHS.getBitWidth(),
+ RHS &= APSInt(llvm::APInt(RHS.getBitWidth(),
static_cast<uint64_t>(LHS.getBitWidth() - 1)),
RHS.isUnsigned());
else if (RHS.isSigned() && RHS.isNegative()) {
case BO_Shr: {
if (Info.getLangOpts().OpenCL)
// OpenCL 6.3j: shift values are effectively % word size of LHS.
- RHS &= APSInt(llvm::APInt(LHS.getBitWidth(),
+ RHS &= APSInt(llvm::APInt(RHS.getBitWidth(),
static_cast<uint64_t>(LHS.getBitWidth() - 1)),
RHS.isUnsigned());
else if (RHS.isSigned() && RHS.isNegative()) {
// OpenCL essentially reduces all shift amounts to the last word-size bits before evaluating.
// Test this both for variables and constants evaluated in the front-end.
-//CHECK: @negativeShift32
+// CHECK: @gtest1 = constant i64 2147483648
+__constant const unsigned long gtest1 = 1UL << 31;
+
+// CHECK: @negativeShift32
int negativeShift32(int a,int b) {
- //CHECK: %array0 = alloca [256 x i8]
+ // CHECK: %array0 = alloca [256 x i8]
char array0[((int)1)<<40];
- //CHECK: %array1 = alloca [256 x i8]
+ // CHECK: %array1 = alloca [256 x i8]
char array1[((int)1)<<(-24)];
- //CHECK: ret i32 65536
+ // CHECK: ret i32 65536
return ((int)1)<<(-16);
}