aboutsummaryrefslogtreecommitdiff
path: root/gost_grasshopper_math.h
diff options
context:
space:
mode:
authorDmitry Belyavskiy <beldmit@gmail.com>2020-09-18 16:27:41 +0300
committerDmitry Belyavskiy <beldmit@gmail.com>2020-09-18 16:27:41 +0300
commit1997dd99db27383a89d1f91bd4d7091b553ca6ee (patch)
tree9638380c656aa304b1d5f5275ecac14531db8b43 /gost_grasshopper_math.h
parentf1f47c6c7710291157aa863768d9048aaeaa9530 (diff)
downloadgost-engine-1997dd99db27383a89d1f91bd4d7091b553ca6ee.zip
gost-engine-1997dd99db27383a89d1f91bd4d7091b553ca6ee.tar.gz
gost-engine-1997dd99db27383a89d1f91bd4d7091b553ca6ee.tar.bz2
Strict alignment Kuznyechik bugfix
Diffstat (limited to 'gost_grasshopper_math.h')
-rw-r--r--gost_grasshopper_math.h6
1 files changed, 6 insertions, 0 deletions
diff --git a/gost_grasshopper_math.h b/gost_grasshopper_math.h
index 43341a8..87d1265 100644
--- a/gost_grasshopper_math.h
+++ b/gost_grasshopper_math.h
@@ -77,9 +77,15 @@ static GRASSHOPPER_INLINE void grasshopper_copy128(grasshopper_w128_t* to, const
static GRASSHOPPER_INLINE void grasshopper_append128(grasshopper_w128_t* x, const grasshopper_w128_t* y) {
int i;
+#ifdef STRICT_ALIGNMENT
+ for (i = 0; i < 16; i++) {
+ GRASSHOPPER_ACCESS_128_VALUE_8(*x, i) ^= GRASSHOPPER_ACCESS_128_VALUE_8(*y, i);
+ }
+#else
for (i = 0; i < GRASSHOPPER_BIT_PARTS; i++) {
GRASSHOPPER_ACCESS_128_VALUE(*x, i) ^= GRASSHOPPER_ACCESS_128_VALUE(*y, i);
}
+#endif
}
static GRASSHOPPER_INLINE void grasshopper_plus128(grasshopper_w128_t* result, const grasshopper_w128_t* x,