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) |
| 22 | ; CHECK-NEXT: ret i64 %c2, !dbg !23 |
| 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 | a8b8d32 | 2018-02-12 21:02:45 +0000 | [diff] [blame] | 29 | define void @test_or(i64 %A) { |
| 30 | ; CHECK-LABEL: @test_or( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 31 | ; 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] | 32 | %1 = or i64 %A, 256 |
| 33 | ret void |
| 34 | } |
| 35 | |
Vedant Kumar | 96b7dc0 | 2018-02-13 01:09:46 +0000 | [diff] [blame] | 36 | define void @test_xor(i32 %A) { |
| 37 | ; CHECK-LABEL: @test_xor( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 38 | ; 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] | 39 | %1 = xor i32 %A, 1 |
| 40 | ret void |
| 41 | } |
| 42 | |
Vedant Kumar | 47b16c4 | 2018-02-13 01:09:47 +0000 | [diff] [blame] | 43 | define void @test_sub_neg(i64 %A) { |
| 44 | ; CHECK-LABEL: @test_sub_neg( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 45 | ; 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] | 46 | %1 = sub i64 %A, -1 |
| 47 | ret void |
| 48 | } |
| 49 | |
| 50 | define void @test_sub_pos(i64 %A) { |
| 51 | ; CHECK-LABEL: @test_sub_pos( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 52 | ; 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] | 53 | %1 = sub i64 %A, 1 |
| 54 | ret void |
| 55 | } |
| 56 | |
Vedant Kumar | 31ec356 | 2018-02-13 01:09:49 +0000 | [diff] [blame] | 57 | define void @test_shl(i64 %A) { |
| 58 | ; CHECK-LABEL: @test_shl( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 59 | ; 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] | 60 | %1 = shl i64 %A, 7 |
| 61 | ret void |
| 62 | } |
| 63 | |
| 64 | define void @test_lshr(i64 %A) { |
| 65 | ; CHECK-LABEL: @test_lshr( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 66 | ; 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] | 67 | %1 = lshr i64 %A, 7 |
| 68 | ret void |
| 69 | } |
| 70 | |
| 71 | define void @test_ashr(i64 %A) { |
| 72 | ; CHECK-LABEL: @test_ashr( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 73 | ; 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] | 74 | %1 = ashr i64 %A, 7 |
| 75 | ret void |
| 76 | } |
| 77 | |
Vedant Kumar | 4011c26 | 2018-02-13 01:09:52 +0000 | [diff] [blame] | 78 | define void @test_mul(i64 %A) { |
| 79 | ; CHECK-LABEL: @test_mul( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 80 | ; 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] | 81 | %1 = mul i64 %A, 7 |
| 82 | ret void |
| 83 | } |
| 84 | |
| 85 | define void @test_sdiv(i64 %A) { |
| 86 | ; CHECK-LABEL: @test_sdiv( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 87 | ; 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] | 88 | %1 = sdiv i64 %A, 7 |
| 89 | ret void |
| 90 | } |
| 91 | |
| 92 | define void @test_srem(i64 %A) { |
| 93 | ; CHECK-LABEL: @test_srem( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 94 | ; 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] | 95 | %1 = srem i64 %A, 7 |
| 96 | ret void |
| 97 | } |
| 98 | |
Vedant Kumar | 388fac5 | 2018-02-13 03:34:23 +0000 | [diff] [blame] | 99 | define void @test_ptrtoint(i64* %P) { |
| 100 | ; CHECK-LABEL: @test_ptrtoint |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 101 | ; CHECK-NEXT: call void @llvm.dbg.value(metadata i64* %P, {{.*}}, metadata !DIExpression()) |
Vedant Kumar | 388fac5 | 2018-02-13 03:34:23 +0000 | [diff] [blame] | 102 | %1 = ptrtoint i64* %P to i64 |
| 103 | ret void |
| 104 | } |
| 105 | |
Petar Jovanovic | 1768957 | 2018-02-14 13:10:35 +0000 | [diff] [blame] | 106 | define void @test_and(i64 %A) { |
| 107 | ; CHECK-LABEL: @test_and( |
Vedant Kumar | 4872535e | 2018-05-24 23:00:23 +0000 | [diff] [blame] | 108 | ; 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] | 109 | %1 = and i64 %A, 256 |
| 110 | ret void |
| 111 | } |