mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-26 04:32:44 +01:00
82 lines
2.4 KiB
LLVM
82 lines
2.4 KiB
LLVM
|
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
|
||
|
; RUN: llc -mtriple=powerpc-unknown-linux-gnu < %s | FileCheck %s
|
||
|
|
||
|
target datalayout = "E-m:e-p:32:32-i64:64-n32"
|
||
|
|
||
|
define void @test() {
|
||
|
; CHECK-LABEL: test:
|
||
|
; CHECK: # %bb.0: # %bb
|
||
|
; CHECK-NEXT: bc 12, 20, .LBB0_2
|
||
|
; CHECK-NEXT: # %bb.1: # %bb2
|
||
|
; CHECK-NEXT: li 3, 0
|
||
|
; CHECK-NEXT: stw 3, 0(3)
|
||
|
; CHECK-NEXT: lis 3, 256
|
||
|
; CHECK-NEXT: stw 3, 0(3)
|
||
|
; CHECK-NEXT: blr
|
||
|
; CHECK-NEXT: .LBB0_2: # %bb1
|
||
|
; CHECK-NEXT: bclr 4, 20, 0
|
||
|
; CHECK-NEXT: # %bb.3: # %bb66
|
||
|
; CHECK-NEXT: lwz 4, 12(0)
|
||
|
; CHECK-NEXT: lwz 5, 8(0)
|
||
|
; CHECK-NEXT: lwz 6, 0(0)
|
||
|
; CHECK-NEXT: lwz 7, 4(0)
|
||
|
; CHECK-NEXT: lbz 3, 0(3)
|
||
|
; CHECK-NEXT: and 5, 5, 6
|
||
|
; CHECK-NEXT: and 4, 4, 7
|
||
|
; CHECK-NEXT: and 4, 4, 5
|
||
|
; CHECK-NEXT: cmpwi 3, 0
|
||
|
; CHECK-NEXT: lis 3, 256
|
||
|
; CHECK-NEXT: lis 7, 512
|
||
|
; CHECK-NEXT: bc 12, 2, .LBB0_4
|
||
|
; CHECK-NEXT: b .LBB0_5
|
||
|
; CHECK-NEXT: .LBB0_4: # %bb66
|
||
|
; CHECK-NEXT: li 3, 0
|
||
|
; CHECK-NEXT: .LBB0_5: # %bb66
|
||
|
; CHECK-NEXT: cmpwi 1, 4, -1
|
||
|
; CHECK-NEXT: cmpwi 5, 4, -1
|
||
|
; CHECK-NEXT: li 6, 0
|
||
|
; CHECK-NEXT: bc 12, 6, .LBB0_6
|
||
|
; CHECK-NEXT: b .LBB0_7
|
||
|
; CHECK-NEXT: .LBB0_6: # %bb66
|
||
|
; CHECK-NEXT: addi 3, 7, 0
|
||
|
; CHECK-NEXT: .LBB0_7: # %bb66
|
||
|
; CHECK-NEXT: cror 20, 22, 2
|
||
|
; CHECK-NEXT: stw 3, 0(3)
|
||
|
; CHECK-NEXT: bc 12, 20, .LBB0_9
|
||
|
; CHECK-NEXT: # %bb.8: # %bb66
|
||
|
; CHECK-NEXT: ori 3, 6, 0
|
||
|
; CHECK-NEXT: b .LBB0_10
|
||
|
; CHECK-NEXT: .LBB0_9: # %bb66
|
||
|
; CHECK-NEXT: li 3, 0
|
||
|
; CHECK-NEXT: .LBB0_10: # %bb66
|
||
|
; CHECK-NEXT: stw 3, 0(3)
|
||
|
; CHECK-NEXT: blr
|
||
|
bb:
|
||
|
br i1 undef, label %bb2, label %bb1
|
||
|
|
||
|
bb2: ; preds = %bb
|
||
|
%i = select i1 undef, i64 0, i64 72057594037927936
|
||
|
store i64 %i, i64* undef, align 8
|
||
|
ret void
|
||
|
|
||
|
bb1: ; preds = %bb
|
||
|
%i50 = load i8, i8* undef, align 8
|
||
|
%i52 = load i128, i128* null, align 8
|
||
|
%i62 = icmp eq i8 %i50, 0
|
||
|
br i1 undef, label %bb66, label %bb64
|
||
|
|
||
|
bb64: ; preds = %bb63
|
||
|
ret void
|
||
|
|
||
|
bb66: ; preds = %bb63
|
||
|
%i67 = lshr i128 -1, 0
|
||
|
%i68 = xor i128 %i52, -1
|
||
|
%i69 = add i128 0, %i68
|
||
|
%i70 = and i128 %i67, %i69
|
||
|
%i71 = icmp eq i128 %i70, 0
|
||
|
%i74 = select i1 %i62, i64 0, i64 72057594037927936
|
||
|
%i75 = select i1 %i71, i64 144115188075855872, i64 %i74
|
||
|
store i64 %i75, i64* undef, align 8
|
||
|
ret void
|
||
|
}
|