16bcf27bb9a4b5c3f79cb44c0e4654a6d7619ad89Stephen Hines// RUN: %clang_cc1 -O1 -triple arm64-apple-ios7 -target-feature +neon -ffreestanding -S -o - -emit-llvm %s | FileCheck %s 2651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines// Test ARM64 SIMD comparison test intrinsics 3651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines 4651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines#include <arm_neon.h> 5651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines 6651f13cea278ec967336033dd032faef0e9fc2ecStephen Hinesuint64x2_t test_vtstq_s64(int64x2_t a1, int64x2_t a2) { 7651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines // CHECK: test_vtstq_s64 8651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines return vtstq_s64(a1, a2); 9651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines // CHECK: [[COMMONBITS:%[A-Za-z0-9.]+]] = and <2 x i64> %a1, %a2 10651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines // CHECK: [[MASK:%[A-Za-z0-9.]+]] = icmp ne <2 x i64> [[COMMONBITS]], zeroinitializer 11651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines // CHECK: [[RES:%[A-Za-z0-9.]+]] = sext <2 x i1> [[MASK]] to <2 x i64> 12651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines // CHECK: ret <2 x i64> [[RES]] 13651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines} 14651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines 15651f13cea278ec967336033dd032faef0e9fc2ecStephen Hinesuint64x2_t test_vtstq_u64(uint64x2_t a1, uint64x2_t a2) { 16651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines // CHECK: test_vtstq_u64 17651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines return vtstq_u64(a1, a2); 18651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines // CHECK: [[COMMONBITS:%[A-Za-z0-9.]+]] = and <2 x i64> %a1, %a2 19651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines // CHECK: [[MASK:%[A-Za-z0-9.]+]] = icmp ne <2 x i64> [[COMMONBITS]], zeroinitializer 20651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines // CHECK: [[RES:%[A-Za-z0-9.]+]] = sext <2 x i1> [[MASK]] to <2 x i64> 21651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines // CHECK: ret <2 x i64> [[RES]] 22651f13cea278ec967336033dd032faef0e9fc2ecStephen Hines} 23