1; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py 2; RUN: llc -verify-machineinstrs -mtriple=powerpc64-unknown-linux-gnu -O2 \ 3; RUN: -ppc-gpr-icmps=all -ppc-asm-full-reg-names -mcpu=pwr8 < %s | FileCheck %s \ 4; RUN: --implicit-check-not cmpw --implicit-check-not cmpd --implicit-check-not cmpl \ 5; RUN: --check-prefixes=CHECK,BE 6; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu -O2 \ 7; RUN: -ppc-gpr-icmps=all -ppc-asm-full-reg-names -mcpu=pwr8 < %s | FileCheck %s \ 8; RUN: --implicit-check-not cmpw --implicit-check-not cmpd --implicit-check-not cmpl \ 9; RUN: --check-prefixes=CHECK,LE 10 11@glob = local_unnamed_addr global i8 0, align 1 12 13; Function Attrs: norecurse nounwind readnone 14define i64 @test_llgeuc(i8 zeroext %a, i8 zeroext %b) { 15; CHECK-LABEL: test_llgeuc: 16; CHECK: # %bb.0: # %entry 17; CHECK-NEXT: sub r3, r3, r4 18; CHECK-NEXT: not r3, r3 19; CHECK-NEXT: rldicl r3, r3, 1, 63 20; CHECK-NEXT: blr 21entry: 22 %cmp = icmp uge i8 %a, %b 23 %conv3 = zext i1 %cmp to i64 24 ret i64 %conv3 25} 26 27; Function Attrs: norecurse nounwind readnone 28define i64 @test_llgeuc_sext(i8 zeroext %a, i8 zeroext %b) { 29; CHECK-LABEL: test_llgeuc_sext: 30; CHECK: # %bb.0: # %entry 31; CHECK-NEXT: sub r3, r3, r4 32; CHECK-NEXT: rldicl r3, r3, 1, 63 33; CHECK-NEXT: addi r3, r3, -1 34; CHECK-NEXT: blr 35entry: 36 %cmp = icmp uge i8 %a, %b 37 %conv3 = sext i1 %cmp to i64 38 ret i64 %conv3 39} 40 41; Function Attrs: norecurse nounwind readnone 42define i64 @test_llgeuc_z(i8 zeroext %a) { 43; CHECK-LABEL: test_llgeuc_z: 44; CHECK: # %bb.0: # %entry 45; CHECK-NEXT: li r3, 1 46; CHECK-NEXT: blr 47entry: 48 %cmp = icmp uge i8 %a, 0 49 %conv1 = zext i1 %cmp to i64 50 ret i64 %conv1 51} 52 53; Function Attrs: norecurse nounwind readnone 54define i64 @test_llgeuc_sext_z(i8 zeroext %a) { 55; CHECK-LABEL: test_llgeuc_sext_z: 56; CHECK: # %bb.0: # %entry 57; CHECK-NEXT: li r3, -1 58; CHECK-NEXT: blr 59entry: 60 %cmp = icmp uge i8 %a, 0 61 %conv1 = sext i1 %cmp to i64 62 ret i64 %conv1 63} 64 65; Function Attrs: norecurse nounwind 66define void @test_llgeuc_store(i8 zeroext %a, i8 zeroext %b) { 67; BE-LABEL: test_llgeuc_store: 68; BE: # %bb.0: # %entry 69; BE-NEXT: addis r5, r2, .LC0@toc@ha 70; BE-NEXT: sub r3, r3, r4 71; BE-NEXT: ld r4, .LC0@toc@l(r5) 72; BE-NEXT: not r3, r3 73; BE-NEXT: rldicl r3, r3, 1, 63 74; BE-NEXT: stb r3, 0(r4) 75; BE-NEXT: blr 76; 77; LE-LABEL: test_llgeuc_store: 78; LE: # %bb.0: # %entry 79; LE-NEXT: sub r3, r3, r4 80; LE-NEXT: addis r5, r2, glob@toc@ha 81; LE-NEXT: not r3, r3 82; LE-NEXT: rldicl r3, r3, 1, 63 83; LE-NEXT: stb r3, glob@toc@l(r5) 84; LE-NEXT: blr 85entry: 86 %cmp = icmp uge i8 %a, %b 87 %conv3 = zext i1 %cmp to i8 88 store i8 %conv3, i8* @glob 89 ret void 90; CHECK_LABEL: test_llgeuc_store: 91} 92 93; Function Attrs: norecurse nounwind 94define void @test_llgeuc_sext_store(i8 zeroext %a, i8 zeroext %b) { 95; BE-LABEL: test_llgeuc_sext_store: 96; BE: # %bb.0: # %entry 97; BE-NEXT: addis r5, r2, .LC0@toc@ha 98; BE-NEXT: sub r3, r3, r4 99; BE-NEXT: ld r4, .LC0@toc@l(r5) 100; BE-NEXT: rldicl r3, r3, 1, 63 101; BE-NEXT: addi r3, r3, -1 102; BE-NEXT: stb r3, 0(r4) 103; BE-NEXT: blr 104; 105; LE-LABEL: test_llgeuc_sext_store: 106; LE: # %bb.0: # %entry 107; LE-NEXT: sub r3, r3, r4 108; LE-NEXT: addis r5, r2, glob@toc@ha 109; LE-NEXT: rldicl r3, r3, 1, 63 110; LE-NEXT: addi r3, r3, -1 111; LE-NEXT: stb r3, glob@toc@l(r5) 112; LE-NEXT: blr 113entry: 114 %cmp = icmp uge i8 %a, %b 115 %conv3 = sext i1 %cmp to i8 116 store i8 %conv3, i8* @glob 117 ret void 118} 119 120; Function Attrs: norecurse nounwind 121define void @test_llgeuc_z_store(i8 zeroext %a) { 122; BE-LABEL: test_llgeuc_z_store: 123; BE: # %bb.0: # %entry 124; BE-NEXT: addis r3, r2, .LC0@toc@ha 125; BE-NEXT: li r4, 1 126; BE-NEXT: ld r3, .LC0@toc@l(r3) 127; BE-NEXT: stb r4, 0(r3) 128; BE-NEXT: blr 129; 130; LE-LABEL: test_llgeuc_z_store: 131; LE: # %bb.0: # %entry 132; LE-NEXT: addis r3, r2, glob@toc@ha 133; LE-NEXT: li r4, 1 134; LE-NEXT: stb r4, glob@toc@l(r3) 135; LE-NEXT: blr 136entry: 137 %cmp = icmp uge i8 %a, 0 138 %conv1 = zext i1 %cmp to i8 139 store i8 %conv1, i8* @glob 140 ret void 141} 142 143; Function Attrs: norecurse nounwind 144define void @test_llgeuc_sext_z_store(i8 zeroext %a) { 145; BE-LABEL: test_llgeuc_sext_z_store: 146; BE: # %bb.0: # %entry 147; BE-NEXT: addis r3, r2, .LC0@toc@ha 148; BE-NEXT: li r4, -1 149; BE-NEXT: ld r3, .LC0@toc@l(r3) 150; BE-NEXT: stb r4, 0(r3) 151; BE-NEXT: blr 152; 153; LE-LABEL: test_llgeuc_sext_z_store: 154; LE: # %bb.0: # %entry 155; LE-NEXT: addis r3, r2, glob@toc@ha 156; LE-NEXT: li r4, -1 157; LE-NEXT: stb r4, glob@toc@l(r3) 158; LE-NEXT: blr 159entry: 160 %cmp = icmp uge i8 %a, 0 161 %conv1 = sext i1 %cmp to i8 162 store i8 %conv1, i8* @glob 163 ret void 164} 165 166