]> git.cryptolib.org Git - avr-crypto-lib.git/blobdiff - bmw/bmw_large.c
further shrinked bmw tiny to 1778 bytes
[avr-crypto-lib.git] / bmw / bmw_large.c
index 5b0039ab31663e81a3864a660a1ea311f2da1e26..719b5859c0199c154a2cc4a861f0a5be1ad00091 100644 (file)
 #include <avr/pgmspace.h>
 #include "bmw_large.h"
 
-#define SHL64(a,n) ((a)<<(n))
-#define SHR64(a,n) ((a)>>(n))
-#define ROTL64(a,n) (((a)<<(n))|((a)>>(64-(n))))
-#define ROTR64(a,n) (((a)>>(n))|((a)<<(64-(n))))
+#define SHL64(a,n)  shiftl64(a,n)
+#define SHR64(a,n)  shiftr64(a,n)
+#define ROTL64(a,n) rotl64(a,n)
+#define ROTR64(a,n) rotr64(a,n)
 
 #define TWEAK   1
 #define BUG24   0
  #define dump_x(a,b,c)
 #endif
 
+static
+uint64_t rotl64(uint64_t a, uint8_t r){
+       return (a<<r)|(a>>(64-r));
+}
+
+static
+uint64_t rotr64(uint64_t a, uint8_t r){
+       return (a>>r)|(a<<(64-r));
+}
+
+static
+uint64_t shiftl64(uint64_t a, uint8_t r){
+       return (a<<r);
+}
+
+static
+uint64_t shiftr64(uint64_t a, uint8_t r){
+       return (a>>r);
+}
+
 static
 uint64_t bmw_large_s0(uint64_t x){
        uint64_t r;