1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2024-12-25 15:58:08 +00:00
trezor-firmware/ed25519-donna/ed25519-donna-portable.h

33 lines
786 B
C
Raw Normal View History

2016-04-22 15:47:48 +00:00
#define mul32x32_64(a,b) (((uint64_t)(a))*(b))
2017-03-28 16:32:58 +00:00
#include <stdlib.h>
#include <string.h>
#include <stdint.h>
2016-04-22 15:47:48 +00:00
2017-05-16 18:19:58 +00:00
#ifdef __GNUC__
#define DONNA_UNUSED __attribute__((unused))
#else
#define DONNA_UNUSED
#endif
#define DONNA_INLINE
2017-03-28 16:32:58 +00:00
#undef ALIGN
#define ALIGN(x) __attribute__((aligned(x)))
#define ROTL32(a,b) (((a) << (b)) | ((a) >> (32 - b)))
#define ROTR32(a,b) (((a) >> (b)) | ((a) << (32 - b)))
2016-04-22 15:47:48 +00:00
static inline void U32TO8_LE(unsigned char *p, const uint32_t v) {
p[0] = (unsigned char)(v );
p[1] = (unsigned char)(v >> 8);
p[2] = (unsigned char)(v >> 16);
p[3] = (unsigned char)(v >> 24);
}
static inline uint32_t U8TO32_LE(const unsigned char *p) {
return
2017-03-28 16:32:58 +00:00
(((uint32_t)(p[0]) ) |
2016-04-22 15:47:48 +00:00
((uint32_t)(p[1]) << 8) |
((uint32_t)(p[2]) << 16) |
((uint32_t)(p[3]) << 24));
}