sha3 1.0.5 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (50) hide show
  1. checksums.yaml +4 -4
  2. checksums.yaml.gz.sig +0 -0
  3. data/.clang-format +54 -0
  4. data/.document +4 -3
  5. data/.rdoc_options +10 -0
  6. data/.rspec +2 -2
  7. data/.rubocop.yml +5 -1
  8. data/CHANGELOG.md +23 -0
  9. data/Gemfile +11 -0
  10. data/LICENSE.txt +1 -1
  11. data/README.md +154 -67
  12. data/Rakefile +9 -3
  13. data/certs/io+sha3@jsg.io.pem +26 -0
  14. data/doc/sha3.rb +81 -0
  15. data/ext/sha3/digest.c +635 -163
  16. data/ext/sha3/digest.h +71 -35
  17. data/ext/sha3/extconf.rb +42 -38
  18. data/ext/sha3/lib/high/Keccak/KeccakDuplex.c +81 -0
  19. data/ext/sha3/lib/high/Keccak/KeccakDuplex.h +73 -0
  20. data/ext/sha3/lib/high/Keccak/KeccakDuplex.inc +201 -0
  21. data/ext/sha3/lib/high/Keccak/KeccakSponge.c +2 -18
  22. data/ext/sha3/lib/high/Keccak/KeccakSponge.h +4 -10
  23. data/ext/sha3/lib/high/Keccak/KeccakSponge.inc +27 -31
  24. data/ext/sha3/lib/high/Keccak/PRG/KeccakPRG.c +61 -0
  25. data/ext/sha3/lib/high/Keccak/PRG/KeccakPRG.h +67 -0
  26. data/ext/sha3/lib/high/Keccak/PRG/KeccakPRG.inc +128 -0
  27. data/ext/sha3/lib/high/Keccak/SP800-185/SP800-185.c +93 -0
  28. data/ext/sha3/lib/high/Keccak/SP800-185/SP800-185.h +599 -0
  29. data/ext/sha3/lib/high/Keccak/SP800-185/SP800-185.inc +573 -0
  30. data/ext/sha3/lib/high/common/Phases.h +25 -0
  31. data/ext/sha3/lib/low/KeccakP-1600/common/KeccakP-1600-64.macros +19 -9
  32. data/ext/sha3/lib/low/KeccakP-1600/ref-32bits/KeccakP-1600-SnP.h +18 -12
  33. data/ext/sha3/lib/low/KeccakP-1600/ref-32bits/KeccakP-1600-reference32BI.c +28 -36
  34. data/ext/sha3/lib/low/KeccakP-1600/ref-64bits/KeccakP-1600-SnP.h +18 -12
  35. data/ext/sha3/lib/low/KeccakP-1600/ref-64bits/KeccakP-1600-reference.c +28 -59
  36. data/ext/sha3/lib/low/common/PlSnP-Fallback.inc +291 -0
  37. data/ext/sha3/lib/low/common/SnP-Relaned.h +145 -0
  38. data/lib/sha3.rb +25 -28
  39. data.tar.gz.sig +0 -0
  40. metadata +55 -115
  41. metadata.gz.sig +0 -0
  42. data/.yardopts +0 -1
  43. data/ChangeLog.rdoc +0 -27
  44. data/certs/johanns.pem +0 -25
  45. data/ext/sha3/sha3.c +0 -62
  46. data/ext/sha3/sha3.h +0 -26
  47. data/lib/sha3/doc.rb +0 -121
  48. data/lib/sha3/version.rb +0 -9
  49. data/sha3.gemspec +0 -54
  50. data/tests.sh +0 -29
@@ -0,0 +1,599 @@
1
+ /*
2
+ The eXtended Keccak Code Package (XKCP)
3
+ https://github.com/XKCP/XKCP
4
+
5
+ Keccak, designed by Guido Bertoni, Joan Daemen, Michaël Peeters and Gilles Van Assche.
6
+
7
+ Implementation by Ronny Van Keer, hereby denoted as "the implementer".
8
+
9
+ For more information, feedback or questions, please refer to the Keccak Team website:
10
+ https://keccak.team/
11
+
12
+ To the extent possible under law, the implementer has waived all copyright
13
+ and related or neighboring rights to the source code in this file.
14
+ http://creativecommons.org/publicdomain/zero/1.0/
15
+ */
16
+
17
+ #ifndef _SP800_185_h_
18
+ #define _SP800_185_h_
19
+
20
+ #include "config.h"
21
+ #ifdef XKCP_has_KeccakP1600
22
+
23
+ #include <stddef.h>
24
+ #include <stdint.h>
25
+ #include "align.h"
26
+ #include "KeccakSponge.h"
27
+ #include "Phases.h"
28
+
29
+ #ifndef _Keccak_BitTypes_
30
+ #define _Keccak_BitTypes_
31
+ typedef uint8_t BitSequence;
32
+
33
+ typedef size_t BitLength;
34
+ #endif
35
+
36
+ typedef struct {
37
+ KeccakWidth1600_SpongeInstance sponge;
38
+ BitLength fixedOutputLength;
39
+ unsigned int lastByteBitLen;
40
+ BitSequence lastByteValue;
41
+ int emptyNameCustom;
42
+ KCP_Phases phase;
43
+ } cSHAKE_Instance;
44
+
45
+ /** cSHAKE128 function, as defined in NIST's Special Publication 800-185,
46
+ * published December 2016.
47
+ * @param input Pointer to the input message (X).
48
+ * @param inputBitLen The length of the input message in bits.
49
+ * @param output Pointer to the output buffer.
50
+ * @param outputBitLen The desired number of output bits (L).
51
+ * @param name Pointer to the function name string (N).
52
+ * @param nameBitLen The length of the function name in bits.
53
+ * Only full bytes are supported, length must be a multiple of 8.
54
+ * @param customization Pointer to the customization string (S).
55
+ * @param customBitLen The length of the customization string in bits.
56
+ * @return 0 if successful, 1 otherwise.
57
+ */
58
+ int cSHAKE128( const BitSequence *input, BitLength inputBitLen, BitSequence *output, BitLength outputBitLen, const BitSequence *name, BitLength nameBitLen, const BitSequence *customization, BitLength customBitLen );
59
+
60
+ /**
61
+ * Function to initialize the cSHAKE128 instance used in sequential hashing mode.
62
+ * @param cskInstance Pointer to the hash instance to be initialized.
63
+ * @param outputBitLen The desired number of output bits (L).
64
+ * or 0 for an arbitrarily-long output (XOF).
65
+ * @param name Pointer to the function name string (N).
66
+ * @param nameBitLen The length of the function name in bits.
67
+ * Only full bytes are supported, length must be a multiple of 8.
68
+ * @param customization Pointer to the customization string (S).
69
+ * @param customBitLen The length of the customization string in bits.
70
+ * @return 0 if successful, 1 otherwise.
71
+ */
72
+ int cSHAKE128_Initialize(cSHAKE_Instance *cskInstance, BitLength outputBitLen, const BitSequence *name, BitLength nameBitLen, const BitSequence *customization, BitLength customBitLen);
73
+
74
+ /**
75
+ * Function to give input data to be absorbed.
76
+ * @param cskInstance Pointer to the hash instance initialized by cSHAKE128_Initialize().
77
+ * @param input Pointer to the input data.
78
+ * @param inputBitLen The number of input bits provided in the input data.
79
+ * Only the last update call can input a partial byte, other calls must have a length multiple of 8.
80
+ * @return 0 if successful, 1 otherwise.
81
+ */
82
+ int cSHAKE128_Update(cSHAKE_Instance *cskInstance, const BitSequence *input, BitLength inputBitLen);
83
+
84
+ /**
85
+ * Function to call after all input blocks have been input and to get
86
+ * output bits if the length was specified when calling cSHAKE128_Initialize().
87
+ * @param cskInstance Pointer to the hash instance initialized by cSHAKE128_Initialize().
88
+ * If @a outputBitLen was not 0 in the call to cSHAKE128_Initialize(), the number of
89
+ * output bits is equal to @a outputBitLen.
90
+ * If @a outputBitLen was 0 in the call to cSHAKE128_Initialize(), the output bits
91
+ * must be extracted using the cSHAKE128_Squeeze() function.
92
+ * @param output Pointer to the buffer where to store the output data.
93
+ * @return 0 if successful, 1 otherwise.
94
+ */
95
+ int cSHAKE128_Final(cSHAKE_Instance *cskInstance, BitSequence *output);
96
+
97
+ /**
98
+ * Function to squeeze output data.
99
+ * @param cskInstance Pointer to the hash instance initialized by cSHAKE128_Initialize().
100
+ * @param output Pointer to the buffer where to store the output data.
101
+ * @param outputBitLen The number of output bits desired.
102
+ * Only the last squeeze call can output a partial byte,
103
+ * other calls must have a length multiple of 8.
104
+ * @pre cSHAKE128_Final() must have been already called.
105
+ * @return 0 if successful, 1 otherwise.
106
+ */
107
+ int cSHAKE128_Squeeze(cSHAKE_Instance *cskInstance, BitSequence *output, BitLength outputBitLen);
108
+
109
+ /* ------------------------------------------------------------------------- */
110
+
111
+ /** cSHAKE256 function, as defined in NIST's Special Publication 800-185,
112
+ * published December 2016.
113
+ * @param input Pointer to the input message (X).
114
+ * @param inputBitLen The length of the input message in bits.
115
+ * @param output Pointer to the output buffer.
116
+ * @param outputBitLen The desired number of output bits (L).
117
+ * @param name Pointer to the function name string (N).
118
+ * @param nameBitLen The length of the function name in bits.
119
+ * Only full bytes are supported, length must be a multiple of 8.
120
+ * @param customization Pointer to the customization string (S).
121
+ * @param customBitLen The length of the customization string in bits.
122
+ * @return 0 if successful, 1 otherwise.
123
+ */
124
+ int cSHAKE256( const BitSequence *input, BitLength inputBitLen, BitSequence *output, BitLength outputBitLen, const BitSequence *name, BitLength nameBitLen, const BitSequence *customization, BitLength customBitLen );
125
+
126
+ /**
127
+ * Function to initialize the cSHAKE256 instance used in sequential hashing mode.
128
+ * @param cskInstance Pointer to the hash instance to be initialized.
129
+ * @param outputBitLen The desired number of output bits (L).
130
+ * or 0 for an arbitrarily-long output (XOF).
131
+ * @param name Pointer to the function name string (N).
132
+ * @param nameBitLen The length of the function name in bits.
133
+ * Only full bytes are supported, length must be a multiple of 8.
134
+ * @param customization Pointer to the customization string (S).
135
+ * @param customBitLen The length of the customization string in bits.
136
+ * @return 0 if successful, 1 otherwise.
137
+ */
138
+ int cSHAKE256_Initialize(cSHAKE_Instance *cskInstance, BitLength outputBitLen, const BitSequence *name, BitLength nameBitLen, const BitSequence *customization, BitLength customBitLen);
139
+
140
+ /**
141
+ * Function to give input data to be absorbed.
142
+ * @param cskInstance Pointer to the hash instance initialized by cSHAKE256_Initialize().
143
+ * @param input Pointer to the input data.
144
+ * @param inputBitLen The number of input bits provided in the input data.
145
+ * Only the last update call can input a partial byte, other calls must have a length multiple of 8.
146
+ * @return 0 if successful, 1 otherwise.
147
+ */
148
+ int cSHAKE256_Update(cSHAKE_Instance *cskInstance, const BitSequence *input, BitLength inputBitLen);
149
+
150
+ /**
151
+ * Function to call after all input blocks have been input and to get
152
+ * output bits if the length was specified when calling cSHAKE256_Initialize().
153
+ * @param cskInstance Pointer to the hash instance initialized by cSHAKE256_Initialize().
154
+ * If @a outputBitLen was not 0 in the call to cSHAKE256_Initialize(), the number of
155
+ * output bits is equal to @a outputBitLen.
156
+ * If @a outputBitLen was 0 in the call to cSHAKE256_Initialize(), the output bits
157
+ * must be extracted using the cSHAKE256_Squeeze() function.
158
+ * @param output Pointer to the buffer where to store the output data.
159
+ * @return 0 if successful, 1 otherwise.
160
+ */
161
+ int cSHAKE256_Final(cSHAKE_Instance *cskInstance, BitSequence *output);
162
+
163
+ /**
164
+ * Function to squeeze output data.
165
+ * @param cskInstance Pointer to the hash instance initialized by cSHAKE256_Initialize().
166
+ * @param output Pointer to the buffer where to store the output data.
167
+ * @param outputBitLen The number of output bits desired.
168
+ * Only the last squeeze call can output a partial byte,
169
+ * other calls must have a length multiple of 8.
170
+ * @pre cSHAKE256_Final() must have been already called.
171
+ * @return 0 if successful, 1 otherwise.
172
+ */
173
+ int cSHAKE256_Squeeze(cSHAKE_Instance *cskInstance, BitSequence *output, BitLength outputBitLen);
174
+
175
+ /* ------------------------------------------------------------------------- */
176
+
177
+ typedef struct {
178
+ cSHAKE_Instance csi;
179
+ BitLength outputBitLen;
180
+ } KMAC_Instance;
181
+
182
+ /** KMAC128 function, as defined in NIST's Special Publication 800-185,
183
+ * published December 2016.
184
+ * @param key Pointer to the key (K).
185
+ * @param keyBitLen The length of the key in bits.
186
+ * @param input Pointer to the input message (X).
187
+ * @param inputBitLen The length of the input message in bits.
188
+ * Only full bytes are supported, length must be a multiple of 8.
189
+ * @param output Pointer to the output buffer.
190
+ * @param outputBitLen The desired number of output bits (L).
191
+ * @param customization Pointer to the customization string (S).
192
+ * @param customBitLen The length of the customization string in bits.
193
+ * @return 0 if successful, 1 otherwise.
194
+ */
195
+ int KMAC128(const BitSequence *key, BitLength keyBitLen, const BitSequence *input, BitLength inputBitLen,
196
+ BitSequence *output, BitLength outputBitLen, const BitSequence *customization, BitLength customBitLen);
197
+
198
+ /**
199
+ * Function to initialize the KMAC128 instance used in sequential MACing mode.
200
+ * @param kmInstance Pointer to the instance to be initialized.
201
+ * @param key Pointer to the key (K).
202
+ * @param keyBitLen The length of the key in bits.
203
+ * @param outputBitLen The desired number of output bits (L).
204
+ * or 0 for an arbitrarily-long output (XOF).
205
+ * @param customization Pointer to the customization string (S).
206
+ * @param customBitLen The length of the customization string in bits.
207
+ * @return 0 if successful, 1 otherwise.
208
+ */
209
+ int KMAC128_Initialize(KMAC_Instance *kmkInstance, const BitSequence *key, BitLength keyBitLen, BitLength outputBitLen,
210
+ const BitSequence *customization, BitLength customBitLen);
211
+
212
+ /**
213
+ * Function to give input data to be MACed.
214
+ * @param kmInstance Pointer to the instance initialized by KMAC128_Initialize().
215
+ * @param input Pointer to the input data.
216
+ * @param inputBitLen The number of input bits provided in the input data.
217
+ * Only full bytes are supported, length must be a multiple of 8.
218
+ * @return 0 if successful, 1 otherwise.
219
+ */
220
+ int KMAC128_Update(KMAC_Instance *kmkInstance, const BitSequence *input, BitLength inputBitLen);
221
+
222
+ /**
223
+ * Function to call after all input data have been input and to get
224
+ * output bits if the length was specified when calling KMAC128_Initialize().
225
+ * @param kmInstance Pointer to the instance initialized by KMAC128_Initialize().
226
+ * If @a outputBitLen was not 0 in the call to KMAC128_Initialize(), the number of
227
+ * output bits is equal to @a outputBitLen.
228
+ * If @a outputBitLen was 0 in the call to KMAC128_Initialize(), the output bits
229
+ * must be extracted using the KMAC128_Squeeze() function.
230
+ * @param output Pointer to the buffer where to store the output data.
231
+ * @return 0 if successful, 1 otherwise.
232
+ */
233
+ int KMAC128_Final(KMAC_Instance *kmkInstance, BitSequence *output);
234
+
235
+ /**
236
+ * Function to squeeze output data.
237
+ * @param kmInstance Pointer to the instance initialized by KMAC128_Initialize().
238
+ * @param output Pointer to the buffer where to store the output data.
239
+ * @param outputBitLen The number of output bits desired.
240
+ * Only the last squeeze call can output a partial byte,
241
+ * other calls must have a length multiple of 8.
242
+ * @pre KMAC128_Final() must have been already called.
243
+ * @return 0 if successful, 1 otherwise.
244
+ */
245
+ int KMAC128_Squeeze(KMAC_Instance *kmkInstance, BitSequence *output, BitLength outputBitLen);
246
+
247
+ /* ------------------------------------------------------------------------- */
248
+
249
+ /** KMAC256 function, as defined in NIST's Special Publication 800-185,
250
+ * published December 2016.
251
+ * @param key Pointer to the key (K).
252
+ * @param keyBitLen The length of the key in bits.
253
+ * @param input Pointer to the input message (X).
254
+ * @param inputBitLen The length of the input message in bits.
255
+ * Only full bytes are supported, length must be a multiple of 8.
256
+ * @param output Pointer to the output buffer.
257
+ * @param outputBitLen The desired number of output bits (L).
258
+ * @param customization Pointer to the customization string (S).
259
+ * @param customBitLen The length of the customization string in bits.
260
+ * @return 0 if successful, 1 otherwise.
261
+ */
262
+ int KMAC256(const BitSequence *key, BitLength keyBitLen, const BitSequence *input, BitLength inputBitLen,
263
+ BitSequence *output, BitLength outputBitLen, const BitSequence *customization, BitLength customBitLen);
264
+
265
+ /**
266
+ * Function to initialize the KMAC256 instance used in sequential MACing mode.
267
+ * @param kmInstance Pointer to the instance to be initialized.
268
+ * @param key Pointer to the key (K).
269
+ * @param keyBitLen The length of the key in bits.
270
+ * @param outputBitLen The desired number of output bits (L).
271
+ * or 0 for an arbitrarily-long output (XOF).
272
+ * @param customization Pointer to the customization string (S).
273
+ * @param customBitLen The length of the customization string in bits.
274
+ * @return 0 if successful, 1 otherwise.
275
+ */
276
+ int KMAC256_Initialize(KMAC_Instance *kmkInstance, const BitSequence *key, BitLength keyBitLen, BitLength outputBitLen,
277
+ const BitSequence *customization, BitLength customBitLen);
278
+
279
+ /**
280
+ * Function to give input data to be MACed.
281
+ * @param kmInstance Pointer to the instance initialized by KMAC256_Initialize().
282
+ * @param input Pointer to the input data.
283
+ * @param inputBitLen The number of input bits provided in the input data.
284
+ * Only full bytes are supported, length must be a multiple of 8.
285
+ * @return 0 if successful, 1 otherwise.
286
+ */
287
+ int KMAC256_Update(KMAC_Instance *kmkInstance, const BitSequence *input, BitLength inputBitLen);
288
+
289
+ /**
290
+ * Function to call after all input data have been input and to get
291
+ * output bits if the length was specified when calling KMAC256_Initialize().
292
+ * @param kmInstance Pointer to the instance initialized by KMAC256_Initialize().
293
+ * If @a outputBitLen was not 0 in the call to KMAC256_Initialize(), the number of
294
+ * output bits is equal to @a outputBitLen.
295
+ * If @a outputBitLen was 0 in the call to KMAC256_Initialize(), the output bits
296
+ * must be extracted using the KMAC256_Squeeze() function.
297
+ * @param output Pointer to the buffer where to store the output data.
298
+ * @return 0 if successful, 1 otherwise.
299
+ */
300
+ int KMAC256_Final(KMAC_Instance *kmkInstance, BitSequence *output);
301
+
302
+ /**
303
+ * Function to squeeze output data.
304
+ * @param kmInstance Pointer to the instance initialized by KMAC256_Initialize().
305
+ * @param output Pointer to the buffer where to store the output data.
306
+ * @param outputBitLen The number of output bits desired.
307
+ * Only the last squeeze call can output a partial byte,
308
+ * other calls must have a length multiple of 8.
309
+ * @pre KMAC256_Final() must have been already called.
310
+ * @return 0 if successful, 1 otherwise.
311
+ */
312
+ int KMAC256_Squeeze(KMAC_Instance *kmkInstance, BitSequence *output, BitLength outputBitLen);
313
+
314
+ /* ------------------------------------------------------------------------- */
315
+
316
+ typedef struct {
317
+ KeccakWidth1600_SpongeInstance queueNode;
318
+ KeccakWidth1600_SpongeInstance finalNode;
319
+ size_t fixedOutputLength;
320
+ size_t blockLen;
321
+ size_t queueAbsorbedLen;
322
+ size_t totalInputSize;
323
+ KCP_Phases phase;
324
+ } ParallelHash_Instance;
325
+
326
+ /** Parallel hash function ParallelHash128, as defined in NIST's Special Publication 800-185,
327
+ * published December 2016.
328
+ * @param input Pointer to the input message (X).
329
+ * @param inputBitLen The number of input bits provided in the input data.
330
+ * Only full bytes are supported, length must be a multiple of 8.
331
+ * @param blockByteLen Block size (B) in bytes, must be a power of 2.
332
+ * The minimum value is 8 in this implementation.
333
+ * @param output Pointer to the output buffer.
334
+ * @param outputBitLen The desired number of output bits (L).
335
+ * @param customization Pointer to the customization string (S).
336
+ * @param customBitLen The length of the customization string in bits.
337
+ * @return 0 if successful, 1 otherwise.
338
+ */
339
+ int ParallelHash128( const BitSequence *input, BitLength inputBitLen, size_t blockByteLen,
340
+ BitSequence *output, BitLength outputBitLen, const BitSequence *customization, BitLength customBitLen);
341
+
342
+ /**
343
+ * Function to initialize the parallel hash function ParallelHash128 instance used in sequential hashing mode.
344
+ * @param ParallelHashInstance Pointer to the hash instance to be initialized.
345
+ * @param blockByteLen Block size (B) in bytes, must be a power of 2.
346
+ * The minimum value is 8 in this implementation.
347
+ * @param outputBitLen The desired number of output bits (L).
348
+ * or 0 for an arbitrarily-long output (XOF).
349
+ * @param customization Pointer to the customization string (S).
350
+ * @param customBitLen The length of the customization string in bits.
351
+ * @return 0 if successful, 1 otherwise.
352
+ */
353
+ int ParallelHash128_Initialize(ParallelHash_Instance *ParallelHashInstance, size_t blockByteLen,
354
+ BitLength outputBitLen, const BitSequence *customization, BitLength customBitLen);
355
+
356
+ /**
357
+ * Function to give input data to be absorbed.
358
+ * @param ParallelHashInstance Pointer to the hash instance initialized by ParallelHash128_Initialize().
359
+ * @param input Pointer to the input data (X).
360
+ * @param inputBitLen The number of input bits provided in the input data.
361
+ * Only full bytes are supported, length must be a multiple of 8.
362
+ * @return 0 if successful, 1 otherwise.
363
+ */
364
+ int ParallelHash128_Update(ParallelHash_Instance *ParallelHashInstance, const BitSequence *input, BitLength inputBitLen);
365
+
366
+ /**
367
+ * Function to call after all input blocks have been input and to get
368
+ * output bits if the length was specified when calling ParallelHash128_Initialize().
369
+ * @param ParallelHashInstance Pointer to the hash instance initialized by ParallelHash128_Initialize().
370
+ * If @a outputBitLen was not 0 in the call to ParallelHash128_Initialize(), the number of
371
+ * output bits is equal to @a outputBitLen.
372
+ * If @a outputBitLen was 0 in the call to ParallelHash128_Initialize(), the output bits
373
+ * must be extracted using the ParallelHash128_Squeeze() function.
374
+ * @param output Pointer to the buffer where to store the output data.
375
+ * @return 0 if successful, 1 otherwise.
376
+ */
377
+ int ParallelHash128_Final(ParallelHash_Instance *ParallelHashInstance, BitSequence * output);
378
+
379
+ /**
380
+ * Function to squeeze output data.
381
+ * @param ParallelHashInstance Pointer to the hash instance initialized by ParallelHash128_Initialize().
382
+ * @param output Pointer to the buffer where to store the output data.
383
+ * @param outputBitLen The number of output bits desired.
384
+ * Only the last squeeze call can output a partial byte,
385
+ * other calls must have a length multiple of 8.
386
+ * @pre ParallelHash128_Final() must have been already called.
387
+ * @return 0 if successful, 1 otherwise.
388
+ */
389
+ int ParallelHash128_Squeeze(ParallelHash_Instance *ParallelHashInstance, BitSequence *output, BitLength outputBitLen);
390
+
391
+ /* ------------------------------------------------------------------------- */
392
+
393
+ /** Parallel hash function ParallelHash256, as defined in NIST's Special Publication 800-185,
394
+ * published December 2016.
395
+ * @param input Pointer to the input message (X).
396
+ * @param inputBitLen The number of input bits provided in the input data.
397
+ * Only full bytes are supported, length must be a multiple of 8.
398
+ * @param blockByteLen Block size (B) in bytes, must be a power of 2.
399
+ * The minimum value is 8 in this implementation.
400
+ * @param output Pointer to the output buffer.
401
+ * @param outputBitLen The desired number of output bits (L).
402
+ * @param customization Pointer to the customization string (S).
403
+ * @param customBitLen The length of the customization string in bits.
404
+ * @return 0 if successful, 1 otherwise.
405
+ */
406
+ int ParallelHash256( const BitSequence *input, BitLength inputBitLen, size_t blockByteLen,
407
+ BitSequence *output, BitLength outputBitLen, const BitSequence *customization, BitLength customBitLen);
408
+
409
+ /**
410
+ * Function to initialize the parallel hash function ParallelHash256 instance used in sequential hashing mode.
411
+ * @param ParallelHashInstance Pointer to the hash instance to be initialized.
412
+ * @param blockByteLen Block size (B) in bytes, must be a power of 2.
413
+ * The minimum value is 8 in this implementation.
414
+ * @param outputBitLen The desired number of output bits (L).
415
+ * or 0 for an arbitrarily-long output (XOF).
416
+ * @param customization Pointer to the customization string (S).
417
+ * @param customBitLen The length of the customization string in bits.
418
+ * @return 0 if successful, 1 otherwise.
419
+ */
420
+ int ParallelHash256_Initialize(ParallelHash_Instance *ParallelHashInstance, size_t blockByteLen,
421
+ BitLength outputBitLen, const BitSequence *customization, BitLength customBitLen);
422
+
423
+ /**
424
+ * Function to give input data to be absorbed.
425
+ * @param ParallelHashInstance Pointer to the hash instance initialized by ParallelHash256_Initialize().
426
+ * @param input Pointer to the input data (X).
427
+ * @param inputBitLen The number of input bits provided in the input data.
428
+ * Only full bytes are supported, length must be a multiple of 8.
429
+ * @return 0 if successful, 1 otherwise.
430
+ */
431
+ int ParallelHash256_Update(ParallelHash_Instance *ParallelHashInstance, const BitSequence *input, BitLength inputBitLen);
432
+
433
+ /**
434
+ * Function to call after all input blocks have been input and to get
435
+ * output bits if the length was specified when calling ParallelHash256_Initialize().
436
+ * @param ParallelHashInstance Pointer to the hash instance initialized by ParallelHash256_Initialize().
437
+ * If @a outputBitLen was not 0 in the call to ParallelHash256_Initialize(), the number of
438
+ * output bits is equal to @a outputBitLen.
439
+ * If @a outputBitLen was 0 in the call to ParallelHash256_Initialize(), the output bits
440
+ * must be extracted using the ParallelHash256_Squeeze() function.
441
+ * @param output Pointer to the buffer where to store the output data.
442
+ * @return 0 if successful, 1 otherwise.
443
+ */
444
+ int ParallelHash256_Final(ParallelHash_Instance *ParallelHashInstance, BitSequence * output);
445
+
446
+ /**
447
+ * Function to squeeze output data.
448
+ * @param ParallelHashInstance Pointer to the hash instance initialized by ParallelHash256_Initialize().
449
+ * @param output Pointer to the buffer where to store the output data.
450
+ * @param outputBitLen The number of output bits desired.
451
+ * Only the last squeeze call can output a partial byte,
452
+ * other calls must have a length multiple of 8.
453
+ * @pre ParallelHash256_Final() must have been already called.
454
+ * @return 0 if successful, 1 otherwise.
455
+ */
456
+ int ParallelHash256_Squeeze(ParallelHash_Instance *ParallelHashInstance, BitSequence *output, BitLength outputBitLen);
457
+
458
+ /* ------------------------------------------------------------------------- */
459
+
460
+ typedef struct {
461
+ cSHAKE_Instance csi;
462
+ BitLength outputBitLen;
463
+ } TupleHash_Instance;
464
+
465
+ typedef struct {
466
+ /** Pointer to the tuple element data (Xn). */
467
+ const BitSequence *input;
468
+
469
+ /** The number of input bits provided in this tuple element.
470
+ * Only full bytes are supported, length must be a multiple of 8.
471
+ */
472
+ BitLength inputBitLen;
473
+ } TupleElement;
474
+
475
+ /** Tuple hash function TupleHash128, as defined in NIST's Special Publication 800-185,
476
+ * published December 2016.
477
+ * @param tuple Pointer to an array of tuple elements (X).
478
+ * @param numberOfElements The number of tuple elements provided in the input data.
479
+ * @param output Pointer to the output buffer.
480
+ * @param outputBitLen The desired number of output bits (L).
481
+ * @param customization Pointer to the customization string (S).
482
+ * @param customBitLen The length of the customization string in bits.
483
+ * @return 0 if successful, 1 otherwise.
484
+ */
485
+ int TupleHash128( const TupleElement *tuple, size_t numberOfElements,
486
+ BitSequence *output, BitLength outputBitLen, const BitSequence *customization, BitLength customBitLen);
487
+
488
+ /**
489
+ * Function to initialize the Tuple hash function TupleHash128 instance used in sequential hashing mode.
490
+ * @param TupleHashInstance Pointer to the hash instance to be initialized.
491
+ * @param outputBitLen The desired number of output bits (L).
492
+ * or 0 for an arbitrarily-long output (XOF).
493
+ * @param customization Pointer to the customization string (S).
494
+ * @param customBitLen The length of the customization string in bits.
495
+ * @return 0 if successful, 1 otherwise.
496
+ */
497
+ int TupleHash128_Initialize(TupleHash_Instance *TupleHashInstance, BitLength outputBitLen,
498
+ const BitSequence *customization, BitLength customBitLen);
499
+
500
+ /**
501
+ * Function to give input data to be absorbed.
502
+ * @param TupleHashInstance Pointer to the hash instance initialized by TupleHash128_Initialize().
503
+ * @param tuple Pointer to an array of tuple elements (X).
504
+ * @param numberOfElements The number of tuple elements provided in the input data.
505
+ * @return 0 if successful, 1 otherwise.
506
+ */
507
+ int TupleHash128_Update(TupleHash_Instance *TupleHashInstance, const TupleElement *tuple, size_t numberOfElements);
508
+
509
+ /**
510
+ * Function to call after all input blocks have been input and to get
511
+ * output bits if the length was specified when calling TupleHash128_Initialize().
512
+ * @param TupleHashInstance Pointer to the hash instance initialized by TupleHash128_Initialize().
513
+ * If @a outputBitLen was not 0 in the call to TupleHash128_Initialize(), the number of
514
+ * output bits is equal to @a outputBitLen.
515
+ * If @a outputBitLen was 0 in the call to TupleHash128_Initialize(), the output bits
516
+ * must be extracted using the TupleHash128_Squeeze() function.
517
+ * @param output Pointer to the buffer where to store the output data.
518
+ * @return 0 if successful, 1 otherwise.
519
+ */
520
+ int TupleHash128_Final(TupleHash_Instance *TupleHashInstance, BitSequence * output);
521
+
522
+ /**
523
+ * Function to squeeze output data.
524
+ * @param TupleHashInstance Pointer to the hash instance initialized by TupleHash128_Initialize().
525
+ * @param output Pointer to the buffer where to store the output data.
526
+ * @param outputBitLen The number of output bits desired.
527
+ * Only the last squeeze call can output a partial byte,
528
+ * other calls must have a length multiple of 8.
529
+ * @pre TupleHash128_Final() must have been already called.
530
+ * @return 0 if successful, 1 otherwise.
531
+ */
532
+ int TupleHash128_Squeeze(TupleHash_Instance *TupleHashInstance, BitSequence *output, BitLength outputBitLen);
533
+
534
+ /* ------------------------------------------------------------------------- */
535
+
536
+ /** Tuple hash function TupleHash256, as defined in NIST's Special Publication 800-185,
537
+ * published December 2016.
538
+ * @param tuple Pointer to an array of tuple elements (X).
539
+ * @param numberOfElements The number of tuple elements provided in the input data.
540
+ * @param output Pointer to the output buffer.
541
+ * @param outputBitLen The desired number of output bits (L).
542
+ * @param customization Pointer to the customization string (S).
543
+ * @param customBitLen The length of the customization string in bits.
544
+ * @return 0 if successful, 1 otherwise.
545
+ */
546
+ int TupleHash256( const TupleElement *tuple, size_t numberOfElements,
547
+ BitSequence *output, BitLength outputBitLen, const BitSequence *customization, BitLength customBitLen);
548
+
549
+ /**
550
+ * Function to initialize the Tuple hash function TupleHash256 instance used in sequential hashing mode.
551
+ * @param TupleHashInstance Pointer to the hash instance to be initialized.
552
+ * @param outputBitLen The desired number of output bits (L).
553
+ * or 0 for an arbitrarily-long output (XOF).
554
+ * @param customization Pointer to the customization string (S).
555
+ * @param customBitLen The length of the customization string in bits.
556
+ * @return 0 if successful, 1 otherwise.
557
+ */
558
+ int TupleHash256_Initialize(TupleHash_Instance *TupleHashInstance, BitLength outputBitLen,
559
+ const BitSequence *customization, BitLength customBitLen);
560
+
561
+ /**
562
+ * Function to give input data to be absorbed.
563
+ * @param TupleHashInstance Pointer to the hash instance initialized by TupleHash256_Initialize().
564
+ * @param tuple Pointer to an array of tuple elements (X).
565
+ * @param numberOfElements The number of tuple elements provided in the input data.
566
+ * @return 0 if successful, 1 otherwise.
567
+ */
568
+ int TupleHash256_Update(TupleHash_Instance *TupleHashInstance, const TupleElement *tuple, size_t numberOfElements);
569
+
570
+ /**
571
+ * Function to call after all input blocks have been input and to get
572
+ * output bits if the length was specified when calling TupleHash256_Initialize().
573
+ * @param TupleHashInstance Pointer to the hash instance initialized by TupleHash256_Initialize().
574
+ * If @a outputBitLen was not 0 in the call to TupleHash256_Initialize(), the number of
575
+ * output bits is equal to @a outputBitLen.
576
+ * If @a outputBitLen was 0 in the call to TupleHash256_Initialize(), the output bits
577
+ * must be extracted using the TupleHash256_Squeeze() function.
578
+ * @param output Pointer to the buffer where to store the output data.
579
+ * @return 0 if successful, 1 otherwise.
580
+ */
581
+ int TupleHash256_Final(TupleHash_Instance *TupleHashInstance, BitSequence * output);
582
+
583
+ /**
584
+ * Function to squeeze output data.
585
+ * @param TupleHashInstance Pointer to the hash instance initialized by TupleHash256_Initialize().
586
+ * @param output Pointer to the buffer where to store the output data.
587
+ * @param outputBitLen The number of output bits desired.
588
+ * Only the last squeeze call can output a partial byte,
589
+ * other calls must have a length multiple of 8.
590
+ * @pre TupleHash256_Final() must have been already called.
591
+ * @return 0 if successful, 1 otherwise.
592
+ */
593
+ int TupleHash256_Squeeze(TupleHash_Instance *TupleHashInstance, BitSequence *output, BitLength outputBitLen);
594
+
595
+ #else
596
+ #error This requires an implementation of Keccak-p[1600]
597
+ #endif
598
+
599
+ #endif