xref: /freebsd/contrib/llvm-project/clang/lib/Headers/riscv_bitmanip.h (revision f5f40dd63bc7acbb5312b26ac1ea1103c12352a6)
1 /*===---- riscv_bitmanip.h - RISC-V Zb* intrinsics --------------------------===
2  *
3  * Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4  * See https://llvm.org/LICENSE.txt for license information.
5  * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6  *
7  *===-----------------------------------------------------------------------===
8  */
9 
10 #ifndef __RISCV_BITMANIP_H
11 #define __RISCV_BITMANIP_H
12 
13 #include <stdint.h>
14 
15 #if defined(__cplusplus)
16 extern "C" {
17 #endif
18 
19 #if defined(__riscv_zbb)
20 static __inline__ uint32_t __attribute__((__always_inline__, __nodebug__))
21 __riscv_orc_b_32(uint32_t __x) {
22   return __builtin_riscv_orc_b_32(__x);
23 }
24 
25 static __inline__ unsigned __attribute__((__always_inline__, __nodebug__))
26 __riscv_clz_32(uint32_t __x) {
27   return __builtin_riscv_clz_32(__x);
28 }
29 
30 static __inline__ unsigned __attribute__((__always_inline__, __nodebug__))
31 __riscv_ctz_32(uint32_t __x) {
32   return __builtin_riscv_ctz_32(__x);
33 }
34 
35 static __inline__ unsigned __attribute__((__always_inline__, __nodebug__))
36 __riscv_cpop_32(uint32_t __x) {
37   return __builtin_popcount(__x);
38 }
39 
40 #if __riscv_xlen == 64
41 static __inline__ uint64_t __attribute__((__always_inline__, __nodebug__))
42 __riscv_orc_b_64(uint64_t __x) {
43   return __builtin_riscv_orc_b_64(__x);
44 }
45 
46 static __inline__ unsigned __attribute__((__always_inline__, __nodebug__))
47 __riscv_clz_64(uint64_t __x) {
48   return __builtin_riscv_clz_64(__x);
49 }
50 
51 static __inline__ unsigned __attribute__((__always_inline__, __nodebug__))
52 __riscv_ctz_64(uint64_t __x) {
53   return __builtin_riscv_ctz_64(__x);
54 }
55 
56 static __inline__ unsigned __attribute__((__always_inline__, __nodebug__))
57 __riscv_cpop_64(uint64_t __x) {
58   return __builtin_popcountll(__x);
59 }
60 #endif
61 #endif // defined(__riscv_zbb)
62 
63 #if defined(__riscv_zbb) || defined(__riscv_zbkb)
64 static __inline__ uint32_t __attribute__((__always_inline__, __nodebug__))
65 __riscv_rev8_32(uint32_t __x) {
66   return __builtin_bswap32(__x);
67 }
68 
69 static __inline__ uint32_t __attribute__((__always_inline__, __nodebug__))
70 __riscv_rol_32(uint32_t __x, uint32_t __y) {
71   return __builtin_rotateleft32(__x, __y);
72 }
73 
74 static __inline__ uint32_t __attribute__((__always_inline__, __nodebug__))
75 __riscv_ror_32(uint32_t __x, uint32_t __y) {
76   return __builtin_rotateright32(__x, __y);
77 }
78 
79 #if __riscv_xlen == 64
80 static __inline__ uint64_t __attribute__((__always_inline__, __nodebug__))
81 __riscv_rev8_64(uint64_t __x) {
82   return __builtin_bswap64(__x);
83 }
84 
85 static __inline__ uint64_t __attribute__((__always_inline__, __nodebug__))
86 __riscv_rol_64(uint64_t __x, uint32_t __y) {
87   return __builtin_rotateleft64(__x, __y);
88 }
89 
90 static __inline__ uint64_t __attribute__((__always_inline__, __nodebug__))
91 __riscv_ror_64(uint64_t __x, uint32_t __y) {
92   return __builtin_rotateright64(__x, __y);
93 }
94 #endif
95 #endif // defined(__riscv_zbb) || defined(__riscv_zbkb)
96 
97 #if defined(__riscv_zbkb)
98 static __inline__ uint32_t __attribute__((__always_inline__, __nodebug__))
99 __riscv_brev8_32(uint32_t __x) {
100   return __builtin_riscv_brev8_32(__x);
101 }
102 
103 #if __riscv_xlen == 64
104 static __inline__ uint64_t __attribute__((__always_inline__, __nodebug__))
105 __riscv_brev8_64(uint64_t __x) {
106   return __builtin_riscv_brev8_64(__x);
107 }
108 #endif
109 
110 #if __riscv_xlen == 32
111 static __inline__ uint32_t __attribute__((__always_inline__, __nodebug__))
112 __riscv_unzip_32(uint32_t __x) {
113   return __builtin_riscv_unzip_32(__x);
114 }
115 
116 static __inline__ uint32_t __attribute__((__always_inline__, __nodebug__))
117 __riscv_zip_32(uint32_t __x) {
118   return __builtin_riscv_zip_32(__x);
119 }
120 #endif
121 #endif // defined(__riscv_zbkb)
122 
123 #if defined(__riscv_zbc)
124 #if __riscv_xlen == 32
125 static __inline__ uint32_t __attribute__((__always_inline__, __nodebug__))
126 __riscv_clmulr_32(uint32_t __x, uint32_t __y) {
127   return __builtin_riscv_clmulr_32(__x, __y);
128 }
129 #endif
130 
131 #if __riscv_xlen == 64
132 static __inline__ uint64_t __attribute__((__always_inline__, __nodebug__))
133 __riscv_clmulr_64(uint64_t __x, uint64_t __y) {
134   return __builtin_riscv_clmulr_64(__x, __y);
135 }
136 #endif
137 #endif // defined(__riscv_zbc)
138 
139 #if defined(__riscv_zbkc) || defined(__riscv_zbc)
140 static __inline__ uint32_t __attribute__((__always_inline__, __nodebug__))
141 __riscv_clmul_32(uint32_t __x, uint32_t __y) {
142   return __builtin_riscv_clmul_32(__x, __y);
143 }
144 
145 #if __riscv_xlen == 32
146 static __inline__ uint32_t __attribute__((__always_inline__, __nodebug__))
147 __riscv_clmulh_32(uint32_t __x, uint32_t __y) {
148   return __builtin_riscv_clmulh_32(__x, __y);
149 }
150 #endif
151 
152 #if __riscv_xlen == 64
153 static __inline__ uint64_t __attribute__((__always_inline__, __nodebug__))
154 __riscv_clmul_64(uint64_t __x, uint64_t __y) {
155   return __builtin_riscv_clmul_64(__x, __y);
156 }
157 
158 static __inline__ uint64_t __attribute__((__always_inline__, __nodebug__))
159 __riscv_clmulh_64(uint64_t __x, uint64_t __y) {
160   return __builtin_riscv_clmulh_64(__x, __y);
161 }
162 #endif
163 #endif // defined(__riscv_zbkc) || defined(__riscv_zbc)
164 
165 #if defined(__riscv_zbkx)
166 #if __riscv_xlen == 32
167 static __inline__ uint32_t __attribute__((__always_inline__, __nodebug__))
168 __riscv_xperm4_32(uint32_t __x, uint32_t __y) {
169   return __builtin_riscv_xperm4_32(__x, __y);
170 }
171 
172 static __inline__ uint32_t __attribute__((__always_inline__, __nodebug__))
173 __riscv_xperm8_32(uint32_t __x, uint32_t __y) {
174   return __builtin_riscv_xperm8_32(__x, __y);
175 }
176 #endif
177 
178 #if __riscv_xlen == 64
179 static __inline__ uint64_t __attribute__((__always_inline__, __nodebug__))
180 __riscv_xperm4_64(uint64_t __x, uint64_t __y) {
181   return __builtin_riscv_xperm4_64(__x, __y);
182 }
183 
184 static __inline__ uint64_t __attribute__((__always_inline__, __nodebug__))
185 __riscv_xperm8_64(uint64_t __x, uint64_t __y) {
186   return __builtin_riscv_xperm8_64(__x, __y);
187 }
188 #endif
189 #endif // defined(__riscv_zbkx)
190 
191 #if defined(__cplusplus)
192 }
193 #endif
194 
195 #endif
196