blob: c6cae4d5b380bd13a16bc63c7743d70dfb537d64 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
/* { dg-do compile } */
/* { dg-options "-g -Os" } */
#include "arm_neon.h"
extern void bar (int32x4_t);
void
foo ()
{
int32x4x4_t rows;
uint64x2x2_t row01;
row01.val[0] = vreinterpretq_u64_s32 (rows.val[0]);
row01.val[1] = vreinterpretq_u64_s32 (rows.val[1]);
uint64x1_t row3l = vget_low_u64 (row01.val[0]);
row01.val[0] = vcombine_u64 (vget_low_u64 (row01.val[1]), row3l);
int32x4_t xxx = vreinterpretq_s32_u64 (row01.val[0]);
int32x4_t out = vtrn1q_s32 (xxx, xxx);
bar (out);
}
/* { dg-do compile } */
/* { dg-options "-g -Os" } */
#include "arm_neon.h"
extern void bar (int32x4_t);
void
foo ()
{
int32x4x4_t rows;
uint64x2x2_t row01;
row01.val[0] = vreinterpretq_u64_s32 (rows.val[0]);
row01.val[1] = vreinterpretq_u64_s32 (rows.val[1]);
uint64x1_t row3l = vget_low_u64 (row01.val[0]);
row01.val[0] = vcombine_u64 (vget_low_u64 (row01.val[1]), row3l);
int32x4_t xxx = vreinterpretq_s32_u64 (row01.val[0]);
int32x4_t out = vtrn1q_s32 (xxx, xxx);
bar (out);
}
|