1; RUN: llc -verify-machineinstrs -o - %s -mtriple=arm64-apple-ios7.0 | FileCheck %s 2 3define i32 @test_floattoi32(float %in) { 4; CHECK-LABEL: test_floattoi32: 5 6 %signed = fptosi float %in to i32 7 %unsigned = fptoui float %in to i32 8; CHECK-DAG: fcvtzu [[UNSIG:w[0-9]+]], {{s[0-9]+}} 9; CHECK-DAG: fcvtzs [[SIG:w[0-9]+]], {{s[0-9]+}} 10 11 %res = sub i32 %signed, %unsigned 12; CHECK: sub {{w[0-9]+}}, [[SIG]], [[UNSIG]] 13 14 ret i32 %res 15; CHECK: ret 16} 17 18define i32 @test_doubletoi32(double %in) { 19; CHECK-LABEL: test_doubletoi32: 20 21 %signed = fptosi double %in to i32 22 %unsigned = fptoui double %in to i32 23; CHECK-DAG: fcvtzu [[UNSIG:w[0-9]+]], {{d[0-9]+}} 24; CHECK-DAG: fcvtzs [[SIG:w[0-9]+]], {{d[0-9]+}} 25 26 %res = sub i32 %signed, %unsigned 27; CHECK: sub {{w[0-9]+}}, [[SIG]], [[UNSIG]] 28 29 ret i32 %res 30; CHECK: ret 31} 32 33define i64 @test_floattoi64(float %in) { 34; CHECK-LABEL: test_floattoi64: 35 36 %signed = fptosi float %in to i64 37 %unsigned = fptoui float %in to i64 38; CHECK-DAG: fcvtzu [[UNSIG:x[0-9]+]], {{s[0-9]+}} 39; CHECK-DAG: fcvtzs [[SIG:x[0-9]+]], {{s[0-9]+}} 40 41 %res = sub i64 %signed, %unsigned 42; CHECK: sub {{x[0-9]+}}, [[SIG]], [[UNSIG]] 43 44 ret i64 %res 45; CHECK: ret 46} 47 48define i64 @test_doubletoi64(double %in) { 49; CHECK-LABEL: test_doubletoi64: 50 51 %signed = fptosi double %in to i64 52 %unsigned = fptoui double %in to i64 53; CHECK-DAG: fcvtzu [[UNSIG:x[0-9]+]], {{d[0-9]+}} 54; CHECK-DAG: fcvtzs [[SIG:x[0-9]+]], {{d[0-9]+}} 55 56 %res = sub i64 %signed, %unsigned 57; CHECK: sub {{x[0-9]+}}, [[SIG]], [[UNSIG]] 58 59 ret i64 %res 60; CHECK: ret 61} 62 63define float @test_i32tofloat(i32 %in) { 64; CHECK-LABEL: test_i32tofloat: 65 66 %signed = sitofp i32 %in to float 67 %unsigned = uitofp i32 %in to float 68; CHECK-DAG: ucvtf [[UNSIG:s[0-9]+]], {{w[0-9]+}} 69; CHECK-DAG: scvtf [[SIG:s[0-9]+]], {{w[0-9]+}} 70 71 %res = fsub float %signed, %unsigned 72; CHECK: fsub {{s[0-9]+}}, [[SIG]], [[UNSIG]] 73 ret float %res 74; CHECK: ret 75} 76 77define double @test_i32todouble(i32 %in) { 78; CHECK-LABEL: test_i32todouble: 79 80 %signed = sitofp i32 %in to double 81 %unsigned = uitofp i32 %in to double 82; CHECK-DAG: ucvtf [[UNSIG:d[0-9]+]], {{w[0-9]+}} 83; CHECK-DAG: scvtf [[SIG:d[0-9]+]], {{w[0-9]+}} 84 85 %res = fsub double %signed, %unsigned 86; CHECK: fsub {{d[0-9]+}}, [[SIG]], [[UNSIG]] 87 ret double %res 88; CHECK: ret 89} 90 91define float @test_i64tofloat(i64 %in) { 92; CHECK-LABEL: test_i64tofloat: 93 94 %signed = sitofp i64 %in to float 95 %unsigned = uitofp i64 %in to float 96; CHECK-DAG: ucvtf [[UNSIG:s[0-9]+]], {{x[0-9]+}} 97; CHECK-DAG: scvtf [[SIG:s[0-9]+]], {{x[0-9]+}} 98 99 %res = fsub float %signed, %unsigned 100; CHECK: fsub {{s[0-9]+}}, [[SIG]], [[UNSIG]] 101 ret float %res 102; CHECK: ret 103} 104 105define double @test_i64todouble(i64 %in) { 106; CHECK-LABEL: test_i64todouble: 107 108 %signed = sitofp i64 %in to double 109 %unsigned = uitofp i64 %in to double 110; CHECK-DAG: ucvtf [[UNSIG:d[0-9]+]], {{x[0-9]+}} 111; CHECK-DAG: scvtf [[SIG:d[0-9]+]], {{x[0-9]+}} 112 113 %res = fsub double %signed, %unsigned 114; CHECK: sub {{d[0-9]+}}, [[SIG]], [[UNSIG]] 115 ret double %res 116; CHECK: ret 117} 118 119define i32 @test_bitcastfloattoi32(float %in) { 120; CHECK-LABEL: test_bitcastfloattoi32: 121 122 %res = bitcast float %in to i32 123; CHECK: fmov {{w[0-9]+}}, {{s[0-9]+}} 124 ret i32 %res 125} 126 127define i64 @test_bitcastdoubletoi64(double %in) { 128; CHECK-LABEL: test_bitcastdoubletoi64: 129 130 %res = bitcast double %in to i64 131; CHECK: fmov {{x[0-9]+}}, {{d[0-9]+}} 132 ret i64 %res 133} 134 135define float @test_bitcasti32tofloat(i32 %in) { 136; CHECK-LABEL: test_bitcasti32tofloat: 137 138 %res = bitcast i32 %in to float 139; CHECK: fmov {{s[0-9]+}}, {{w[0-9]+}} 140 ret float %res 141 142} 143 144define double @test_bitcasti64todouble(i64 %in) { 145; CHECK-LABEL: test_bitcasti64todouble: 146 147 %res = bitcast i64 %in to double 148; CHECK: fmov {{d[0-9]+}}, {{x[0-9]+}} 149 ret double %res 150 151} 152 153define double @bitcast_fabs(double %x) { 154; CHECK-LABEL: bitcast_fabs: 155; CHECK: ; BB#0: 156; CHECK-NEXT: fabs d0, d0 157; CHECK-NEXT: ret 158; 159 %bc1 = bitcast double %x to i64 160 %and = and i64 %bc1, 9223372036854775807 161 %bc2 = bitcast i64 %and to double 162 ret double %bc2 163} 164 165define float @bitcast_fneg(float %x) { 166; CHECK-LABEL: bitcast_fneg: 167; CHECK: ; BB#0: 168; CHECK-NEXT: fneg s0, s0 169; CHECK-NEXT: ret 170; 171 %bc1 = bitcast float %x to i32 172 %xor = xor i32 %bc1, 2147483648 173 %bc2 = bitcast i32 %xor to float 174 ret float %bc2 175} 176 177