| OLD | NEW |
| 1 ; RUIN: %llvm2ice -verbose inst %s | FileCheck %s | 1 ; RUIN: %llvm2ice -verbose inst %s | FileCheck %s |
| 2 ; RUIN: %llvm2ice --verbose none %s | FileCheck --check-prefix=ERRORS %s | 2 ; RUIN: %llvm2ice --verbose none %s | FileCheck --check-prefix=ERRORS %s |
| 3 ; RUN: %szdiff --llvm2ice=%llvm2ice %s | FileCheck --check-prefix=DUMP %s | 3 ; RUN: %llvm2iceinsts %s | %szdiff %s | FileCheck --check-prefix=DUMP %s |
| 4 ; RUN: %llvm2iceinsts --pnacl %s | %szdiff %s \ |
| 5 ; RUN: | FileCheck --check-prefix=DUMP %s |
| 4 | 6 |
| 5 @i1 = common global i32 0, align 4 | 7 @i1 = global [4 x i8] zeroinitializer, align 4 |
| 6 @i2 = common global i32 0, align 4 | 8 @i2 = global [4 x i8] zeroinitializer, align 4 |
| 7 @u1 = common global i32 0, align 4 | 9 @u1 = global [4 x i8] zeroinitializer, align 4 |
| 8 @u2 = common global i32 0, align 4 | |
| 9 | 10 |
| 10 define void @conv1() { | 11 define void @conv1() { |
| 11 entry: | 12 entry: |
| 12 %v0 = load i32* @u1, align 1 | 13 %__0 = bitcast [4 x i8]* @u1 to i32* |
| 14 %v0 = load i32* %__0, align 1 |
| 13 %sext = shl i32 %v0, 24 | 15 %sext = shl i32 %v0, 24 |
| 14 %v1 = ashr i32 %sext, 24 | 16 %v1 = ashr i32 %sext, 24 |
| 15 store i32 %v1, i32* @i1, align 1 | 17 %__4 = bitcast [4 x i8]* @i1 to i32* |
| 18 store i32 %v1, i32* %__4, align 1 |
| 16 ret void | 19 ret void |
| 17 ; CHECK: shl eax, 24 | 20 ; CHECK: shl eax, 24 |
| 18 ; CHECK-NEXT: sar eax, 24 | 21 ; CHECK-NEXT: sar eax, 24 |
| 19 } | 22 } |
| 20 | 23 |
| 21 define void @conv2() { | 24 define void @conv2() { |
| 22 entry: | 25 entry: |
| 23 %v0 = load i32* @u1, align 1 | 26 %__0 = bitcast [4 x i8]* @u1 to i32* |
| 27 %v0 = load i32* %__0, align 1 |
| 24 %sext1 = shl i32 %v0, 16 | 28 %sext1 = shl i32 %v0, 16 |
| 25 %v1 = ashr i32 %sext1, 16 | 29 %v1 = ashr i32 %sext1, 16 |
| 26 store i32 %v1, i32* @i2, align 1 | 30 %__4 = bitcast [4 x i8]* @i2 to i32* |
| 31 store i32 %v1, i32* %__4, align 1 |
| 27 ret void | 32 ret void |
| 28 ; CHECK: shl eax, 16 | 33 ; CHECK: shl eax, 16 |
| 29 ; CHECK-NEXT: sar eax, 16 | 34 ; CHECK-NEXT: sar eax, 16 |
| 30 } | 35 } |
| 31 | 36 |
| 32 ; ERRORS-NOT: ICE translation error | 37 ; ERRORS-NOT: ICE translation error |
| 33 ; DUMP-NOT: SZ | 38 ; DUMP-NOT: SZ |
| OLD | NEW |