Vedant Kumar | e48597a | 2018-01-26 22:02:52 +0000 | [diff] [blame] | 1 | ; RUN: opt < %s -debugify -instcombine -S | FileCheck %s |
| 2 | |
Vedant Kumar | 6379a62 | 2018-07-06 17:32:39 +0000 | [diff] [blame] | 3 | declare void @escape32(i32) |
| 4 | |
Vedant Kumar | e48597a | 2018-01-26 22:02:52 +0000 | [diff] [blame] | 5 | define i64 @test_sext_zext(i16 %A) { |
| 6 | ; CHECK-LABEL: @test_sext_zext( |
| 7 | ; CHECK-NEXT: [[C2:%.*]] = zext i16 %A to i64 |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 8 | ; CHECK-NEXT: call void @llvm.dbg.value(metadata i64 [[C2]], {{.*}}, metadata !DIExpression()) |
| 9 | ; CHECK-NEXT: call void @llvm.dbg.value(metadata i64 [[C2]], {{.*}}, metadata !DIExpression()) |
Vedant Kumar | e48597a | 2018-01-26 22:02:52 +0000 | [diff] [blame] | 10 | %c1 = zext i16 %A to i32 |
| 11 | %c2 = sext i32 %c1 to i64 |
| 12 | ret i64 %c2 |
| 13 | } |
| 14 | |
Vedant Kumar | 6379a62 | 2018-07-06 17:32:39 +0000 | [diff] [blame] | 15 | define i64 @test_used_sext_zext(i16 %A) { |
| 16 | ; CHECK-LABEL: @test_used_sext_zext( |
| 17 | ; CHECK-NEXT: [[C1:%.*]] = zext i16 %A to i32 |
| 18 | ; CHECK-NEXT: call void @llvm.dbg.value(metadata i32 [[C1]], {{.*}}, metadata !DIExpression()) |
| 19 | ; CHECK-NEXT: [[C2:%.*]] = zext i16 %A to i64 |
| 20 | ; CHECK-NEXT: call void @llvm.dbg.value(metadata i64 [[C2]], {{.*}}, metadata !DIExpression()) |
| 21 | ; CHECK-NEXT: call void @escape32(i32 %c1) |
Vedant Kumar | ced3fd4 | 2018-07-17 18:08:34 +0000 | [diff] [blame] | 22 | ; CHECK-NEXT: ret i64 %c2 |
Vedant Kumar | 6379a62 | 2018-07-06 17:32:39 +0000 | [diff] [blame] | 23 | %c1 = zext i16 %A to i32 |
| 24 | %c2 = sext i32 %c1 to i64 |
| 25 | call void @escape32(i32 %c1) |
| 26 | ret i64 %c2 |
| 27 | } |
| 28 | |
Vedant Kumar | 9ece818 | 2018-07-17 18:08:36 +0000 | [diff] [blame^] | 29 | define i32 @test_cast_select(i1 %cond) { |
| 30 | ; CHECK-LABEL: @test_cast_select( |
| 31 | ; CHECK-NEXT: [[sel:%.*]] = select i1 %cond, i32 3, i32 5 |
| 32 | ; CHECK-NEXT: call void @llvm.dbg.value(metadata i32 [[sel]], {{.*}}, metadata !DIExpression()) |
| 33 | ; CHECK-NEXT: call void @llvm.dbg.value(metadata i32 [[sel]], {{.*}}, metadata !DIExpression()) |
| 34 | ; CHECK-NEXT: ret i32 [[sel]] |
| 35 | %sel = select i1 %cond, i16 3, i16 5 |
| 36 | %cast = zext i16 %sel to i32 |
| 37 | ret i32 %cast |
| 38 | } |
| 39 | |
Vedant Kumar | a8b8d32 | 2018-02-12 21:02:45 +0000 | [diff] [blame] | 40 | define void @test_or(i64 %A) { |
| 41 | ; CHECK-LABEL: @test_or( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 42 | ; CHECK-NEXT: call void @llvm.dbg.value(metadata i64 %A, {{.*}}, metadata !DIExpression(DW_OP_constu, 256, DW_OP_or, DW_OP_stack_value)) |
Vedant Kumar | a8b8d32 | 2018-02-12 21:02:45 +0000 | [diff] [blame] | 43 | %1 = or i64 %A, 256 |
| 44 | ret void |
| 45 | } |
| 46 | |
Vedant Kumar | 96b7dc0 | 2018-02-13 01:09:46 +0000 | [diff] [blame] | 47 | define void @test_xor(i32 %A) { |
| 48 | ; CHECK-LABEL: @test_xor( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 49 | ; CHECK-NEXT: call void @llvm.dbg.value(metadata i32 %A, {{.*}}, metadata !DIExpression(DW_OP_constu, 1, DW_OP_xor, DW_OP_stack_value)) |
Vedant Kumar | 96b7dc0 | 2018-02-13 01:09:46 +0000 | [diff] [blame] | 50 | %1 = xor i32 %A, 1 |
| 51 | ret void |
| 52 | } |
| 53 | |
Vedant Kumar | 47b16c4 | 2018-02-13 01:09:47 +0000 | [diff] [blame] | 54 | define void @test_sub_neg(i64 %A) { |
| 55 | ; CHECK-LABEL: @test_sub_neg( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 56 | ; CHECK-NEXT: call void @llvm.dbg.value(metadata i64 %A, {{.*}}, metadata !DIExpression(DW_OP_plus_uconst, 1, DW_OP_stack_value)) |
Vedant Kumar | 47b16c4 | 2018-02-13 01:09:47 +0000 | [diff] [blame] | 57 | %1 = sub i64 %A, -1 |
| 58 | ret void |
| 59 | } |
| 60 | |
| 61 | define void @test_sub_pos(i64 %A) { |
| 62 | ; CHECK-LABEL: @test_sub_pos( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 63 | ; CHECK-NEXT: call void @llvm.dbg.value(metadata i64 %A, {{.*}}, metadata !DIExpression(DW_OP_constu, 1, DW_OP_minus, DW_OP_stack_value)) |
Vedant Kumar | 47b16c4 | 2018-02-13 01:09:47 +0000 | [diff] [blame] | 64 | %1 = sub i64 %A, 1 |
| 65 | ret void |
| 66 | } |
| 67 | |
Vedant Kumar | 31ec356 | 2018-02-13 01:09:49 +0000 | [diff] [blame] | 68 | define void @test_shl(i64 %A) { |
| 69 | ; CHECK-LABEL: @test_shl( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 70 | ; CHECK-NEXT: call void @llvm.dbg.value(metadata i64 %A, {{.*}}, metadata !DIExpression(DW_OP_constu, 7, DW_OP_shl, DW_OP_stack_value)) |
Vedant Kumar | 31ec356 | 2018-02-13 01:09:49 +0000 | [diff] [blame] | 71 | %1 = shl i64 %A, 7 |
| 72 | ret void |
| 73 | } |
| 74 | |
| 75 | define void @test_lshr(i64 %A) { |
| 76 | ; CHECK-LABEL: @test_lshr( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 77 | ; CHECK-NEXT: call void @llvm.dbg.value(metadata i64 %A, {{.*}}, metadata !DIExpression(DW_OP_constu, 7, DW_OP_shr, DW_OP_stack_value)) |
Vedant Kumar | 31ec356 | 2018-02-13 01:09:49 +0000 | [diff] [blame] | 78 | %1 = lshr i64 %A, 7 |
| 79 | ret void |
| 80 | } |
| 81 | |
| 82 | define void @test_ashr(i64 %A) { |
| 83 | ; CHECK-LABEL: @test_ashr( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 84 | ; CHECK-NEXT: call void @llvm.dbg.value(metadata i64 %A, {{.*}}, metadata !DIExpression(DW_OP_constu, 7, DW_OP_shra, DW_OP_stack_value)) |
Vedant Kumar | 31ec356 | 2018-02-13 01:09:49 +0000 | [diff] [blame] | 85 | %1 = ashr i64 %A, 7 |
| 86 | ret void |
| 87 | } |
| 88 | |
Vedant Kumar | 4011c26 | 2018-02-13 01:09:52 +0000 | [diff] [blame] | 89 | define void @test_mul(i64 %A) { |
| 90 | ; CHECK-LABEL: @test_mul( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 91 | ; CHECK-NEXT: call void @llvm.dbg.value(metadata i64 %A, {{.*}}, metadata !DIExpression(DW_OP_constu, 7, DW_OP_mul, DW_OP_stack_value)) |
Vedant Kumar | 4011c26 | 2018-02-13 01:09:52 +0000 | [diff] [blame] | 92 | %1 = mul i64 %A, 7 |
| 93 | ret void |
| 94 | } |
| 95 | |
| 96 | define void @test_sdiv(i64 %A) { |
| 97 | ; CHECK-LABEL: @test_sdiv( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 98 | ; CHECK-NEXT: call void @llvm.dbg.value(metadata i64 %A, {{.*}}, metadata !DIExpression(DW_OP_constu, 7, DW_OP_div, DW_OP_stack_value)) |
Vedant Kumar | 4011c26 | 2018-02-13 01:09:52 +0000 | [diff] [blame] | 99 | %1 = sdiv i64 %A, 7 |
| 100 | ret void |
| 101 | } |
| 102 | |
| 103 | define void @test_srem(i64 %A) { |
| 104 | ; CHECK-LABEL: @test_srem( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 105 | ; CHECK-NEXT: call void @llvm.dbg.value(metadata i64 %A, {{.*}}, metadata !DIExpression(DW_OP_constu, 7, DW_OP_mod, DW_OP_stack_value)) |
Vedant Kumar | 4011c26 | 2018-02-13 01:09:52 +0000 | [diff] [blame] | 106 | %1 = srem i64 %A, 7 |
| 107 | ret void |
| 108 | } |
| 109 | |
Vedant Kumar | 388fac5 | 2018-02-13 03:34:23 +0000 | [diff] [blame] | 110 | define void @test_ptrtoint(i64* %P) { |
| 111 | ; CHECK-LABEL: @test_ptrtoint |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 112 | ; CHECK-NEXT: call void @llvm.dbg.value(metadata i64* %P, {{.*}}, metadata !DIExpression()) |
Vedant Kumar | 388fac5 | 2018-02-13 03:34:23 +0000 | [diff] [blame] | 113 | %1 = ptrtoint i64* %P to i64 |
| 114 | ret void |
| 115 | } |
| 116 | |
Petar Jovanovic | 1768957 | 2018-02-14 13:10:35 +0000 | [diff] [blame] | 117 | define void @test_and(i64 %A) { |
| 118 | ; CHECK-LABEL: @test_and( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 119 | ; CHECK-NEXT: call void @llvm.dbg.value(metadata i64 %A, {{.*}}, metadata !DIExpression(DW_OP_constu, 256, DW_OP_and, DW_OP_stack_value)) |
Petar Jovanovic | 1768957 | 2018-02-14 13:10:35 +0000 | [diff] [blame] | 120 | %1 = and i64 %A, 256 |
| 121 | ret void |
| 122 | } |