aboutsummaryrefslogtreecommitdiff
path: root/clang/test/CodeGenOpenCL/ext-int-shift.cl
blob: 3e6d170a70bd2e02fc166934344e4bcc61612f3f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
// RUN: %clang_cc1 -triple x86_64-linux-pc -O3 -disable-llvm-passes %s -emit-llvm -o - | FileCheck %s

void Shifts(_BitInt(12) E, int i) {
  E << 99;
  // CHECK: shl i12 %{{.+}}, 3

  77 << E;
  // CHECK: %[[PROM:.+]] = zext i12 %{{.+}} to i32
  // CHECK: %[[MASK:.+]] = and i32 %[[PROM]], 31
  // CHECK: shl i32 77, %[[MASK]]

  E << i;
  // CHECK: %[[PROM:.+]] = trunc i32 %{{.+}} to i12
  // CHECK: %[[MASK:.+]] = urem i12 %[[PROM]], 12
  // CHECK: shl i12 %{{.+}}, %[[MASK]]

  i << E;
  // CHECK: %[[PROM:.+]] = zext i12 %{{.+}} to i32
  // CHECK: %[[MASK:.+]] = and i32 %[[PROM]], 31
  // CHECK: shl i32 %{{.+}}, %[[MASK]]
}