abcd22bf62
Reviewed-by: Bernd Edlinger <bernd.edlinger@hotmail.de> (Merged from https://github.com/openssl/openssl/pull/5105)
24 lines
719 B
C
24 lines
719 B
C
/* Copyright (c) 2016 Cryptography Research, Inc.
|
|
* Released under the MIT License. See LICENSE.txt for license information.
|
|
*/
|
|
|
|
#ifndef __ARCH_ARM_32_ARCH_INTRINSICS_H__
|
|
#define __ARCH_ARM_32_ARCH_INTRINSICS_H__
|
|
|
|
#define ARCH_WORD_BITS 32
|
|
|
|
static __inline__ __attribute((always_inline,unused))
|
|
uint32_t word_is_zero(uint32_t a) {
|
|
uint32_t ret;
|
|
asm("subs %0, %1, #1;\n\tsbc %0, %0, %0" : "=r"(ret) : "r"(a) : "cc");
|
|
return ret;
|
|
}
|
|
|
|
static __inline__ __attribute((always_inline,unused))
|
|
uint64_t widemul(uint32_t a, uint32_t b) {
|
|
/* Could be UMULL, but it's hard to express to CC that the registers must be different */
|
|
return ((uint64_t)a) * b;
|
|
}
|
|
|
|
#endif /* __ARCH_ARM_32_ARCH_INTRINSICS_H__ */
|
|
|