;; Copyright (c) 2012, Intel Corporation ;; All rights reserved. ;; ;; Redistribution and use in source and binary forms, with or without ;; modification, are permitted provided that the following conditions are ;; met: ;; ;; * Redistributions of source code must retain the above copyright ;; notice, this list of conditions and the following disclaimer. ;; ;; * Redistributions in binary form must reproduce the above copyright ;; notice, this list of conditions and the following disclaimer in the ;; documentation and/or other materials provided with the distribution. ;; ;; * Neither the name of Intel Corporation nor the names of its ;; contributors may be used to endorse or promote products derived from ;; this software without specific prior written permission. ;; ;; ;; THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS ;; IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED ;; TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A ;; PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER ;; OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, ;; EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, ;; PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR ;; PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF ;; LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING ;; NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS ;; SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. define(`NO_HALF_DECLARES', `1') include(`target-avx1-x2.ll') ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; float/half conversions declare <8 x float> @llvm.x86.vcvtph2ps.256(<8 x i16>) nounwind readnone ; 0 is round nearest even declare <8 x i16> @llvm.x86.vcvtps2ph.256(<8 x float>, i32) nounwind readnone define <16 x float> @__half_to_float_varying(<16 x i16> %v) nounwind readnone { %r_0 = shufflevector <16 x i16> %v, <16 x i16> undef, <8 x i32> %vr_0 = call <8 x float> @llvm.x86.vcvtph2ps.256(<8 x i16> %r_0) %r_1 = shufflevector <16 x i16> %v, <16 x i16> undef, <8 x i32> %vr_1 = call <8 x float> @llvm.x86.vcvtph2ps.256(<8 x i16> %r_1) %r = shufflevector <8 x float> %vr_0, <8 x float> %vr_1, <16 x i32> ret <16 x float> %r } define <16 x i16> @__float_to_half_varying(<16 x float> %v) nounwind readnone { %r_0 = shufflevector <16 x float> %v, <16 x float> undef, <8 x i32> %vr_0 = call <8 x i16> @llvm.x86.vcvtps2ph.256(<8 x float> %r_0, i32 0) %r_1 = shufflevector <16 x float> %v, <16 x float> undef, <8 x i32> %vr_1 = call <8 x i16> @llvm.x86.vcvtps2ph.256(<8 x float> %r_1, i32 0) %r = shufflevector <8 x i16> %vr_0, <8 x i16> %vr_1, <16 x i32> ret <16 x i16> %r } define float @__half_to_float_uniform(i16 %v) nounwind readnone { %v1 = bitcast i16 %v to <1 x i16> %vv = shufflevector <1 x i16> %v1, <1 x i16> undef, <8 x i32> %rv = call <8 x float> @llvm.x86.vcvtph2ps.256(<8 x i16> %vv) %r = extractelement <8 x float> %rv, i32 0 ret float %r } define i16 @__float_to_half_uniform(float %v) nounwind readnone { %v1 = bitcast float %v to <1 x float> %vv = shufflevector <1 x float> %v1, <1 x float> undef, <8 x i32> ; round to nearest even %rv = call <8 x i16> @llvm.x86.vcvtps2ph.256(<8 x float> %vv, i32 0) %r = extractelement <8 x i16> %rv, i32 0 ret i16 %r }