| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
|
|
| #ifndef NETTLE_MACROS_H_INCLUDED |
| #define NETTLE_MACROS_H_INCLUDED |
|
|
| |
| #define READ_UINT64(p) \ |
| ( (((uint64_t) (p)[0]) << 56) \ |
| | (((uint64_t) (p)[1]) << 48) \ |
| | (((uint64_t) (p)[2]) << 40) \ |
| | (((uint64_t) (p)[3]) << 32) \ |
| | (((uint64_t) (p)[4]) << 24) \ |
| | (((uint64_t) (p)[5]) << 16) \ |
| | (((uint64_t) (p)[6]) << 8) \ |
| | ((uint64_t) (p)[7])) |
|
|
| #define WRITE_UINT64(p, i) \ |
| do { \ |
| (p)[0] = ((i) >> 56) & 0xff; \ |
| (p)[1] = ((i) >> 48) & 0xff; \ |
| (p)[2] = ((i) >> 40) & 0xff; \ |
| (p)[3] = ((i) >> 32) & 0xff; \ |
| (p)[4] = ((i) >> 24) & 0xff; \ |
| (p)[5] = ((i) >> 16) & 0xff; \ |
| (p)[6] = ((i) >> 8) & 0xff; \ |
| (p)[7] = (i) & 0xff; \ |
| } while(0) |
|
|
| |
| #define READ_UINT32(p) \ |
| ( (((uint32_t) (p)[0]) << 24) \ |
| | (((uint32_t) (p)[1]) << 16) \ |
| | (((uint32_t) (p)[2]) << 8) \ |
| | ((uint32_t) (p)[3])) |
|
|
| #define WRITE_UINT32(p, i) \ |
| do { \ |
| (p)[0] = ((i) >> 24) & 0xff; \ |
| (p)[1] = ((i) >> 16) & 0xff; \ |
| (p)[2] = ((i) >> 8) & 0xff; \ |
| (p)[3] = (i) & 0xff; \ |
| } while(0) |
|
|
| |
| #define READ_UINT24(p) \ |
| ( (((uint32_t) (p)[0]) << 16) \ |
| | (((uint32_t) (p)[1]) << 8) \ |
| | ((uint32_t) (p)[2])) |
|
|
| #define WRITE_UINT24(p, i) \ |
| do { \ |
| (p)[0] = ((i) >> 16) & 0xff; \ |
| (p)[1] = ((i) >> 8) & 0xff; \ |
| (p)[2] = (i) & 0xff; \ |
| } while(0) |
|
|
| #define READ_UINT16(p) \ |
| ( (((uint32_t) (p)[0]) << 8) \ |
| | ((uint32_t) (p)[1])) |
|
|
| #define WRITE_UINT16(p, i) \ |
| do { \ |
| (p)[0] = ((i) >> 8) & 0xff; \ |
| (p)[1] = (i) & 0xff; \ |
| } while(0) |
|
|
| |
| #define LE_READ_UINT64(p) \ |
| ( (((uint64_t) (p)[7]) << 56) \ |
| | (((uint64_t) (p)[6]) << 48) \ |
| | (((uint64_t) (p)[5]) << 40) \ |
| | (((uint64_t) (p)[4]) << 32) \ |
| | (((uint64_t) (p)[3]) << 24) \ |
| | (((uint64_t) (p)[2]) << 16) \ |
| | (((uint64_t) (p)[1]) << 8) \ |
| | ((uint64_t) (p)[0])) |
|
|
| #define LE_WRITE_UINT64(p, i) \ |
| do { \ |
| (p)[7] = ((i) >> 56) & 0xff; \ |
| (p)[6] = ((i) >> 48) & 0xff; \ |
| (p)[5] = ((i) >> 40) & 0xff; \ |
| (p)[4] = ((i) >> 32) & 0xff; \ |
| (p)[3] = ((i) >> 24) & 0xff; \ |
| (p)[2] = ((i) >> 16) & 0xff; \ |
| (p)[1] = ((i) >> 8) & 0xff; \ |
| (p)[0] = (i) & 0xff; \ |
| } while (0) |
|
|
| #define LE_READ_UINT32(p) \ |
| ( (((uint32_t) (p)[3]) << 24) \ |
| | (((uint32_t) (p)[2]) << 16) \ |
| | (((uint32_t) (p)[1]) << 8) \ |
| | ((uint32_t) (p)[0])) |
|
|
| #define LE_WRITE_UINT32(p, i) \ |
| do { \ |
| (p)[3] = ((i) >> 24) & 0xff; \ |
| (p)[2] = ((i) >> 16) & 0xff; \ |
| (p)[1] = ((i) >> 8) & 0xff; \ |
| (p)[0] = (i) & 0xff; \ |
| } while(0) |
|
|
| |
| #define LE_READ_UINT16(p) \ |
| ( (((uint32_t) (p)[1]) << 8) \ |
| | ((uint32_t) (p)[0])) |
|
|
| #define LE_WRITE_UINT16(p, i) \ |
| do { \ |
| (p)[1] = ((i) >> 8) & 0xff; \ |
| (p)[0] = (i) & 0xff; \ |
| } while(0) |
|
|
| |
| #define FOR_BLOCKS(length, dst, src, blocksize) \ |
| assert( !((length) % (blocksize))); \ |
| for (; (length); ((length) -= (blocksize), \ |
| (dst) += (blocksize), \ |
| (src) += (blocksize)) ) |
|
|
| |
| |
| |
| #define ROTL32(n,x) (((x)<<(n)) | ((x)>>((-(n)&31)))) |
|
|
| #define ROTL64(n,x) (((x)<<(n)) | ((x)>>((-(n))&63))) |
|
|
| |
| #define INCREMENT(size, ctr) \ |
| do { \ |
| unsigned increment_i = (size) - 1; \ |
| if (++(ctr)[increment_i] == 0) \ |
| while (increment_i > 0 \ |
| && ++(ctr)[--increment_i] == 0 ) \ |
| ; \ |
| } while (0) |
|
|
|
|
| |
| |
| |
| |
| |
| |
|
|
| |
| #define MD_INCR(ctx) ((ctx)->count_high += !++(ctx)->count_low) |
|
|
| |
| |
| #define MD_UPDATE(ctx, length, data, f, incr) \ |
| do { \ |
| if ((ctx)->index) \ |
| { \ |
| \ |
| unsigned __md_left = sizeof((ctx)->block) - (ctx)->index; \ |
| if ((length) < __md_left) \ |
| { \ |
| memcpy((ctx)->block + (ctx)->index, (data), (length)); \ |
| (ctx)->index += (length); \ |
| goto __md_done; \ |
| } \ |
| else \ |
| { \ |
| memcpy((ctx)->block + (ctx)->index, (data), __md_left); \ |
| \ |
| f((ctx), (ctx)->block); \ |
| (incr); \ |
| \ |
| (data) += __md_left; \ |
| (length) -= __md_left; \ |
| } \ |
| } \ |
| while ((length) >= sizeof((ctx)->block)) \ |
| { \ |
| f((ctx), (data)); \ |
| (incr); \ |
| \ |
| (data) += sizeof((ctx)->block); \ |
| (length) -= sizeof((ctx)->block); \ |
| } \ |
| memcpy ((ctx)->block, (data), (length)); \ |
| (ctx)->index = (length); \ |
| __md_done: \ |
| ; \ |
| } while (0) |
|
|
| |
| |
| |
| #define MD_PAD(ctx, size, f) \ |
| do { \ |
| unsigned __md_i; \ |
| __md_i = (ctx)->index; \ |
| \ |
| |
| \ |
| \ |
| assert(__md_i < sizeof((ctx)->block)); \ |
| (ctx)->block[__md_i++] = 0x80; \ |
| \ |
| if (__md_i > (sizeof((ctx)->block) - (size))) \ |
| { |
| \ |
| memset((ctx)->block + __md_i, 0, sizeof((ctx)->block) - __md_i); \ |
| \ |
| f((ctx), (ctx)->block); \ |
| __md_i = 0; \ |
| } \ |
| memset((ctx)->block + __md_i, 0, \ |
| sizeof((ctx)->block) - (size) - __md_i); \ |
| \ |
| } while (0) |
|
|
| #endif |
|
|