Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / Bitcode / bitwiseInstructions.3.2.ll
blobaaaf4f543a8ebc385fbd73401983a5020e81b2c8
1 ; RUN: llvm-dis < %s.bc| FileCheck %s
2 ; RUN: verify-uselistorder < %s.bc
4 ; bitwiseOperations.3.2.ll.bc was generated by passing this file to llvm-as-3.2.
5 ; The test checks that LLVM does not misread bitwise instructions from
6 ; older bitcode files.
8 define void @shl(i8 %x1){
9 entry:
10 ; CHECK: %res1 = shl i8 %x1, %x1
11   %res1 = shl i8 %x1, %x1
13 ; CHECK: %res2 = shl nuw i8 %x1, %x1
14   %res2 = shl nuw i8 %x1, %x1
16 ; CHECK: %res3 = shl nsw i8 %x1, %x1
17   %res3 = shl nsw i8 %x1, %x1
19 ; CHECK: %res4 = shl nuw nsw i8 %x1, %x1
20   %res4 = shl nuw nsw i8 %x1, %x1
22   ret void
25 define void @lshr(i8 %x1){
26 entry:
27 ; CHECK: %res1 = lshr i8 %x1, %x1
28   %res1 = lshr i8 %x1, %x1
30 ; CHECK: %res2 = lshr exact i8 %x1, %x1
31   %res2 = lshr exact i8 %x1, %x1
33   ret void
36 define void @ashr(i8 %x1){
37 entry:
38 ; CHECK: %res1 = ashr i8 %x1, %x1
39   %res1 = ashr i8 %x1, %x1
41 ; CHECK-NEXT: %res2 = ashr exact i8 %x1, %x1
42   %res2 = ashr exact i8 %x1, %x1
44   ret void
47 define void @and(i8 %x1){
48 entry:
49 ; CHECK: %res1 = and i8 %x1, %x1
50   %res1 = and i8 %x1, %x1
52   ret void
55 define void @or(i8 %x1){
56 entry:
57 ; CHECK: %res1 = or i8 %x1, %x1
58   %res1 = or i8 %x1, %x1
60   ret void
63 define void @xor(i8 %x1){
64 entry:
65 ; CHECK: %res1 = xor i8 %x1, %x1
66   %res1 = xor i8 %x1, %x1
68   ret void