2021-09-15 23:57:18 +00:00
|
|
|
#ifndef PORTABLE_BLAKE2_IMPL_H
|
|
|
|
#define PORTABLE_BLAKE2_IMPL_H
|
2021-09-28 05:58:51 +00:00
|
|
|
#include "libc/str/str.h"
|
|
|
|
/* clang-format off */
|
2021-09-15 23:57:18 +00:00
|
|
|
|
2021-09-28 05:58:51 +00:00
|
|
|
static inline uint64_t load64(const void *src) {
|
|
|
|
#if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
|
2021-09-15 23:57:18 +00:00
|
|
|
uint64_t w;
|
|
|
|
memcpy(&w, src, sizeof w);
|
|
|
|
return w;
|
|
|
|
#else
|
|
|
|
const uint8_t *p = (const uint8_t *)src;
|
|
|
|
uint64_t w = *p++;
|
|
|
|
w |= (uint64_t)(*p++) << 8;
|
|
|
|
w |= (uint64_t)(*p++) << 16;
|
|
|
|
w |= (uint64_t)(*p++) << 24;
|
|
|
|
w |= (uint64_t)(*p++) << 32;
|
|
|
|
w |= (uint64_t)(*p++) << 40;
|
|
|
|
w |= (uint64_t)(*p++) << 48;
|
|
|
|
w |= (uint64_t)(*p++) << 56;
|
|
|
|
return w;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2021-09-28 05:58:51 +00:00
|
|
|
static inline void store32(void *dst, uint32_t w) {
|
|
|
|
#if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
|
2021-09-15 23:57:18 +00:00
|
|
|
memcpy(dst, &w, sizeof w);
|
|
|
|
#else
|
|
|
|
uint8_t *p = (uint8_t *)dst;
|
|
|
|
*p++ = (uint8_t)w;
|
|
|
|
w >>= 8;
|
|
|
|
*p++ = (uint8_t)w;
|
|
|
|
w >>= 8;
|
|
|
|
*p++ = (uint8_t)w;
|
|
|
|
w >>= 8;
|
|
|
|
*p++ = (uint8_t)w;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2021-09-28 05:58:51 +00:00
|
|
|
static inline void store64(void *dst, uint64_t w) {
|
|
|
|
#if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
|
2021-09-15 23:57:18 +00:00
|
|
|
memcpy(dst, &w, sizeof w);
|
|
|
|
#else
|
|
|
|
uint8_t *p = (uint8_t *)dst;
|
|
|
|
*p++ = (uint8_t)w;
|
|
|
|
w >>= 8;
|
|
|
|
*p++ = (uint8_t)w;
|
|
|
|
w >>= 8;
|
|
|
|
*p++ = (uint8_t)w;
|
|
|
|
w >>= 8;
|
|
|
|
*p++ = (uint8_t)w;
|
|
|
|
w >>= 8;
|
|
|
|
*p++ = (uint8_t)w;
|
|
|
|
w >>= 8;
|
|
|
|
*p++ = (uint8_t)w;
|
|
|
|
w >>= 8;
|
|
|
|
*p++ = (uint8_t)w;
|
|
|
|
w >>= 8;
|
|
|
|
*p++ = (uint8_t)w;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2021-09-28 05:58:51 +00:00
|
|
|
static inline uint64_t load48(const void *src) {
|
2021-09-15 23:57:18 +00:00
|
|
|
const uint8_t *p = (const uint8_t *)src;
|
|
|
|
uint64_t w = *p++;
|
|
|
|
w |= (uint64_t)(*p++) << 8;
|
|
|
|
w |= (uint64_t)(*p++) << 16;
|
|
|
|
w |= (uint64_t)(*p++) << 24;
|
|
|
|
w |= (uint64_t)(*p++) << 32;
|
|
|
|
w |= (uint64_t)(*p++) << 40;
|
|
|
|
return w;
|
|
|
|
}
|
|
|
|
|
2021-09-28 05:58:51 +00:00
|
|
|
static inline void store48(void *dst, uint64_t w) {
|
2021-09-15 23:57:18 +00:00
|
|
|
uint8_t *p = (uint8_t *)dst;
|
|
|
|
*p++ = (uint8_t)w;
|
|
|
|
w >>= 8;
|
|
|
|
*p++ = (uint8_t)w;
|
|
|
|
w >>= 8;
|
|
|
|
*p++ = (uint8_t)w;
|
|
|
|
w >>= 8;
|
|
|
|
*p++ = (uint8_t)w;
|
|
|
|
w >>= 8;
|
|
|
|
*p++ = (uint8_t)w;
|
|
|
|
w >>= 8;
|
|
|
|
*p++ = (uint8_t)w;
|
|
|
|
}
|
|
|
|
|
2021-09-28 05:58:51 +00:00
|
|
|
static inline uint32_t rotr32(const uint32_t w, const unsigned c) {
|
2021-09-15 23:57:18 +00:00
|
|
|
return (w >> c) | (w << (32 - c));
|
|
|
|
}
|
|
|
|
|
2021-09-28 05:58:51 +00:00
|
|
|
static inline uint64_t rotr64(const uint64_t w, const unsigned c) {
|
2021-09-15 23:57:18 +00:00
|
|
|
return (w >> c) | (w << (64 - c));
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|