annotate gcc/testsuite/g++.dg/other/i386-11.C @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 // PR target/80799
kono
parents:
diff changeset
2 // { dg-do compile { target i?86-*-* x86_64-*-* } }
kono
parents:
diff changeset
3 // { dg-require-effective-target c++11 }
kono
parents:
diff changeset
4 // { dg-options "-O2 -msse2" }
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 #include <xmmintrin.h>
kono
parents:
diff changeset
7 #include <emmintrin.h>
kono
parents:
diff changeset
8
kono
parents:
diff changeset
9 class alignas(16) GSVector4i
kono
parents:
diff changeset
10 {
kono
parents:
diff changeset
11 public:
kono
parents:
diff changeset
12 __m128i m;
kono
parents:
diff changeset
13
kono
parents:
diff changeset
14 explicit GSVector4i(__m128i m)
kono
parents:
diff changeset
15 {
kono
parents:
diff changeset
16 this->m = m;
kono
parents:
diff changeset
17 }
kono
parents:
diff changeset
18
kono
parents:
diff changeset
19 static void storel(void* p, const GSVector4i& v)
kono
parents:
diff changeset
20 {
kono
parents:
diff changeset
21 _mm_storel_epi64((__m128i*)p, v.m);
kono
parents:
diff changeset
22 }
kono
parents:
diff changeset
23
kono
parents:
diff changeset
24 static GSVector4i loadl(const void* p)
kono
parents:
diff changeset
25 {
kono
parents:
diff changeset
26 return GSVector4i(_mm_loadl_epi64((__m128i*)p));
kono
parents:
diff changeset
27 }
kono
parents:
diff changeset
28
kono
parents:
diff changeset
29 bool eq(const GSVector4i& v) const
kono
parents:
diff changeset
30 {
kono
parents:
diff changeset
31 return _mm_movemask_epi8(_mm_cmpeq_epi32(m, v.m)) == 0xffff;
kono
parents:
diff changeset
32 }
kono
parents:
diff changeset
33 };
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 union GIFRegTRXPOS
kono
parents:
diff changeset
37 {
kono
parents:
diff changeset
38 unsigned long long u64;
kono
parents:
diff changeset
39 void operator = (const GSVector4i& v) {GSVector4i::storel(this, v);}
kono
parents:
diff changeset
40 bool operator != (const union GIFRegTRXPOS& r) const {return !((GSVector4i)r).eq(*this);}
kono
parents:
diff changeset
41 operator GSVector4i() const {return GSVector4i::loadl(this);}
kono
parents:
diff changeset
42 };
kono
parents:
diff changeset
43
kono
parents:
diff changeset
44 extern void dummy_call();
kono
parents:
diff changeset
45 extern GIFRegTRXPOS TRXPOS;
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 void GIFRegHandlerTRXPOS(const GIFRegTRXPOS& p)
kono
parents:
diff changeset
48 {
kono
parents:
diff changeset
49 if(p != TRXPOS)
kono
parents:
diff changeset
50 {
kono
parents:
diff changeset
51 dummy_call();
kono
parents:
diff changeset
52 }
kono
parents:
diff changeset
53
kono
parents:
diff changeset
54 TRXPOS = (GSVector4i)p;
kono
parents:
diff changeset
55 }
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 // { dg-final { scan-assembler-not "%mm" } }