mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-31 20:51:52 +01:00
aed4cd7b82
The directive was a typo when I first wrote the test case, then decided to use the script and the script didn't remove the line with the typo.
258 lines
7.9 KiB
LLVM
258 lines
7.9 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
|
|
; RUN: llc -verify-machineinstrs -mtriple=powerpc64-unknown-linux-gnu -O2 \
|
|
; RUN: -ppc-gpr-icmps=all -ppc-asm-full-reg-names -mcpu=pwr8 < %s | FileCheck %s --check-prefix=CHECK-BE \
|
|
; RUN: --implicit-check-not cmpw --implicit-check-not cmpd --implicit-check-not cmpl
|
|
; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu -O2 \
|
|
; RUN: -ppc-gpr-icmps=all -ppc-asm-full-reg-names -mcpu=pwr8 < %s | FileCheck %s --check-prefix=CHECK-LE \
|
|
; RUN: --implicit-check-not cmpw --implicit-check-not cmpd --implicit-check-not cmpl
|
|
|
|
@glob = local_unnamed_addr global i32 0, align 4
|
|
|
|
; Function Attrs: norecurse nounwind readnone
|
|
define i64 @test_lleqsi(i32 signext %a, i32 signext %b) {
|
|
; CHECK-LABEL: test_lleqsi:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: xor r3, r3, r4
|
|
; CHECK-NEXT: cntlzw r3, r3
|
|
; CHECK-NEXT: srwi r3, r3, 5
|
|
; CHECK-NEXT: blr
|
|
; CHECK-BE-LABEL: test_lleqsi:
|
|
; CHECK-BE: # %bb.0: # %entry
|
|
; CHECK-BE-NEXT: xor r3, r3, r4
|
|
; CHECK-BE-NEXT: cntlzw r3, r3
|
|
; CHECK-BE-NEXT: srwi r3, r3, 5
|
|
; CHECK-BE-NEXT: blr
|
|
;
|
|
; CHECK-LE-LABEL: test_lleqsi:
|
|
; CHECK-LE: # %bb.0: # %entry
|
|
; CHECK-LE-NEXT: xor r3, r3, r4
|
|
; CHECK-LE-NEXT: cntlzw r3, r3
|
|
; CHECK-LE-NEXT: srwi r3, r3, 5
|
|
; CHECK-LE-NEXT: blr
|
|
entry:
|
|
%cmp = icmp eq i32 %a, %b
|
|
%conv1 = zext i1 %cmp to i64
|
|
ret i64 %conv1
|
|
}
|
|
|
|
; Function Attrs: norecurse nounwind readnone
|
|
define i64 @test_lleqsi_sext(i32 signext %a, i32 signext %b) {
|
|
; CHECK-LABEL: test_lleqsi_sext:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: xor r3, r3, r4
|
|
; CHECK-NEXT: cntlzw r3, r3
|
|
; CHECK-NEXT: srwi r3, r3, 5
|
|
; CHECK-NEXT: neg r3, r3
|
|
; CHECK-NEXT: blr
|
|
; CHECK-BE-LABEL: test_lleqsi_sext:
|
|
; CHECK-BE: # %bb.0: # %entry
|
|
; CHECK-BE-NEXT: xor r3, r3, r4
|
|
; CHECK-BE-NEXT: cntlzw r3, r3
|
|
; CHECK-BE-NEXT: srwi r3, r3, 5
|
|
; CHECK-BE-NEXT: neg r3, r3
|
|
; CHECK-BE-NEXT: blr
|
|
;
|
|
; CHECK-LE-LABEL: test_lleqsi_sext:
|
|
; CHECK-LE: # %bb.0: # %entry
|
|
; CHECK-LE-NEXT: xor r3, r3, r4
|
|
; CHECK-LE-NEXT: cntlzw r3, r3
|
|
; CHECK-LE-NEXT: srwi r3, r3, 5
|
|
; CHECK-LE-NEXT: neg r3, r3
|
|
; CHECK-LE-NEXT: blr
|
|
entry:
|
|
%cmp = icmp eq i32 %a, %b
|
|
%conv1 = sext i1 %cmp to i64
|
|
ret i64 %conv1
|
|
}
|
|
|
|
; Function Attrs: norecurse nounwind readnone
|
|
define i64 @test_lleqsi_z(i32 signext %a) {
|
|
; CHECK-LABEL: test_lleqsi_z:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: cntlzw r3, r3
|
|
; CHECK-NEXT: srwi r3, r3, 5
|
|
; CHECK-NEXT: blr
|
|
; CHECK-BE-LABEL: test_lleqsi_z:
|
|
; CHECK-BE: # %bb.0: # %entry
|
|
; CHECK-BE-NEXT: cntlzw r3, r3
|
|
; CHECK-BE-NEXT: srwi r3, r3, 5
|
|
; CHECK-BE-NEXT: blr
|
|
;
|
|
; CHECK-LE-LABEL: test_lleqsi_z:
|
|
; CHECK-LE: # %bb.0: # %entry
|
|
; CHECK-LE-NEXT: cntlzw r3, r3
|
|
; CHECK-LE-NEXT: srwi r3, r3, 5
|
|
; CHECK-LE-NEXT: blr
|
|
entry:
|
|
%cmp = icmp eq i32 %a, 0
|
|
%conv1 = zext i1 %cmp to i64
|
|
ret i64 %conv1
|
|
}
|
|
|
|
; Function Attrs: norecurse nounwind readnone
|
|
define i64 @test_lleqsi_sext_z(i32 signext %a) {
|
|
; CHECK-LABEL: test_lleqsi_sext_z:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: cntlzw r3, r3
|
|
; CHECK-NEXT: srwi r3, r3, 5
|
|
; CHECK-NEXT: neg r3, r3
|
|
; CHECK-NEXT: blr
|
|
; CHECK-BE-LABEL: test_lleqsi_sext_z:
|
|
; CHECK-BE: # %bb.0: # %entry
|
|
; CHECK-BE-NEXT: cntlzw r3, r3
|
|
; CHECK-BE-NEXT: srwi r3, r3, 5
|
|
; CHECK-BE-NEXT: neg r3, r3
|
|
; CHECK-BE-NEXT: blr
|
|
;
|
|
; CHECK-LE-LABEL: test_lleqsi_sext_z:
|
|
; CHECK-LE: # %bb.0: # %entry
|
|
; CHECK-LE-NEXT: cntlzw r3, r3
|
|
; CHECK-LE-NEXT: srwi r3, r3, 5
|
|
; CHECK-LE-NEXT: neg r3, r3
|
|
; CHECK-LE-NEXT: blr
|
|
entry:
|
|
%cmp = icmp eq i32 %a, 0
|
|
%conv1 = sext i1 %cmp to i64
|
|
ret i64 %conv1
|
|
}
|
|
|
|
; Function Attrs: norecurse nounwind
|
|
define void @test_lleqsi_store(i32 signext %a, i32 signext %b) {
|
|
; CHECK-LABEL: test_lleqsi_store:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: xor r3, r3, r4
|
|
; CHECK-NEXT: addis r5, r2, glob@toc@ha
|
|
; CHECK-NEXT: cntlzw r3, r3
|
|
; CHECK-NEXT: srwi r3, r3, 5
|
|
; CHECK-NEXT: stw r3, glob@toc@l(r5)
|
|
; CHECK-NEXT: blr
|
|
; CHECK-BE-LABEL: test_lleqsi_store:
|
|
; CHECK-BE: # %bb.0: # %entry
|
|
; CHECK-BE-NEXT: addis r5, r2, .LC0@toc@ha
|
|
; CHECK-BE-NEXT: xor r3, r3, r4
|
|
; CHECK-BE-NEXT: ld r4, .LC0@toc@l(r5)
|
|
; CHECK-BE-NEXT: cntlzw r3, r3
|
|
; CHECK-BE-NEXT: srwi r3, r3, 5
|
|
; CHECK-BE-NEXT: stw r3, 0(r4)
|
|
; CHECK-BE-NEXT: blr
|
|
;
|
|
; CHECK-LE-LABEL: test_lleqsi_store:
|
|
; CHECK-LE: # %bb.0: # %entry
|
|
; CHECK-LE-NEXT: xor r3, r3, r4
|
|
; CHECK-LE-NEXT: addis r5, r2, glob@toc@ha
|
|
; CHECK-LE-NEXT: cntlzw r3, r3
|
|
; CHECK-LE-NEXT: srwi r3, r3, 5
|
|
; CHECK-LE-NEXT: stw r3, glob@toc@l(r5)
|
|
; CHECK-LE-NEXT: blr
|
|
entry:
|
|
%cmp = icmp eq i32 %a, %b
|
|
%conv = zext i1 %cmp to i32
|
|
store i32 %conv, i32* @glob, align 4
|
|
ret void
|
|
}
|
|
|
|
; Function Attrs: norecurse nounwind
|
|
define void @test_lleqsi_sext_store(i32 signext %a, i32 signext %b) {
|
|
; CHECK-LABEL: test_lleqsi_sext_store:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: xor r3, r3, r4
|
|
; CHECK-NEXT: addis r5, r2, glob@toc@ha
|
|
; CHECK-NEXT: cntlzw r3, r3
|
|
; CHECK-NEXT: srwi r3, r3, 5
|
|
; CHECK-NEXT: neg r3, r3
|
|
; CHECK-NEXT: stw r3, glob@toc@l(r5)
|
|
; CHECK-NEXT: blr
|
|
; CHECK-BE-LABEL: test_lleqsi_sext_store:
|
|
; CHECK-BE: # %bb.0: # %entry
|
|
; CHECK-BE-NEXT: addis r5, r2, .LC0@toc@ha
|
|
; CHECK-BE-NEXT: xor r3, r3, r4
|
|
; CHECK-BE-NEXT: cntlzw r3, r3
|
|
; CHECK-BE-NEXT: ld r4, .LC0@toc@l(r5)
|
|
; CHECK-BE-NEXT: srwi r3, r3, 5
|
|
; CHECK-BE-NEXT: neg r3, r3
|
|
; CHECK-BE-NEXT: stw r3, 0(r4)
|
|
; CHECK-BE-NEXT: blr
|
|
;
|
|
; CHECK-LE-LABEL: test_lleqsi_sext_store:
|
|
; CHECK-LE: # %bb.0: # %entry
|
|
; CHECK-LE-NEXT: xor r3, r3, r4
|
|
; CHECK-LE-NEXT: addis r5, r2, glob@toc@ha
|
|
; CHECK-LE-NEXT: cntlzw r3, r3
|
|
; CHECK-LE-NEXT: srwi r3, r3, 5
|
|
; CHECK-LE-NEXT: neg r3, r3
|
|
; CHECK-LE-NEXT: stw r3, glob@toc@l(r5)
|
|
; CHECK-LE-NEXT: blr
|
|
entry:
|
|
%cmp = icmp eq i32 %a, %b
|
|
%sub = sext i1 %cmp to i32
|
|
store i32 %sub, i32* @glob, align 4
|
|
ret void
|
|
}
|
|
|
|
; Function Attrs: norecurse nounwind
|
|
define void @test_lleqsi_z_store(i32 signext %a) {
|
|
; CHECK-LABEL: test_lleqsi_z_store:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: cntlzw r3, r3
|
|
; CHECK-NEXT: addis r4, r2, glob@toc@ha
|
|
; CHECK-NEXT: srwi r3, r3, 5
|
|
; CHECK-NEXT: stw r3, glob@toc@l(r4)
|
|
; CHECK-NEXT: blr
|
|
; CHECK-BE-LABEL: test_lleqsi_z_store:
|
|
; CHECK-BE: # %bb.0: # %entry
|
|
; CHECK-BE-NEXT: addis r4, r2, .LC0@toc@ha
|
|
; CHECK-BE-NEXT: cntlzw r3, r3
|
|
; CHECK-BE-NEXT: ld r4, .LC0@toc@l(r4)
|
|
; CHECK-BE-NEXT: srwi r3, r3, 5
|
|
; CHECK-BE-NEXT: stw r3, 0(r4)
|
|
; CHECK-BE-NEXT: blr
|
|
;
|
|
; CHECK-LE-LABEL: test_lleqsi_z_store:
|
|
; CHECK-LE: # %bb.0: # %entry
|
|
; CHECK-LE-NEXT: cntlzw r3, r3
|
|
; CHECK-LE-NEXT: addis r4, r2, glob@toc@ha
|
|
; CHECK-LE-NEXT: srwi r3, r3, 5
|
|
; CHECK-LE-NEXT: stw r3, glob@toc@l(r4)
|
|
; CHECK-LE-NEXT: blr
|
|
entry:
|
|
%cmp = icmp eq i32 %a, 0
|
|
%conv = zext i1 %cmp to i32
|
|
store i32 %conv, i32* @glob, align 4
|
|
ret void
|
|
}
|
|
|
|
; Function Attrs: norecurse nounwind
|
|
define void @test_lleqsi_sext_z_store(i32 signext %a) {
|
|
; CHECK-LABEL: test_lleqsi_sext_z_store:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: cntlzw r3, r3
|
|
; CHECK-NEXT: addis r4, r2, glob@toc@ha
|
|
; CHECK-NEXT: srwi r3, r3, 5
|
|
; CHECK-NEXT: neg r3, r3
|
|
; CHECK-NEXT: stw r3, glob@toc@l(r4)
|
|
; CHECK-NEXT: blr
|
|
; CHECK-BE-LABEL: test_lleqsi_sext_z_store:
|
|
; CHECK-BE: # %bb.0: # %entry
|
|
; CHECK-BE-NEXT: addis r4, r2, .LC0@toc@ha
|
|
; CHECK-BE-NEXT: cntlzw r3, r3
|
|
; CHECK-BE-NEXT: ld r4, .LC0@toc@l(r4)
|
|
; CHECK-BE-NEXT: srwi r3, r3, 5
|
|
; CHECK-BE-NEXT: neg r3, r3
|
|
; CHECK-BE-NEXT: stw r3, 0(r4)
|
|
; CHECK-BE-NEXT: blr
|
|
;
|
|
; CHECK-LE-LABEL: test_lleqsi_sext_z_store:
|
|
; CHECK-LE: # %bb.0: # %entry
|
|
; CHECK-LE-NEXT: cntlzw r3, r3
|
|
; CHECK-LE-NEXT: addis r4, r2, glob@toc@ha
|
|
; CHECK-LE-NEXT: srwi r3, r3, 5
|
|
; CHECK-LE-NEXT: neg r3, r3
|
|
; CHECK-LE-NEXT: stw r3, glob@toc@l(r4)
|
|
; CHECK-LE-NEXT: blr
|
|
entry:
|
|
%cmp = icmp eq i32 %a, 0
|
|
%sub = sext i1 %cmp to i32
|
|
store i32 %sub, i32* @glob, align 4
|
|
ret void
|
|
}
|