annotate gcc/testsuite/g++.dg/opt/pr66119.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 /* PR66119 - MOVE_RATIO is not constant in a compiler run, so Scalar
kono
parents:
diff changeset
2 Reduction of Aggregates must ask the back-end more than once what
kono
parents:
diff changeset
3 the value of MOVE_RATIO now is. */
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 /* { dg-do compile { target { { i?86-*-* x86_64-*-* } && c++11 } } } */
kono
parents:
diff changeset
6 /* { dg-options "-O3 -mavx -fdump-tree-sra -march=slm -mtune=slm" } */
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 #include <immintrin.h>
kono
parents:
diff changeset
9
kono
parents:
diff changeset
10 class MyAVX
kono
parents:
diff changeset
11 {
kono
parents:
diff changeset
12 __m256d data;
kono
parents:
diff changeset
13 public:
kono
parents:
diff changeset
14 MyAVX () = default;
kono
parents:
diff changeset
15 MyAVX (const MyAVX &) = default;
kono
parents:
diff changeset
16 MyAVX (__m256d _data) : data(_data) { ; }
kono
parents:
diff changeset
17
kono
parents:
diff changeset
18 MyAVX & operator= (const MyAVX &) = default;
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 operator __m256d () const { return data; }
kono
parents:
diff changeset
21 MyAVX operator+ (MyAVX s2) { return data+s2.data; }
kono
parents:
diff changeset
22 };
kono
parents:
diff changeset
23
kono
parents:
diff changeset
24 template <typename T> class AVX_trait { ; };
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 template <> class AVX_trait<double> {
kono
parents:
diff changeset
27 public:
kono
parents:
diff changeset
28 typedef __m256d TSIMD;
kono
parents:
diff changeset
29 };
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 template <typename T>
kono
parents:
diff changeset
33 class MyTSIMD
kono
parents:
diff changeset
34 {
kono
parents:
diff changeset
35 typename AVX_trait<T>::TSIMD data;
kono
parents:
diff changeset
36
kono
parents:
diff changeset
37 public:
kono
parents:
diff changeset
38 MyTSIMD () = default;
kono
parents:
diff changeset
39 MyTSIMD (const MyTSIMD &) = default;
kono
parents:
diff changeset
40 // MyTSIMD (const MyTSIMD & s2) : data(s2.data) { ; }
kono
parents:
diff changeset
41 MyTSIMD (typename AVX_trait<T>::TSIMD _data) : data(_data) { ; }
kono
parents:
diff changeset
42
kono
parents:
diff changeset
43 operator typename AVX_trait<T>::TSIMD() const { return data; }
kono
parents:
diff changeset
44 MyTSIMD operator+ (MyTSIMD s2) { return data+s2.data; }
kono
parents:
diff changeset
45 };
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 // using MyVec = MyAVX;
kono
parents:
diff changeset
48 using MyVec = MyTSIMD<double>;
kono
parents:
diff changeset
49
kono
parents:
diff changeset
50 class Vec2
kono
parents:
diff changeset
51 {
kono
parents:
diff changeset
52 MyVec a, b;
kono
parents:
diff changeset
53 public:
kono
parents:
diff changeset
54 Vec2 (MyVec aa, MyVec ab) : a(aa), b(ab) { ; }
kono
parents:
diff changeset
55 Vec2 operator+ (Vec2 v2) { return Vec2(a+v2.a, b+v2.b); }
kono
parents:
diff changeset
56 };
kono
parents:
diff changeset
57
kono
parents:
diff changeset
58 inline __attribute__ ((__always_inline__))
kono
parents:
diff changeset
59 Vec2 ComputeSomething (Vec2 a, Vec2 b)
kono
parents:
diff changeset
60 {
kono
parents:
diff changeset
61 return a+b;
kono
parents:
diff changeset
62 }
kono
parents:
diff changeset
63
kono
parents:
diff changeset
64 Vec2 TestFunction (Vec2 a, Vec2 b)
kono
parents:
diff changeset
65 {
kono
parents:
diff changeset
66 return ComputeSomething (a,b);
kono
parents:
diff changeset
67 }
kono
parents:
diff changeset
68
kono
parents:
diff changeset
69 /* { dg-final { scan-tree-dump "Created a replacement for b" "sra" } } */