1 ; RUN: llc < %s -verify-machineinstrs -mtriple=aarch64-none-linux-gnu -mattr=+neon | FileCheck %s 2 3 ; Set of tests for when the intrinsic is used. 4 5 declare <2 x float> @llvm.arm.neon.vrsqrts.v2f32(<2 x float>, <2 x float>) 6 declare <4 x float> @llvm.arm.neon.vrsqrts.v4f32(<4 x float>, <4 x float>) 7 declare <2 x double> @llvm.arm.neon.vrsqrts.v2f64(<2 x double>, <2 x double>) 8 9 define <2 x float> @frsqrts_from_intr_v2f32(<2 x float> %lhs, <2 x float> %rhs) { 10 ; Using registers other than v0, v1 are possible, but would be odd. 11 ; CHECK: frsqrts v0.2s, v0.2s, v1.2s 12 %val = call <2 x float> @llvm.arm.neon.vrsqrts.v2f32(<2 x float> %lhs, <2 x float> %rhs) 13 ret <2 x float> %val 14 } 15 16 define <4 x float> @frsqrts_from_intr_v4f32(<4 x float> %lhs, <4 x float> %rhs) { 17 ; Using registers other than v0, v1 are possible, but would be odd. 18 ; CHECK: frsqrts v0.4s, v0.4s, v1.4s 19 %val = call <4 x float> @llvm.arm.neon.vrsqrts.v4f32(<4 x float> %lhs, <4 x float> %rhs) 20 ret <4 x float> %val 21 } 22 23 define <2 x double> @frsqrts_from_intr_v2f64(<2 x double> %lhs, <2 x double> %rhs) { 24 ; Using registers other than v0, v1 are possible, but would be odd. 25 ; CHECK: frsqrts v0.2d, v0.2d, v1.2d 26 %val = call <2 x double> @llvm.arm.neon.vrsqrts.v2f64(<2 x double> %lhs, <2 x double> %rhs) 27 ret <2 x double> %val 28 } 29 30 declare <2 x float> @llvm.arm.neon.vrecps.v2f32(<2 x float>, <2 x float>) 31 declare <4 x float> @llvm.arm.neon.vrecps.v4f32(<4 x float>, <4 x float>) 32 declare <2 x double> @llvm.arm.neon.vrecps.v2f64(<2 x double>, <2 x double>) 33 34 define <2 x float> @frecps_from_intr_v2f32(<2 x float> %lhs, <2 x float> %rhs) { 35 ; Using registers other than v0, v1 are possible, but would be odd. 36 ; CHECK: frecps v0.2s, v0.2s, v1.2s 37 %val = call <2 x float> @llvm.arm.neon.vrecps.v2f32(<2 x float> %lhs, <2 x float> %rhs) 38 ret <2 x float> %val 39 } 40 41 define <4 x float> @frecps_from_intr_v4f32(<4 x float> %lhs, <4 x float> %rhs) { 42 ; Using registers other than v0, v1 are possible, but would be odd. 43 ; CHECK: frecps v0.4s, v0.4s, v1.4s 44 %val = call <4 x float> @llvm.arm.neon.vrecps.v4f32(<4 x float> %lhs, <4 x float> %rhs) 45 ret <4 x float> %val 46 } 47 48 define <2 x double> @frecps_from_intr_v2f64(<2 x double> %lhs, <2 x double> %rhs) { 49 ; Using registers other than v0, v1 are possible, but would be odd. 50 ; CHECK: frecps v0.2d, v0.2d, v1.2d 51 %val = call <2 x double> @llvm.arm.neon.vrecps.v2f64(<2 x double> %lhs, <2 x double> %rhs) 52 ret <2 x double> %val 53 } 54 55