2015-08-30 01:13:40 +08:00
|
|
|
// REQUIRES: x86-registered-target
|
2015-10-14 13:40:21 +08:00
|
|
|
// RUN: %clang_cc1 %s -triple=x86_64-unknown-unknown -target-feature +3dnow -emit-llvm -o - -Werror | FileCheck %s
|
|
|
|
// RUN: %clang_cc1 %s -triple=x86_64-unknown-unknown -target-feature +3dnow -S -o - -Werror | FileCheck %s --check-prefix=CHECK-ASM
|
2012-02-20 15:35:45 +08:00
|
|
|
|
|
|
|
// Don't include mm_malloc.h, it's system specific.
|
|
|
|
#define __MM_MALLOC_H
|
|
|
|
|
|
|
|
#include <x86intrin.h>
|
|
|
|
|
|
|
|
__m64 test_m_pavgusb(__m64 m1, __m64 m2) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pavgusb
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnow.pavgusb
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pavgusb %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pavgusb(m1, m2);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pf2id(__m64 m) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pf2id
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnow.pf2id
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pf2id %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pf2id(m);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pfacc(__m64 m1, __m64 m2) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pfacc
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnow.pfacc
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pfacc %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pfacc(m1, m2);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pfadd(__m64 m1, __m64 m2) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pfadd
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnow.pfadd
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pfadd %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pfadd(m1, m2);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pfcmpeq(__m64 m1, __m64 m2) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pfcmpeq
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnow.pfcmpeq
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pfcmpeq %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pfcmpeq(m1, m2);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pfcmpge(__m64 m1, __m64 m2) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pfcmpge
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnow.pfcmpge
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pfcmpge %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pfcmpge(m1, m2);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pfcmpgt(__m64 m1, __m64 m2) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pfcmpgt
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnow.pfcmpgt
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pfcmpgt %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pfcmpgt(m1, m2);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pfmax(__m64 m1, __m64 m2) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pfmax
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnow.pfmax
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pfmax %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pfmax(m1, m2);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pfmin(__m64 m1, __m64 m2) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pfmin
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnow.pfmin
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pfmin %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pfmin(m1, m2);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pfmul(__m64 m1, __m64 m2) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pfmul
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnow.pfmul
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pfmul %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pfmul(m1, m2);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pfrcp(__m64 m) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pfrcp
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnow.pfrcp
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pfrcp %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pfrcp(m);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pfrcpit1(__m64 m1, __m64 m2) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pfrcpit1
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnow.pfrcpit1
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pfrcpit1 %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pfrcpit1(m1, m2);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pfrcpit2(__m64 m1, __m64 m2) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pfrcpit2
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnow.pfrcpit2
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pfrcpit2 %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pfrcpit2(m1, m2);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pfrsqrt(__m64 m) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pfrsqrt
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnow.pfrsqrt
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pfrsqrt %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pfrsqrt(m);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pfrsqrtit1(__m64 m1, __m64 m2) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pfrsqrtit1
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnow.pfrsqit1
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pfrsqit1 %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pfrsqrtit1(m1, m2);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pfsub(__m64 m1, __m64 m2) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pfsub
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnow.pfsub
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pfsub %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pfsub(m1, m2);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pfsubr(__m64 m1, __m64 m2) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pfsubr
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnow.pfsubr
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pfsubr %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pfsubr(m1, m2);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pi2fd(__m64 m) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pi2fd
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnow.pi2fd
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pi2fd %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pi2fd(m);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pmulhrw(__m64 m1, __m64 m2) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pmulhrw
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnow.pmulhrw
|
|
|
|
return _m_pmulhrw(m1, m2);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pf2iw(__m64 m) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pf2iw
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnowa.pf2iw
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pf2iw %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pf2iw(m);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pfnacc(__m64 m1, __m64 m2) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pfnacc
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnowa.pfnacc
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pfnacc %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pfnacc(m1, m2);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pfpnacc(__m64 m1, __m64 m2) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pfpnacc
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnowa.pfpnacc
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pfpnacc %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pfpnacc(m1, m2);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pi2fw(__m64 m) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pi2fw
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnowa.pi2fw
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pi2fw %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pi2fw(m);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pswapdsf(__m64 m) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pswapdsf
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnowa.pswapd
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pswapd %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pswapdsf(m);
|
|
|
|
}
|
|
|
|
|
|
|
|
__m64 test_m_pswapdsi(__m64 m) {
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define i64 @test_m_pswapdsi
|
2012-02-20 15:35:45 +08:00
|
|
|
// CHECK: @llvm.x86.3dnowa.pswapd
|
2015-08-30 01:13:40 +08:00
|
|
|
// CHECK-ASM: pswapd %mm{{.*}}, %mm{{.*}}
|
2012-02-20 15:35:45 +08:00
|
|
|
return _m_pswapdsi(m);
|
|
|
|
}
|