forked from gost-engine/engine
-
Notifications
You must be signed in to change notification settings - Fork 2
/
gost_grasshopper_defines.h
73 lines (57 loc) · 1.44 KB
/
gost_grasshopper_defines.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/*
* Maxim Tishkov 2016
* This file is distributed under the same license as OpenSSL
*/
#ifndef GOST_GRASSHOPPER_DEFINES_H
#define GOST_GRASSHOPPER_DEFINES_H
#if defined(__cplusplus)
extern "C" {
#endif
#include <stdbool.h>
#include <stdint.h>
# if !defined(inline) && !defined(__cplusplus)
# if defined(__STDC_VERSION__) && __STDC_VERSION__ >= 199901L
# define GRASSHOPPER_INLINE inline
# elif defined(__GNUC__) && __GNUC__ >= 2
# define GRASSHOPPER_INLINE __inline__
# define likely(x) __builtin_expect(!!(x), 1)
# elif defined(_MSC_VER)
# define GRASSHOPPER_INLINE __inline
# else
# define GRASSHOPPER_INLINE
# endif
# else
# define GRASSHOPPER_INLINE inline
# endif
# if !defined(likely)
# define likely(x) x
# endif
typedef union {
uint8_t b[16];
uint64_t q[2];
uint32_t d[4];
uint16_t w[8];
} grasshopper_w128_t;
typedef union {
uint8_t b[32];
uint64_t q[4];
uint32_t d[8];
uint16_t w[16];
grasshopper_w128_t k[2];
} grasshopper_w256_t;
typedef struct {
grasshopper_w256_t k;
} grasshopper_key_t;
#define GRASSHOPPER_ROUND_KEYS_COUNT 10
typedef struct {
grasshopper_w128_t k[GRASSHOPPER_ROUND_KEYS_COUNT];
} grasshopper_round_keys_t;
extern const uint8_t grasshopper_pi[0x100];
extern const uint8_t grasshopper_pi_inv[0x100];
extern const uint8_t grasshopper_lvec[16];
#define GRASSHOPPER_BLOCK_SIZE (128/8)
#define GRASSHOPPER_KEY_SIZE (256/8)
#if defined(__cplusplus)
}
#endif
#endif