mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-01-31 11:37:35 +00:00
39bf41f4eb
- Python static hello world now 1.8mb - Python static fully loaded now 10mb - Python HTTPS client now uses MbedTLS - Python REPL now completes import stmts - Increase stack size for Python for now - Begin synthesizing posixpath and ntpath - Restore Python \N{UNICODE NAME} support - Restore Python NFKD symbol normalization - Add optimized code path for Intel SHA-NI - Get more Python unit tests passing faster - Get Python help() pagination working on NT - Python hashlib now supports MbedTLS PBKDF2 - Make memcpy/memmove/memcmp/bcmp/etc. faster - Add Mersenne Twister and Vigna to LIBC_RAND - Provide privileged __printf() for error code - Fix zipos opendir() so that it reports ENOTDIR - Add basic chmod() implementation for Windows NT - Add Cosmo's best functions to Python cosmo module - Pin function trace indent depth to that of caller - Show memory diagram on invalid access in MODE=dbg - Differentiate stack overflow on crash in MODE=dbg - Add stb_truetype and tools for analyzing font files - Upgrade to UNICODE 13 and reduce its binary footprint - COMPILE.COM now logs resource usage of build commands - Start implementing basic poll() support on bare metal - Set getauxval(AT_EXECFN) to GetModuleFileName() on NT - Add descriptions to strerror() in non-TINY build modes - Add COUNTBRANCH() macro to help with micro-optimizations - Make error / backtrace / asan / memory code more unbreakable - Add fast perfect C implementation of μ-Law and a-Law audio codecs - Make strtol() functions consistent with other libc implementations - Improve Linenoise implementation (see also github.com/jart/bestline) - COMPILE.COM now suppresses stdout/stderr of successful build commands
39 lines
2.1 KiB
C
39 lines
2.1 KiB
C
#ifndef BLAKE_ROUND_MKA_H
|
|
#define BLAKE_ROUND_MKA_H
|
|
#include "third_party/argon2/blake2-impl.h"
|
|
#include "third_party/argon2/blake2.h"
|
|
/* clang-format off */
|
|
|
|
/* designed by the Lyra PHC team */
|
|
static inline uint64_t fBlaMka(uint64_t x, uint64_t y) {
|
|
const uint64_t m = UINT64_C(0xFFFFFFFF);
|
|
const uint64_t xy = (x & m) * (y & m);
|
|
return x + y + 2 * xy;
|
|
}
|
|
|
|
#define G(a, b, c, d) \
|
|
do { \
|
|
a = fBlaMka(a, b); \
|
|
d = rotr64(d ^ a, 32); \
|
|
c = fBlaMka(c, d); \
|
|
b = rotr64(b ^ c, 24); \
|
|
a = fBlaMka(a, b); \
|
|
d = rotr64(d ^ a, 16); \
|
|
c = fBlaMka(c, d); \
|
|
b = rotr64(b ^ c, 63); \
|
|
} while ((void)0, 0)
|
|
|
|
#define BLAKE2_ROUND_NOMSG(v0, v1, v2, v3, v4, v5, v6, v7, v8, v9, v10, v11, \
|
|
v12, v13, v14, v15) \
|
|
do { \
|
|
G(v0, v4, v8, v12); \
|
|
G(v1, v5, v9, v13); \
|
|
G(v2, v6, v10, v14); \
|
|
G(v3, v7, v11, v15); \
|
|
G(v0, v5, v10, v15); \
|
|
G(v1, v6, v11, v12); \
|
|
G(v2, v7, v8, v13); \
|
|
G(v3, v4, v9, v14); \
|
|
} while ((void)0, 0)
|
|
|
|
#endif /* BLAKE_ROUND_MKA_H */
|