201b3735b3eb2002ea0a0c318f38fb20ee5de61f
[openssl.git] / crypto / ec / curve448 / arch_neon / arch_intrinsics.h
1 /*
2  * Copyright 2017 The OpenSSL Project Authors. All Rights Reserved.
3  * Copyright 2016 Cryptography Research, Inc.
4  *
5  * Licensed under the OpenSSL license (the "License").  You may not use
6  * this file except in compliance with the License.  You can obtain a copy
7  * in the file LICENSE in the source distribution or at
8  * https://www.openssl.org/source/license.html
9  *
10  * Originally written by Mike Hamburg
11  */
12
13 #ifndef __ARCH_NEON_ARCH_INTRINSICS_H__
14 # define __ARCH_NEON_ARCH_INTRINSICS_H__
15
16 # define ARCH_WORD_BITS 32
17
18 static __inline__ __attribute((always_inline, unused))
19 uint32_t word_is_zero(uint32_t a)
20 {
21     uint32_t ret;
22  __asm__("subs %0, %1, #1;\n\tsbc %0, %0, %0": "=r"(ret): "r"(a):"cc");
23     return ret;
24 }
25
26 static __inline__ __attribute((always_inline, unused))
27 uint64_t widemul(uint32_t a, uint32_t b)
28 {
29     /*
30      * Could be UMULL, but it's hard to express to CC that the registers must
31      * be different
32      */
33     return ((uint64_t)a) * b;
34 }
35
36 #endif                          /* __ARCH_NEON_ARCH_INTRINSICS_H__ */