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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
|
/* { dg-do run } */
/* { dg-require-effective-target arm_mve_hw } */
/* { dg-options "-O2" } */
/* { dg-add-options arm_v8_1m_mve } */
#include <arm_mve.h>
volatile int32x4_t c1;
volatile uint32x4_t c2;
int *carry;
int
main ()
{
int32x4_t a1 = vcreateq_s32 (0, 0);
int32x4_t b1 = vcreateq_s32 (0, 0);
int32x4_t inactive1 = vcreateq_s32 (0, 0);
uint32x4_t a2 = vcreateq_u32 (0, 0);
uint32x4_t b2 = vcreateq_u32 (0, 0);
uint32x4_t inactive2 = vcreateq_u32 (0, 0);
mve_pred16_t p = 0xFFFF;
(*carry) = 0xFFFFFFFF;
__builtin_arm_set_fpscr_nzcvqc (0);
c1 = vadcq (a1, b1, carry);
if (__builtin_arm_get_fpscr_nzcvqc () & !0x20000000)
__builtin_abort ();
(*carry) = 0xFFFFFFFF;
__builtin_arm_set_fpscr_nzcvqc (0);
c2 = vadcq (a2, b2, carry);
if (__builtin_arm_get_fpscr_nzcvqc () & !0x20000000)
__builtin_abort ();
(*carry) = 0xFFFFFFFF;
__builtin_arm_set_fpscr_nzcvqc (0);
c1 = vsbcq (a1, b1, carry);
if (__builtin_arm_get_fpscr_nzcvqc () & !0x20000000)
__builtin_abort ();
(*carry) = 0xFFFFFFFF;
__builtin_arm_set_fpscr_nzcvqc (0);
c2 = vsbcq (a2, b2, carry);
if (__builtin_arm_get_fpscr_nzcvqc () & !0x20000000)
__builtin_abort ();
(*carry) = 0xFFFFFFFF;
__builtin_arm_set_fpscr_nzcvqc (0);
c1 = vadcq_m (inactive1, a1, b1, carry, p);
if (__builtin_arm_get_fpscr_nzcvqc () & !0x20000000)
__builtin_abort ();
(*carry) = 0xFFFFFFFF;
__builtin_arm_set_fpscr_nzcvqc (0);
c2 = vadcq_m (inactive2, a2, b2, carry, p);
if (__builtin_arm_get_fpscr_nzcvqc () & !0x20000000)
__builtin_abort ();
(*carry) = 0xFFFFFFFF;
__builtin_arm_set_fpscr_nzcvqc (0);
c1 = vsbcq_m (inactive1, a1, b1, carry, p);
if (__builtin_arm_get_fpscr_nzcvqc () & !0x20000000)
__builtin_abort ();
(*carry) = 0xFFFFFFFF;
__builtin_arm_set_fpscr_nzcvqc (0);
c2 = vsbcq_m (inactive2, a2, b2, carry, p);
if (__builtin_arm_get_fpscr_nzcvqc () & !0x20000000)
__builtin_abort ();
return 0;
}
|