annotate gcc/testsuite/gcc.target/arm/bfloat16_scalar_2_2.c @ 152:2b5abeee2509

update gcc11
author anatofuz
date Mon, 25 May 2020 07:50:57 +0900
parents 1830386684a0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
145
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
1 /* { dg-do assemble { target { arm*-*-* } } } */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
2 /* { dg-require-effective-target arm_v8_neon_ok } */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
3 /* { dg-require-effective-target arm_v8_2a_bf16_neon_ok } */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
4 /* { dg-additional-options "-march=armv8.2-a -mfloat-abi=softfp -mfpu=neon-fp-armv8" } */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
5 /* { dg-additional-options "-O3 --save-temps -std=gnu90" } */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
6 /* { dg-final { check-function-bodies "**" "" } } */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
7
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
8 #include <arm_bf16.h>
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
9
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
10 #pragma GCC push_options
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
11 #pragma GCC target ("+bf16")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
12
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
13 /*
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
14 **stacktest1:
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
15 ** ...
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
16 ** strh r[0-9]+, \[r[0-9]+\] @ __bf16
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
17 ** ldrh r[0-9]+, \[sp, #[0-9]+\] @ __bf16
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
18 ** ...
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
19 ** bx lr
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
20 */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
21 bfloat16_t stacktest1 (bfloat16_t __a)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
22 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
23 volatile bfloat16_t b = __a;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
24 return b;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
25 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
26
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
27 /*
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
28 **bfloat_mov_ww:
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
29 ** ...
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
30 ** vmov.f32 s1, s15
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
31 ** ...
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
32 ** bx lr
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
33 */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
34 void bfloat_mov_ww (void)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
35 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
36 register bfloat16_t x asm ("s15");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
37 register bfloat16_t y asm ("s1");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
38 asm volatile ("#foo" : "=t" (x));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
39 y = x;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
40 asm volatile ("#foo" :: "t" (y));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
41 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
42
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
43 /*
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
44 **bfloat_mov_rw:
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
45 ** ...
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
46 ** vmov s1, r4
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
47 ** ...
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
48 ** bx lr
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
49 */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
50 void bfloat_mov_rw (void)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
51 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
52 register bfloat16_t x asm ("r4");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
53 register bfloat16_t y asm ("s1");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
54 asm volatile ("#foo" : "=r" (x));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
55 y = x;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
56 asm volatile ("#foo" :: "t" (y));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
57 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
58
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
59 /*
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
60 **bfloat_mov_wr:
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
61 ** ...
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
62 ** vmov r4, s1
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
63 ** ...
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
64 ** bx lr
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
65 */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
66 void bfloat_mov_wr (void)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
67 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
68 register bfloat16_t x asm ("s1");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
69 register bfloat16_t y asm ("r4");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
70 asm volatile ("#foo" : "=t" (x));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
71 y = x;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
72 asm volatile ("#foo" :: "r" (y));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
73 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
74
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
75 /*
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
76 **bfloat_mov_rr:
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
77 ** ...
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
78 ** mov r4, r5 @ __bf16
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
79 ** ...
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
80 ** bx lr
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
81 */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
82 void bfloat_mov_rr (void)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
83 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
84 register bfloat16_t x asm ("r5");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
85 register bfloat16_t y asm ("r4");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
86 asm volatile ("#foo" : "=r" (x));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
87 y = x;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
88 asm volatile ("#foo" :: "r" (y));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
89 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
90
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
91 /*
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
92 **bfloat_mov_rm:
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
93 ** ...
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
94 ** strh r4, \[.*\] @ __bf16
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
95 ** ...
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
96 ** bx lr
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
97 */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
98 void bfloat_mov_rm (void)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
99 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
100 register bfloat16_t x asm ("r4");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
101 volatile bfloat16_t y;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
102 asm volatile ("#foo" : "=r" (x));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
103 y = x;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
104 asm volatile ("#foo" : : : "memory");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
105 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
106
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
107 /*
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
108 **bfloat_mov_mr:
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
109 ** ...
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
110 ** ldrh r4, \[.*\] @ __bf16
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
111 ** ...
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
112 ** bx lr
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
113 */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
114 void bfloat_mov_mr (void)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
115 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
116 volatile bfloat16_t x;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
117 register bfloat16_t y asm ("r4");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
118 asm volatile ("#foo" : : : "memory");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
119 y = x;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
120 asm volatile ("#foo" :: "r" (y));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
121 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
122
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
123 #pragma GCC pop_options
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
124