1; RUN: llc < %s -O0 -verify-machineinstrs -fast-isel-abort=1 -mtriple=powerpc64-unknown-linux-gnu -mcpu=pwr5 | FileCheck %s --check-prefix=ELF64 2 3; Test sitofp 4 5define void @sitofp_double_i32(i32 %a, double %b) nounwind ssp { 6entry: 7; ELF64: sitofp_double_i32 8 %b.addr = alloca double, align 8 9 %conv = sitofp i32 %a to double 10; ELF64: std {{[0-9]+}}, -[[OFFSET:[0-9]+]](1) 11; ELF64: lfd {{[0-9]+}}, -[[OFFSET]](1) 12; ELF64: fcfid 13 store double %conv, double* %b.addr, align 8 14 ret void 15} 16 17define void @sitofp_double_i64(i64 %a, double %b) nounwind ssp { 18entry: 19; ELF64: sitofp_double_i64 20 %b.addr = alloca double, align 8 21 %conv = sitofp i64 %a to double 22; ELF64: std {{[0-9]+}}, -[[OFFSET:[0-9]+]](1) 23; ELF64: lfd {{[0-9]+}}, -[[OFFSET]](1) 24; ELF64: fcfid 25 store double %conv, double* %b.addr, align 8 26 ret void 27} 28 29define void @sitofp_double_i16(i16 %a, double %b) nounwind ssp { 30entry: 31; ELF64: sitofp_double_i16 32 %b.addr = alloca double, align 8 33 %conv = sitofp i16 %a to double 34; ELF64: extsh 35; ELF64: std {{[0-9]+}}, -[[OFFSET:[0-9]+]](1) 36; ELF64: lfd {{[0-9]+}}, -[[OFFSET]](1) 37; ELF64: fcfid 38 store double %conv, double* %b.addr, align 8 39 ret void 40} 41 42define void @sitofp_double_i8(i8 %a, double %b) nounwind ssp { 43entry: 44; ELF64: sitofp_double_i8 45 %b.addr = alloca double, align 8 46 %conv = sitofp i8 %a to double 47; ELF64: extsb 48; ELF64: std {{[0-9]+}}, -[[OFFSET:[0-9]+]](1) 49; ELF64: lfd {{[0-9]+}}, -[[OFFSET]](1) 50; ELF64: fcfid 51 store double %conv, double* %b.addr, align 8 52 ret void 53} 54 55; Test fptosi 56 57define void @fptosi_float_i32(float %a) nounwind ssp { 58entry: 59; ELF64: fptosi_float_i32 60 %b.addr = alloca i32, align 4 61 %conv = fptosi float %a to i32 62; ELF64: fctiwz 63; ELF64: stfd 64; ELF64: lwa 65 store i32 %conv, i32* %b.addr, align 4 66 ret void 67} 68 69define void @fptosi_float_i64(float %a) nounwind ssp { 70entry: 71; ELF64: fptosi_float_i64 72 %b.addr = alloca i64, align 4 73 %conv = fptosi float %a to i64 74; ELF64: fctidz 75; ELF64: stfd 76; ELF64: ld 77 store i64 %conv, i64* %b.addr, align 4 78 ret void 79} 80 81define void @fptosi_double_i32(double %a) nounwind ssp { 82entry: 83; ELF64: fptosi_double_i32 84 %b.addr = alloca i32, align 8 85 %conv = fptosi double %a to i32 86; ELF64: fctiwz 87; ELF64: stfd 88; ELF64: lwa 89 store i32 %conv, i32* %b.addr, align 8 90 ret void 91} 92 93define void @fptosi_double_i64(double %a) nounwind ssp { 94entry: 95; ELF64: fptosi_double_i64 96 %b.addr = alloca i64, align 8 97 %conv = fptosi double %a to i64 98; ELF64: fctidz 99; ELF64: stfd 100; ELF64: ld 101 store i64 %conv, i64* %b.addr, align 8 102 ret void 103} 104 105; Test fptoui 106 107define void @fptoui_float_i32(float %a) nounwind ssp { 108entry: 109; ELF64: fptoui_float_i32 110 %b.addr = alloca i32, align 4 111 %conv = fptoui float %a to i32 112; ELF64: fctidz 113; ELF64: stfd 114; ELF64: lwz 115 store i32 %conv, i32* %b.addr, align 4 116 ret void 117} 118 119define void @fptoui_double_i32(double %a) nounwind ssp { 120entry: 121; ELF64: fptoui_double_i32 122 %b.addr = alloca i32, align 8 123 %conv = fptoui double %a to i32 124; ELF64: fctidz 125; ELF64: stfd 126; ELF64: lwz 127 store i32 %conv, i32* %b.addr, align 8 128 ret void 129} 130 131