|
| 1 | +; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py |
1 | 2 | ; RUN: llc < %s -mtriple=aarch64-apple-darwin | FileCheck %s
|
2 | 3 |
|
3 | 4 | declare i16 @llvm.bswap.i16(i16)
|
4 | 5 | declare i32 @llvm.bswap.i32(i32)
|
| 6 | +declare i64 @llvm.bswap.i64(i64) |
5 | 7 |
|
6 |
| -; CHECK-LABEL: @test1 |
7 |
| -; CHECK: mov w0, #1 |
8 | 8 | define i1 @test1(i16 %arg) {
|
| 9 | +; CHECK-LABEL: test1: |
| 10 | +; CHECK: ; %bb.0: |
| 11 | +; CHECK-NEXT: mov w0, #1 |
| 12 | +; CHECK-NEXT: ret |
9 | 13 | %a = or i16 %arg, 511
|
10 | 14 | %b = call i16 @llvm.bswap.i16(i16 %a)
|
11 | 15 | %and = and i16 %b, 256
|
12 | 16 | %res = icmp eq i16 %and, 256
|
13 | 17 | ret i1 %res
|
14 | 18 | }
|
15 | 19 |
|
16 |
| -; CHECK-LABEL: @test2 |
17 |
| -; CHECK: mov w0, #1 |
18 | 20 | define i1 @test2(i16 %arg) {
|
| 21 | +; CHECK-LABEL: test2: |
| 22 | +; CHECK: ; %bb.0: |
| 23 | +; CHECK-NEXT: mov w0, #1 |
| 24 | +; CHECK-NEXT: ret |
19 | 25 | %a = or i16 %arg, 1
|
20 | 26 | %b = call i16 @llvm.bswap.i16(i16 %a)
|
21 | 27 | %and = and i16 %b, 256
|
22 | 28 | %res = icmp eq i16 %and, 256
|
23 | 29 | ret i1 %res
|
24 | 30 | }
|
25 | 31 |
|
26 |
| -; CHECK-LABEL: @test3 |
27 |
| -; CHECK: mov w0, #1 |
28 | 32 | define i1 @test3(i16 %arg) {
|
| 33 | +; CHECK-LABEL: test3: |
| 34 | +; CHECK: ; %bb.0: |
| 35 | +; CHECK-NEXT: mov w0, #1 |
| 36 | +; CHECK-NEXT: ret |
29 | 37 | %a = or i16 %arg, 256
|
30 | 38 | %b = call i16 @llvm.bswap.i16(i16 %a)
|
31 | 39 | %and = and i16 %b, 1
|
32 | 40 | %res = icmp eq i16 %and, 1
|
33 | 41 | ret i1 %res
|
34 | 42 | }
|
35 | 43 |
|
36 |
| -; CHECK-LABEL: @test4 |
37 |
| -; CHECK: mov w0, #1 |
38 | 44 | define i1 @test4(i32 %arg) {
|
| 45 | +; CHECK-LABEL: test4: |
| 46 | +; CHECK: ; %bb.0: |
| 47 | +; CHECK-NEXT: mov w0, #1 |
| 48 | +; CHECK-NEXT: ret |
39 | 49 | %a = or i32 %arg, 2147483647 ; i32_MAX
|
40 | 50 | %b = call i32 @llvm.bswap.i32(i32 %a)
|
41 | 51 | %and = and i32 %b, 127
|
42 | 52 | %res = icmp eq i32 %and, 127
|
43 | 53 | ret i1 %res
|
44 | 54 | }
|
| 55 | + |
| 56 | +define i8 @demand_one_byte0(i32 %x) { |
| 57 | +; CHECK-LABEL: demand_one_byte0: |
| 58 | +; CHECK: ; %bb.0: |
| 59 | +; CHECK-NEXT: rev w0, w0 |
| 60 | +; CHECK-NEXT: ret |
| 61 | + %b = call i32 @llvm.bswap.i32(i32 %x) |
| 62 | + %r = trunc i32 %b to i8 |
| 63 | + ret i8 %r |
| 64 | +} |
| 65 | + |
| 66 | +define i32 @demand_one_byte1(i32 %x) { |
| 67 | +; CHECK-LABEL: demand_one_byte1: |
| 68 | +; CHECK: ; %bb.0: |
| 69 | +; CHECK-NEXT: rev w8, w0 |
| 70 | +; CHECK-NEXT: and w0, w8, #0xff00 |
| 71 | +; CHECK-NEXT: ret |
| 72 | + %b = call i32 @llvm.bswap.i32(i32 %x) |
| 73 | + %r = and i32 %b, 65280 ; 0x0000ff00 |
| 74 | + ret i32 %r |
| 75 | +} |
| 76 | + |
| 77 | +define i32 @demand_one_byte2(i32 %x) { |
| 78 | +; CHECK-LABEL: demand_one_byte2: |
| 79 | +; CHECK: ; %bb.0: |
| 80 | +; CHECK-NEXT: rev w8, w0 |
| 81 | +; CHECK-NEXT: orr w0, w8, #0xff00ffff |
| 82 | +; CHECK-NEXT: ret |
| 83 | + %b = call i32 @llvm.bswap.i32(i32 %x) |
| 84 | + %r = or i32 %b, 4278255615 ; 0xff00ffff |
| 85 | + ret i32 %r |
| 86 | +} |
| 87 | + |
| 88 | +define i64 @demand_one_byte3(i64 %x) { |
| 89 | +; CHECK-LABEL: demand_one_byte3: |
| 90 | +; CHECK: ; %bb.0: |
| 91 | +; CHECK-NEXT: rev x8, x0 |
| 92 | +; CHECK-NEXT: lsr x0, x8, #56 |
| 93 | +; CHECK-NEXT: ret |
| 94 | + %b = call i64 @llvm.bswap.i64(i64 %x) |
| 95 | + %r = lshr i64 %b, 56 |
| 96 | + ret i64 %r |
| 97 | +} |
| 98 | + |
| 99 | +define void @demand_one_loaded_byte(i64* %xp, i32* %yp) { |
| 100 | +; CHECK-LABEL: demand_one_loaded_byte: |
| 101 | +; CHECK: ; %bb.0: |
| 102 | +; CHECK-NEXT: ldr x8, [x0] |
| 103 | +; CHECK-NEXT: lsr x8, x8, #8 |
| 104 | +; CHECK-NEXT: rev w8, w8 |
| 105 | +; CHECK-NEXT: strb w8, [x1] |
| 106 | +; CHECK-NEXT: ret |
| 107 | + %x = load i64, i64* %xp, align 8 |
| 108 | + %x_zzzz7654 = lshr i64 %x, 32 |
| 109 | + %x_z7654zzz = shl nuw nsw i64 %x_zzzz7654, 24 |
| 110 | + %x_4zzz = trunc i64 %x_z7654zzz to i32 |
| 111 | + %y = load i32, i32* %yp, align 4 |
| 112 | + %y_321z = and i32 %y, -256 |
| 113 | + %x_zzz4 = call i32 @llvm.bswap.i32(i32 %x_4zzz) |
| 114 | + %r = or i32 %x_zzz4, %y_321z |
| 115 | + store i32 %r, i32* %yp, align 4 |
| 116 | + ret void |
| 117 | +} |
0 commit comments