Skip to content
Toggle navigation
P
Projects
G
Groups
S
Snippets
Help
lwc
/
candidates
This project
Loading...
Sign in
Toggle navigation
Go to a project
Project
Repository
Issues
0
Merge Requests
0
Pipelines
Wiki
Members
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Commit
a34b1718
authored
Sep 25, 2020
by
Zhao Xuefeng
Committed by
Sebastian Renner
Sep 25, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
knot arm
parent
017a9cea
Show whitespace changes
Inline
Side-by-side
Showing
96 changed files
with
5847 additions
and
0 deletions
+5847
-0
knot/Implementations/crypto_aead/knot128v1/armcortexm_5/api.h
+8
-0
knot/Implementations/crypto_aead/knot128v1/armcortexm_5/auxFormat.c
+209
-0
knot/Implementations/crypto_aead/knot128v1/armcortexm_5/auxFormat.h
+12
-0
knot/Implementations/crypto_aead/knot128v1/armcortexm_5/crypto_aead.h
+18
-0
knot/Implementations/crypto_aead/knot128v1/armcortexm_5/encrypt.c
+180
-0
knot/Implementations/crypto_aead/knot128v2/armcortexm_5/api.h
+7
-0
knot/Implementations/crypto_aead/knot128v2/armcortexm_5/auxFormat.c
+74
-0
knot/Implementations/crypto_aead/knot128v2/armcortexm_5/auxFormat.h
+227
-0
knot/Implementations/crypto_aead/knot128v2/armcortexm_5/crypto_aead.h
+17
-0
knot/Implementations/crypto_aead/knot128v2/armcortexm_5/encrypt.c
+177
-0
knot/Implementations/crypto_aead/knot192/armcortexm_5/api.h
+6
-0
knot/Implementations/crypto_aead/knot192/armcortexm_5/auxFormat.c
+88
-0
knot/Implementations/crypto_aead/knot192/armcortexm_5/auxFormat.h
+213
-0
knot/Implementations/crypto_aead/knot192/armcortexm_5/crypto_aead.h
+18
-0
knot/Implementations/crypto_aead/knot192/armcortexm_5/encrypt.c
+193
-0
knot/Implementations/crypto_aead/knot256/armcortexm_5/api.h
+7
-0
knot/Implementations/crypto_aead/knot256/armcortexm_5/auxFormat.c
+114
-0
knot/Implementations/crypto_aead/knot256/armcortexm_5/auxFormat.h
+134
-0
knot/Implementations/crypto_aead/knot256/armcortexm_5/crypto_aead.h
+17
-0
knot/Implementations/crypto_aead/knot256/armcortexm_5/encrypt.c
+199
-0
knot/Implementations/crypto_hash/knot256v1/armcortexm_2/api.h
+1
-0
knot/Implementations/crypto_hash/knot256v1/armcortexm_2/auxFormat.c
+89
-0
knot/Implementations/crypto_hash/knot256v1/armcortexm_2/auxFormat.h
+23
-0
knot/Implementations/crypto_hash/knot256v1/armcortexm_2/crypto_hash.h
+7
-0
knot/Implementations/crypto_hash/knot256v1/armcortexm_2/hash.c
+117
-0
knot/Implementations/crypto_hash/knot256v1/armcortexm_3/api.h
+3
-0
knot/Implementations/crypto_hash/knot256v1/armcortexm_3/auxFormat.h
+49
-0
knot/Implementations/crypto_hash/knot256v1/armcortexm_3/crypto_hash.h
+7
-0
knot/Implementations/crypto_hash/knot256v1/armcortexm_3/hash.c
+57
-0
knot/Implementations/crypto_hash/knot256v1/armcortexm_4/api.h
+1
-0
knot/Implementations/crypto_hash/knot256v1/armcortexm_4/auxFormat.c
+45
-0
knot/Implementations/crypto_hash/knot256v1/armcortexm_4/auxFormat.h
+23
-0
knot/Implementations/crypto_hash/knot256v1/armcortexm_4/crypto_hash.h
+7
-0
knot/Implementations/crypto_hash/knot256v1/armcortexm_4/hash.c
+117
-0
knot/Implementations/crypto_hash/knot256v1/armcortexm_5/api.h
+1
-0
knot/Implementations/crypto_hash/knot256v1/armcortexm_5/auxFormat.c
+204
-0
knot/Implementations/crypto_hash/knot256v1/armcortexm_5/auxFormat.h
+15
-0
knot/Implementations/crypto_hash/knot256v1/armcortexm_5/crypto_hash.h
+7
-0
knot/Implementations/crypto_hash/knot256v1/armcortexm_5/hash.c
+115
-0
knot/Implementations/crypto_hash/knot256v2/armcortexm_2/api.h
+2
-0
knot/Implementations/crypto_hash/knot256v2/armcortexm_2/auxFormat.c
+87
-0
knot/Implementations/crypto_hash/knot256v2/armcortexm_2/auxFormat.h
+118
-0
knot/Implementations/crypto_hash/knot256v2/armcortexm_2/crypto_hash.h
+7
-0
knot/Implementations/crypto_hash/knot256v2/armcortexm_2/hash.c
+56
-0
knot/Implementations/crypto_hash/knot256v2/armcortexm_3/api.h
+3
-0
knot/Implementations/crypto_hash/knot256v2/armcortexm_3/auxFormat.h
+129
-0
knot/Implementations/crypto_hash/knot256v2/armcortexm_3/crypto_hash.h
+7
-0
knot/Implementations/crypto_hash/knot256v2/armcortexm_3/hash.c
+64
-0
knot/Implementations/crypto_hash/knot256v2/armcortexm_4/api.h
+2
-0
knot/Implementations/crypto_hash/knot256v2/armcortexm_4/auxFormat.c
+93
-0
knot/Implementations/crypto_hash/knot256v2/armcortexm_4/auxFormat.h
+53
-0
knot/Implementations/crypto_hash/knot256v2/armcortexm_4/crypto_hash.h
+7
-0
knot/Implementations/crypto_hash/knot256v2/armcortexm_4/hash.c
+56
-0
knot/Implementations/crypto_hash/knot256v2/armcortexm_5/api.h
+2
-0
knot/Implementations/crypto_hash/knot256v2/armcortexm_5/auxFormat.c
+96
-0
knot/Implementations/crypto_hash/knot256v2/armcortexm_5/auxFormat.h
+192
-0
knot/Implementations/crypto_hash/knot256v2/armcortexm_5/crypto_hash.h
+7
-0
knot/Implementations/crypto_hash/knot256v2/armcortexm_5/hash.c
+58
-0
knot/Implementations/crypto_hash/knot384/armcortexm_2/api.h
+2
-0
knot/Implementations/crypto_hash/knot384/armcortexm_2/auxFormat.c
+70
-0
knot/Implementations/crypto_hash/knot384/armcortexm_2/auxFormat.h
+126
-0
knot/Implementations/crypto_hash/knot384/armcortexm_2/crypto_hash.h
+7
-0
knot/Implementations/crypto_hash/knot384/armcortexm_2/hash.c
+43
-0
knot/Implementations/crypto_hash/knot384/armcortexm_3/api.h
+2
-0
knot/Implementations/crypto_hash/knot384/armcortexm_3/auxFormat.h
+107
-0
knot/Implementations/crypto_hash/knot384/armcortexm_3/crypto_hash.h
+7
-0
knot/Implementations/crypto_hash/knot384/armcortexm_3/hash.c
+63
-0
knot/Implementations/crypto_hash/knot384/armcortexm_4/api.h
+2
-0
knot/Implementations/crypto_hash/knot384/armcortexm_4/auxFormat.c
+76
-0
knot/Implementations/crypto_hash/knot384/armcortexm_4/auxFormat.h
+57
-0
knot/Implementations/crypto_hash/knot384/armcortexm_4/crypto_hash.h
+7
-0
knot/Implementations/crypto_hash/knot384/armcortexm_4/hash.c
+43
-0
knot/Implementations/crypto_hash/knot384/armcortexm_5/api.h
+2
-0
knot/Implementations/crypto_hash/knot384/armcortexm_5/auxFormat.c
+77
-0
knot/Implementations/crypto_hash/knot384/armcortexm_5/auxFormat.h
+191
-0
knot/Implementations/crypto_hash/knot384/armcortexm_5/crypto_hash.h
+7
-0
knot/Implementations/crypto_hash/knot384/armcortexm_5/hash.c
+43
-0
knot/Implementations/crypto_hash/knot512/armcortexm_2/api.h
+2
-0
knot/Implementations/crypto_hash/knot512/armcortexm_2/auxFormat.c
+58
-0
knot/Implementations/crypto_hash/knot512/armcortexm_2/auxFormat.h
+145
-0
knot/Implementations/crypto_hash/knot512/armcortexm_2/crypto_hash.h
+7
-0
knot/Implementations/crypto_hash/knot512/armcortexm_2/hash.c
+196
-0
knot/Implementations/crypto_hash/knot512/armcortexm_3/api.h
+4
-0
knot/Implementations/crypto_hash/knot512/armcortexm_3/auxFormat.h
+90
-0
knot/Implementations/crypto_hash/knot512/armcortexm_3/crypto_hash.h
+7
-0
knot/Implementations/crypto_hash/knot512/armcortexm_3/hash.c
+81
-0
knot/Implementations/crypto_hash/knot512/armcortexm_4/api.h
+2
-0
knot/Implementations/crypto_hash/knot512/armcortexm_4/auxFormat.c
+59
-0
knot/Implementations/crypto_hash/knot512/armcortexm_4/auxFormat.h
+47
-0
knot/Implementations/crypto_hash/knot512/armcortexm_4/crypto_hash.h
+7
-0
knot/Implementations/crypto_hash/knot512/armcortexm_4/hash.c
+62
-0
knot/Implementations/crypto_hash/knot512/armcortexm_5/api.h
+2
-0
knot/Implementations/crypto_hash/knot512/armcortexm_5/auxFormat.c
+94
-0
knot/Implementations/crypto_hash/knot512/armcortexm_5/auxFormat.h
+137
-0
knot/Implementations/crypto_hash/knot512/armcortexm_5/crypto_hash.h
+7
-0
knot/Implementations/crypto_hash/knot512/armcortexm_5/hash.c
+63
-0
No files found.
knot/Implementations/crypto_aead/knot128v1/armcortexm_5/api.h
0 → 100644
View file @
a34b1718
#define CRYPTO_KEYBYTES 16 //
#define CRYPTO_NSECBYTES 0
#define CRYPTO_NPUBBYTES 16
#define CRYPTO_ABYTES 16
#define CRYPTO_NOOVERLAP 1
knot/Implementations/crypto_aead/knot128v1/armcortexm_5/auxFormat.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
void
P256
(
unsigned
int
*
s
,
unsigned
char
*
rc
,
unsigned
char
rounds
)
{
unsigned
int
reg1
,
reg2
;
asm
volatile
(
"/*add round const*/
\n\t
"
"ldrb %[reg1], [%[rc]]
\n\t
"
"and %[reg2], %[reg1], 0xf
\n\t
"
"eors %[S_0], %[S_0], %[reg1],LSR #4
\n\t
"
/*s[0] ^= constant6Format[lunNum]>>4;*/
\
"eors %[S_1], %[S_1], %[reg2]
\n\t
"
/*s[1] ^= constant6Format[lunNum] & 0x0f;*/
\
"adds %[rc], %[rc], #1
\n\t
"
"/*sbox first column 0,2,4,6 sbox1(s[0], s[2], s[4], s[6]); */
\n\t
"
"mvns %[S_0], %[S_0]
\n\t
"
"ands %[reg1], %[S_2], %[S_0]
\n\t
"
"eors %[reg1], %[S_4], %[reg1]
\n\t
"
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
"eors %[reg2], %[S_2], %[S_6]
\n\t
"
"eors %[S_6], %[S_6], %[reg1]
\n\t
"
"ands %[S_0], %[reg1],%[S_0]
\n\t
"
"eors %[S_0], %[reg2],%[S_0]
\n\t
"
"ands %[S_2], %[S_4], %[reg2]
\n\t
"
"eors %[S_2], %[reg1], %[S_2]
\n\t
"
"/*sbox first column 1,3,5,7 sbox1(s[1], s[3], s[5], s[7]) */
\n\t
"
"mvns %[S_1], %[S_1]
\n\t
"
"ands %[reg1], %[S_3], %[S_1]
\n\t
"
"eors %[reg1], %[S_5], %[reg1]
\n\t
"
"orrs %[S_5], %[S_3], %[S_5]
\n\t
"
"eors %[S_1], %[S_7], %[S_1]
\n\t
"
"eors %[S_5], %[S_5], %[S_1]
\n\t
"
"eors %[reg2], %[S_3], %[S_7]
\n\t
"
"eors %[S_7], %[S_7], %[reg1]
\n\t
"
"ands %[S_1], %[reg1],%[S_1]
\n\t
"
"eors %[S_1], %[reg2],%[S_1]
\n\t
"
"ands %[S_3], %[S_5], %[reg2]
\n\t
"
"eors %[S_3], %[reg1], %[S_3]
\n\t
"
"enc_loop:
\n\t
"
"/*add round const*/
\n\t
"
"ldrb %[reg1], [%[rc]]
\n\t
"
"and %[reg2], %[reg1], 0xf
\n\t
"
"eors %[S_0], %[S_0], %[reg1],LSR #4
\n\t
"
/*s[0] ^= constant6Format[lunNum]>>4;*/
\
"eors %[S_1], %[S_1], %[reg2]
\n\t
"
/*s[1] ^= constant6Format[lunNum] & 0x0f;*/
\
"adds %[rc], %[rc], #1
\n\t
"
"/*sbox first column 0,3,4,7 sbox1(s[0], s[3],ROR(s[4], 28), ROR(s[7], 20)); */
\n\t
"
"ROR %[S_4], #28
\n\t
"
\
"ROR %[S_7], #20
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
"ands %[reg1], %[S_3], %[S_0]
\n\t
"
"eors %[reg1], %[S_4], %[reg1]
\n\t
"
"orrs %[S_4], %[S_3], %[S_4]
\n\t
"
"eors %[S_0], %[S_7], %[S_0]
\n\t
"
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
"eors %[reg2], %[S_3], %[S_7]
\n\t
"
"eors %[S_7], %[S_7], %[reg1]
\n\t
"
"ands %[S_0], %[reg1],%[S_0]
\n\t
"
"eors %[S_0], %[reg2],%[S_0]
\n\t
"
"ands %[S_3], %[S_4], %[reg2]
\n\t
"
"eors %[S_3], %[reg1], %[S_3]
\n\t
"
"/*sbox first column 1,2,5,6 sbox1(s[1], ROR(s[2], 31), ROR(s[5], 28), ROR(s[6], 19)); */
\n\t
"
"ROR %[S_2], #31
\n\t
"
\
"ROR %[S_5], #28
\n\t
"
\
"ROR %[S_6], #19
\n\t
"
\
"mvns %[S_1], %[S_1]
\n\t
"
"ands %[reg1], %[S_2], %[S_1]
\n\t
"
"eors %[reg1], %[S_5], %[reg1]
\n\t
"
"orrs %[S_5], %[S_2], %[S_5]
\n\t
"
"eors %[S_1], %[S_6], %[S_1]
\n\t
"
"eors %[S_5], %[S_5], %[S_1]
\n\t
"
"eors %[reg2], %[S_2], %[S_6]
\n\t
"
"eors %[S_6], %[S_6], %[reg1]
\n\t
"
"ands %[S_1], %[reg1],%[S_1]
\n\t
"
"eors %[S_1], %[reg2],%[S_1]
\n\t
"
"ands %[S_2], %[S_5], %[reg2]
\n\t
"
"eors %[S_2], %[reg1], %[S_2]
\n\t
"
"/*add round const*/
\n\t
"
"ldrb %[reg1], [%[rc]]
\n\t
"
"and %[reg2], %[reg1], 0xf
\n\t
"
"eors %[S_0], %[S_0], %[reg1],LSR #4
\n\t
"
/*s[0] ^= constant6Format[lunNum]>>4;*/
\
"eors %[S_1], %[S_1], %[reg2]
\n\t
"
/*s[1] ^= constant6Format[lunNum] & 0x0f;*/
\
"adds %[rc], %[rc], #1
\n\t
"
"/*sbox first column 0,2,4,6 sbox1(s[0], s[2], ROR(s[4], 28), ROR(s[6], 20)); */
\n\t
"
"ROR %[S_4], #28
\n\t
"
\
"ROR %[S_6], #20
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
"ands %[reg1], %[S_2], %[S_0]
\n\t
"
"eors %[reg1], %[S_4], %[reg1]
\n\t
"
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
"eors %[reg2], %[S_2], %[S_6]
\n\t
"
"eors %[S_6], %[S_6], %[reg1]
\n\t
"
"ands %[S_0], %[reg1],%[S_0]
\n\t
"
"eors %[S_0], %[reg2],%[S_0]
\n\t
"
"ands %[S_2], %[S_4], %[reg2]
\n\t
"
"eors %[S_2], %[reg1], %[S_2]
\n\t
"
"/*sbox first column 1,3,5,7 sbox1(s[1], ROR(s[3], 31), ROR(s[5], 28), ROR(s[7], 19)); */
\n\t
"
"ROR %[S_3], #31
\n\t
"
\
"ROR %[S_5], #28
\n\t
"
\
"ROR %[S_7], #19
\n\t
"
\
"mvns %[S_1], %[S_1]
\n\t
"
"ands %[reg1], %[S_3], %[S_1]
\n\t
"
"eors %[reg1], %[S_5], %[reg1]
\n\t
"
"orrs %[S_5], %[S_3], %[S_5]
\n\t
"
"eors %[S_1], %[S_7], %[S_1]
\n\t
"
"eors %[S_5], %[S_5], %[S_1]
\n\t
"
"eors %[reg2], %[S_3], %[S_7]
\n\t
"
"eors %[S_7], %[S_7], %[reg1]
\n\t
"
"ands %[S_1], %[reg1],%[S_1]
\n\t
"
"eors %[S_1], %[reg2],%[S_1]
\n\t
"
"ands %[S_3], %[S_5], %[reg2]
\n\t
"
"eors %[S_3], %[reg1], %[S_3]
\n\t
"
"/*loop control*/
\n\t
"
"subs %[ro], %[ro], #1
\n\t
"
"bne enc_loop
\n\t
"
"/*add round const*/
\n\t
"
"ldrb %[reg1], [%[rc]]
\n\t
"
"and %[reg2], %[reg1], 0xf
\n\t
"
"eors %[S_0], %[S_0], %[reg1],LSR #4
\n\t
"
/*s[0] ^= constant6Format[lunNum]>>4;*/
\
"eors %[S_1], %[S_1], %[reg2]
\n\t
"
/*s[1] ^= constant6Format[lunNum] & 0x0f;*/
\
"/*sbox first column 0,3,4,7 sbox1(s[0], s[3],ROR(s[4], 28), ROR(s[7], 20)); */
\n\t
"
"ROR %[S_4], #28
\n\t
"
\
"ROR %[S_7], #20
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
"ands %[reg1], %[S_3], %[S_0]
\n\t
"
"eors %[reg1], %[S_4], %[reg1]
\n\t
"
"orrs %[S_4], %[S_3], %[S_4]
\n\t
"
"eors %[S_0], %[S_7], %[S_0]
\n\t
"
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
"eors %[reg2], %[S_3], %[S_7]
\n\t
"
"eors %[S_7], %[S_7], %[reg1]
\n\t
"
"ands %[S_0], %[reg1],%[S_0]
\n\t
"
"eors %[S_0], %[reg2],%[S_0]
\n\t
"
"ands %[S_3], %[S_4], %[reg2]
\n\t
"
"eors %[S_3], %[reg1], %[S_3]
\n\t
"
"/*sbox first column 1,2,5,6 sbox1(s[1], ROR(s[2], 31), ROR(s[5], 28), ROR(s[6], 19)); */
\n\t
"
"ROR %[S_2], #31
\n\t
"
\
"ROR %[S_5], #28
\n\t
"
\
"ROR %[S_6], #19
\n\t
"
\
"mvns %[S_1], %[S_1]
\n\t
"
"ands %[reg1], %[S_2], %[S_1]
\n\t
"
"eors %[reg1], %[S_5], %[reg1]
\n\t
"
"orrs %[S_5], %[S_2], %[S_5]
\n\t
"
"eors %[S_1], %[S_6], %[S_1]
\n\t
"
"eors %[S_5], %[S_5], %[S_1]
\n\t
"
"eors %[reg2], %[S_2], %[S_6]
\n\t
"
"eors %[S_6], %[S_6], %[reg1]
\n\t
"
"ands %[S_1], %[reg1],%[S_1]
\n\t
"
"eors %[S_1], %[reg2],%[S_1]
\n\t
"
"ands %[S_2], %[S_5], %[reg2]
\n\t
"
"eors %[S_2], %[reg1], %[S_2]
\n\t
"
"ROR %[S_3], #31
\n\t
"
"ROR %[S_4], #28
\n\t
"
"ROR %[S_5], #28
\n\t
"
"ROR %[S_6], #20
\n\t
"
"ROR %[S_7], #19
\n\t
"
:
/* output variables - including inputs that are changed */
[
ro
]
"+r"
(
rounds
),[
reg1
]
"=r"
(
reg1
),
[
reg2
]
"=r"
(
reg2
),
[
rc
]
"+r"
(
rc
),
[
S_0
]
"+r"
(
s
[
0
]),
[
S_2
]
"+r"
(
s
[
2
]),
[
S_4
]
"+r"
(
s
[
4
]),
[
S_6
]
"+r"
(
s
[
6
])
,
[
S_1
]
"+r"
(
s
[
1
]),
[
S_3
]
"+r"
(
s
[
3
]),
[
S_5
]
"+r"
(
s
[
5
]),
[
S_7
]
"+r"
(
s
[
7
])
:
/* input variables */
:
/* clobber registers for temporary values */
);
}
void
packFormat
(
u32
*
out
,
const
u8
*
in
)
{
u32
t0
=
U32BIG
(((
u32
*
)
in
)[
0
]);
u32
t1
=
U32BIG
(((
u32
*
)
in
)[
1
]);
u32
r0
,
r1
;
r0
=
(
t0
^
(
t0
>>
1
))
&
0x22222222
,
t0
^=
r0
^
(
r0
<<
1
);
r0
=
(
t0
^
(
t0
>>
2
))
&
0x0C0C0C0C
,
t0
^=
r0
^
(
r0
<<
2
);
r0
=
(
t0
^
(
t0
>>
4
))
&
0x00F000F0
,
t0
^=
r0
^
(
r0
<<
4
);
r0
=
(
t0
^
(
t0
>>
8
))
&
0x0000FF00
,
t0
^=
r0
^
(
r0
<<
8
);
//t0 odd even
r1
=
(
t1
^
(
t1
>>
1
))
&
0x22222222
,
t1
^=
r1
^
(
r1
<<
1
);
r1
=
(
t1
^
(
t1
>>
2
))
&
0x0C0C0C0C
,
t1
^=
r1
^
(
r1
<<
2
);
r1
=
(
t1
^
(
t1
>>
4
))
&
0x00F000F0
,
t1
^=
r1
^
(
r1
<<
4
);
r1
=
(
t1
^
(
t1
>>
8
))
&
0x0000FF00
,
t1
^=
r1
^
(
r1
<<
8
);
//t1 odd even
out
[
0
]
=
(
t1
&
0xFFFF0000
)
|
(
t0
>>
16
);
// t1.odd|t0.odd
out
[
1
]
=
(
t1
<<
16
)
|
(
t0
&
0x0000FFFF
);
// t1.even|t0.even
}
void
unpackFormat
(
u8
*
out
,
u32
*
in
)
{
u32
t
[
2
]
=
{
0
};
t
[
1
]
=
(
in
[
0
]
&
0xFFFF0000
)
|
(
in
[
1
]
>>
16
);
t
[
0
]
=
(
in
[
1
]
&
0x0000FFFF
)
|
(
in
[
0
]
<<
16
);
u32
r0
,
r1
;
r0
=
(
t
[
0
]
^
(
t
[
0
]
>>
8
))
&
0x0000FF00
,
t
[
0
]
^=
r0
^
(
r0
<<
8
);
r0
=
(
t
[
0
]
^
(
t
[
0
]
>>
4
))
&
0x00F000F0
,
t
[
0
]
^=
r0
^
(
r0
<<
4
);
r0
=
(
t
[
0
]
^
(
t
[
0
]
>>
2
))
&
0x0C0C0C0C
,
t
[
0
]
^=
r0
^
(
r0
<<
2
);
r0
=
(
t
[
0
]
^
(
t
[
0
]
>>
1
))
&
0x22222222
,
t
[
0
]
^=
r0
^
(
r0
<<
1
);
r1
=
(
t
[
1
]
^
(
t
[
1
]
>>
8
))
&
0x0000FF00
,
t
[
1
]
^=
r1
^
(
r1
<<
8
);
r1
=
(
t
[
1
]
^
(
t
[
1
]
>>
4
))
&
0x00F000F0
,
t
[
1
]
^=
r1
^
(
r1
<<
4
);
r1
=
(
t
[
1
]
^
(
t
[
1
]
>>
2
))
&
0x0C0C0C0C
,
t
[
1
]
^=
r1
^
(
r1
<<
2
);
r1
=
(
t
[
1
]
^
(
t
[
1
]
>>
1
))
&
0x22222222
,
t
[
1
]
^=
r1
^
(
r1
<<
1
);
memcpy
(
out
,
t
,
8
*
sizeof
(
unsigned
char
));
}
knot/Implementations/crypto_aead/knot128v1/armcortexm_5/auxFormat.h
0 → 100644
View file @
a34b1718
#include"crypto_aead.h"
#include"api.h"
#include <string.h>
#define U32BIG(x) (x)
typedef
unsigned
char
u8
;
typedef
unsigned
int
u32
;
typedef
unsigned
long
long
u64
;
void
P256
(
unsigned
int
*
s
,
unsigned
char
*
rc
,
unsigned
char
rounds
);
void
packFormat
(
u32
*
out
,
const
u8
*
in
);
void
unpackFormat
(
u8
*
out
,
u32
*
in
);
knot/Implementations/crypto_aead/knot128v1/armcortexm_5/crypto_aead.h
0 → 100644
View file @
a34b1718
int
crypto_aead_encrypt
(
unsigned
char
*
c
,
unsigned
long
long
*
clen
,
const
unsigned
char
*
m
,
unsigned
long
long
mlen
,
const
unsigned
char
*
ad
,
unsigned
long
long
adlen
,
const
unsigned
char
*
nsec
,
const
unsigned
char
*
npub
,
const
unsigned
char
*
k
);
int
crypto_aead_decrypt
(
unsigned
char
*
m
,
unsigned
long
long
*
mlen
,
unsigned
char
*
nsec
,
const
unsigned
char
*
c
,
unsigned
long
long
clen
,
const
unsigned
char
*
ad
,
unsigned
long
long
adlen
,
const
unsigned
char
*
npub
,
const
unsigned
char
*
k
);
knot/Implementations/crypto_aead/knot128v1/armcortexm_5/encrypt.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
#define RATE (64 / 8)
/*
#define PR0_ROUNDS 52
#define PR_ROUNDS 28
#define PRF_ROUNDS 32
#define PR0_ROUNDS 25
#define PR_ROUNDS 13
#define PRF_ROUNDS 15
#define PR0_ROUNDS 25
#define PR_ROUNDS 17
#define PRF_ROUNDS 19
* */
#define PR0_ROUNDS 25
#define PR_ROUNDS 13
#define PRF_ROUNDS 15
unsigned
char
constant6Format
[
52
]
=
{
0x01
,
0x10
,
0x02
,
0x20
,
0x04
,
0x41
,
0x11
,
0x12
,
0x22
,
0x24
,
0x45
,
0x50
,
0x03
,
0x30
,
0x06
,
0x61
,
0x15
,
0x53
,
0x33
,
0x36
,
0x67
,
0x74
,
0x46
,
0x60
,
0x05
,
0x51
,
0x13
,
0x32
,
0x26
,
0x65
,
0x54
,
0x42
,
0x21
,
0x14
,
0x43
,
0x31
,
0x16
,
0x63
,
0x35
,
0x57
,
0x72
,
0x27
,
0x75
,
0x56
,
0x62
,
0x25
,
0x55
,
0x52
,
0x23
,
0x34
,
0x47
,
0x70
,
};
int
crypto_aead_encrypt
(
unsigned
char
*
c
,
unsigned
long
long
*
clen
,
const
unsigned
char
*
m
,
unsigned
long
long
mlen
,
const
unsigned
char
*
ad
,
unsigned
long
long
adlen
,
const
unsigned
char
*
nsec
,
const
unsigned
char
*
npub
,
const
unsigned
char
*
k
)
{
u32
s
[
8
]
=
{
0
};
u32
dataFormat
[
2
]
=
{
0
};
u8
tempData
[
16
];
// u32 t1, t2, t3, t5;
//initialization
*
clen
=
mlen
+
CRYPTO_ABYTES
;
packFormat
(
s
,
npub
);
packFormat
((
s
+
2
),
(
npub
+
8
));
packFormat
((
s
+
4
),
k
);
packFormat
((
s
+
6
),
(
k
+
8
));
P256
(
s
,
constant6Format
,
PR0_ROUNDS
);
// process associated data
if
(
adlen
)
{
while
(
adlen
>=
RATE
)
{
packFormat
(
dataFormat
,
ad
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
P256
(
s
,
constant6Format
,
PR_ROUNDS
);
adlen
-=
RATE
;
ad
+=
RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
ad
,
adlen
*
sizeof
(
unsigned
char
));
tempData
[
adlen
]
=
0x01
;
packFormat
(
dataFormat
,
tempData
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
P256
(
s
,
constant6Format
,
PR_ROUNDS
);
}
s
[
6
]
^=
0x80000000
;
//Encryption:
if
(
mlen
)
{
while
(
mlen
>=
RATE
)
{
packFormat
(
dataFormat
,
m
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
unpackFormat
(
c
,
s
);
P256
(
s
,
constant6Format
,
PR_ROUNDS
);
mlen
-=
RATE
;
m
+=
RATE
;
c
+=
RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
m
,
mlen
*
sizeof
(
unsigned
char
));
tempData
[
mlen
]
=
0x01
;
packFormat
(
dataFormat
,
tempData
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
unpackFormat
(
tempData
,
s
);
memcpy
(
c
,
tempData
,
mlen
*
sizeof
(
unsigned
char
));
c
+=
mlen
;
}
// finalization
P256
(
s
,
constant6Format
,
PRF_ROUNDS
);
unpackFormat
(
tempData
,
s
);
unpackFormat
((
tempData
+
8
),
(
s
+
2
));
memcpy
(
c
,
tempData
,
8
);
memcpy
(
c
+
8
,
tempData
+
8
,
8
);
return
0
;
}
int
crypto_aead_decrypt
(
unsigned
char
*
m
,
unsigned
long
long
*
mlen
,
unsigned
char
*
nsec
,
const
unsigned
char
*
c
,
unsigned
long
long
clen
,
const
unsigned
char
*
ad
,
unsigned
long
long
adlen
,
const
unsigned
char
*
npub
,
const
unsigned
char
*
k
)
{
u32
s
[
8
]
=
{
0
};
u32
dataFormat
[
4
]
=
{
0
};
u32
dataFormat_1
[
2
]
=
{
0
};
u8
tempU8
[
32
]
=
{
0
};
u8
tempData
[
16
];
//u32 t1, t2, t3, t5;
*
mlen
=
clen
-
CRYPTO_ABYTES
;
if
(
clen
<
CRYPTO_ABYTES
)
return
-
1
;
//initialization
packFormat
(
s
,
npub
);
packFormat
((
s
+
2
),
(
npub
+
8
));
packFormat
((
s
+
4
),
k
);
packFormat
((
s
+
6
),
(
k
+
8
));
P256
(
s
,
constant6Format
,
PR0_ROUNDS
);
// process associated data
if
(
adlen
)
{
while
(
adlen
>=
RATE
)
{
packFormat
(
dataFormat
,
ad
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
P256
(
s
,
constant6Format
,
PR_ROUNDS
);
adlen
-=
RATE
;
ad
+=
RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
ad
,
adlen
*
sizeof
(
unsigned
char
));
tempData
[
adlen
]
=
0x01
;
packFormat
(
dataFormat
,
tempData
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
P256
(
s
,
constant6Format
,
PR_ROUNDS
);
}
s
[
6
]
^=
0x80000000
;
// process c
clen
=
clen
-
CRYPTO_KEYBYTES
;
if
(
clen
)
{
while
(
clen
>=
RATE
)
{
packFormat
(
dataFormat
,
c
);
dataFormat_1
[
0
]
=
s
[
0
]
^
dataFormat
[
0
];
dataFormat_1
[
1
]
=
s
[
1
]
^
dataFormat
[
1
];
unpackFormat
(
m
,
dataFormat_1
);
s
[
0
]
=
dataFormat
[
0
];
s
[
1
]
=
dataFormat
[
1
];
P256
(
s
,
constant6Format
,
PR_ROUNDS
);
clen
-=
RATE
;
m
+=
RATE
;
c
+=
RATE
;
}
unpackFormat
(
tempU8
,
s
);
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
c
,
clen
*
sizeof
(
unsigned
char
));
tempData
[
clen
]
=
0x01
;
U32BIG
(((
u32
*
)
tempU8
)[
0
])
^=
U32BIG
(
((
u32
*
)
tempData
)[
0
]);
U32BIG
(((
u32
*
)
tempU8
)[
1
])
^=
U32BIG
(
((
u32
*
)
tempData
)[
1
]);
memcpy
(
m
,
tempU8
,
clen
*
sizeof
(
unsigned
char
));
memcpy
(
tempU8
,
tempData
,
clen
*
sizeof
(
unsigned
char
));
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
c
+=
clen
;
packFormat
(
s
,
tempU8
);
}
// finalization
P256
(
s
,
constant6Format
,
PRF_ROUNDS
);
unpackFormat
(
tempData
,
s
);
unpackFormat
((
tempData
+
8
),
(
s
+
2
));
if
(
memcmp
((
void
*
)
tempData
,
(
void
*
)
c
,
CRYPTO_ABYTES
))
{
memset
(
m
,
0
,
sizeof
(
unsigned
char
)
*
(
*
mlen
));
*
mlen
=
0
;
return
-
1
;
}
return
0
;
}
knot/Implementations/crypto_aead/knot128v2/armcortexm_5/api.h
0 → 100644
View file @
a34b1718
#define CRYPTO_KEYBYTES 16
#define CRYPTO_NSECBYTES 0
#define CRYPTO_NPUBBYTES 16
#define CRYPTO_ABYTES 16
#define CRYPTO_NOOVERLAP 1
knot/Implementations/crypto_aead/knot128v2/armcortexm_5/auxFormat.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
void
ROUND384_Three
(
unsigned
int
*
s
,
unsigned
char
*
c
,
int
lunnum
)
{
unsigned
int
t
,
t1
,
t2
;
u32
rci
;
rci
=
c
[
0
];
ROUND384_1
(
rci
);
t
=
1
;
while
(
lunnum
--
)
{
rci
=
c
[
t
];
ROUND384_2
(
rci
);
t
++
;
rci
=
c
[
t
];
ROUND384_3
(
rci
);
t
++
;
rci
=
c
[
t
];
ROUND384_4
(
rci
);
t
++
;
}
}
void
packU96FormatToThreePacket
(
u32
*
out
,
u8
*
in
)
{
u32
temp0
[
3
]
=
{
0
};
u32
temp1
[
3
]
=
{
0
};
u32
temp2
[
3
]
=
{
0
};
temp0
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
0
]);
temp0
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
1
;
temp0
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
2
;
puckU32ToThree_1
(
temp0
[
0
]);
puckU32ToThree_1
(
temp0
[
1
]);
puckU32ToThree_1
(
temp0
[
2
]);
temp1
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
1
]);
temp1
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
1
])
>>
1
;
temp1
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
1
])
>>
2
;
puckU32ToThree_1
(
temp1
[
0
]);
puckU32ToThree_1
(
temp1
[
1
]);
puckU32ToThree_1
(
temp1
[
2
]);
temp2
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
2
]);
temp2
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
2
])
>>
1
;
temp2
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
2
])
>>
2
;
puckU32ToThree_1
(
temp2
[
0
]);
puckU32ToThree_1
(
temp2
[
1
]);
puckU32ToThree_1
(
temp2
[
2
]);
out
[
0
]
=
(
temp2
[
1
]
<<
21
)
|
(
temp1
[
0
]
<<
10
)
|
temp0
[
2
];
out
[
1
]
=
(
temp2
[
0
]
<<
21
)
|
(
temp1
[
2
]
<<
11
)
|
temp0
[
1
];
out
[
2
]
=
(
temp2
[
2
]
<<
22
)
|
(
temp1
[
1
]
<<
11
)
|
temp0
[
0
];
}
void
unpackU96FormatToThreePacket
(
u8
*
out
,
u32
*
in
)
{
u32
temp0
[
3
]
=
{
0
};
u32
temp1
[
3
]
=
{
0
};
u32
temp2
[
3
]
=
{
0
};
u32
t
[
3
]
=
{
0
};
temp0
[
0
]
=
in
[
2
]
&
0x7ff
;
temp0
[
1
]
=
in
[
1
]
&
0x7ff
;
temp0
[
2
]
=
in
[
0
]
&
0x3ff
;
temp1
[
0
]
=
(
in
[
0
]
>>
10
)
&
0x7ff
;
temp1
[
1
]
=
(
in
[
2
]
>>
11
)
&
0x7ff
;
temp1
[
2
]
=
(
in
[
1
]
>>
11
)
&
0x3ff
;
temp2
[
0
]
=
in
[
1
]
>>
21
;
temp2
[
1
]
=
in
[
0
]
>>
21
;
temp2
[
2
]
=
in
[
2
]
>>
22
;
unpuckU32ToThree_1
(
temp0
[
0
]);
unpuckU32ToThree_1
(
temp0
[
1
]);
unpuckU32ToThree_1
(
temp0
[
2
]);
t
[
0
]
=
temp0
[
0
]
|
temp0
[
1
]
<<
1
|
temp0
[
2
]
<<
2
;
unpuckU32ToThree_1
(
temp1
[
0
]);
unpuckU32ToThree_1
(
temp1
[
1
]);
unpuckU32ToThree_1
(
temp1
[
2
]);
t
[
1
]
=
temp1
[
0
]
|
temp1
[
1
]
<<
1
|
temp1
[
2
]
<<
2
;
unpuckU32ToThree_1
(
temp2
[
0
]);
unpuckU32ToThree_1
(
temp2
[
1
]);
unpuckU32ToThree_1
(
temp2
[
2
]);
t
[
2
]
=
temp2
[
0
]
|
temp2
[
1
]
<<
1
|
temp2
[
2
]
<<
2
;
memcpy
(
out
,
t
,
12
*
sizeof
(
unsigned
char
));
}
knot/Implementations/crypto_aead/knot128v2/armcortexm_5/auxFormat.h
0 → 100644
View file @
a34b1718
#include"crypto_aead.h"
#include"api.h"
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#define U32BIG(x) (x)
typedef
unsigned
char
u8
;
typedef
unsigned
int
u32
;
typedef
unsigned
long
long
u64
;
void
ROUND384_Three
(
unsigned
int
*
s
,
unsigned
char
*
c
,
int
lunnum
);
#define puckU32ToThree_1(x){\
x
&=
0x49249249
;
\
x
=
(
x
|
(
x
>>
2
))
&
0xc30c30c3
;
\
x
=
(
x
|
(
x
>>
4
))
&
0x0f00f00f
;
\
x
=
(
x
|
(
x
>>
8
))
&
0xff0000ff
;
\
x
=
(
x
|
(
x
>>
16
))
&
0xfff
;
\
}
#define unpuckU32ToThree_1(x){\
x
&=
0xfff
;
\
x
=
(
x
|
(
x
<<
16
))
&
0xff0000ff
;
\
x
=
(
x
|
(
x
<<
8
))
&
0x0f00f00f
;
\
x
=
(
x
|
(
x
<<
4
))
&
0xc30c30c3
;
\
x
=
(
x
|
(
x
<<
2
))
&
0x49249249
;
\
}
#define ARR_SIZE(a) (sizeof((a))/sizeof((a[0])))
//Processing_Data:
#define Processing_Data(data) \
do
{
\
packU96FormatToThreePacket
(
dataFormat
,
data
);
\
s
[
0
]
^=
dataFormat
[
0
];
\
s
[
1
]
^=
dataFormat
[
1
];
\
s
[
2
]
^=
dataFormat
[
2
];
\
packU96FormatToThreePacket
((
dataFormat
+
3
),
(
data
+
12
));
\
s
[
3
]
^=
dataFormat
[
3
];
\
s
[
4
]
^=
dataFormat
[
4
];
\
s
[
5
]
^=
dataFormat
[
5
];
\
}
while
(
0
)
/////////////////////////
#define ARC(rci) \
do
{
\
__asm__
__volatile__
(
\
"/*add round const s0 s1 s2 */
\n\t
"
\
"ands %[t1], %[rci], #0xc0
\n\t
"
\
"eors %[S_0], %[S_0], %[t1], LSR #6
\n\t
"
/*s[0] ^= (constant7Format[lunNum] >> 6) & 0x3;*/
\
"ands %[t1], %[rci], #0x38
\n\t
"
\
"eors %[S_1], %[S_1], %[t1], LSR #3
\n\t
"
/*s[0] ^= (constant7Format[lunNum] >> 6) & 0x3;*/
\
"ands %[t1], %[rci], #0x7
\n\t
"
\
"eors %[S_3], %[S_3], %[t1]
\n\t
"
/*s[2] ^= constant7Format[lunNum] & 0x7;*/
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
rci
]
"+r"
(
rci
),
\
[
S_0
]
"+r"
(
s
[
0
]),
[
S_1
]
"+r"
(
s
[
1
]),
[
S_3
]
"+r"
(
s
[
2
])
\
:
:
);
\
}
while
(
0
)
#define SBOX(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define SBOX1(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"ROR %[S_4] , #30
\n\t
"
\
"ROR %[S_6] , #14
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define SBOX2(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"ROR %[S_4] , #29
\n\t
"
\
"ROR %[S_6] , #14
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define SBOX3(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"ROR %[S_2] , #31
\n\t
"
\
"ROR %[S_4] , #29
\n\t
"
\
"ROR %[S_6] , #13
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define ROUND384_1(rci) {\
ARC
(
rci
);
\
SBOX
(
s
[
0
],
s
[
3
],
s
[
6
],
s
[
9
]
);
\
SBOX
(
s
[
1
],
s
[
4
],
s
[
7
],
s
[
10
]);
\
SBOX
(
s
[
2
],
s
[
5
],
s
[
8
],
s
[
11
]);
\
}
#define ROUND384_2(rci) {\
ARC
(
rci
);
\
SBOX1
(
s
[
0
],
s
[
4
],
s
[
8
],
s
[
10
]
);
\
SBOX2
(
s
[
1
],
s
[
5
],
s
[
6
],
s
[
11
]);
\
SBOX3
(
s
[
2
],
s
[
3
],
s
[
7
],
s
[
9
]);
\
}
#define ROUND384_3(rci) {\
ARC
(
rci
);
\
SBOX1
(
s
[
0
],
s
[
5
],
s
[
7
],
s
[
11
]);
\
SBOX2
(
s
[
1
],
s
[
3
],
s
[
8
],
s
[
9
]);
\
SBOX3
(
s
[
2
],
s
[
4
],
s
[
6
],
s
[
10
]);
\
}
#define ROUND384_4(rci) {\
ARC
(
rci
);
\
SBOX1
(
s
[
0
],
s
[
3
],
s
[
6
],
s
[
9
]);
\
SBOX2
(
s
[
1
],
s
[
4
],
s
[
7
],
s
[
10
]);
\
SBOX3
(
s
[
2
],
s
[
5
],
s
[
8
],
s
[
11
]);
\
}
#define P384_1( s, round, lunNum) {\
u32
t1
;
\
ROUND384_Three
(
s
,
round
,
lunNum
);
\
__asm__
__volatile__
(
\
"/*rotate shift left 1 bit [w9 w5 w1-> (w1,1) w9 w5] */
\n\t
"
\
"mov %[t1], %[S_3]
\n\t
"
\
"mov %[S_3], %[S_4]
\n\t
"
\
"mov %[S_4], %[S_5]
\n\t
"
\
"ROR %[S_5], %[t1] , #31
\n\t
"
\
"/*rotate shift left 8 bits [w10 w6 w2-> (w6,3) (w2,3) ( w10,2)]*/
\n\t
"
\
"mov %[t1], %[S_8]
\n\t
"
\
"ROR %[S_8], %[S_7] , #29
\n\t
"
\
"ROR %[S_7], %[S_6] , #29
\n\t
"
\
"ROR %[S_6], %[t1] , #30
\n\t
"
\
"/*rotate shift left 55 bit [w11 w7 w3-> (w3,13) (w11,14) ( w7,14)] */
\n\t
"
\
"mov %[t1], %[S_9]
\n\t
"
\
"ROR %[S_9], %[S_10] , #14
\n\t
"
\
"ROR %[S_10], %[S_11] , #14
\n\t
"
\
"ROR %[S_11], %[t1] , #13
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
\
[
S_3
]
"+r"
(
s
[
3
]),
[
S_6
]
"+r"
(
s
[
6
]),
[
S_9
]
"+r"
(
s
[
9
])
,
\
[
S_4
]
"+r"
(
s
[
4
]),
[
S_7
]
"+r"
(
s
[
7
]),
[
S_10
]
"+r"
(
s
[
10
]),
\
[
S_5
]
"+r"
(
s
[
5
]),
[
S_8
]
"+r"
(
s
[
8
]),
[
S_11
]
"+r"
(
s
[
11
])
\
:
:
);
\
}
#define P384_2( s, round, lunNum) {\
u32
t1
,
rci
;
\
ROUND384_Three
(
s
,
round
,
lunNum
);
\
rci
=
round
[
lunNum
*
3
+
1
];
\
ROUND384_2
(
rci
);
\
__asm__
__volatile__
(
\
"/*rotate shift left 1 bit [w9 w5 w1-> (w1,1) w9 w5] */
\n\t
"
\
"mov %[t1], %[S_4]
\n\t
"
\
"mov %[S_4], %[S_3]
\n\t
"
\
"mov %[S_3], %[S_5]
\n\t
"
\
"ROR %[S_5], %[t1] , #31
\n\t
"
\
"/*rotate shift left 8 bits [w10 w6 w2-> (w6,3) (w2,3) ( w10,2)]*/
\n\t
"
\
"mov %[t1], %[S_8]
\n\t
"
\
"ROR %[S_8], %[S_6] , #29
\n\t
"
\
"ROR %[S_6], %[S_7] , #30
\n\t
"
\
"ROR %[S_7], %[t1] , #29
\n\t
"
\
"/*rotate shift left 55 bit [w11 w7 w3-> (w3,13) (w11,14) ( w7,14)] */
\n\t
"
\
"mov %[t1], %[S_10]
\n\t
"
\
"ROR %[S_10], %[S_9] , #14
\n\t
"
\
"ROR %[S_9], %[S_11] , #14
\n\t
"
\
"ROR %[S_11], %[t1] , #13
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
\
[
S_3
]
"+r"
(
s
[
3
]),
[
S_6
]
"+r"
(
s
[
6
]),
[
S_9
]
"+r"
(
s
[
9
])
,
\
[
S_4
]
"+r"
(
s
[
4
]),
[
S_7
]
"+r"
(
s
[
7
]),
[
S_10
]
"+r"
(
s
[
10
]),
\
[
S_5
]
"+r"
(
s
[
5
]),
[
S_8
]
"+r"
(
s
[
8
]),
[
S_11
]
"+r"
(
s
[
11
])
\
:
:
);
\
}
//////////////////////
knot/Implementations/crypto_aead/knot128v2/armcortexm_5/crypto_aead.h
0 → 100644
View file @
a34b1718
int
crypto_aead_encrypt
(
unsigned
char
*
c
,
unsigned
long
long
*
clen
,
const
unsigned
char
*
m
,
unsigned
long
long
mlen
,
const
unsigned
char
*
ad
,
unsigned
long
long
adlen
,
const
unsigned
char
*
nsec
,
const
unsigned
char
*
npub
,
const
unsigned
char
*
k
);
int
crypto_aead_decrypt
(
unsigned
char
*
m
,
unsigned
long
long
*
mlen
,
unsigned
char
*
nsec
,
const
unsigned
char
*
c
,
unsigned
long
long
clen
,
const
unsigned
char
*
ad
,
unsigned
long
long
adlen
,
const
unsigned
char
*
npub
,
const
unsigned
char
*
k
);
knot/Implementations/crypto_aead/knot128v2/armcortexm_5/encrypt.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
#define aead_RATE (192 / 8)
/*
#define PR0_ROUNDS 76 /3=25+1
#define PR_ROUNDS 28 /3=9+1
#define PRF_ROUNDS 32 /3=10+2
#define PR0_ROUNDS 25
#define PR_ROUNDS 13
#define PRF_ROUNDS 14
*/
#define PR0_ROUNDS 25
#define PR_ROUNDS 9
#define PRF_ROUNDS 10
unsigned
char
constant7Format
[
76
]
=
{
0x01
,
0x08
,
0x40
,
0x02
,
0x10
,
0x80
,
0x05
,
0x09
,
0x48
,
0x42
,
0x12
,
0x90
,
0x85
,
0x0c
,
0x41
,
0x0a
,
0x50
,
0x82
,
0x15
,
0x89
,
0x4d
,
0x4b
,
0x5a
,
0xd2
,
0x97
,
0x9c
,
0xc4
,
0x06
,
0x11
,
0x88
,
0x45
,
0x0b
,
0x58
,
0xc2
,
0x17
,
0x99
,
0xcd
,
0x4e
,
0x53
,
0x9a
,
0xd5
,
0x8e
,
0x54
,
0x83
,
0x1d
,
0xc9
,
0x4f
,
0x5b
,
0xda
,
0xd7
,
0x9e
,
0xd4
,
0x86
,
0x14
,
0x81
,
0x0d
,
0x49
,
0x4a
,
0x52
,
0x92
,
0x95
,
0x8c
,
0x44
,
0x03
,
0x18
,
0xc0
,
0x07
,
0x19
,
0xc8
,
0x47
,
0x1b
,
0xd8
,
0xc7
,
0x1e
,
0xd1
,
0x8f
,
};
int
crypto_aead_encrypt
(
unsigned
char
*
c
,
unsigned
long
long
*
clen
,
const
unsigned
char
*
m
,
unsigned
long
long
mlen
,
const
unsigned
char
*
ad
,
unsigned
long
long
adlen
,
const
unsigned
char
*
nsec
,
const
unsigned
char
*
npub
,
const
unsigned
char
*
k
)
{
u32
s
[
12
]
=
{
0
};
u8
tempData
[
24
]
=
{
0
};
u32
dataFormat
[
6
]
=
{
0
};
u8
tempU8
[
24
]
=
{
0
};
u32
t2
;
*
clen
=
mlen
+
CRYPTO_ABYTES
;
// initialization
packU96FormatToThreePacket
(
s
,
npub
);
memcpy
(
tempData
,
npub
+
12
,
sizeof
(
unsigned
char
)
*
4
);
memcpy
(
tempData
+
4
,
k
,
sizeof
(
unsigned
char
)
*
16
);
packU96FormatToThreePacket
((
s
+
3
),
tempData
);
packU96FormatToThreePacket
((
s
+
6
),
(
tempData
+
12
));
s
[
9
]
=
0x80000000
;
P384_1
(
s
,
constant7Format
,
PR0_ROUNDS
);
// process associated data
if
(
adlen
)
{
while
(
adlen
>=
aead_RATE
)
{
Processing_Data
(
ad
);
P384_1
(
s
,
constant7Format
,
PR_ROUNDS
);
adlen
-=
aead_RATE
;
ad
+=
aead_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
ad
,
adlen
*
sizeof
(
unsigned
char
));
tempData
[
adlen
]
=
0x01
;
Processing_Data
(
tempData
);
P384_1
(
s
,
constant7Format
,
PR_ROUNDS
);
}
s
[
9
]
^=
0x80000000
;
// process p data
if
(
mlen
)
{
while
(
mlen
>=
aead_RATE
)
{
Processing_Data
(
m
);
unpackU96FormatToThreePacket
(
c
,
s
);
unpackU96FormatToThreePacket
((
c
+
12
),
(
s
+
3
));
P384_1
(
s
,
constant7Format
,
PR_ROUNDS
);
mlen
-=
aead_RATE
;
m
+=
aead_RATE
;
c
+=
aead_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
m
,
mlen
*
sizeof
(
unsigned
char
));
tempData
[
mlen
]
=
0x01
;
Processing_Data
(
tempData
);
unpackU96FormatToThreePacket
(
tempData
,
s
);
unpackU96FormatToThreePacket
((
tempData
+
12
),
(
s
+
3
));
memcpy
(
c
,
tempData
,
mlen
*
sizeof
(
unsigned
char
));
c
+=
mlen
;
}
// finalization
P384_2
(
s
,
constant7Format
,
PRF_ROUNDS
);
unpackU96FormatToThreePacket
(
tempU8
,
s
);
unpackU96FormatToThreePacket
((
tempU8
+
12
),
(
s
+
3
));
memcpy
(
c
,
tempU8
,
sizeof
(
unsigned
char
)
*
12
);
memcpy
(
c
+
12
,
tempU8
+
12
,
sizeof
(
unsigned
char
)
*
4
);
return
0
;
}
int
crypto_aead_decrypt
(
unsigned
char
*
m
,
unsigned
long
long
*
mlen
,
unsigned
char
*
nsec
,
const
unsigned
char
*
c
,
unsigned
long
long
clen
,
const
unsigned
char
*
ad
,
unsigned
long
long
adlen
,
const
unsigned
char
*
npub
,
const
unsigned
char
*
k
)
{
u32
s
[
12
]
=
{
0
};
u32
dataFormat
[
12
]
=
{
0
};
u32
dataFormat_1
[
12
]
=
{
0
};
u8
tempData
[
24
]
=
{
0
};
u8
tempU8
[
24
]
=
{
0
};
u32
t2
;
*
mlen
=
clen
-
CRYPTO_ABYTES
;
if
(
clen
<
CRYPTO_ABYTES
)
return
-
1
;
// initialization
packU96FormatToThreePacket
(
s
,
npub
);
memcpy
(
tempData
,
npub
+
12
,
sizeof
(
unsigned
char
)
*
4
);
memcpy
(
tempData
+
4
,
k
,
sizeof
(
unsigned
char
)
*
16
);
packU96FormatToThreePacket
((
s
+
3
),
tempData
);
packU96FormatToThreePacket
((
s
+
6
),
(
tempData
+
12
));
s
[
9
]
=
0x80000000
;
P384_1
(
s
,
constant7Format
,
PR0_ROUNDS
);
// process associated data
if
(
adlen
)
{
while
(
adlen
>=
aead_RATE
)
{
Processing_Data
(
ad
);
P384_1
(
s
,
constant7Format
,
PR_ROUNDS
);
adlen
-=
aead_RATE
;
ad
+=
aead_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
ad
,
adlen
*
sizeof
(
unsigned
char
));
tempData
[
adlen
]
=
0x01
;
Processing_Data
(
tempData
);
P384_1
(
s
,
constant7Format
,
PR_ROUNDS
);
}
s
[
9
]
^=
0x80000000
;
clen
-=
CRYPTO_ABYTES
;
if
(
clen
)
{
while
(
clen
>=
aead_RATE
)
{
packU96FormatToThreePacket
(
dataFormat
,
c
);
dataFormat_1
[
0
]
=
s
[
0
]
^
dataFormat
[
0
];
dataFormat_1
[
1
]
=
s
[
1
]
^
dataFormat
[
1
];
dataFormat_1
[
2
]
=
s
[
2
]
^
dataFormat
[
2
];
packU96FormatToThreePacket
((
dataFormat
+
3
),
(
c
+
12
));
dataFormat_1
[
3
]
=
s
[
3
]
^
dataFormat
[
3
];
dataFormat_1
[
4
]
=
s
[
4
]
^
dataFormat
[
4
];
dataFormat_1
[
5
]
=
s
[
5
]
^
dataFormat
[
5
];
unpackU96FormatToThreePacket
(
m
,
dataFormat_1
);
unpackU96FormatToThreePacket
((
m
+
12
),
(
dataFormat_1
+
3
));
s
[
0
]
=
dataFormat
[
0
];
s
[
1
]
=
dataFormat
[
1
];
s
[
2
]
=
dataFormat
[
2
];
s
[
3
]
=
dataFormat
[
3
];
s
[
4
]
=
dataFormat
[
4
];
s
[
5
]
=
dataFormat
[
5
];
P384_1
(
s
,
constant7Format
,
PR_ROUNDS
);
clen
-=
aead_RATE
;
m
+=
aead_RATE
;
c
+=
aead_RATE
;
}
unpackU96FormatToThreePacket
(
tempU8
,
s
);
unpackU96FormatToThreePacket
((
tempU8
+
12
),
(
s
+
3
));
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
c
,
clen
*
sizeof
(
unsigned
char
));
tempData
[
clen
]
=
0x01
;
U32BIG
(((
u32
*
)
tempU8
)[
0
])
^=
U32BIG
(((
u32
*
)
tempData
)[
0
]);
U32BIG
(((
u32
*
)
tempU8
)[
1
])
^=
U32BIG
(((
u32
*
)
tempData
)[
1
]);
U32BIG
(((
u32
*
)
tempU8
)[
2
])
^=
U32BIG
(((
u32
*
)
tempData
)[
2
]);
U32BIG
(((
u32
*
)
tempU8
)[
3
])
^=
U32BIG
(((
u32
*
)
tempData
)[
3
]);
U32BIG
(((
u32
*
)
tempU8
)[
4
])
^=
U32BIG
(((
u32
*
)
tempData
)[
4
]);
U32BIG
(((
u32
*
)
tempU8
)[
5
])
^=
U32BIG
(((
u32
*
)
tempData
)[
5
]);
memcpy
(
m
,
tempU8
,
clen
*
sizeof
(
unsigned
char
));
memcpy
(
tempU8
,
tempData
,
clen
*
sizeof
(
unsigned
char
));
c
+=
clen
;
packU96FormatToThreePacket
(
s
,
tempU8
);
packU96FormatToThreePacket
((
s
+
3
),
(
tempU8
+
12
));
}
// finalization
P384_2
(
s
,
constant7Format
,
PRF_ROUNDS
);
unpackU96FormatToThreePacket
(
tempU8
,
s
);
unpackU96FormatToThreePacket
((
tempU8
+
12
),
(
s
+
3
));
if
(
memcmp
((
void
*
)
tempU8
,
(
void
*
)
(
c
),
CRYPTO_ABYTES
))
{
memset
(
m
,
0
,
sizeof
(
unsigned
char
)
*
(
*
mlen
));
*
mlen
=
0
;
return
-
1
;
}
return
0
;
}
knot/Implementations/crypto_aead/knot192/armcortexm_5/api.h
0 → 100644
View file @
a34b1718
#define CRYPTO_KEYBYTES 24
#define CRYPTO_NSECBYTES 0
#define CRYPTO_NPUBBYTES 24
#define CRYPTO_ABYTES 24
#define CRYPTO_NOOVERLAP 1
knot/Implementations/crypto_aead/knot192/armcortexm_5/auxFormat.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
void
ROUND384_Three
(
unsigned
int
*
s
,
unsigned
char
*
c
,
int
lunnum
)
{
\
unsigned
int
t
,
t1
,
t2
;
u32
rci
;
rci
=
c
[
0
];
ROUND384_1
(
rci
);
t
=
1
;
while
(
lunnum
--
)
{
rci
=
c
[
t
];
ROUND384_2
(
rci
);
t
++
;
rci
=
c
[
t
];
ROUND384_3
(
rci
);
t
++
;
rci
=
c
[
t
];
ROUND384_4
(
rci
);
t
++
;
}
}
void
packU96FormatToThreePacket
(
u32
*
out
,
u8
*
in
)
{
u32
temp0
[
3
]
=
{
0
};
u32
temp1
[
3
]
=
{
0
};
u32
temp2
[
3
]
=
{
0
};
temp0
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
0
]);
temp0
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
1
;
temp0
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
2
;
puckU32ToThree_1
(
temp0
[
0
]);
puckU32ToThree_1
(
temp0
[
1
]);
puckU32ToThree_1
(
temp0
[
2
]);
temp1
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
1
]);
temp1
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
1
])
>>
1
;
temp1
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
1
])
>>
2
;
puckU32ToThree_1
(
temp1
[
0
]);
puckU32ToThree_1
(
temp1
[
1
]);
puckU32ToThree_1
(
temp1
[
2
]);
temp2
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
2
]);
temp2
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
2
])
>>
1
;
temp2
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
2
])
>>
2
;
puckU32ToThree_1
(
temp2
[
0
]);
puckU32ToThree_1
(
temp2
[
1
]);
puckU32ToThree_1
(
temp2
[
2
]);
out
[
0
]
=
(
temp2
[
1
]
<<
21
)
|
(
temp1
[
0
]
<<
10
)
|
temp0
[
2
];
out
[
1
]
=
(
temp2
[
0
]
<<
21
)
|
(
temp1
[
2
]
<<
11
)
|
temp0
[
1
];
out
[
2
]
=
(
temp2
[
2
]
<<
22
)
|
(
temp1
[
1
]
<<
11
)
|
temp0
[
0
];
}
void
unpackU96FormatToThreePacket
(
u8
*
out
,
u32
*
in
)
{
u32
temp0
[
3
]
=
{
0
};
u32
temp1
[
3
]
=
{
0
};
u32
temp2
[
3
]
=
{
0
};
u32
t
[
3
]
=
{
0
};
temp0
[
0
]
=
in
[
2
]
&
0x7ff
;
temp0
[
1
]
=
in
[
1
]
&
0x7ff
;
temp0
[
2
]
=
in
[
0
]
&
0x3ff
;
temp1
[
0
]
=
(
in
[
0
]
>>
10
)
&
0x7ff
;
temp1
[
1
]
=
(
in
[
2
]
>>
11
)
&
0x7ff
;
temp1
[
2
]
=
(
in
[
1
]
>>
11
)
&
0x3ff
;
temp2
[
0
]
=
in
[
1
]
>>
21
;
temp2
[
1
]
=
in
[
0
]
>>
21
;
temp2
[
2
]
=
in
[
2
]
>>
22
;
unpuckU32ToThree_1
(
temp0
[
0
]);
unpuckU32ToThree_1
(
temp0
[
1
]);
unpuckU32ToThree_1
(
temp0
[
2
]);
t
[
0
]
=
temp0
[
0
]
|
temp0
[
1
]
<<
1
|
temp0
[
2
]
<<
2
;
unpuckU32ToThree_1
(
temp1
[
0
]);
unpuckU32ToThree_1
(
temp1
[
1
]);
unpuckU32ToThree_1
(
temp1
[
2
]);
t
[
1
]
=
temp1
[
0
]
|
temp1
[
1
]
<<
1
|
temp1
[
2
]
<<
2
;
unpuckU32ToThree_1
(
temp2
[
0
]);
unpuckU32ToThree_1
(
temp2
[
1
]);
unpuckU32ToThree_1
(
temp2
[
2
]);
t
[
2
]
=
temp2
[
0
]
|
temp2
[
1
]
<<
1
|
temp2
[
2
]
<<
2
;
memcpy
(
out
,
t
,
12
*
sizeof
(
unsigned
char
));
}
void
packU48FormatToThreePacket
(
u32
*
out
,
u8
*
in
)
{
u32
t1
=
(
u32
)
U16BIG
(
*
(
u16
*
)(
in
+
4
));
u32
temp0
[
3
]
=
{
0
};
u32
temp1
[
3
]
=
{
0
};
temp0
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
0
]);
temp0
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
1
;
temp0
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
2
;
puckU32ToThree_1
(
temp0
[
0
]);
puckU32ToThree_1
(
temp0
[
1
]);
puckU32ToThree_1
(
temp0
[
2
]);
temp1
[
0
]
=
t1
;
temp1
[
1
]
=
t1
>>
1
;
temp1
[
2
]
=
t1
>>
2
;
puckU32ToThree_1
(
temp1
[
0
]);
puckU32ToThree_1
(
temp1
[
1
]);
puckU32ToThree_1
(
temp1
[
2
]);
out
[
0
]
=
(
temp1
[
0
]
<<
10
)
|
temp0
[
2
];
out
[
1
]
=
(
temp1
[
2
]
<<
11
)
|
temp0
[
1
];
out
[
2
]
=
(
temp1
[
1
]
<<
11
)
|
temp0
[
0
];
}
knot/Implementations/crypto_aead/knot192/armcortexm_5/auxFormat.h
0 → 100644
View file @
a34b1718
#include"crypto_aead.h"
#include"api.h"
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#define U32BIG(x) (x)
#define U16BIG(x) (x)
typedef
unsigned
char
u8
;
typedef
unsigned
short
u16
;
typedef
unsigned
int
u32
;
typedef
unsigned
long
long
u64
;
#define puckU32ToThree_1(x){\
x
&=
0x49249249
;
\
x
=
(
x
|
(
x
>>
2
))
&
0xc30c30c3
;
\
x
=
(
x
|
(
x
>>
4
))
&
0x0f00f00f
;
\
x
=
(
x
|
(
x
>>
8
))
&
0xff0000ff
;
\
x
=
(
x
|
(
x
>>
16
))
&
0xfff
;
\
}
#define unpuckU32ToThree_1(x){\
x
&=
0xfff
;
\
x
=
(
x
|
(
x
<<
16
))
&
0xff0000ff
;
\
x
=
(
x
|
(
x
<<
8
))
&
0x0f00f00f
;
\
x
=
(
x
|
(
x
<<
4
))
&
0xc30c30c3
;
\
x
=
(
x
|
(
x
<<
2
))
&
0x49249249
;
\
}
void
ROUND384_Three
(
unsigned
int
*
s
,
unsigned
char
*
c
,
int
lunnum
);
#define ARC(rci) \
do
{
\
__asm__
__volatile__
(
\
"/*add round const s0 s1 s2 */
\n\t
"
\
"ands %[t1], %[rci], #0xc0
\n\t
"
\
"eors %[S_0], %[S_0], %[t1], LSR #6
\n\t
"
/*s[0] ^= (constant7Format[lunNum] >> 6) & 0x3;*/
\
"ands %[t1], %[rci], #0x38
\n\t
"
\
"eors %[S_1], %[S_1], %[t1], LSR #3
\n\t
"
/*s[0] ^= (constant7Format[lunNum] >> 6) & 0x3;*/
\
"ands %[t1], %[rci], #0x7
\n\t
"
\
"eors %[S_3], %[S_3], %[t1]
\n\t
"
/*s[2] ^= constant7Format[lunNum] & 0x7;*/
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
rci
]
"+r"
(
rci
),
\
[
S_0
]
"+r"
(
s
[
0
]),
[
S_1
]
"+r"
(
s
[
1
]),
[
S_3
]
"+r"
(
s
[
2
])
\
:
:
);
\
}
while
(
0
)
#define SBOX(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define SBOX1(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"ROR %[S_4] , #30
\n\t
"
\
"ROR %[S_6] , #14
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define SBOX2(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"ROR %[S_4] , #29
\n\t
"
\
"ROR %[S_6] , #14
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define SBOX3(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"ROR %[S_2] , #31
\n\t
"
\
"ROR %[S_4] , #29
\n\t
"
\
"ROR %[S_6] , #13
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define ROUND384_1(rci) {\
ARC
(
rci
);
\
SBOX
(
s
[
0
],
s
[
3
],
s
[
6
],
s
[
9
]
);
\
SBOX
(
s
[
1
],
s
[
4
],
s
[
7
],
s
[
10
]);
\
SBOX
(
s
[
2
],
s
[
5
],
s
[
8
],
s
[
11
]);
\
}
#define ROUND384_2(rci) {\
ARC
(
rci
);
\
SBOX1
(
s
[
0
],
s
[
4
],
s
[
8
],
s
[
10
]
);
\
SBOX2
(
s
[
1
],
s
[
5
],
s
[
6
],
s
[
11
]);
\
SBOX3
(
s
[
2
],
s
[
3
],
s
[
7
],
s
[
9
]);
\
}
#define ROUND384_3(rci) {\
ARC
(
rci
);
\
SBOX1
(
s
[
0
],
s
[
5
],
s
[
7
],
s
[
11
]);
\
SBOX2
(
s
[
1
],
s
[
3
],
s
[
8
],
s
[
9
]);
\
SBOX3
(
s
[
2
],
s
[
4
],
s
[
6
],
s
[
10
]);
\
}
#define ROUND384_4(rci) {\
ARC
(
rci
);
\
SBOX1
(
s
[
0
],
s
[
3
],
s
[
6
],
s
[
9
]);
\
SBOX2
(
s
[
1
],
s
[
4
],
s
[
7
],
s
[
10
]);
\
SBOX3
(
s
[
2
],
s
[
5
],
s
[
8
],
s
[
11
]);
\
}
#define P384_1( s, round, lunNum) {\
u32
t1
;
\
ROUND384_Three
(
s
,
round
,
lunNum
);
\
__asm__
__volatile__
(
\
"/*rotate shift left 1 bit [w9 w5 w1-> (w1,1) w9 w5] */
\n\t
"
\
"mov %[t1], %[S_3]
\n\t
"
\
"mov %[S_3], %[S_4]
\n\t
"
\
"mov %[S_4], %[S_5]
\n\t
"
\
"ROR %[S_5], %[t1] , #31
\n\t
"
\
"/*rotate shift left 8 bits [w10 w6 w2-> (w6,3) (w2,3) ( w10,2)]*/
\n\t
"
\
"mov %[t1], %[S_8]
\n\t
"
\
"ROR %[S_8], %[S_7] , #29
\n\t
"
\
"ROR %[S_7], %[S_6] , #29
\n\t
"
\
"ROR %[S_6], %[t1] , #30
\n\t
"
\
"/*rotate shift left 55 bit [w11 w7 w3-> (w3,13) (w11,14) ( w7,14)] */
\n\t
"
\
"mov %[t1], %[S_9]
\n\t
"
\
"ROR %[S_9], %[S_10] , #14
\n\t
"
\
"ROR %[S_10], %[S_11] , #14
\n\t
"
\
"ROR %[S_11], %[t1] , #13
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
\
[
S_3
]
"+r"
(
s
[
3
]),
[
S_6
]
"+r"
(
s
[
6
]),
[
S_9
]
"+r"
(
s
[
9
])
,
\
[
S_4
]
"+r"
(
s
[
4
]),
[
S_7
]
"+r"
(
s
[
7
]),
[
S_10
]
"+r"
(
s
[
10
]),
\
[
S_5
]
"+r"
(
s
[
5
]),
[
S_8
]
"+r"
(
s
[
8
]),
[
S_11
]
"+r"
(
s
[
11
])
\
:
:
);
\
}
#define P384_2( s, round, lunNum) {\
u32
t1
,
rci
;
\
ROUND384_Three
(
s
,
round
,
lunNum
);
\
rci
=
round
[
lunNum
*
3
+
1
];
\
ROUND384_2
(
rci
);
\
__asm__
__volatile__
(
\
"/*rotate shift left 1 bit [w9 w5 w1-> (w1,1) w9 w5] */
\n\t
"
\
"mov %[t1], %[S_4]
\n\t
"
\
"mov %[S_4], %[S_3]
\n\t
"
\
"mov %[S_3], %[S_5]
\n\t
"
\
"ROR %[S_5], %[t1] , #31
\n\t
"
\
"/*rotate shift left 8 bits [w10 w6 w2-> (w6,3) (w2,3) ( w10,2)]*/
\n\t
"
\
"mov %[t1], %[S_8]
\n\t
"
\
"ROR %[S_8], %[S_6] , #29
\n\t
"
\
"ROR %[S_6], %[S_7] , #30
\n\t
"
\
"ROR %[S_7], %[t1] , #29
\n\t
"
\
"/*rotate shift left 55 bit [w11 w7 w3-> (w3,13) (w11,14) ( w7,14)] */
\n\t
"
\
"mov %[t1], %[S_10]
\n\t
"
\
"ROR %[S_10], %[S_9] , #14
\n\t
"
\
"ROR %[S_9], %[S_11] , #14
\n\t
"
\
"ROR %[S_11], %[t1] , #13
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
\
[
S_3
]
"+r"
(
s
[
3
]),
[
S_6
]
"+r"
(
s
[
6
]),
[
S_9
]
"+r"
(
s
[
9
])
,
\
[
S_4
]
"+r"
(
s
[
4
]),
[
S_7
]
"+r"
(
s
[
7
]),
[
S_10
]
"+r"
(
s
[
10
]),
\
[
S_5
]
"+r"
(
s
[
5
]),
[
S_8
]
"+r"
(
s
[
8
]),
[
S_11
]
"+r"
(
s
[
11
])
\
:
:
);
\
}
knot/Implementations/crypto_aead/knot192/armcortexm_5/crypto_aead.h
0 → 100644
View file @
a34b1718
int
crypto_aead_encrypt
(
unsigned
char
*
c
,
unsigned
long
long
*
clen
,
const
unsigned
char
*
m
,
unsigned
long
long
mlen
,
const
unsigned
char
*
ad
,
unsigned
long
long
adlen
,
const
unsigned
char
*
nsec
,
const
unsigned
char
*
npub
,
const
unsigned
char
*
k
);
int
crypto_aead_decrypt
(
unsigned
char
*
m
,
unsigned
long
long
*
mlen
,
unsigned
char
*
nsec
,
const
unsigned
char
*
c
,
unsigned
long
long
clen
,
const
unsigned
char
*
ad
,
unsigned
long
long
adlen
,
const
unsigned
char
*
npub
,
const
unsigned
char
*
k
);
knot/Implementations/crypto_aead/knot192/armcortexm_5/encrypt.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
#define aead_RATE (96 / 8)
#define PR0_ROUNDS 25
#define PR_ROUNDS 13
#define PRF_ROUNDS 14
/*
#define PR0_ROUNDS 25
#define PR_ROUNDS 18
#define PRF_ROUNDS 19
#define PR0_ROUNDS 25
#define PR_ROUNDS 13
#define PRF_ROUNDS 14
#define PR0_ROUNDS 76 /3=25+1
#define PR_ROUNDS 40 /3=13+1
#define PRF_ROUNDS 44 /3=14+2
* */
unsigned
char
constant7Format
[
76
]
=
{
0x01
,
0x08
,
0x40
,
0x02
,
0x10
,
0x80
,
0x05
,
0x09
,
0x48
,
0x42
,
0x12
,
0x90
,
0x85
,
0x0c
,
0x41
,
0x0a
,
0x50
,
0x82
,
0x15
,
0x89
,
0x4d
,
0x4b
,
0x5a
,
0xd2
,
0x97
,
0x9c
,
0xc4
,
0x06
,
0x11
,
0x88
,
0x45
,
0x0b
,
0x58
,
0xc2
,
0x17
,
0x99
,
0xcd
,
0x4e
,
0x53
,
0x9a
,
0xd5
,
0x8e
,
0x54
,
0x83
,
0x1d
,
0xc9
,
0x4f
,
0x5b
,
0xda
,
0xd7
,
0x9e
,
0xd4
,
0x86
,
0x14
,
0x81
,
0x0d
,
0x49
,
0x4a
,
0x52
,
0x92
,
0x95
,
0x8c
,
0x44
,
0x03
,
0x18
,
0xc0
,
0x07
,
0x19
,
0xc8
,
0x47
,
0x1b
,
0xd8
,
0xc7
,
0x1e
,
0xd1
,
0x8f
};
int
crypto_aead_encrypt
(
unsigned
char
*
c
,
unsigned
long
long
*
clen
,
const
unsigned
char
*
m
,
unsigned
long
long
mlen
,
const
unsigned
char
*
ad
,
unsigned
long
long
adlen
,
const
unsigned
char
*
nsec
,
const
unsigned
char
*
npub
,
const
unsigned
char
*
k
)
{
u32
s
[
12
]
=
{
0
};
u32
dataFormat
[
3
]
=
{
0
};
u8
tempData
[
12
]
=
{
0
};
u32
t2
;
u32
temp0
[
3
]
=
{
0
};
u32
temp1
[
3
]
=
{
0
};
u32
temp2
[
3
]
=
{
0
};
u32
t
[
3
]
=
{
0
};
*
clen
=
mlen
+
CRYPTO_ABYTES
;
// initialization
packU96FormatToThreePacket
(
s
,
npub
);
packU96FormatToThreePacket
((
s
+
3
),
(
npub
+
12
));
packU96FormatToThreePacket
((
s
+
6
),
k
);
packU96FormatToThreePacket
((
s
+
9
),
(
k
+
12
));
P384_1
(
s
,
constant7Format
,
PR0_ROUNDS
);
// process associated data
if
(
adlen
)
{
while
(
adlen
>=
aead_RATE
)
{
packU96FormatToThreePacket
(
dataFormat
,
ad
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
P384_1
(
s
,
constant7Format
,
PR_ROUNDS
);
adlen
-=
aead_RATE
;
ad
+=
aead_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
ad
,
adlen
);
tempData
[
adlen
]
=
0x01
;
packU96FormatToThreePacket
(
dataFormat
,
tempData
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
P384_1
(
s
,
constant7Format
,
PR_ROUNDS
);
}
s
[
9
]
^=
0x80000000
;
if
(
mlen
)
{
while
(
mlen
>=
aead_RATE
)
{
packU96FormatToThreePacket
(
dataFormat
,
m
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
unpackU96FormatToThreePacket
(
c
,
s
);
P384_1
(
s
,
constant7Format
,
PR_ROUNDS
);
mlen
-=
aead_RATE
;
m
+=
aead_RATE
;
c
+=
aead_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
m
,
mlen
);
tempData
[
mlen
]
=
0x01
;
packU96FormatToThreePacket
(
dataFormat
,
tempData
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
unpackU96FormatToThreePacket
(
tempData
,
s
);
memcpy
(
c
,
tempData
,
mlen
);
c
+=
mlen
;
}
// finalization
P384_2
(
s
,
constant7Format
,
PRF_ROUNDS
);
// return tag
unpackU96FormatToThreePacket
(
c
,
s
);
unpackU96FormatToThreePacket
((
c
+
12
),
(
s
+
3
));
return
0
;
}
int
crypto_aead_decrypt
(
unsigned
char
*
m
,
unsigned
long
long
*
mlen
,
unsigned
char
*
nsec
,
const
unsigned
char
*
c
,
unsigned
long
long
clen
,
const
unsigned
char
*
ad
,
unsigned
long
long
adlen
,
const
unsigned
char
*
npub
,
const
unsigned
char
*
k
)
{
u32
s
[
12
]
=
{
0
};
u32
dataFormat
[
6
]
=
{
0
};
u32
dataFormat_1
[
3
]
=
{
0
};
u8
tempData
[
12
]
=
{
0
};
u8
tempU8
[
48
]
=
{
0
};
u32
t2
;
u32
temp0
[
3
]
=
{
0
};
u32
temp1
[
3
]
=
{
0
};
u32
temp2
[
3
]
=
{
0
};
u32
t
[
3
]
=
{
0
};
\
*
mlen
=
clen
-
CRYPTO_ABYTES
;
if
(
clen
<
CRYPTO_ABYTES
)
return
-
1
;
// initialization
packU96FormatToThreePacket
(
s
,
npub
);
packU96FormatToThreePacket
((
s
+
3
),
(
npub
+
12
));
packU96FormatToThreePacket
((
s
+
6
),
k
);
packU96FormatToThreePacket
((
s
+
9
),
(
k
+
12
));
P384_1
(
s
,
constant7Format
,
PR0_ROUNDS
);
// process associated data
if
(
adlen
)
{
while
(
adlen
>=
aead_RATE
)
{
packU96FormatToThreePacket
(
dataFormat
,
ad
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
P384_1
(
s
,
constant7Format
,
PR_ROUNDS
);
adlen
-=
aead_RATE
;
ad
+=
aead_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
ad
,
adlen
);
tempData
[
adlen
]
=
0x01
;
packU96FormatToThreePacket
(
dataFormat
,
tempData
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
P384_1
(
s
,
constant7Format
,
PR_ROUNDS
);
}
s
[
9
]
^=
0x80000000
;
clen
-=
CRYPTO_ABYTES
;
if
(
clen
)
{
while
(
clen
>=
aead_RATE
)
{
packU96FormatToThreePacket
(
dataFormat
,
c
);
dataFormat_1
[
0
]
=
s
[
0
]
^
dataFormat
[
0
];
dataFormat_1
[
1
]
=
s
[
1
]
^
dataFormat
[
1
];
dataFormat_1
[
2
]
=
s
[
2
]
^
dataFormat
[
2
];
unpackU96FormatToThreePacket
(
m
,
dataFormat_1
);
s
[
0
]
=
dataFormat
[
0
];
s
[
1
]
=
dataFormat
[
1
];
s
[
2
]
=
dataFormat
[
2
];
P384_1
(
s
,
constant7Format
,
PR_ROUNDS
);
clen
-=
aead_RATE
;
m
+=
aead_RATE
;
c
+=
aead_RATE
;
}
unpackU96FormatToThreePacket
(
tempU8
,
s
);
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
c
,
clen
*
sizeof
(
unsigned
char
));
tempData
[
clen
]
=
0x01
;
U32BIG
(((
u32
*
)
tempU8
)[
0
])
^=
U32BIG
(((
u32
*
)
tempData
)[
0
]);
U32BIG
(((
u32
*
)
tempU8
)[
1
])
^=
U32BIG
(((
u32
*
)
tempData
)[
1
]);
U32BIG
(((
u32
*
)
tempU8
)[
2
])
^=
U32BIG
(((
u32
*
)
tempData
)[
2
]);
memcpy
(
m
,
tempU8
,
clen
*
sizeof
(
unsigned
char
));
memcpy
(
tempU8
,
tempData
,
clen
*
sizeof
(
unsigned
char
));
packU96FormatToThreePacket
(
s
,
tempU8
);
c
+=
clen
;
}
// finalization
P384_2
(
s
,
constant7Format
,
PRF_ROUNDS
);
// return tag
packU96FormatToThreePacket
(
dataFormat
,
c
);
packU96FormatToThreePacket
((
dataFormat
+
3
),
(
c
+
12
));
if
(
dataFormat
[
0
]
!=
s
[
0
]
||
dataFormat
[
1
]
!=
s
[
1
]
||
dataFormat
[
2
]
!=
s
[
2
]
||
dataFormat
[
3
]
!=
s
[
3
]
||
dataFormat
[
4
]
!=
s
[
4
]
||
dataFormat
[
5
]
!=
s
[
5
])
{
return
-
1
;
}
//////////
return
0
;
}
knot/Implementations/crypto_aead/knot256/armcortexm_5/api.h
0 → 100644
View file @
a34b1718
#define CRYPTO_KEYBYTES 32 //256/8=32
#define CRYPTO_NSECBYTES 0
#define CRYPTO_NPUBBYTES 32
#define CRYPTO_ABYTES 32
#define CRYPTO_NOOVERLAP 1
knot/Implementations/crypto_aead/knot256/armcortexm_5/auxFormat.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
void
P512
(
unsigned
int
*
s
,
unsigned
char
*
round
,
unsigned
char
rounds
)
{
u32
rci
,
t1
,
t2
,
t3
,
t9
;
unsigned
char
rcNum
=
0
;
rci
=
round
[
rcNum
++
];
ARC
(
rci
);
SBOX1
(
s
[
0
],
s
[
4
],
s
[
8
],
s
[
12
]);
SBOX1
(
s
[
1
],
s
[
5
],
s
[
9
],
s
[
13
]);
SBOX1
(
s
[
2
],
s
[
6
],
s
[
10
],
s
[
14
]);
SBOX1
(
s
[
3
],
s
[
7
],
s
[
11
],
s
[
15
]);
while
(
rounds
--
)
{
rci
=
round
[
rcNum
++
];
ARC
(
rci
);
SBOX2
(
s
[
0
],
s
[
7
],
s
[
8
],
s
[
15
]);
SBOX3
(
s
[
1
],
s
[
4
],
s
[
9
],
s
[
12
]);
SBOX3
(
s
[
2
],
s
[
5
],
s
[
10
],
s
[
13
]);
SBOX3
(
s
[
3
],
s
[
6
],
s
[
11
],
s
[
14
]);
rci
=
round
[
rcNum
++
];
ARC
(
rci
);
SBOX2
(
s
[
0
],
s
[
6
],
s
[
8
],
s
[
14
]);
SBOX3
(
s
[
1
],
s
[
7
],
s
[
9
],
s
[
15
]);
SBOX3
(
s
[
2
],
s
[
4
],
s
[
10
],
s
[
12
]);
SBOX3
(
s
[
3
],
s
[
5
],
s
[
11
],
s
[
13
]);
rci
=
round
[
rcNum
++
];
ARC
(
rci
);
SBOX2
(
s
[
0
],
s
[
5
],
s
[
8
],
s
[
13
]);
SBOX3
(
s
[
1
],
s
[
6
],
s
[
9
],
s
[
14
]);
SBOX3
(
s
[
2
],
s
[
7
],
s
[
10
],
s
[
15
]);
SBOX3
(
s
[
3
],
s
[
4
],
s
[
11
],
s
[
12
]);
rci
=
round
[
rcNum
++
];
ARC
(
rci
);
SBOX2
(
s
[
0
],
s
[
4
],
s
[
8
],
s
[
12
]);
SBOX3
(
s
[
1
],
s
[
5
],
s
[
9
],
s
[
13
]);
SBOX3
(
s
[
2
],
s
[
6
],
s
[
10
],
s
[
14
]);
SBOX3
(
s
[
3
],
s
[
7
],
s
[
11
],
s
[
15
]);
}
rci
=
round
[
rcNum
++
];
ARC
(
rci
);
SBOX2
(
s
[
0
],
s
[
7
],
s
[
8
],
s
[
15
]);
SBOX3
(
s
[
1
],
s
[
4
],
s
[
9
],
s
[
12
]);
SBOX3
(
s
[
2
],
s
[
5
],
s
[
10
],
s
[
13
]);
SBOX3
(
s
[
3
],
s
[
6
],
s
[
11
],
s
[
14
]);
rci
=
round
[
rcNum
++
];
ARC
(
rci
);
SBOX2
(
s
[
0
],
s
[
6
],
s
[
8
],
s
[
14
]);
SBOX3
(
s
[
1
],
s
[
7
],
s
[
9
],
s
[
15
]);
SBOX3
(
s
[
2
],
s
[
4
],
s
[
10
],
s
[
12
]);
SBOX3
(
s
[
3
],
s
[
5
],
s
[
11
],
s
[
13
]);
rci
=
round
[
rcNum
++
];
ARC
(
rci
);
SBOX2
(
s
[
0
],
s
[
5
],
s
[
8
],
s
[
13
]);
SBOX3
(
s
[
1
],
s
[
6
],
s
[
9
],
s
[
14
]);
SBOX3
(
s
[
2
],
s
[
7
],
s
[
10
],
s
[
15
]);
SBOX3
(
s
[
3
],
s
[
4
],
s
[
11
],
s
[
12
]);
SR
(
s
[
4
],
s
[
8
],
s
[
9
],
s
[
10
],
s
[
11
],
s
[
12
],
s
[
13
],
s
[
14
],
s
[
15
]);
}
void
packU128FormatToFourPacket
(
u32
*
out
,
u8
*
in
)
{
u32
t0
=
U32BIG
(((
u32
*
)
in
)[
0
]);
u32
t1
=
U32BIG
(((
u32
*
)
in
)[
1
]);
u32
t2
=
U32BIG
(((
u32
*
)
in
)[
2
]);
u32
t3
=
U32BIG
(((
u32
*
)
in
)[
3
]);
u32
temp1
;
puck32
(
t0
);
puck32
(
t0
);
puck32
(
t1
);
puck32
(
t1
);
puck32
(
t2
);
puck32
(
t2
);
puck32
(
t3
);
puck32
(
t3
);
out
[
3
]
=
(
t3
&
0xff000000
)
|
((
t2
>>
8
)
&
0x00ff0000
)
|
((
t1
>>
16
)
&
0x0000ff00
)
|
(
t0
>>
24
);
out
[
2
]
=
((
t3
<<
8
)
&
0xff000000
)
|
(
t2
&
0x00ff0000
)
|
((
t1
>>
8
)
&
0x0000ff00
)
|
((
t0
>>
16
)
&
0x000000ff
);
out
[
1
]
=
((
t3
<<
16
)
&
0xff000000
)
|
((
t2
<<
8
)
&
0x00ff0000
)
|
(
t1
&
0x0000ff00
)
|
((
t0
>>
8
)
&
0x000000ff
);
out
[
0
]
=
((
t3
<<
24
)
&
0xff000000
)
|
((
t2
<<
16
)
&
0x00ff0000
)
|
((
t1
<<
8
)
&
0x0000ff00
)
|
(
t0
&
0x000000ff
);
}
void
unpackU128FormatToFourPacket
(
u8
*
out
,
u32
*
in
)
{
u32
t
[
4
]
=
{
0
};
u32
r0
;
t
[
3
]
=
(
in
[
3
]
&
0xff000000
)
|
((
in
[
2
]
>>
8
)
&
0x00ff0000
)
|
((
in
[
1
]
>>
16
)
&
0x0000ff00
)
|
(
in
[
0
]
>>
24
);
t
[
2
]
=
((
in
[
3
]
<<
8
)
&
0xff000000
)
|
(
in
[
2
]
&
0x00ff0000
)
|
((
in
[
1
]
>>
8
)
&
0x0000ff00
)
|
((
in
[
0
]
>>
16
)
&
0x000000ff
);
t
[
1
]
=
((
in
[
3
]
<<
16
)
&
0xff000000
)
|
((
in
[
2
]
<<
8
)
&
0x00ff0000
)
|
(
in
[
1
]
&
0x0000ff00
)
|
((
in
[
0
]
>>
8
)
&
0x000000ff
);
t
[
0
]
=
((
in
[
3
]
<<
24
)
&
0xff000000
)
|
((
in
[
2
]
<<
16
)
&
0x00ff0000
)
|
((
in
[
1
]
<<
8
)
&
0x0000ff00
)
|
(
in
[
0
]
&
0x000000ff
);
unpuck32
(
t
[
0
]);
unpuck32
(
t
[
0
]);
unpuck32
(
t
[
1
]);
unpuck32
(
t
[
1
]);
unpuck32
(
t
[
2
]);
unpuck32
(
t
[
2
]);
unpuck32
(
t
[
3
]);
unpuck32
(
t
[
3
]);
memcpy
(
out
,
t
,
16
*
sizeof
(
unsigned
char
));
}
void
packU64FormatToFourPacket
(
u32
*
out
,
u8
*
in
)
{
u32
t1
,
t2
,
temp1
;
t1
=
U32BIG
(((
u32
*
)
in
)[
0
]);
t2
=
U32BIG
(((
u32
*
)
in
)[
1
]);
puck32
(
t1
);
puck32
(
t1
);
puck32
(
t2
);
puck32
(
t2
);
out
[
3
]
=
((
t2
>>
16
)
&
0x0000ff00
)
|
((
t1
>>
24
));
out
[
2
]
=
((
t2
>>
8
)
&
0x0000ff00
)
|
((
t1
>>
16
)
&
0x000000ff
);
out
[
1
]
=
(
t2
&
0x0000ff00
)
|
((
t1
>>
8
)
&
0x000000ff
);
out
[
0
]
=
((
t2
<<
8
)
&
0x0000ff00
)
|
(
t1
&
0x000000ff
);
}
knot/Implementations/crypto_aead/knot256/armcortexm_5/auxFormat.h
0 → 100644
View file @
a34b1718
#include"crypto_aead.h"
#include"api.h"
#include <string.h>
#define U32BIG(x) (x)
void
P512
(
unsigned
int
*
s
,
unsigned
char
*
round
,
unsigned
char
rounds
);
typedef
unsigned
char
u8
;
typedef
unsigned
int
u32
;
typedef
unsigned
long
long
u64
;
void
printU8
(
char
name
[],
u8
var
[],
long
len
,
int
offset
);
#define puck32(in)\
{
\
temp1
=
(
in
^
(
in
>>
1
))
&
0x22222222
;
in
^=
temp1
^
(
temp1
<<
1
);
\
temp1
=
(
in
^
(
in
>>
2
))
&
0x0C0C0C0C
;
in
^=
temp1
^
(
temp1
<<
2
);
\
temp1
=
(
in
^
(
in
>>
4
))
&
0x00F000F0
;
in
^=
temp1
^
(
temp1
<<
4
);
\
temp1
=
(
in
^
(
in
>>
8
))
&
0x0000FF00
;
in
^=
temp1
^
(
temp1
<<
8
);
\
}
#define unpuck32(t0){\
r0
=
(
t0
^
(
t0
>>
8
))
&
0x0000FF00
,
t0
^=
r0
^
(
r0
<<
8
);
\
r0
=
(
t0
^
(
t0
>>
4
))
&
0x00F000F0
,
t0
^=
r0
^
(
r0
<<
4
);
\
r0
=
(
t0
^
(
t0
>>
2
))
&
0x0C0C0C0C
,
t0
^=
r0
^
(
r0
<<
2
);
\
r0
=
(
t0
^
(
t0
>>
1
))
&
0x22222222
,
t0
^=
r0
^
(
r0
<<
1
);
\
}
//t1
#define ARC(rci) \
do
{
\
__asm__
__volatile__
(
\
"/*add round const s0 s1 s2 s3*/
\n\t
"
\
"ands %[t1] , %[rci], #0xc0
\n\t
"
\
"eors %[S_3], %[S_3], %[t1], LSR #6
\n\t
"
/*s[3] ^= (constant7Format_aead[lunNum] >> 6) & 0x3;*/
\
"ands %[t2] , %[rci], #0x30
\n\t
"
\
"eors %[S_2], %[S_2], %[t2], LSR #4
\n\t
"
/*s[2] ^= (constant7Format_aead[lunNum] >> 4) & 0x3;*/
\
"ands %[t3] , %[rci], #0xc
\n\t
"
\
"eors %[S_1], %[S_1], %[t3], LSR #2
\n\t
"
/*s[1] ^= (constant7Format_aead[lunNum] >> 2) & 0x3;*/
\
"ands %[t4] , %[rci], #0x3
\n\t
"
\
"eors %[S_0], %[S_0], %[t4]
\n\t
"
/*s[0] ^= constant7Format_aead[lunNum] & 0x3;*/
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
[
t3
]
"=r"
(
t3
),
[
t4
]
"=r"
(
t9
),
[
rci
]
"+r"
(
rci
),
\
[
S_0
]
"+r"
(
s
[
0
]),
[
S_1
]
"+r"
(
s
[
1
]),
[
S_2
]
"+r"
(
s
[
2
]),[
S_3
]
"+r"
(
s
[
3
])
\
:
:
);
\
}
while
(
0
)
#define SBOX2(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"ROR %[S_2] , #31
\n\t
"
\
"ROR %[S_4] , #28
\n\t
"
\
"ROR %[S_6] , #25
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define SBOX3(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"ROR %[S_4] , #28
\n\t
"
\
"ROR %[S_6] , #26
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define SBOX1(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define SR(S4,S8,S9,S10,S11,S12,S13,S14,S15) \
do
{
\
__asm__
__volatile__
(
\
"ROR %[S_4] , #31
\n\t
"
\
"ROR %[S_11] , #28
\n\t
"
\
"ROR %[S_10] , #28
\n\t
"
\
"ROR %[S_9] , #28
\n\t
"
\
"ROR %[S_8] , #28
\n\t
"
\
"ROR %[S_12] , #25
\n\t
"
\
"ROR %[S_13] , #26
\n\t
"
\
"ROR %[S_14] , #26
\n\t
"
\
"ROR %[S_15] , #26
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
S_4
]
"+r"
(
S4
),
\
[
S_12
]
"+r"
(
S12
),
[
S_8
]
"+r"
(
S8
)
,
\
[
S_13
]
"+r"
(
S13
),
[
S_9
]
"+r"
(
S9
)
,
\
[
S_14
]
"+r"
(
S14
),
[
S_10
]
"+r"
(
S10
),
\
[
S_15
]
"+r"
(
S15
),
[
S_11
]
"+r"
(
S11
)
\
:
:
);
\
}
while
(
0
)
unsigned
char
constant7Format_aead
[
100
];
knot/Implementations/crypto_aead/knot256/armcortexm_5/crypto_aead.h
0 → 100644
View file @
a34b1718
int
crypto_aead_encrypt
(
unsigned
char
*
c
,
unsigned
long
long
*
clen
,
const
unsigned
char
*
m
,
unsigned
long
long
mlen
,
const
unsigned
char
*
ad
,
unsigned
long
long
adlen
,
const
unsigned
char
*
nsec
,
const
unsigned
char
*
npub
,
const
unsigned
char
*
k
);
int
crypto_aead_decrypt
(
unsigned
char
*
m
,
unsigned
long
long
*
mlen
,
unsigned
char
*
nsec
,
const
unsigned
char
*
c
,
unsigned
long
long
clen
,
const
unsigned
char
*
ad
,
unsigned
long
long
adlen
,
const
unsigned
char
*
npub
,
const
unsigned
char
*
k
);
knot/Implementations/crypto_aead/knot256/armcortexm_5/encrypt.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
#define aead_RATE (128 / 8)
/*
#define PR0_ROUNDS 100 /4=25
#define PR_ROUNDS 52 /4=13
#define PRF_ROUNDS 56 /4=14
#define PR0_ROUNDS 24
#define PR_ROUNDS 18
#define PRF_ROUNDS 19
* */
#define PR0_ROUNDS 24
#define PR_ROUNDS 12
#define PRF_ROUNDS 13
unsigned
char
constant7Format_aead
[
100
]
=
{
0x01
,
0x04
,
0x10
,
0x40
,
0x02
,
0x08
,
0x21
,
0x05
,
0x14
,
0x50
,
0x42
,
0x0a
,
0x29
,
0x24
,
0x11
,
0x44
,
0x12
,
0x48
,
0x23
,
0x0d
,
0x35
,
0x55
,
0x56
,
0x5a
,
0x6b
,
0x2e
,
0x38
,
0x60
,
0x03
,
0x0c
,
0x31
,
0x45
,
0x16
,
0x58
,
0x63
,
0x0f
,
0x3d
,
0x74
,
0x53
,
0x4e
,
0x3b
,
0x6c
,
0x32
,
0x49
,
0x27
,
0x1d
,
0x75
,
0x57
,
0x5e
,
0x7b
,
0x6e
,
0x3a
,
0x68
,
0x22
,
0x09
,
0x25
,
0x15
,
0x54
,
0x52
,
0x4a
,
0x2b
,
0x2c
,
0x30
,
0x41
,
0x06
,
0x18
,
0x61
,
0x07
,
0x1c
,
0x71
,
0x47
,
0x1e
,
0x79
,
0x66
,
0x1b
,
0x6d
,
0x36
,
0x59
,
0x67
,
0x1f
,
0x7d
,
0x76
,
0x5b
,
0x6f
,
0x3e
,
0x78
,
0x62
,
0x0b
,
0x2d
,
0x34
,
0x51
,
0x46
,
0x1a
,
0x69
,
0x26
,
0x19
,
0x65
,
0x17
,
0x5c
,
0x73
,
};
//initialization
#define Processing_Data(data) \
do
{
\
packU128FormatToFourPacket
(
dataFormat
,
data
);
\
s
[
0
]
^=
dataFormat
[
0
];
\
s
[
1
]
^=
dataFormat
[
1
];
\
s
[
2
]
^=
dataFormat
[
2
];
\
s
[
3
]
^=
dataFormat
[
3
];
\
}
while
(
0
)
int
crypto_aead_encrypt
(
unsigned
char
*
c
,
unsigned
long
long
*
clen
,
const
unsigned
char
*
m
,
unsigned
long
long
mlen
,
const
unsigned
char
*
ad
,
unsigned
long
long
adlen
,
const
unsigned
char
*
nsec
,
const
unsigned
char
*
npub
,
const
unsigned
char
*
k
)
{
u32
s
[
16
]
=
{
0
};
u32
dataFormat
[
4
]
=
{
0
};
u8
tempData
[
16
]
=
{
0
};
u8
tempU8
[
32
]
=
{
0
};
*
clen
=
mlen
+
CRYPTO_ABYTES
;
//initialization
packU128FormatToFourPacket
(
s
,
npub
);
packU128FormatToFourPacket
((
s
+
4
),
(
npub
+
16
));
packU128FormatToFourPacket
((
s
+
8
),
k
);
packU128FormatToFourPacket
((
s
+
12
),
(
k
+
16
));
P512
(
s
,
constant7Format_aead
,
PR0_ROUNDS
);
// process associated data
if
(
adlen
)
{
while
(
adlen
>=
aead_RATE
)
{
packU128FormatToFourPacket
(
dataFormat
,
ad
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
s
[
3
]
^=
dataFormat
[
3
];
P512
(
s
,
constant7Format_aead
,
PR_ROUNDS
);
adlen
-=
aead_RATE
;
ad
+=
aead_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
ad
,
adlen
*
sizeof
(
unsigned
char
));
tempData
[
adlen
]
=
0x01
;
packU128FormatToFourPacket
(
dataFormat
,
tempData
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
s
[
3
]
^=
dataFormat
[
3
];
P512
(
s
,
constant7Format_aead
,
PR_ROUNDS
);
}
s
[
15
]
^=
0x80000000
;
// process p data
if
(
mlen
)
{
while
(
mlen
>=
aead_RATE
)
{
Processing_Data
(
m
);
unpackU128FormatToFourPacket
(
c
,
s
);
P512
(
s
,
constant7Format_aead
,
PR_ROUNDS
);
mlen
-=
aead_RATE
;
m
+=
aead_RATE
;
c
+=
aead_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
m
,
mlen
*
sizeof
(
unsigned
char
));
tempData
[
mlen
]
=
0x01
;
Processing_Data
(
tempData
);
unpackU128FormatToFourPacket
(
tempData
,
s
);
memcpy
(
c
,
tempData
,
mlen
*
sizeof
(
unsigned
char
));
c
+=
mlen
;
}
// finalization
P512
(
s
,
constant7Format_aead
,
PRF_ROUNDS
);
unpackU128FormatToFourPacket
(
tempU8
,
s
);
\
unpackU128FormatToFourPacket
((
tempU8
+
16
),
(
s
+
4
));
\
memcpy
(
c
,
tempU8
,
CRYPTO_ABYTES
*
sizeof
(
unsigned
char
));
return
0
;
}
int
crypto_aead_decrypt
(
unsigned
char
*
m
,
unsigned
long
long
*
mlen
,
unsigned
char
*
nsec
,
const
unsigned
char
*
c
,
unsigned
long
long
clen
,
const
unsigned
char
*
ad
,
unsigned
long
long
adlen
,
const
unsigned
char
*
npub
,
const
unsigned
char
*
k
)
{
// initialization
u32
s
[
16
]
=
{
0
};
u32
dataFormat_1
[
4
]
=
{
0
};
u32
dataFormat
[
4
]
=
{
0
};
u8
tempData
[
32
]
=
{
0
};
u8
tempU8
[
64
]
=
{
0
};
if
(
clen
<
CRYPTO_ABYTES
)
return
-
1
;
*
mlen
=
clen
-
CRYPTO_ABYTES
;
//initialization
packU128FormatToFourPacket
(
s
,
npub
);
packU128FormatToFourPacket
((
s
+
4
),
(
npub
+
16
));
packU128FormatToFourPacket
((
s
+
8
),
k
);
packU128FormatToFourPacket
((
s
+
12
),
(
k
+
16
));
P512
(
s
,
constant7Format_aead
,
PR0_ROUNDS
);
// process associated data
if
(
adlen
)
{
while
(
adlen
>=
aead_RATE
)
{
packU128FormatToFourPacket
(
dataFormat
,
ad
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
s
[
3
]
^=
dataFormat
[
3
];
P512
(
s
,
constant7Format_aead
,
PR_ROUNDS
);
adlen
-=
aead_RATE
;
ad
+=
aead_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
ad
,
adlen
*
sizeof
(
unsigned
char
));
tempData
[
adlen
]
=
0x01
;
packU128FormatToFourPacket
(
dataFormat
,
tempData
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
s
[
3
]
^=
dataFormat
[
3
];
P512
(
s
,
constant7Format_aead
,
PR_ROUNDS
);
}
s
[
15
]
^=
0x80000000
;
// process c data
clen
=
clen
-
CRYPTO_KEYBYTES
;
if
(
clen
)
{
while
(
clen
>=
aead_RATE
)
{
packU128FormatToFourPacket
(
dataFormat
,
c
);
dataFormat_1
[
0
]
=
s
[
0
]
^
dataFormat
[
0
];
dataFormat_1
[
1
]
=
s
[
1
]
^
dataFormat
[
1
];
dataFormat_1
[
2
]
=
s
[
2
]
^
dataFormat
[
2
];
dataFormat_1
[
3
]
=
s
[
3
]
^
dataFormat
[
3
];
unpackU128FormatToFourPacket
(
m
,
dataFormat_1
);
s
[
0
]
=
dataFormat
[
0
];
s
[
1
]
=
dataFormat
[
1
];
s
[
2
]
=
dataFormat
[
2
];
s
[
3
]
=
dataFormat
[
3
];
P512
(
s
,
constant7Format_aead
,
PR_ROUNDS
);
clen
-=
aead_RATE
;
m
+=
aead_RATE
;
c
+=
aead_RATE
;
}
unpackU128FormatToFourPacket
(
tempU8
,
s
);
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
c
,
clen
*
sizeof
(
unsigned
char
));
tempData
[
clen
]
=
0x01
;
U32BIG
(((
u32
*
)
tempU8
)[
0
])
^=
U32BIG
(
((
u32
*
)
tempData
)[
0
]);
U32BIG
(((
u32
*
)
tempU8
)[
1
])
^=
U32BIG
(
((
u32
*
)
tempData
)[
1
]);
U32BIG
(((
u32
*
)
tempU8
)[
2
])
^=
U32BIG
(
((
u32
*
)
tempData
)[
2
]);
U32BIG
(((
u32
*
)
tempU8
)[
3
])
^=
U32BIG
(
((
u32
*
)
tempData
)[
3
]);
memcpy
(
m
,
tempU8
,
clen
*
sizeof
(
unsigned
char
));
memcpy
(
tempU8
,
tempData
,
clen
*
sizeof
(
unsigned
char
));
packU128FormatToFourPacket
(
s
,
tempU8
);
c
+=
clen
;
}
// finalization
P512
(
s
,
constant7Format_aead
,
PRF_ROUNDS
);
unpackU128FormatToFourPacket
(
tempU8
,
s
);
\
unpackU128FormatToFourPacket
((
tempU8
+
16
),
(
s
+
4
));
\
if
(
memcmp
((
void
*
)
tempU8
,
(
void
*
)
c
,
CRYPTO_ABYTES
))
{
memset
(
m
,
0
,
sizeof
(
unsigned
char
)
*
(
*
mlen
));
*
mlen
=
0
;
return
-
1
;
}
return
0
;
}
knot/Implementations/crypto_hash/knot256v1/armcortexm_2/api.h
0 → 100644
View file @
a34b1718
#define CRYPTO_BYTES 32
knot/Implementations/crypto_hash/knot256v1/armcortexm_2/auxFormat.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
void
P256
(
unsigned
int
*
s
,
unsigned
char
*
rc
,
unsigned
char
rounds
)
{
unsigned
int
reg1
,
reg2
;
asm
volatile
(
"enc_loop:
\n\t
"
"/*add round const*/
\n\t
"
"ldrb %[reg1], [%[rc]]
\n\t
"
"and %[reg2], %[reg1], 0xf
\n\t
"
"eors %[S_0], %[S_0], %[reg1],LSR #4
\n\t
"
/*s[0] ^= constant6Format[lunNum]>>4;*/
\
"eors %[S_1], %[S_1], %[reg2]
\n\t
"
/*s[1] ^= constant6Format[lunNum] & 0x0f;*/
\
"/*sbox first column*/
\n\t
"
"mvns %[S_0], %[S_0]
\n\t
"
"ands %[reg1], %[S_2], %[S_0]
\n\t
"
"eors %[reg1], %[S_4], %[reg1]
\n\t
"
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
"eors %[reg2], %[S_2], %[S_6]
\n\t
"
"eors %[S_6], %[S_6], %[reg1]
\n\t
"
"ands %[S_0], %[reg1],%[S_0]
\n\t
"
"eors %[S_0], %[reg2],%[S_0]
\n\t
"
"ands %[S_2], %[S_4], %[reg2]
\n\t
"
"eors %[S_2], %[reg1], %[S_2]
\n\t
"
"/*sbox first column*/
\n\t
"
"mvns %[S_1], %[S_1]
\n\t
"
"ands %[reg1], %[S_3], %[S_1]
\n\t
"
"eors %[reg1], %[S_5], %[reg1]
\n\t
"
"orrs %[S_5], %[S_3], %[S_5]
\n\t
"
"eors %[S_1], %[S_7], %[S_1]
\n\t
"
"eors %[S_5], %[S_5], %[S_1]
\n\t
"
"eors %[reg2], %[S_3], %[S_7]
\n\t
"
"eors %[S_7], %[S_7], %[reg1]
\n\t
"
"ands %[S_1], %[reg1],%[S_1]
\n\t
"
"eors %[S_1], %[reg2],%[S_1]
\n\t
"
"ands %[S_3], %[S_5], %[reg2]
\n\t
"
"eors %[S_3], %[reg1], %[S_3]
\n\t
"
"/*rotate shift left 1 bit*/
\n\t
"
"mov %[reg1], %[S_3]
\n\t
"
"mov %[S_3], %[S_2] , ROR #31
\n\t
"
"mov %[S_2], %[reg1]
\n\t
"
"/*rotate shift left 8 bits*/
\n\t
"
"mov %[S_4], %[S_4] , ROR #28
\n\t
"
"mov %[S_5], %[S_5] , ROR #28
\n\t
"
"/*rotate shift left 25 bits*/
\n\t
"
"mov %[reg1], %[S_6]
\n\t
"
"mov %[S_6], %[S_7] , ROR #20
\n\t
"
"mov %[S_7], %[reg1] , ROR #19
\n\t
"
"/*loop control*/
\n\t
"
"adds %[rc], %[rc], #1
\n\t
"
"subs %[ro], %[ro], #1
\n\t
"
"bne enc_loop
\n\t
"
/* ----------------------------- */
:
/* output variables - including inputs that are changed */
[
ro
]
"+r"
(
rounds
),[
reg1
]
"=r"
(
reg1
),
[
reg2
]
"=r"
(
reg2
),
[
rc
]
"+r"
(
rc
),
[
S_0
]
"+r"
(
s
[
0
]),
[
S_2
]
"+r"
(
s
[
2
]),
[
S_4
]
"+r"
(
s
[
4
]),
[
S_6
]
"+r"
(
s
[
6
])
,
[
S_1
]
"+r"
(
s
[
1
]),
[
S_3
]
"+r"
(
s
[
3
]),
[
S_5
]
"+r"
(
s
[
5
]),
[
S_7
]
"+r"
(
s
[
7
])
:
/* input variables */
:
/* clobber registers for temporary values */
);
}
void
unpackFormat
(
u8
*
out
,
u32
*
in
)
{
u32
t
[
2
]
=
{
0
};
t
[
1
]
=
(
in
[
0
]
&
0xFFFF0000
)
|
(
in
[
1
]
>>
16
);
t
[
0
]
=
(
in
[
1
]
&
0x0000FFFF
)
|
(
in
[
0
]
<<
16
);
u32
r0
,
r1
;
r0
=
(
t
[
0
]
^
(
t
[
0
]
>>
8
))
&
0x0000FF00
,
t
[
0
]
^=
r0
^
(
r0
<<
8
);
r0
=
(
t
[
0
]
^
(
t
[
0
]
>>
4
))
&
0x00F000F0
,
t
[
0
]
^=
r0
^
(
r0
<<
4
);
r0
=
(
t
[
0
]
^
(
t
[
0
]
>>
2
))
&
0x0C0C0C0C
,
t
[
0
]
^=
r0
^
(
r0
<<
2
);
r0
=
(
t
[
0
]
^
(
t
[
0
]
>>
1
))
&
0x22222222
,
t
[
0
]
^=
r0
^
(
r0
<<
1
);
r1
=
(
t
[
1
]
^
(
t
[
1
]
>>
8
))
&
0x0000FF00
,
t
[
1
]
^=
r1
^
(
r1
<<
8
);
r1
=
(
t
[
1
]
^
(
t
[
1
]
>>
4
))
&
0x00F000F0
,
t
[
1
]
^=
r1
^
(
r1
<<
4
);
r1
=
(
t
[
1
]
^
(
t
[
1
]
>>
2
))
&
0x0C0C0C0C
,
t
[
1
]
^=
r1
^
(
r1
<<
2
);
r1
=
(
t
[
1
]
^
(
t
[
1
]
>>
1
))
&
0x22222222
,
t
[
1
]
^=
r1
^
(
r1
<<
1
);
memcpy
(
out
,
t
,
8
*
sizeof
(
unsigned
char
));
}
void
getU32Format
(
u32
*
out
,
const
u8
*
in
)
{
u32
r0
,
lo
=
U32BIG
(((
u32
*
)
in
)[
0
]);
r0
=
(
lo
^
(
lo
>>
1
))
&
0x22222222
,
lo
^=
r0
^
(
r0
<<
1
);
r0
=
(
lo
^
(
lo
>>
2
))
&
0x0C0C0C0C
,
lo
^=
r0
^
(
r0
<<
2
);
r0
=
(
lo
^
(
lo
>>
4
))
&
0x00F000F0
,
lo
^=
r0
^
(
r0
<<
4
);
r0
=
(
lo
^
(
lo
>>
8
))
&
0x0000FF00
,
lo
^=
r0
^
(
r0
<<
8
);
*
out
=
lo
;
}
knot/Implementations/crypto_hash/knot256v1/armcortexm_2/auxFormat.h
0 → 100644
View file @
a34b1718
#include"crypto_hash.h"
#include"api.h"
#define U32BIG(x) (x)
#include<string.h>
#include<stdio.h>
typedef
unsigned
char
u8
;
typedef
unsigned
int
u32
;
typedef
unsigned
long
long
u64
;
#define sbox(a, b, c, d, f, g, h) \
{
\
t1
=
~
a
;
t2
=
b
&
t1
;
t3
=
c
^
t2
;
h
=
d
^
t3
;
t5
=
b
|
c
;
t6
=
d
^
t1
;
g
=
t5
^
t6
;
t8
=
b
^
d
;
t9
=
t3
&
t6
;
a
=
t8
^
t9
;
t11
=
g
&
t8
;
f
=
t3
^
t11
;
\
}
#define ARR_SIZE(a) (sizeof((a))/sizeof((a[0])))
#define LOTR32(x,n) (((x)<<(n))|((x)>>(32-(n))))
void
getU32Format
(
u32
*
out
,
const
u8
*
in
);
void
unpackFormat
(
u8
*
out
,
u32
*
in
)
;
void
P256
(
unsigned
int
*
s
,
unsigned
char
*
rc
,
unsigned
char
rounds
);
knot/Implementations/crypto_hash/knot256v1/armcortexm_2/crypto_hash.h
0 → 100644
View file @
a34b1718
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
);
knot/Implementations/crypto_hash/knot256v1/armcortexm_2/hash.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
#define hash_RATE (32 / 8)
/*
#define PR0_ROUNDS 68 /3=22+2
* */
#define PRH_ROUNDS 68
unsigned
char
constant7Format
[
68
]
=
{
/*constant7_hash_256v1:*/
0x1
,
0x10
,
0x2
,
0x20
,
0x4
,
0x40
,
0x9
,
0x11
,
0x12
,
0x22
,
0x24
,
0x44
,
0x49
,
0x18
,
0x3
,
0x30
,
0x6
,
0x60
,
0xd
,
0x51
,
0x1b
,
0x33
,
0x36
,
0x66
,
0x6d
,
0x5c
,
0x4a
,
0x28
,
0x5
,
0x50
,
0xb
,
0x31
,
0x16
,
0x62
,
0x2d
,
0x55
,
0x5b
,
0x3a
,
0x27
,
0x74
,
0x4f
,
0x78
,
0xe
,
0x61
,
0x1d
,
0x53
,
0x3b
,
0x37
,
0x76
,
0x6f
,
0x7c
,
0x4e
,
0x68
,
0xc
,
0x41
,
0x19
,
0x13
,
0x32
,
0x26
,
0x64
,
0x4d
,
0x58
,
0xa
,
0x21
,
0x14
,
0x42
,
0x29
,
0x15
,
};
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
)
{
u32
dataFormat
[
2
]
=
{
0
};
// initialization
u32
s
[
8
]
=
{
0
};
u8
tempData
[
32
];
//absorb
while
(
inlen
>=
hash_RATE
)
{
getU32Format
(
dataFormat
,
in
);
s
[
0
]
^=
dataFormat
[
0
]
>>
16
;
s
[
1
]
^=
dataFormat
[
0
]
&
0xffff
;
P256
(
s
,
constant7Format
,
PRH_ROUNDS
);
inlen
-=
hash_RATE
;
in
+=
hash_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
in
,
inlen
*
sizeof
(
unsigned
char
));
tempData
[
inlen
]
=
0x01
;
getU32Format
(
dataFormat
,
tempData
);
s
[
0
]
^=
dataFormat
[
0
]
>>
16
;
s
[
1
]
^=
dataFormat
[
0
]
&
0xffff
;
P256
(
s
,
constant7Format
,
PRH_ROUNDS
);
//sequeez
unpackFormat
(
out
,
s
);
unpackFormat
((
out
+
8
),
(
s
+
2
));
P256
(
s
,
constant7Format
,
PRH_ROUNDS
);
out
+=
CRYPTO_BYTES
/
2
;
unpackFormat
(
out
,
s
);
unpackFormat
((
out
+
8
),
(
s
+
2
));
return
0
;
}
knot/Implementations/crypto_hash/knot256v1/armcortexm_3/api.h
0 → 100644
View file @
a34b1718
#define CRYPTO_BYTES 32
knot/Implementations/crypto_hash/knot256v1/armcortexm_3/auxFormat.h
0 → 100644
View file @
a34b1718
//#include<malloc.h>
#include"api.h"
#include <string.h>
#define U32BIG(x) (x)
#define ARR_SIZE(a) (sizeof((a))/sizeof((a[0])))
#define LOTR32(x,n) (((x)<<(n))|((x)>>(32-(n))))
#define sbox(a, b, c, d, f, g, h) \
{
\
t1
=
~
a
;
t2
=
b
&
t1
;
t3
=
c
^
t2
;
h
=
d
^
t3
;
t5
=
b
|
c
;
t6
=
d
^
t1
;
g
=
t5
^
t6
;
t8
=
b
^
d
;
t9
=
t3
&
t6
;
a
=
t8
^
t9
;
t11
=
g
&
t8
;
f
=
t3
^
t11
;
\
}
typedef
unsigned
char
u8
;
typedef
unsigned
int
u32
;
typedef
unsigned
long
long
u64
;
#define ROUND256( constant6Format,lunNum) {\
s
[
0
]
^=
constant6Format
[
lunNum
]
>>
4
;
\
s
[
1
]
^=
constant6Format
[
lunNum
]
&
0x0f
;
\
sbox
(
s
[
0
],
s
[
2
],
s
[
4
],
s
[
6
],
s_temp
[
2
],
s_temp
[
4
],
s_temp
[
6
]);
\
sbox
(
s
[
1
],
s
[
3
],
s
[
5
],
s
[
7
],
s
[
2
],
s_temp
[
5
],
s_temp
[
7
]);
\
s
[
3
]
=
LOTR32
(
s_temp
[
2
],
1
);
\
s
[
4
]
=
LOTR32
(
s_temp
[
4
],
4
);
\
s
[
5
]
=
LOTR32
(
s_temp
[
5
],
4
);
\
s
[
6
]
=
LOTR32
(
s_temp
[
7
],
12
);
\
s
[
7
]
=
LOTR32
(
s_temp
[
6
],
13
);
\
}
#define getU32Format(out, in) {\
t2
=
U32BIG
(((
u32
*
)
in
)[
0
]);
\
t1
=
(
t2
^
(
t2
>>
1
))
&
0x22222222
,
t2
^=
t1
^
(
t1
<<
1
);
\
t1
=
(
t2
^
(
t2
>>
2
))
&
0x0C0C0C0C
,
t2
^=
t1
^
(
t1
<<
2
);
\
t1
=
(
t2
^
(
t2
>>
4
))
&
0x00F000F0
,
t2
^=
t1
^
(
t1
<<
4
);
\
t1
=
(
t2
^
(
t2
>>
8
))
&
0x0000FF00
,
t2
^=
t1
^
(
t1
<<
8
);
\
*
out
=
t2
;
\
}
#define unpackFormat(out, in) {\
t2
=
(
in
[
0
]
&
0xFFFF0000
)
|
(
in
[
1
]
>>
16
);
\
t1
=
(
in
[
1
]
&
0x0000FFFF
)
|
(
in
[
0
]
<<
16
);
\
t3
=
(
t1
^
(
t1
>>
8
))
&
0x0000FF00
,
t1
^=
t3
^
(
t3
<<
8
);
\
t3
=
(
t1
^
(
t1
>>
4
))
&
0x00F000F0
,
t1
^=
t3
^
(
t3
<<
4
);
\
t3
=
(
t1
^
(
t1
>>
2
))
&
0x0C0C0C0C
,
t1
^=
t3
^
(
t3
<<
2
);
\
t3
=
(
t1
^
(
t1
>>
1
))
&
0x22222222
,
t1
^=
t3
^
(
t3
<<
1
);
\
t5
=
(
t2
^
(
t2
>>
8
))
&
0x0000FF00
,
t2
^=
t5
^
(
t5
<<
8
);
\
t5
=
(
t2
^
(
t2
>>
4
))
&
0x00F000F0
,
t2
^=
t5
^
(
t5
<<
4
);
\
t5
=
(
t2
^
(
t2
>>
2
))
&
0x0C0C0C0C
,
t2
^=
t5
^
(
t5
<<
2
);
\
t5
=
(
t2
^
(
t2
>>
1
))
&
0x22222222
,
t2
^=
t5
^
(
t5
<<
1
);
\
*
((
u64
*
)
out
)
=
((
u64
)
t2
<<
32
|
t1
);
\
}
knot/Implementations/crypto_hash/knot256v1/armcortexm_3/crypto_hash.h
0 → 100644
View file @
a34b1718
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
);
knot/Implementations/crypto_hash/knot256v1/armcortexm_3/hash.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
#define hash_RATE (32 / 8)
#define PRH_ROUNDS 68
unsigned
char
constant7Format
[
68
]
=
{
0x01
,
0x10
,
0x02
,
0x20
,
0x04
,
0x40
,
0x09
,
0x11
,
0x12
,
0x22
,
0x24
,
0x44
,
0x49
,
0x18
,
0x03
,
0x30
,
0x06
,
0x60
,
0x0d
,
0x51
,
0x1b
,
0x33
,
0x36
,
0x66
,
0x6d
,
0x5c
,
0x4a
,
0x28
,
0x05
,
0x50
,
0x0b
,
0x31
,
0x16
,
0x62
,
0x2d
,
0x55
,
0x5b
,
0x3a
,
0x27
,
0x74
,
0x4f
,
0x78
,
0x0e
,
0x61
,
0x1d
,
0x53
,
0x3b
,
0x37
,
0x76
,
0x6f
,
0x7c
,
0x4e
,
0x68
,
0x0c
,
0x41
,
0x19
,
0x13
,
0x32
,
0x26
,
0x64
,
0x4d
,
0x58
,
0x0a
,
0x21
,
0x14
,
0x42
,
0x29
,
0x15
,
};
#define Processing_Data(data) \
do
{
\
getU32Format
(
dataFormat
,
data
);
\
s
[
0
]
^=
dataFormat
[
0
]
>>
16
;
\
s
[
1
]
^=
dataFormat
[
0
]
&
0xffff
;
\
}
while
(
0
)
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
)
{
u32
s_temp
[
8
]
=
{
0
};
u32
t1
,
t2
,
t3
,
t5
,
t6
,
t8
,
t9
,
t11
;
u8
i
;
u32
dataFormat
[
2
]
=
{
0
};
// initialization
u32
s
[
8
]
=
{
0
};
u8
tempData
[
32
];
//absorb
while
(
inlen
>=
hash_RATE
)
{
Processing_Data
(
in
);
for
(
i
=
0
;
i
<
PRH_ROUNDS
;
i
++
)
{
ROUND256
(
constant7Format
,
i
);
}
inlen
-=
hash_RATE
;
in
+=
hash_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
in
,
inlen
*
sizeof
(
unsigned
char
));
tempData
[
inlen
]
=
0x01
;
Processing_Data
(
tempData
);
for
(
i
=
0
;
i
<
PRH_ROUNDS
;
i
++
)
{
ROUND256
(
constant7Format
,
i
);
}
//sequeez
unpackFormat
(
out
,
s
);
unpackFormat
((
out
+
8
),
(
s
+
2
));
for
(
i
=
0
;
i
<
PRH_ROUNDS
;
i
++
)
{
ROUND256
(
constant7Format
,
i
);
}
out
+=
CRYPTO_BYTES
/
2
;
unpackFormat
(
out
,
s
);
unpackFormat
((
out
+
8
),
(
s
+
2
));
return
0
;
}
knot/Implementations/crypto_hash/knot256v1/armcortexm_4/api.h
0 → 100644
View file @
a34b1718
#define CRYPTO_BYTES 32
knot/Implementations/crypto_hash/knot256v1/armcortexm_4/auxFormat.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
void
P256
(
unsigned
int
*
s
,
unsigned
char
*
round
,
unsigned
char
lunNum
)
{
u32
s_temp
[
8
]
=
{
0
};
u32
t1
,
t2
,
t3
,
t5
,
t6
,
t8
,
t9
,
t11
;
unsigned
char
i
;
for
(
i
=
0
;
i
<
lunNum
;
i
++
)
{
s
[
0
]
^=
round
[
i
]
>>
4
;
s
[
1
]
^=
round
[
i
]
&
0x0f
;
sbox
(
s
[
0
],
s
[
2
],
s
[
4
],
s
[
6
],
s_temp
[
2
],
s_temp
[
4
],
s_temp
[
6
]);
sbox
(
s
[
1
],
s
[
3
],
s
[
5
],
s
[
7
],
s
[
2
],
s_temp
[
5
],
s_temp
[
7
]);
s
[
3
]
=
LOTR32
(
s_temp
[
2
],
1
);
s
[
4
]
=
LOTR32
(
s_temp
[
4
],
4
);
s
[
5
]
=
LOTR32
(
s_temp
[
5
],
4
);
s
[
6
]
=
LOTR32
(
s_temp
[
7
],
12
);
s
[
7
]
=
LOTR32
(
s_temp
[
6
],
13
);
}
}
void
unpackFormat
(
u8
*
out
,
u32
*
in
)
{
u32
t
[
2
]
=
{
0
};
t
[
1
]
=
(
in
[
0
]
&
0xFFFF0000
)
|
(
in
[
1
]
>>
16
);
t
[
0
]
=
(
in
[
1
]
&
0x0000FFFF
)
|
(
in
[
0
]
<<
16
);
u32
r0
,
r1
;
r0
=
(
t
[
0
]
^
(
t
[
0
]
>>
8
))
&
0x0000FF00
,
t
[
0
]
^=
r0
^
(
r0
<<
8
);
r0
=
(
t
[
0
]
^
(
t
[
0
]
>>
4
))
&
0x00F000F0
,
t
[
0
]
^=
r0
^
(
r0
<<
4
);
r0
=
(
t
[
0
]
^
(
t
[
0
]
>>
2
))
&
0x0C0C0C0C
,
t
[
0
]
^=
r0
^
(
r0
<<
2
);
r0
=
(
t
[
0
]
^
(
t
[
0
]
>>
1
))
&
0x22222222
,
t
[
0
]
^=
r0
^
(
r0
<<
1
);
r1
=
(
t
[
1
]
^
(
t
[
1
]
>>
8
))
&
0x0000FF00
,
t
[
1
]
^=
r1
^
(
r1
<<
8
);
r1
=
(
t
[
1
]
^
(
t
[
1
]
>>
4
))
&
0x00F000F0
,
t
[
1
]
^=
r1
^
(
r1
<<
4
);
r1
=
(
t
[
1
]
^
(
t
[
1
]
>>
2
))
&
0x0C0C0C0C
,
t
[
1
]
^=
r1
^
(
r1
<<
2
);
r1
=
(
t
[
1
]
^
(
t
[
1
]
>>
1
))
&
0x22222222
,
t
[
1
]
^=
r1
^
(
r1
<<
1
);
memcpy
(
out
,
t
,
8
*
sizeof
(
unsigned
char
));
}
void
getU32Format
(
u32
*
out
,
const
u8
*
in
)
{
u32
r0
,
lo
=
U32BIG
(((
u32
*
)
in
)[
0
]);
r0
=
(
lo
^
(
lo
>>
1
))
&
0x22222222
,
lo
^=
r0
^
(
r0
<<
1
);
r0
=
(
lo
^
(
lo
>>
2
))
&
0x0C0C0C0C
,
lo
^=
r0
^
(
r0
<<
2
);
r0
=
(
lo
^
(
lo
>>
4
))
&
0x00F000F0
,
lo
^=
r0
^
(
r0
<<
4
);
r0
=
(
lo
^
(
lo
>>
8
))
&
0x0000FF00
,
lo
^=
r0
^
(
r0
<<
8
);
*
out
=
lo
;
}
knot/Implementations/crypto_hash/knot256v1/armcortexm_4/auxFormat.h
0 → 100644
View file @
a34b1718
#include"crypto_hash.h"
#include"api.h"
#define U32BIG(x) (x)
#include<stdio.h>
typedef
unsigned
char
u8
;
typedef
unsigned
int
u32
;
typedef
unsigned
long
long
u64
;
#define sbox(a, b, c, d, f, g, h) \
{
\
t1
=
~
a
;
t2
=
b
&
t1
;
t3
=
c
^
t2
;
h
=
d
^
t3
;
t5
=
b
|
c
;
t6
=
d
^
t1
;
g
=
t5
^
t6
;
t8
=
b
^
d
;
t9
=
t3
&
t6
;
a
=
t8
^
t9
;
t11
=
g
&
t8
;
f
=
t3
^
t11
;
\
}
#define ARR_SIZE(a) (sizeof((a))/sizeof((a[0])))
#define LOTR32(x,n) (((x)<<(n))|((x)>>(32-(n))))
void
getU32Format
(
u32
*
out
,
const
u8
*
in
);
void
unpackFormat
(
u8
*
out
,
u32
*
in
)
;
void
P256
(
unsigned
int
*
s
,
unsigned
char
*
rc
,
unsigned
char
rounds
);
knot/Implementations/crypto_hash/knot256v1/armcortexm_4/crypto_hash.h
0 → 100644
View file @
a34b1718
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
);
knot/Implementations/crypto_hash/knot256v1/armcortexm_4/hash.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
#define hash_RATE (32 / 8)
/*
#define PR0_ROUNDS 68 /3=22+2
* */
#define PRH_ROUNDS 68
unsigned
char
constant7Format
[
68
]
=
{
/*constant7_hash_256v1:*/
0x1
,
0x10
,
0x2
,
0x20
,
0x4
,
0x40
,
0x9
,
0x11
,
0x12
,
0x22
,
0x24
,
0x44
,
0x49
,
0x18
,
0x3
,
0x30
,
0x6
,
0x60
,
0xd
,
0x51
,
0x1b
,
0x33
,
0x36
,
0x66
,
0x6d
,
0x5c
,
0x4a
,
0x28
,
0x5
,
0x50
,
0xb
,
0x31
,
0x16
,
0x62
,
0x2d
,
0x55
,
0x5b
,
0x3a
,
0x27
,
0x74
,
0x4f
,
0x78
,
0xe
,
0x61
,
0x1d
,
0x53
,
0x3b
,
0x37
,
0x76
,
0x6f
,
0x7c
,
0x4e
,
0x68
,
0xc
,
0x41
,
0x19
,
0x13
,
0x32
,
0x26
,
0x64
,
0x4d
,
0x58
,
0xa
,
0x21
,
0x14
,
0x42
,
0x29
,
0x15
,
};
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
)
{
u32
dataFormat
[
2
]
=
{
0
};
// initialization
u32
s
[
8
]
=
{
0
};
u8
tempData
[
32
];
//absorb
while
(
inlen
>=
hash_RATE
)
{
getU32Format
(
dataFormat
,
in
);
s
[
0
]
^=
dataFormat
[
0
]
>>
16
;
s
[
1
]
^=
dataFormat
[
0
]
&
0xffff
;
P256
(
s
,
constant7Format
,
PRH_ROUNDS
);
inlen
-=
hash_RATE
;
in
+=
hash_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
in
,
inlen
*
sizeof
(
unsigned
char
));
tempData
[
inlen
]
=
0x01
;
getU32Format
(
dataFormat
,
tempData
);
s
[
0
]
^=
dataFormat
[
0
]
>>
16
;
s
[
1
]
^=
dataFormat
[
0
]
&
0xffff
;
P256
(
s
,
constant7Format
,
PRH_ROUNDS
);
//sequeez
unpackFormat
(
out
,
s
);
unpackFormat
((
out
+
8
),
(
s
+
2
));
P256
(
s
,
constant7Format
,
PRH_ROUNDS
);
out
+=
CRYPTO_BYTES
/
2
;
unpackFormat
(
out
,
s
);
unpackFormat
((
out
+
8
),
(
s
+
2
));
return
0
;
}
knot/Implementations/crypto_hash/knot256v1/armcortexm_5/api.h
0 → 100644
View file @
a34b1718
#define CRYPTO_BYTES 32
knot/Implementations/crypto_hash/knot256v1/armcortexm_5/auxFormat.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
void
P256
(
unsigned
int
*
s
,
unsigned
char
*
rc
,
unsigned
char
rounds
)
{
unsigned
int
reg1
,
reg2
;
asm
volatile
(
"/*add round const*/
\n\t
"
"ldrb %[reg1], [%[rc]]
\n\t
"
"and %[reg2], %[reg1], 0xf
\n\t
"
"eors %[S_0], %[S_0], %[reg1],LSR #4
\n\t
"
/*s[0] ^= constant6Format[lunNum]>>4;*/
\
"eors %[S_1], %[S_1], %[reg2]
\n\t
"
/*s[1] ^= constant6Format[lunNum] & 0x0f;*/
\
"adds %[rc], %[rc], #1
\n\t
"
"/*sbox first column 0,2,4,6 sbox1(s[0], s[2], s[4], s[6]); */
\n\t
"
"mvns %[S_0], %[S_0]
\n\t
"
"ands %[reg1], %[S_2], %[S_0]
\n\t
"
"eors %[reg1], %[S_4], %[reg1]
\n\t
"
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
"eors %[reg2], %[S_2], %[S_6]
\n\t
"
"eors %[S_6], %[S_6], %[reg1]
\n\t
"
"ands %[S_0], %[reg1],%[S_0]
\n\t
"
"eors %[S_0], %[reg2],%[S_0]
\n\t
"
"ands %[S_2], %[S_4], %[reg2]
\n\t
"
"eors %[S_2], %[reg1], %[S_2]
\n\t
"
"/*sbox first column 1,3,5,7 sbox1(s[1], s[3], s[5], s[7]) */
\n\t
"
"mvns %[S_1], %[S_1]
\n\t
"
"ands %[reg1], %[S_3], %[S_1]
\n\t
"
"eors %[reg1], %[S_5], %[reg1]
\n\t
"
"orrs %[S_5], %[S_3], %[S_5]
\n\t
"
"eors %[S_1], %[S_7], %[S_1]
\n\t
"
"eors %[S_5], %[S_5], %[S_1]
\n\t
"
"eors %[reg2], %[S_3], %[S_7]
\n\t
"
"eors %[S_7], %[S_7], %[reg1]
\n\t
"
"ands %[S_1], %[reg1],%[S_1]
\n\t
"
"eors %[S_1], %[reg2],%[S_1]
\n\t
"
"ands %[S_3], %[S_5], %[reg2]
\n\t
"
"eors %[S_3], %[reg1], %[S_3]
\n\t
"
"enc_loop:
\n\t
"
"/*add round const*/
\n\t
"
"ldrb %[reg1], [%[rc]]
\n\t
"
"and %[reg2], %[reg1], 0xf
\n\t
"
"eors %[S_0], %[S_0], %[reg1],LSR #4
\n\t
"
/*s[0] ^= constant6Format[lunNum]>>4;*/
\
"eors %[S_1], %[S_1], %[reg2]
\n\t
"
/*s[1] ^= constant6Format[lunNum] & 0x0f;*/
\
"adds %[rc], %[rc], #1
\n\t
"
"/*sbox first column 0,3,4,7 sbox1(s[0], s[3],ROR(s[4], 28), ROR(s[7], 20)); */
\n\t
"
"ROR %[S_4], #28
\n\t
"
\
"ROR %[S_7], #20
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
"ands %[reg1], %[S_3], %[S_0]
\n\t
"
"eors %[reg1], %[S_4], %[reg1]
\n\t
"
"orrs %[S_4], %[S_3], %[S_4]
\n\t
"
"eors %[S_0], %[S_7], %[S_0]
\n\t
"
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
"eors %[reg2], %[S_3], %[S_7]
\n\t
"
"eors %[S_7], %[S_7], %[reg1]
\n\t
"
"ands %[S_0], %[reg1],%[S_0]
\n\t
"
"eors %[S_0], %[reg2],%[S_0]
\n\t
"
"ands %[S_3], %[S_4], %[reg2]
\n\t
"
"eors %[S_3], %[reg1], %[S_3]
\n\t
"
"/*sbox first column 1,2,5,6 sbox1(s[1], ROR(s[2], 31), ROR(s[5], 28), ROR(s[6], 19)); */
\n\t
"
"ROR %[S_2], #31
\n\t
"
\
"ROR %[S_5], #28
\n\t
"
\
"ROR %[S_6], #19
\n\t
"
\
"mvns %[S_1], %[S_1]
\n\t
"
"ands %[reg1], %[S_2], %[S_1]
\n\t
"
"eors %[reg1], %[S_5], %[reg1]
\n\t
"
"orrs %[S_5], %[S_2], %[S_5]
\n\t
"
"eors %[S_1], %[S_6], %[S_1]
\n\t
"
"eors %[S_5], %[S_5], %[S_1]
\n\t
"
"eors %[reg2], %[S_2], %[S_6]
\n\t
"
"eors %[S_6], %[S_6], %[reg1]
\n\t
"
"ands %[S_1], %[reg1],%[S_1]
\n\t
"
"eors %[S_1], %[reg2],%[S_1]
\n\t
"
"ands %[S_2], %[S_5], %[reg2]
\n\t
"
"eors %[S_2], %[reg1], %[S_2]
\n\t
"
"/*add round const*/
\n\t
"
"ldrb %[reg1], [%[rc]]
\n\t
"
"and %[reg2], %[reg1], 0xf
\n\t
"
"eors %[S_0], %[S_0], %[reg1],LSR #4
\n\t
"
/*s[0] ^= constant6Format[lunNum]>>4;*/
\
"eors %[S_1], %[S_1], %[reg2]
\n\t
"
/*s[1] ^= constant6Format[lunNum] & 0x0f;*/
\
"adds %[rc], %[rc], #1
\n\t
"
"/*sbox first column 0,2,4,6 sbox1(s[0], s[2], ROR(s[4], 28), ROR(s[6], 20)); */
\n\t
"
"ROR %[S_4], #28
\n\t
"
\
"ROR %[S_6], #20
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
"ands %[reg1], %[S_2], %[S_0]
\n\t
"
"eors %[reg1], %[S_4], %[reg1]
\n\t
"
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
"eors %[reg2], %[S_2], %[S_6]
\n\t
"
"eors %[S_6], %[S_6], %[reg1]
\n\t
"
"ands %[S_0], %[reg1],%[S_0]
\n\t
"
"eors %[S_0], %[reg2],%[S_0]
\n\t
"
"ands %[S_2], %[S_4], %[reg2]
\n\t
"
"eors %[S_2], %[reg1], %[S_2]
\n\t
"
"/*sbox first column 1,3,5,7 sbox1(s[1], ROR(s[3], 31), ROR(s[5], 28), ROR(s[7], 19)); */
\n\t
"
"ROR %[S_3], #31
\n\t
"
\
"ROR %[S_5], #28
\n\t
"
\
"ROR %[S_7], #19
\n\t
"
\
"mvns %[S_1], %[S_1]
\n\t
"
"ands %[reg1], %[S_3], %[S_1]
\n\t
"
"eors %[reg1], %[S_5], %[reg1]
\n\t
"
"orrs %[S_5], %[S_3], %[S_5]
\n\t
"
"eors %[S_1], %[S_7], %[S_1]
\n\t
"
"eors %[S_5], %[S_5], %[S_1]
\n\t
"
"eors %[reg2], %[S_3], %[S_7]
\n\t
"
"eors %[S_7], %[S_7], %[reg1]
\n\t
"
"ands %[S_1], %[reg1],%[S_1]
\n\t
"
"eors %[S_1], %[reg2],%[S_1]
\n\t
"
"ands %[S_3], %[S_5], %[reg2]
\n\t
"
"eors %[S_3], %[reg1], %[S_3]
\n\t
"
"/*loop control*/
\n\t
"
"subs %[ro], %[ro], #1
\n\t
"
"bne enc_loop
\n\t
"
"/*add round const*/
\n\t
"
"ldrb %[reg1], [%[rc]]
\n\t
"
"and %[reg2], %[reg1], 0xf
\n\t
"
"eors %[S_0], %[S_0], %[reg1],LSR #4
\n\t
"
/*s[0] ^= constant6Format[lunNum]>>4;*/
\
"eors %[S_1], %[S_1], %[reg2]
\n\t
"
/*s[1] ^= constant6Format[lunNum] & 0x0f;*/
\
"/*sbox first column 0,3,4,7 sbox1(s[0], s[3],ROR(s[4], 28), ROR(s[7], 20)); */
\n\t
"
"ROR %[S_4], #28
\n\t
"
\
"ROR %[S_7], #20
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
"ands %[reg1], %[S_3], %[S_0]
\n\t
"
"eors %[reg1], %[S_4], %[reg1]
\n\t
"
"orrs %[S_4], %[S_3], %[S_4]
\n\t
"
"eors %[S_0], %[S_7], %[S_0]
\n\t
"
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
"eors %[reg2], %[S_3], %[S_7]
\n\t
"
"eors %[S_7], %[S_7], %[reg1]
\n\t
"
"ands %[S_0], %[reg1],%[S_0]
\n\t
"
"eors %[S_0], %[reg2],%[S_0]
\n\t
"
"ands %[S_3], %[S_4], %[reg2]
\n\t
"
"eors %[S_3], %[reg1], %[S_3]
\n\t
"
"/*sbox first column 1,2,5,6 sbox1(s[1], ROR(s[2], 31), ROR(s[5], 28), ROR(s[6], 19)); */
\n\t
"
"ROR %[S_2], #31
\n\t
"
\
"ROR %[S_5], #28
\n\t
"
\
"ROR %[S_6], #19
\n\t
"
\
"mvns %[S_1], %[S_1]
\n\t
"
"ands %[reg1], %[S_2], %[S_1]
\n\t
"
"eors %[reg1], %[S_5], %[reg1]
\n\t
"
"orrs %[S_5], %[S_2], %[S_5]
\n\t
"
"eors %[S_1], %[S_6], %[S_1]
\n\t
"
"eors %[S_5], %[S_5], %[S_1]
\n\t
"
"eors %[reg2], %[S_2], %[S_6]
\n\t
"
"eors %[S_6], %[S_6], %[reg1]
\n\t
"
"ands %[S_1], %[reg1],%[S_1]
\n\t
"
"eors %[S_1], %[reg2],%[S_1]
\n\t
"
"ands %[S_2], %[S_5], %[reg2]
\n\t
"
"eors %[S_2], %[reg1], %[S_2]
\n\t
"
"ROR %[S_3], #31
\n\t
"
"ROR %[S_4], #28
\n\t
"
"ROR %[S_5], #28
\n\t
"
"ROR %[S_6], #20
\n\t
"
"ROR %[S_7], #19
\n\t
"
:
/* output variables - including inputs that are changed */
[
ro
]
"+r"
(
rounds
),[
reg1
]
"=r"
(
reg1
),
[
reg2
]
"=r"
(
reg2
),
[
rc
]
"+r"
(
rc
),
[
S_0
]
"+r"
(
s
[
0
]),
[
S_2
]
"+r"
(
s
[
2
]),
[
S_4
]
"+r"
(
s
[
4
]),
[
S_6
]
"+r"
(
s
[
6
])
,
[
S_1
]
"+r"
(
s
[
1
]),
[
S_3
]
"+r"
(
s
[
3
]),
[
S_5
]
"+r"
(
s
[
5
]),
[
S_7
]
"+r"
(
s
[
7
])
:
/* input variables */
:
/* clobber registers for temporary values */
);
}
void
unpackFormat
(
u8
*
out
,
u32
*
in
)
{
u32
t
[
2
]
=
{
0
};
t
[
1
]
=
(
in
[
0
]
&
0xFFFF0000
)
|
(
in
[
1
]
>>
16
);
t
[
0
]
=
(
in
[
1
]
&
0x0000FFFF
)
|
(
in
[
0
]
<<
16
);
u32
r0
,
r1
;
r0
=
(
t
[
0
]
^
(
t
[
0
]
>>
8
))
&
0x0000FF00
,
t
[
0
]
^=
r0
^
(
r0
<<
8
);
r0
=
(
t
[
0
]
^
(
t
[
0
]
>>
4
))
&
0x00F000F0
,
t
[
0
]
^=
r0
^
(
r0
<<
4
);
r0
=
(
t
[
0
]
^
(
t
[
0
]
>>
2
))
&
0x0C0C0C0C
,
t
[
0
]
^=
r0
^
(
r0
<<
2
);
r0
=
(
t
[
0
]
^
(
t
[
0
]
>>
1
))
&
0x22222222
,
t
[
0
]
^=
r0
^
(
r0
<<
1
);
r1
=
(
t
[
1
]
^
(
t
[
1
]
>>
8
))
&
0x0000FF00
,
t
[
1
]
^=
r1
^
(
r1
<<
8
);
r1
=
(
t
[
1
]
^
(
t
[
1
]
>>
4
))
&
0x00F000F0
,
t
[
1
]
^=
r1
^
(
r1
<<
4
);
r1
=
(
t
[
1
]
^
(
t
[
1
]
>>
2
))
&
0x0C0C0C0C
,
t
[
1
]
^=
r1
^
(
r1
<<
2
);
r1
=
(
t
[
1
]
^
(
t
[
1
]
>>
1
))
&
0x22222222
,
t
[
1
]
^=
r1
^
(
r1
<<
1
);
memcpy
(
out
,
t
,
8
*
sizeof
(
unsigned
char
));
}
void
getU32Format
(
u32
*
out
,
const
u8
*
in
)
{
u32
r0
,
lo
=
U32BIG
(((
u32
*
)
in
)[
0
]);
r0
=
(
lo
^
(
lo
>>
1
))
&
0x22222222
,
lo
^=
r0
^
(
r0
<<
1
);
r0
=
(
lo
^
(
lo
>>
2
))
&
0x0C0C0C0C
,
lo
^=
r0
^
(
r0
<<
2
);
r0
=
(
lo
^
(
lo
>>
4
))
&
0x00F000F0
,
lo
^=
r0
^
(
r0
<<
4
);
r0
=
(
lo
^
(
lo
>>
8
))
&
0x0000FF00
,
lo
^=
r0
^
(
r0
<<
8
);
*
out
=
lo
;
}
knot/Implementations/crypto_hash/knot256v1/armcortexm_5/auxFormat.h
0 → 100644
View file @
a34b1718
#include"crypto_hash.h"
#include"api.h"
#define U32BIG(x) (x)
#include<string.h>
typedef
unsigned
char
u8
;
typedef
unsigned
int
u32
;
typedef
unsigned
long
long
u64
;
void
getU32Format
(
u32
*
out
,
const
u8
*
in
);
void
unpackFormat
(
u8
*
out
,
u32
*
in
)
;
void
P256
(
unsigned
int
*
s
,
unsigned
char
*
rc
,
unsigned
char
rounds
);
knot/Implementations/crypto_hash/knot256v1/armcortexm_5/crypto_hash.h
0 → 100644
View file @
a34b1718
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
);
knot/Implementations/crypto_hash/knot256v1/armcortexm_5/hash.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
#define hash_RATE (32 / 8)
#define PRH_ROUNDS 33
//#define PRH_ROUNDS 68
unsigned
char
constant7Format
[
68
]
=
{
/*constant7_hash_256v1:*/
0x1
,
0x10
,
0x2
,
0x20
,
0x4
,
0x40
,
0x9
,
0x11
,
0x12
,
0x22
,
0x24
,
0x44
,
0x49
,
0x18
,
0x3
,
0x30
,
0x6
,
0x60
,
0xd
,
0x51
,
0x1b
,
0x33
,
0x36
,
0x66
,
0x6d
,
0x5c
,
0x4a
,
0x28
,
0x5
,
0x50
,
0xb
,
0x31
,
0x16
,
0x62
,
0x2d
,
0x55
,
0x5b
,
0x3a
,
0x27
,
0x74
,
0x4f
,
0x78
,
0xe
,
0x61
,
0x1d
,
0x53
,
0x3b
,
0x37
,
0x76
,
0x6f
,
0x7c
,
0x4e
,
0x68
,
0xc
,
0x41
,
0x19
,
0x13
,
0x32
,
0x26
,
0x64
,
0x4d
,
0x58
,
0xa
,
0x21
,
0x14
,
0x42
,
0x29
,
0x15
,
};
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
)
{
u32
dataFormat
[
2
]
=
{
0
};
// initialization
u32
s
[
8
]
=
{
0
};
u8
tempData
[
32
];
//absorb
//RATE=4
while
(
inlen
>=
hash_RATE
)
{
getU32Format
(
dataFormat
,
in
);
s
[
0
]
^=
dataFormat
[
0
]
>>
16
;
s
[
1
]
^=
dataFormat
[
0
]
&
0xffff
;
P256
(
s
,
constant7Format
,
PRH_ROUNDS
);
inlen
-=
hash_RATE
;
in
+=
hash_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
in
,
inlen
*
sizeof
(
unsigned
char
));
tempData
[
inlen
]
=
0x01
;
getU32Format
(
dataFormat
,
tempData
);
s
[
0
]
^=
dataFormat
[
0
]
>>
16
;
s
[
1
]
^=
dataFormat
[
0
]
&
0xffff
;
P256
(
s
,
constant7Format
,
PRH_ROUNDS
);
//sequeez
unpackFormat
(
out
,
s
);
unpackFormat
((
out
+
8
),
(
s
+
2
));
P256
(
s
,
constant7Format
,
PRH_ROUNDS
);
out
+=
CRYPTO_BYTES
/
2
;
unpackFormat
(
out
,
s
);
unpackFormat
((
out
+
8
),
(
s
+
2
));
return
0
;
}
knot/Implementations/crypto_hash/knot256v2/armcortexm_2/api.h
0 → 100644
View file @
a34b1718
#define CRYPTO_BYTES 32
knot/Implementations/crypto_hash/knot256v2/armcortexm_2/auxFormat.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
void
packU32FormatToThreePacket
(
u32
*
out
,
u8
*
in
)
{
u32
t2
=
U32BIG
(((
u32
*
)
in
)[
0
]);
out
[
2
]
=
t2
;
out
[
1
]
=
t2
>>
1
;
out
[
0
]
=
t2
>>
2
;
//temp2[0] 0;temp2[1] 1;temp2[2] 2;
puckU32ToThree_1
(
out
[
0
]);
puckU32ToThree_1
(
out
[
1
]);
puckU32ToThree_1
(
out
[
2
]);
}
void
unpackU32FormatToThreePacket
(
u8
*
out
,
u32
*
in
)
{
u32
temp0
[
3
]
=
{
0
};
temp0
[
0
]
=
in
[
0
]
&
0x3ff
;
temp0
[
1
]
=
in
[
1
]
&
0x7ff
;
temp0
[
2
]
=
in
[
2
]
&
0x7ff
;
unpuckU32ToThree_1
(
temp0
[
0
]);
unpuckU32ToThree_1
(
temp0
[
1
]);
unpuckU32ToThree_1
(
temp0
[
2
]);
*
(
u32
*
)(
out
)
=
U32BIG
(
temp0
[
0
]
<<
2
|
temp0
[
1
]
<<
1
|
temp0
[
2
]);
}
void
packU96FormatToThreePacket
(
u32
*
out
,
u8
*
in
)
{
u32
temp0
[
3
]
=
{
0
};
u32
temp1
[
3
]
=
{
0
};
u32
temp2
[
3
]
=
{
0
};
temp0
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
0
]);
temp0
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
1
;
temp0
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
2
;
puckU32ToThree_1
(
temp0
[
0
]);
puckU32ToThree_1
(
temp0
[
1
]);
puckU32ToThree_1
(
temp0
[
2
]);
temp1
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
1
]);
temp1
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
1
])
>>
1
;
temp1
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
1
])
>>
2
;
puckU32ToThree_1
(
temp1
[
0
]);
puckU32ToThree_1
(
temp1
[
1
]);
puckU32ToThree_1
(
temp1
[
2
]);
temp2
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
2
]);
temp2
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
2
])
>>
1
;
temp2
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
2
])
>>
2
;
puckU32ToThree_1
(
temp2
[
0
]);
puckU32ToThree_1
(
temp2
[
1
]);
puckU32ToThree_1
(
temp2
[
2
]);
out
[
0
]
=
(
temp2
[
1
]
<<
21
)
|
(
temp1
[
0
]
<<
10
)
|
temp0
[
2
];
out
[
1
]
=
(
temp2
[
0
]
<<
21
)
|
(
temp1
[
2
]
<<
11
)
|
temp0
[
1
];
out
[
2
]
=
(
temp2
[
2
]
<<
22
)
|
(
temp1
[
1
]
<<
11
)
|
temp0
[
0
];
}
void
unpackU96FormatToThreePacket
(
u8
*
out
,
u32
*
in
)
{
u32
temp0
[
3
]
=
{
0
};
u32
temp1
[
3
]
=
{
0
};
u32
temp2
[
3
]
=
{
0
};
u32
t
[
3
]
=
{
0
};
temp0
[
0
]
=
in
[
2
]
&
0x7ff
;
temp0
[
1
]
=
in
[
1
]
&
0x7ff
;
temp0
[
2
]
=
in
[
0
]
&
0x3ff
;
temp1
[
0
]
=
(
in
[
0
]
>>
10
)
&
0x7ff
;
temp1
[
1
]
=
(
in
[
2
]
>>
11
)
&
0x7ff
;
temp1
[
2
]
=
(
in
[
1
]
>>
11
)
&
0x3ff
;
temp2
[
0
]
=
in
[
1
]
>>
21
;
temp2
[
1
]
=
in
[
0
]
>>
21
;
temp2
[
2
]
=
in
[
2
]
>>
22
;
unpuckU32ToThree_1
(
temp0
[
0
]);
unpuckU32ToThree_1
(
temp0
[
1
]);
unpuckU32ToThree_1
(
temp0
[
2
]);
t
[
0
]
=
temp0
[
0
]
|
temp0
[
1
]
<<
1
|
temp0
[
2
]
<<
2
;
unpuckU32ToThree_1
(
temp1
[
0
]);
unpuckU32ToThree_1
(
temp1
[
1
]);
unpuckU32ToThree_1
(
temp1
[
2
]);
t
[
1
]
=
temp1
[
0
]
|
temp1
[
1
]
<<
1
|
temp1
[
2
]
<<
2
;
unpuckU32ToThree_1
(
temp2
[
0
]);
unpuckU32ToThree_1
(
temp2
[
1
]);
unpuckU32ToThree_1
(
temp2
[
2
]);
t
[
2
]
=
temp2
[
0
]
|
temp2
[
1
]
<<
1
|
temp2
[
2
]
<<
2
;
memcpy
(
out
,
t
,
12
*
sizeof
(
unsigned
char
));
}
unsigned
char
constant7Format
[
80
]
=
{
/*constant7Format[127]: 12*6=72*/
0x01
,
0x08
,
0x40
,
0x02
,
0x10
,
0x80
,
0x05
,
0x09
,
0x48
,
0x42
,
0x12
,
0x90
,
0x85
,
0x0c
,
0x41
,
0x0a
,
0x50
,
0x82
,
0x15
,
0x89
,
0x4d
,
0x4b
,
0x5a
,
0xd2
,
0x97
,
0x9c
,
0xc4
,
0x06
,
0x11
,
0x88
,
0x45
,
0x0b
,
0x58
,
0xc2
,
0x17
,
0x99
,
0xcd
,
0x4e
,
0x53
,
0x9a
,
0xd5
,
0x8e
,
0x54
,
0x83
,
0x1d
,
0xc9
,
0x4f
,
0x5b
,
0xda
,
0xd7
,
0x9e
,
0xd4
,
0x86
,
0x14
,
0x81
,
0x0d
,
0x49
,
0x4a
,
0x52
,
0x92
,
0x95
,
0x8c
,
0x44
,
0x03
,
0x18
,
0xc0
,
0x07
,
0x19
,
0xc8
,
0x47
,
0x1b
,
0xd8
,
0xc7
,
0x1e
,
0xd1
,
0x8f
,
0x5c
,
0xc3
,
0x1f
,
0xd9
,};
void
P384
(
unsigned
int
*
s
,
unsigned
char
*
round
,
unsigned
char
lunNum
)
{
u32
rci
,
t1
,
t2
;
unsigned
char
i
;
for
(
i
=
0
;
i
<
lunNum
;
i
++
)
{
rci
=
constant7Format
[
i
];
\
P384_ARC_SC1
(
rci
,
s
[
3
],
s
[
6
],
s
[
9
]);
\
P384_2SC
(
s
[
1
],
s
[
4
],
s
[
7
],
s
[
10
],
s
[
2
],
s
[
5
],
s
[
8
],
s
[
11
]);
\
P384_SR
();
\
}
}
knot/Implementations/crypto_hash/knot256v2/armcortexm_2/auxFormat.h
0 → 100644
View file @
a34b1718
#include<malloc.h>
#include"crypto_hash.h"
#include"api.h"
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#define U32BIG(x) (x)
typedef
unsigned
char
u8
;
typedef
unsigned
int
u32
;
typedef
unsigned
long
long
u64
;
#define puckU32ToThree_1(x){\
x
&=
0x49249249
;
\
x
=
(
x
|
(
x
>>
2
))
&
0xc30c30c3
;
\
x
=
(
x
|
(
x
>>
4
))
&
0x0f00f00f
;
\
x
=
(
x
|
(
x
>>
8
))
&
0xff0000ff
;
\
x
=
(
x
|
(
x
>>
16
))
&
0xfff
;
\
}
#define unpuckU32ToThree_1(x){\
x
&=
0xfff
;
\
x
=
(
x
|
(
x
<<
16
))
&
0xff0000ff
;
\
x
=
(
x
|
(
x
<<
8
))
&
0x0f00f00f
;
\
x
=
(
x
|
(
x
<<
4
))
&
0xc30c30c3
;
\
x
=
(
x
|
(
x
<<
2
))
&
0x49249249
;
\
}
unsigned
char
constant7Format
[
80
];
#define P384_ARC_SC1(rci,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*add round const s0 s1 s2 */
\n\t
"
\
"ands %[t1], %[rci], #0xc0
\n\t
"
\
"eors %[S_0], %[S_0], %[t1], LSR #6
\n\t
"
/*s[0] ^= (constant7Format[lunNum] >> 6) & 0x3;*/
\
"ands %[t1], %[rci], #0x38
\n\t
"
\
"eors %[S_1], %[S_1], %[t1], LSR #3
\n\t
"
/*s[0] ^= (constant7Format[lunNum] >> 6) & 0x3;*/
\
"ands %[t1], %[rci], #0x7
\n\t
"
\
"eors %[S_3], %[S_3], %[t1]
\n\t
"
/*s[2] ^= constant7Format[lunNum] & 0x7;*/
\
"/*sbox column*/
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1],%[S_0]
\n\t
"
\
"eors %[S_0], %[t2],%[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1], %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
[
rci
]
"+r"
(
rci
),
\
[
S_0
]
"+r"
(
s
[
0
]),
[
S_1
]
"+r"
(
s
[
1
]),
[
S_3
]
"+r"
(
s
[
2
]),
\
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define P384_2SC(S1,S2,S3,S4,S5,S6,S7,S8) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1],%[S_0]
\n\t
"
\
"eors %[S_0], %[t2],%[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1], %[S_2]
\n\t
"
\
"/*sbox column*/
\n\t
"
\
"mvns %[S_1], %[S_1]
\n\t
"
\
"ands %[t1], %[S_3], %[S_1]
\n\t
"
\
"eors %[t1], %[S_5], %[t1]
\n\t
"
\
"orrs %[S_5], %[S_3], %[S_5]
\n\t
"
\
"eors %[S_1], %[S_7], %[S_1]
\n\t
"
\
"eors %[S_5], %[S_5], %[S_1]
\n\t
"
\
"eors %[t2], %[S_3], %[S_7]
\n\t
"
\
"eors %[S_7], %[S_7], %[t1]
\n\t
"
\
"ands %[S_1], %[t1],%[S_1]
\n\t
"
\
"eors %[S_1], %[t2],%[S_1]
\n\t
"
\
"ands %[S_3], %[S_5], %[t2]
\n\t
"
\
"eors %[S_3], %[t1], %[S_3]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
,
\
[
S_1
]
"+r"
(
S5
),
[
S_3
]
"+r"
(
S6
),
[
S_5
]
"+r"
(
S7
),
[
S_7
]
"+r"
(
S8
)
\
:
:
);
\
}
while
(
0
)
#define P384_SR() \
do
{
\
__asm__
__volatile__
(
\
"/*rotate shift left 1 bit [w9 w5 w1-> (w1,1) w9 w5] */
\n\t
"
\
"mov %[t1], %[S_3]
\n\t
"
\
"mov %[S_3], %[S_4]
\n\t
"
\
"mov %[S_4], %[S_5]
\n\t
"
\
"ROR %[S_5], %[t1] , #31
\n\t
"
\
"/*rotate shift left 8 bits [w10 w6 w2-> (w6,3) (w2,3) ( w10,2)]*/
\n\t
"
\
"mov %[t1], %[S_8]
\n\t
"
\
"ROR %[S_8], %[S_7] , #29
\n\t
"
\
"ROR %[S_7], %[S_6] , #29
\n\t
"
\
"ROR %[S_6], %[t1] , #30
\n\t
"
\
"/*rotate shift left 55 bit [w11 w7 w3-> (w3,13) (w11,14) ( w7,14)] */
\n\t
"
\
"mov %[t1], %[S_9]
\n\t
"
\
"ROR %[S_9], %[S_10] , #14
\n\t
"
\
"ROR %[S_10], %[S_11] , #14
\n\t
"
\
"ROR %[S_11], %[t1] , #13
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
\
[
S_3
]
"+r"
(
s
[
3
]),
[
S_6
]
"+r"
(
s
[
6
]),
[
S_9
]
"+r"
(
s
[
9
])
,
\
[
S_4
]
"+r"
(
s
[
4
]),
[
S_7
]
"+r"
(
s
[
7
]),
[
S_10
]
"+r"
(
s
[
10
]),
\
[
S_5
]
"+r"
(
s
[
5
]),
[
S_8
]
"+r"
(
s
[
8
]),
[
S_11
]
"+r"
(
s
[
11
])
\
:
:
);
\
}
while
(
0
)
knot/Implementations/crypto_hash/knot256v2/armcortexm_2/crypto_hash.h
0 → 100644
View file @
a34b1718
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
);
\ No newline at end of file
knot/Implementations/crypto_hash/knot256v2/armcortexm_2/hash.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
#define hash_RATE (128 / 8)
#define PRH_ROUNDS 80
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
)
{
u32
s
[
12
]
=
{
0
};
u32
dataFormat
[
6
]
=
{
0
};
u8
tempData
[
24
]
=
{
0
};
// initialization
s
[
9
]
=
0x80000000
;
//absorb
while
(
inlen
>=
hash_RATE
)
{
packU96FormatToThreePacket
(
dataFormat
,
in
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
packU32FormatToThreePacket
(
dataFormat
+
3
,
in
+
12
);
s
[
3
]
^=
dataFormat
[
3
];
s
[
4
]
^=
dataFormat
[
4
];
s
[
5
]
^=
dataFormat
[
5
];
P384
(
s
,
constant7Format
,
PRH_ROUNDS
);
inlen
-=
hash_RATE
;
in
+=
hash_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
in
,
inlen
*
sizeof
(
unsigned
char
));
tempData
[
inlen
]
=
0x01
;
packU96FormatToThreePacket
(
dataFormat
,
tempData
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
packU32FormatToThreePacket
(
dataFormat
+
3
,
tempData
+
12
);
s
[
3
]
^=
dataFormat
[
3
];
s
[
4
]
^=
dataFormat
[
4
];
s
[
5
]
^=
dataFormat
[
5
];
P384
(
s
,
constant7Format
,
PRH_ROUNDS
);
//sequeez
unpackU96FormatToThreePacket
(
out
,
s
);
unpackU32FormatToThreePacket
(
out
+
12
,
s
+
3
);
P384
(
s
,
constant7Format
,
PRH_ROUNDS
);
out
+=
CRYPTO_BYTES
/
2
;
unpackU96FormatToThreePacket
(
out
,
s
);
unpackU32FormatToThreePacket
(
out
+
12
,
s
+
3
);
return
0
;
}
knot/Implementations/crypto_hash/knot256v2/armcortexm_3/api.h
0 → 100644
View file @
a34b1718
#define CRYPTO_BYTES 32
knot/Implementations/crypto_hash/knot256v2/armcortexm_3/auxFormat.h
0 → 100644
View file @
a34b1718
#include<malloc.h>
#include"crypto_hash.h"
#include"api.h"
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#define U32BIG(x) (x)
typedef
unsigned
char
u8
;
typedef
unsigned
int
u32
;
typedef
unsigned
long
long
u64
;
#define ARR_SIZE(a) (sizeof((a))/sizeof((a[0])))
#define LOTR32(x,n) (((x)<<(n))|((x)>>(32-(n))))
#define ARR_SIZE(a) (sizeof((a))/sizeof((a[0])))
#define sbox(a, b, c, d, f, g, h) \
{
\
t1
=
~
a
;
t2
=
b
&
t1
;
t3
=
c
^
t2
;
h
=
d
^
t3
;
t5
=
b
|
c
;
t6
=
d
^
t1
;
g
=
t5
^
t6
;
t8
=
b
^
d
;
t9
=
t3
&
t6
;
a
=
t8
^
t9
;
t11
=
g
&
t8
;
f
=
t3
^
t11
;
\
}
#define U96_BIT_LOTR32_8(t0,t1,t2,t3,t4,t5){\
t3
=
LOTR32
(
t2
,
2
);
\
t4
=
LOTR32
(
t0
,
3
);
\
t5
=
LOTR32
(
t1
,
3
);
\
}
#define U96_BIT_LOTR32_55(t0,t1,t2,t3,t4,t5){\
t3
=
LOTR32
(
t1
,
18
);
\
t4
=
LOTR32
(
t2
,
18
);
\
t5
=
LOTR32
(
t0
,
19
);
\
}
/*
s0 s1 s2
s3 s4 s5
s6 s7 s8
s9 s10 s11
*/
#define ROUND384(lunNum) {\
s
[
0
]
^=
(
constant7Format
[
lunNum
]
>>
6
)
&
0x3
;
\
s
[
1
]
^=
(
constant7Format
[
lunNum
]
>>
3
)
&
0x7
;
\
s
[
2
]
^=
constant7Format
[
lunNum
]
&
0x7
;
\
sbox
(
s
[
0
],
s
[
3
],
s
[
6
],
s
[
9
]
,
s_temp
[
3
],
s_temp
[
6
],
s_temp
[
9
]);
\
sbox
(
s
[
1
],
s
[
4
],
s
[
7
],
s
[
10
],
s
[
3
]
,
s_temp
[
7
],
s_temp
[
10
]);
\
sbox
(
s
[
2
],
s
[
5
],
s
[
8
],
s
[
11
],
s
[
4
]
,
s_temp
[
8
],
s_temp
[
11
]);
\
s
[
5
]
=
LOTR32
(
s_temp
[
3
],
1
);
\
U96_BIT_LOTR32_8
(
s_temp
[
6
],
s_temp
[
7
],
s_temp
[
8
],
s
[
6
],
s
[
7
],
s
[
8
]);
\
U96_BIT_LOTR32_55
(
s_temp
[
9
],
s_temp
[
10
],
s_temp
[
11
],
s
[
9
],
s
[
10
],
s
[
11
]);
\
}
#define puckU32ToThree_1(x){\
x
&=
0x49249249
;
\
x
=
(
x
|
(
x
>>
2
))
&
0xc30c30c3
;
\
x
=
(
x
|
(
x
>>
4
))
&
0x0f00f00f
;
\
x
=
(
x
|
(
x
>>
8
))
&
0xff0000ff
;
\
x
=
(
x
|
(
x
>>
16
))
&
0xfff
;
\
}
#define unpuckU32ToThree_1(x){\
x
&=
0xfff
;
\
x
=
(
x
|
(
x
<<
16
))
&
0xff0000ff
;
\
x
=
(
x
|
(
x
<<
8
))
&
0x0f00f00f
;
\
x
=
(
x
|
(
x
<<
4
))
&
0xc30c30c3
;
\
x
=
(
x
|
(
x
<<
2
))
&
0x49249249
;
\
}
#define packU32FormatToThreePacket(out, in) { \
u32
t2
=
U32BIG
(((
u32
*
)
in
)[
0
]);
\
out
[
2
]
=
t2
;
out
[
1
]
=
t2
>>
1
;
out
[
0
]
=
t2
>>
2
;
\
puckU32ToThree_1
(
out
[
0
]);
\
puckU32ToThree_1
(
out
[
1
]);
\
puckU32ToThree_1
(
out
[
2
]);
\
}
#define unpackU32FormatToThreePacket(out, in) { \
u32
temp0
[
3
]
=
{
0
};
\
temp0
[
0
]
=
in
[
0
]
&
0x3ff
;
\
temp0
[
1
]
=
in
[
1
]
&
0x7ff
;
\
temp0
[
2
]
=
in
[
2
]
&
0x7ff
;
\
unpuckU32ToThree_1
(
temp0
[
0
]);
\
unpuckU32ToThree_1
(
temp0
[
1
]);
\
unpuckU32ToThree_1
(
temp0
[
2
]);
\
*
(
u32
*
)(
out
)
=
U32BIG
(
temp0
[
0
]
<<
2
|
temp0
[
1
]
<<
1
|
temp0
[
2
]);
\
}
#define packU96FormatToThreePacket(out, in) { \
u32
temp0
[
3
]
=
{
0
};
\
u32
temp1
[
3
]
=
{
0
};
\
u32
temp2
[
3
]
=
{
0
};
\
temp0
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
0
]);
temp0
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
1
;
temp0
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
2
;
\
puckU32ToThree_1
(
temp0
[
0
]);
\
puckU32ToThree_1
(
temp0
[
1
]);
\
puckU32ToThree_1
(
temp0
[
2
]);
\
temp1
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
1
]);
temp1
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
1
])
>>
1
;
temp1
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
1
])
>>
2
;
\
puckU32ToThree_1
(
temp1
[
0
]);
\
puckU32ToThree_1
(
temp1
[
1
]);
\
puckU32ToThree_1
(
temp1
[
2
]);
\
temp2
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
2
]);
temp2
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
2
])
>>
1
;
temp2
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
2
])
>>
2
;
\
puckU32ToThree_1
(
temp2
[
0
]);
\
puckU32ToThree_1
(
temp2
[
1
]);
\
puckU32ToThree_1
(
temp2
[
2
]);
\
out
[
0
]
=
(
temp2
[
1
]
<<
21
)
|
(
temp1
[
0
]
<<
10
)
|
temp0
[
2
];
\
out
[
1
]
=
(
temp2
[
0
]
<<
21
)
|
(
temp1
[
2
]
<<
11
)
|
temp0
[
1
];
\
out
[
2
]
=
(
temp2
[
2
]
<<
22
)
|
(
temp1
[
1
]
<<
11
)
|
temp0
[
0
];
\
}
#define unpackU96FormatToThreePacket(out, in) { \
u32
temp0
[
3
]
=
{
0
};
\
u32
temp1
[
3
]
=
{
0
};
\
u32
temp2
[
3
]
=
{
0
};
\
u32
t
[
3
]
=
{
0
};
\
temp0
[
0
]
=
in
[
2
]
&
0x7ff
;
\
temp0
[
1
]
=
in
[
1
]
&
0x7ff
;
\
temp0
[
2
]
=
in
[
0
]
&
0x3ff
;
\
temp1
[
0
]
=
(
in
[
0
]
>>
10
)
&
0x7ff
;
\
temp1
[
1
]
=
(
in
[
2
]
>>
11
)
&
0x7ff
;
\
temp1
[
2
]
=
(
in
[
1
]
>>
11
)
&
0x3ff
;
\
temp2
[
0
]
=
in
[
1
]
>>
21
;
\
temp2
[
1
]
=
in
[
0
]
>>
21
;
\
temp2
[
2
]
=
in
[
2
]
>>
22
;
\
unpuckU32ToThree_1
(
temp0
[
0
]);
\
unpuckU32ToThree_1
(
temp0
[
1
]);
\
unpuckU32ToThree_1
(
temp0
[
2
]);
\
t
[
0
]
=
temp0
[
0
]
|
temp0
[
1
]
<<
1
|
temp0
[
2
]
<<
2
;
\
unpuckU32ToThree_1
(
temp1
[
0
]);
\
unpuckU32ToThree_1
(
temp1
[
1
]);
\
unpuckU32ToThree_1
(
temp1
[
2
]);
\
t
[
1
]
=
temp1
[
0
]
|
temp1
[
1
]
<<
1
|
temp1
[
2
]
<<
2
;
\
unpuckU32ToThree_1
(
temp2
[
0
]);
\
unpuckU32ToThree_1
(
temp2
[
1
]);
\
unpuckU32ToThree_1
(
temp2
[
2
]);
\
t
[
2
]
=
temp2
[
0
]
|
temp2
[
1
]
<<
1
|
temp2
[
2
]
<<
2
;
\
memcpy
(
out
,
t
,
12
*
sizeof
(
unsigned
char
));
\
}
knot/Implementations/crypto_hash/knot256v2/armcortexm_3/crypto_hash.h
0 → 100644
View file @
a34b1718
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
);
\ No newline at end of file
knot/Implementations/crypto_hash/knot256v2/armcortexm_3/hash.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
#define hash_RATE (128 / 8)
#define PRH_ROUNDS 80
//12*7=84
unsigned
char
constant7Format
[
80
]
=
{
/*constant7Format[127]:*/
0x01
,
0x08
,
0x40
,
0x02
,
0x10
,
0x80
,
0x05
,
0x09
,
0x48
,
0x42
,
0x12
,
0x90
,
0x85
,
0x0c
,
0x41
,
0x0a
,
0x50
,
0x82
,
0x15
,
0x89
,
0x4d
,
0x4b
,
0x5a
,
0xd2
,
0x97
,
0x9c
,
0xc4
,
0x06
,
0x11
,
0x88
,
0x45
,
0x0b
,
0x58
,
0xc2
,
0x17
,
0x99
,
0xcd
,
0x4e
,
0x53
,
0x9a
,
0xd5
,
0x8e
,
0x54
,
0x83
,
0x1d
,
0xc9
,
0x4f
,
0x5b
,
0xda
,
0xd7
,
0x9e
,
0xd4
,
0x86
,
0x14
,
0x81
,
0x0d
,
0x49
,
0x4a
,
0x52
,
0x92
,
0x95
,
0x8c
,
0x44
,
0x03
,
0x18
,
0xc0
,
0x07
,
0x19
,
0xc8
,
0x47
,
0x1b
,
0xd8
,
0xc7
,
0x1e
,
0xd1
,
0x8f
,
0x5c
,
0xc3
,
0x1f
,
0xd9
,
};
#define Processing_Data(data) \
do
{
\
packU96FormatToThreePacket
(
dataFormat
,
data
);
\
s
[
0
]
^=
dataFormat
[
0
];
\
s
[
1
]
^=
dataFormat
[
1
];
\
s
[
2
]
^=
dataFormat
[
2
];
\
packU32FormatToThreePacket
((
dataFormat
+
3
),
(
data
+
12
));
\
s
[
3
]
^=
dataFormat
[
3
];
\
s
[
4
]
^=
dataFormat
[
4
];
\
s
[
5
]
^=
dataFormat
[
5
];
\
}
while
(
0
)
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
)
{
u32
s
[
12
]
=
{
0
};
u32
dataFormat
[
6
]
=
{
0
};
u8
i
,
tempData
[
24
]
=
{
0
};
u32
s_temp
[
12
]
=
{
0
};
u32
t1
,
t2
,
t3
,
t5
,
t6
,
t8
,
t9
,
t11
;
// initialization
s
[
9
]
=
0x80000000
;
//absorb
while
(
inlen
>=
hash_RATE
)
{
Processing_Data
(
in
);
for
(
i
=
0
;
i
<
PRH_ROUNDS
;
i
++
)
{
ROUND384
(
i
);
}
inlen
-=
hash_RATE
;
in
+=
hash_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
in
,
inlen
*
sizeof
(
unsigned
char
));
tempData
[
inlen
]
=
0x01
;
Processing_Data
(
tempData
);
for
(
i
=
0
;
i
<
PRH_ROUNDS
;
i
++
)
{
ROUND384
(
i
);
}
//sequeez
unpackU96FormatToThreePacket
(
out
,
s
);
unpackU32FormatToThreePacket
((
out
+
12
),
(
s
+
3
));
for
(
i
=
0
;
i
<
PRH_ROUNDS
;
i
++
)
{
ROUND384
(
i
);
}
out
+=
CRYPTO_BYTES
/
2
;
unpackU96FormatToThreePacket
(
out
,
s
);
unpackU32FormatToThreePacket
((
out
+
12
),
(
s
+
3
));
return
0
;
}
knot/Implementations/crypto_hash/knot256v2/armcortexm_4/api.h
0 → 100644
View file @
a34b1718
#define CRYPTO_BYTES 32
knot/Implementations/crypto_hash/knot256v2/armcortexm_4/auxFormat.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
void
packU32FormatToThreePacket
(
u32
*
out
,
u8
*
in
)
{
u32
t2
=
U32BIG
(((
u32
*
)
in
)[
0
]);
out
[
2
]
=
t2
;
out
[
1
]
=
t2
>>
1
;
out
[
0
]
=
t2
>>
2
;
//temp2[0] 0;temp2[1] 1;temp2[2] 2;
puckU32ToThree_1
(
out
[
0
]);
puckU32ToThree_1
(
out
[
1
]);
puckU32ToThree_1
(
out
[
2
]);
}
void
unpackU32FormatToThreePacket
(
u8
*
out
,
u32
*
in
)
{
u32
temp0
[
3
]
=
{
0
};
temp0
[
0
]
=
in
[
0
]
&
0x3ff
;
temp0
[
1
]
=
in
[
1
]
&
0x7ff
;
temp0
[
2
]
=
in
[
2
]
&
0x7ff
;
unpuckU32ToThree_1
(
temp0
[
0
]);
unpuckU32ToThree_1
(
temp0
[
1
]);
unpuckU32ToThree_1
(
temp0
[
2
]);
*
(
u32
*
)(
out
)
=
U32BIG
(
temp0
[
0
]
<<
2
|
temp0
[
1
]
<<
1
|
temp0
[
2
]);
}
void
packU96FormatToThreePacket
(
u32
*
out
,
u8
*
in
)
{
u32
temp0
[
3
]
=
{
0
};
u32
temp1
[
3
]
=
{
0
};
u32
temp2
[
3
]
=
{
0
};
temp0
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
0
]);
temp0
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
1
;
temp0
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
2
;
puckU32ToThree_1
(
temp0
[
0
]);
puckU32ToThree_1
(
temp0
[
1
]);
puckU32ToThree_1
(
temp0
[
2
]);
temp1
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
1
]);
temp1
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
1
])
>>
1
;
temp1
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
1
])
>>
2
;
puckU32ToThree_1
(
temp1
[
0
]);
puckU32ToThree_1
(
temp1
[
1
]);
puckU32ToThree_1
(
temp1
[
2
]);
temp2
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
2
]);
temp2
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
2
])
>>
1
;
temp2
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
2
])
>>
2
;
puckU32ToThree_1
(
temp2
[
0
]);
puckU32ToThree_1
(
temp2
[
1
]);
puckU32ToThree_1
(
temp2
[
2
]);
out
[
0
]
=
(
temp2
[
1
]
<<
21
)
|
(
temp1
[
0
]
<<
10
)
|
temp0
[
2
];
out
[
1
]
=
(
temp2
[
0
]
<<
21
)
|
(
temp1
[
2
]
<<
11
)
|
temp0
[
1
];
out
[
2
]
=
(
temp2
[
2
]
<<
22
)
|
(
temp1
[
1
]
<<
11
)
|
temp0
[
0
];
}
void
unpackU96FormatToThreePacket
(
u8
*
out
,
u32
*
in
)
{
u32
temp0
[
3
]
=
{
0
};
u32
temp1
[
3
]
=
{
0
};
u32
temp2
[
3
]
=
{
0
};
u32
t
[
3
]
=
{
0
};
temp0
[
0
]
=
in
[
2
]
&
0x7ff
;
temp0
[
1
]
=
in
[
1
]
&
0x7ff
;
temp0
[
2
]
=
in
[
0
]
&
0x3ff
;
temp1
[
0
]
=
(
in
[
0
]
>>
10
)
&
0x7ff
;
temp1
[
1
]
=
(
in
[
2
]
>>
11
)
&
0x7ff
;
temp1
[
2
]
=
(
in
[
1
]
>>
11
)
&
0x3ff
;
temp2
[
0
]
=
in
[
1
]
>>
21
;
temp2
[
1
]
=
in
[
0
]
>>
21
;
temp2
[
2
]
=
in
[
2
]
>>
22
;
unpuckU32ToThree_1
(
temp0
[
0
]);
unpuckU32ToThree_1
(
temp0
[
1
]);
unpuckU32ToThree_1
(
temp0
[
2
]);
t
[
0
]
=
temp0
[
0
]
|
temp0
[
1
]
<<
1
|
temp0
[
2
]
<<
2
;
unpuckU32ToThree_1
(
temp1
[
0
]);
unpuckU32ToThree_1
(
temp1
[
1
]);
unpuckU32ToThree_1
(
temp1
[
2
]);
t
[
1
]
=
temp1
[
0
]
|
temp1
[
1
]
<<
1
|
temp1
[
2
]
<<
2
;
unpuckU32ToThree_1
(
temp2
[
0
]);
unpuckU32ToThree_1
(
temp2
[
1
]);
unpuckU32ToThree_1
(
temp2
[
2
]);
t
[
2
]
=
temp2
[
0
]
|
temp2
[
1
]
<<
1
|
temp2
[
2
]
<<
2
;
memcpy
(
out
,
t
,
12
*
sizeof
(
unsigned
char
));
}
unsigned
char
constant7Format
[
80
]
=
{
/*constant7Format[127]: 12*6=72*/
0x01
,
0x08
,
0x40
,
0x02
,
0x10
,
0x80
,
0x05
,
0x09
,
0x48
,
0x42
,
0x12
,
0x90
,
0x85
,
0x0c
,
0x41
,
0x0a
,
0x50
,
0x82
,
0x15
,
0x89
,
0x4d
,
0x4b
,
0x5a
,
0xd2
,
0x97
,
0x9c
,
0xc4
,
0x06
,
0x11
,
0x88
,
0x45
,
0x0b
,
0x58
,
0xc2
,
0x17
,
0x99
,
0xcd
,
0x4e
,
0x53
,
0x9a
,
0xd5
,
0x8e
,
0x54
,
0x83
,
0x1d
,
0xc9
,
0x4f
,
0x5b
,
0xda
,
0xd7
,
0x9e
,
0xd4
,
0x86
,
0x14
,
0x81
,
0x0d
,
0x49
,
0x4a
,
0x52
,
0x92
,
0x95
,
0x8c
,
0x44
,
0x03
,
0x18
,
0xc0
,
0x07
,
0x19
,
0xc8
,
0x47
,
0x1b
,
0xd8
,
0xc7
,
0x1e
,
0xd1
,
0x8f
,
0x5c
,
0xc3
,
0x1f
,
0xd9
,};
void
P384
(
unsigned
int
*
s
,
unsigned
char
*
round
,
unsigned
char
lunNum
)
{
u32
s_temp
[
12
]
=
{
0
};
u32
t1
,
t2
,
t3
,
t5
,
t6
,
t8
,
t9
,
t11
;
unsigned
char
i
;
for
(
i
=
0
;
i
<
lunNum
;
i
++
)
{
s
[
0
]
^=
(
round
[
i
]
>>
6
)
&
0x3
;
\
s
[
1
]
^=
(
round
[
i
]
>>
3
)
&
0x7
;
\
s
[
2
]
^=
round
[
i
]
&
0x7
;
\
sbox
(
s
[
0
],
s
[
3
],
s
[
6
],
s
[
9
]
,
s_temp
[
3
],
s_temp
[
6
],
s_temp
[
9
]);
\
sbox
(
s
[
1
],
s
[
4
],
s
[
7
],
s
[
10
],
s
[
3
]
,
s_temp
[
7
],
s_temp
[
10
]);
\
sbox
(
s
[
2
],
s
[
5
],
s
[
8
],
s
[
11
],
s
[
4
]
,
s_temp
[
8
],
s_temp
[
11
]);
\
s
[
5
]
=
LOTR32
(
s_temp
[
3
],
1
);
\
U96_BIT_LOTR32_8
(
s_temp
[
6
],
s_temp
[
7
],
s_temp
[
8
],
s
[
6
],
s
[
7
],
s
[
8
]);
\
U96_BIT_LOTR32_55
(
s_temp
[
9
],
s_temp
[
10
],
s_temp
[
11
],
s
[
9
],
s
[
10
],
s
[
11
]);
\
}
}
knot/Implementations/crypto_hash/knot256v2/armcortexm_4/auxFormat.h
0 → 100644
View file @
a34b1718
#include<malloc.h>
#include"crypto_hash.h"
#include"api.h"
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#define U32BIG(x) (x)
typedef
unsigned
char
u8
;
typedef
unsigned
int
u32
;
typedef
unsigned
long
long
u64
;
void
P384
(
unsigned
int
*
s
,
unsigned
char
*
round
,
unsigned
char
lunNum
)
;
void
unpackU96FormatToThreePacket
(
u8
*
out
,
u32
*
in
)
;
void
packU96FormatToThreePacket
(
u32
*
out
,
u8
*
in
);
void
unpackU32FormatToThreePacket
(
u8
*
out
,
u32
*
in
);
void
packU32FormatToThreePacket
(
u32
*
out
,
u8
*
in
);
#define puckU32ToThree_1(x){\
x
&=
0x49249249
;
\
x
=
(
x
|
(
x
>>
2
))
&
0xc30c30c3
;
\
x
=
(
x
|
(
x
>>
4
))
&
0x0f00f00f
;
\
x
=
(
x
|
(
x
>>
8
))
&
0xff0000ff
;
\
x
=
(
x
|
(
x
>>
16
))
&
0xfff
;
\
}
#define unpuckU32ToThree_1(x){\
x
&=
0xfff
;
\
x
=
(
x
|
(
x
<<
16
))
&
0xff0000ff
;
\
x
=
(
x
|
(
x
<<
8
))
&
0x0f00f00f
;
\
x
=
(
x
|
(
x
<<
4
))
&
0xc30c30c3
;
\
x
=
(
x
|
(
x
<<
2
))
&
0x49249249
;
\
}
unsigned
char
constant7Format
[
80
];
#define ARR_SIZE(a) (sizeof((a))/sizeof((a[0])))
#define LOTR32(x,n) (((x)<<(n))|((x)>>(32-(n))))
#define sbox(a, b, c, d, f, g, h) \
{
\
t1
=
~
a
;
t2
=
b
&
t1
;
t3
=
c
^
t2
;
h
=
d
^
t3
;
t5
=
b
|
c
;
t6
=
d
^
t1
;
g
=
t5
^
t6
;
t8
=
b
^
d
;
t9
=
t3
&
t6
;
a
=
t8
^
t9
;
t11
=
g
&
t8
;
f
=
t3
^
t11
;
\
}
#define U96_BIT_LOTR32_8(t0,t1,t2,t3,t4,t5){\
t3
=
LOTR32
(
t2
,
2
);
\
t4
=
LOTR32
(
t0
,
3
);
\
t5
=
LOTR32
(
t1
,
3
);
\
}
//55=3*18+1
#define U96_BIT_LOTR32_55(t0,t1,t2,t3,t4,t5){\
t3
=
LOTR32
(
t1
,
18
);
\
t4
=
LOTR32
(
t2
,
18
);
\
t5
=
LOTR32
(
t0
,
19
);
\
}
knot/Implementations/crypto_hash/knot256v2/armcortexm_4/crypto_hash.h
0 → 100644
View file @
a34b1718
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
);
\ No newline at end of file
knot/Implementations/crypto_hash/knot256v2/armcortexm_4/hash.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
#define hash_RATE (128 / 8)
#define PRH_ROUNDS 80
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
)
{
u32
s
[
12
]
=
{
0
};
u32
dataFormat
[
6
]
=
{
0
};
u8
tempData
[
24
]
=
{
0
};
// initialization
s
[
9
]
=
0x80000000
;
//absorb
while
(
inlen
>=
hash_RATE
)
{
packU96FormatToThreePacket
(
dataFormat
,
in
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
packU32FormatToThreePacket
(
dataFormat
+
3
,
in
+
12
);
s
[
3
]
^=
dataFormat
[
3
];
s
[
4
]
^=
dataFormat
[
4
];
s
[
5
]
^=
dataFormat
[
5
];
P384
(
s
,
constant7Format
,
PRH_ROUNDS
);
inlen
-=
hash_RATE
;
in
+=
hash_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
in
,
inlen
*
sizeof
(
unsigned
char
));
tempData
[
inlen
]
=
0x01
;
packU96FormatToThreePacket
(
dataFormat
,
tempData
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
packU32FormatToThreePacket
(
dataFormat
+
3
,
tempData
+
12
);
s
[
3
]
^=
dataFormat
[
3
];
s
[
4
]
^=
dataFormat
[
4
];
s
[
5
]
^=
dataFormat
[
5
];
P384
(
s
,
constant7Format
,
PRH_ROUNDS
);
//sequeez
unpackU96FormatToThreePacket
(
out
,
s
);
unpackU32FormatToThreePacket
(
out
+
12
,
s
+
3
);
P384
(
s
,
constant7Format
,
PRH_ROUNDS
);
out
+=
CRYPTO_BYTES
/
2
;
unpackU96FormatToThreePacket
(
out
,
s
);
unpackU32FormatToThreePacket
(
out
+
12
,
s
+
3
);
return
0
;
}
knot/Implementations/crypto_hash/knot256v2/armcortexm_5/api.h
0 → 100644
View file @
a34b1718
#define CRYPTO_BYTES 32
knot/Implementations/crypto_hash/knot256v2/armcortexm_5/auxFormat.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
void
packU32FormatToThreePacket
(
u32
*
out
,
u8
*
in
)
{
u32
t2
=
U32BIG
(((
u32
*
)
in
)[
0
]);
out
[
2
]
=
t2
;
out
[
1
]
=
t2
>>
1
;
out
[
0
]
=
t2
>>
2
;
//temp2[0] 0;temp2[1] 1;temp2[2] 2;
puckU32ToThree_1
(
out
[
0
]);
puckU32ToThree_1
(
out
[
1
]);
puckU32ToThree_1
(
out
[
2
]);
}
void
unpackU32FormatToThreePacket
(
u8
*
out
,
u32
*
in
)
{
u32
temp0
[
3
]
=
{
0
};
temp0
[
0
]
=
in
[
0
]
&
0x3ff
;
temp0
[
1
]
=
in
[
1
]
&
0x7ff
;
temp0
[
2
]
=
in
[
2
]
&
0x7ff
;
unpuckU32ToThree_1
(
temp0
[
0
]);
unpuckU32ToThree_1
(
temp0
[
1
]);
unpuckU32ToThree_1
(
temp0
[
2
]);
*
(
u32
*
)(
out
)
=
U32BIG
(
temp0
[
0
]
<<
2
|
temp0
[
1
]
<<
1
|
temp0
[
2
]);
}
void
packU96FormatToThreePacket
(
u32
*
out
,
u8
*
in
)
{
u32
temp0
[
3
]
=
{
0
};
u32
temp1
[
3
]
=
{
0
};
u32
temp2
[
3
]
=
{
0
};
temp0
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
0
]);
temp0
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
1
;
temp0
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
2
;
puckU32ToThree_1
(
temp0
[
0
]);
puckU32ToThree_1
(
temp0
[
1
]);
puckU32ToThree_1
(
temp0
[
2
]);
temp1
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
1
]);
temp1
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
1
])
>>
1
;
temp1
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
1
])
>>
2
;
puckU32ToThree_1
(
temp1
[
0
]);
puckU32ToThree_1
(
temp1
[
1
]);
puckU32ToThree_1
(
temp1
[
2
]);
temp2
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
2
]);
temp2
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
2
])
>>
1
;
temp2
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
2
])
>>
2
;
puckU32ToThree_1
(
temp2
[
0
]);
puckU32ToThree_1
(
temp2
[
1
]);
puckU32ToThree_1
(
temp2
[
2
]);
out
[
0
]
=
(
temp2
[
1
]
<<
21
)
|
(
temp1
[
0
]
<<
10
)
|
temp0
[
2
];
out
[
1
]
=
(
temp2
[
0
]
<<
21
)
|
(
temp1
[
2
]
<<
11
)
|
temp0
[
1
];
out
[
2
]
=
(
temp2
[
2
]
<<
22
)
|
(
temp1
[
1
]
<<
11
)
|
temp0
[
0
];
}
void
unpackU96FormatToThreePacket
(
u8
*
out
,
u32
*
in
)
{
u32
temp0
[
3
]
=
{
0
};
u32
temp1
[
3
]
=
{
0
};
u32
temp2
[
3
]
=
{
0
};
u32
t
[
3
]
=
{
0
};
temp0
[
0
]
=
in
[
2
]
&
0x7ff
;
temp0
[
1
]
=
in
[
1
]
&
0x7ff
;
temp0
[
2
]
=
in
[
0
]
&
0x3ff
;
temp1
[
0
]
=
(
in
[
0
]
>>
10
)
&
0x7ff
;
temp1
[
1
]
=
(
in
[
2
]
>>
11
)
&
0x7ff
;
temp1
[
2
]
=
(
in
[
1
]
>>
11
)
&
0x3ff
;
temp2
[
0
]
=
in
[
1
]
>>
21
;
temp2
[
1
]
=
in
[
0
]
>>
21
;
temp2
[
2
]
=
in
[
2
]
>>
22
;
unpuckU32ToThree_1
(
temp0
[
0
]);
unpuckU32ToThree_1
(
temp0
[
1
]);
unpuckU32ToThree_1
(
temp0
[
2
]);
t
[
0
]
=
temp0
[
0
]
|
temp0
[
1
]
<<
1
|
temp0
[
2
]
<<
2
;
unpuckU32ToThree_1
(
temp1
[
0
]);
unpuckU32ToThree_1
(
temp1
[
1
]);
unpuckU32ToThree_1
(
temp1
[
2
]);
t
[
1
]
=
temp1
[
0
]
|
temp1
[
1
]
<<
1
|
temp1
[
2
]
<<
2
;
unpuckU32ToThree_1
(
temp2
[
0
]);
unpuckU32ToThree_1
(
temp2
[
1
]);
unpuckU32ToThree_1
(
temp2
[
2
]);
t
[
2
]
=
temp2
[
0
]
|
temp2
[
1
]
<<
1
|
temp2
[
2
]
<<
2
;
memcpy
(
out
,
t
,
12
*
sizeof
(
unsigned
char
));
}
void
ROUND384_Three
(
unsigned
int
*
s
,
unsigned
char
*
c
,
int
lunnum
)
{
\
unsigned
int
t
,
t1
,
t2
;
u32
rci
;
rci
=
c
[
0
];
ROUND384_1
(
rci
);
t
=
1
;
while
(
lunnum
--
)
{
rci
=
c
[
t
];
ROUND384_2
(
rci
);
t
++
;
rci
=
c
[
t
];
ROUND384_3
(
rci
);
t
++
;
rci
=
c
[
t
];
ROUND384_4
(
rci
);
t
++
;
}
}
unsigned
char
constant7Format
[
80
]
=
{
/*constant7Format[127]: 12*6=72*/
0x01
,
0x08
,
0x40
,
0x02
,
0x10
,
0x80
,
0x05
,
0x09
,
0x48
,
0x42
,
0x12
,
0x90
,
0x85
,
0x0c
,
0x41
,
0x0a
,
0x50
,
0x82
,
0x15
,
0x89
,
0x4d
,
0x4b
,
0x5a
,
0xd2
,
0x97
,
0x9c
,
0xc4
,
0x06
,
0x11
,
0x88
,
0x45
,
0x0b
,
0x58
,
0xc2
,
0x17
,
0x99
,
0xcd
,
0x4e
,
0x53
,
0x9a
,
0xd5
,
0x8e
,
0x54
,
0x83
,
0x1d
,
0xc9
,
0x4f
,
0x5b
,
0xda
,
0xd7
,
0x9e
,
0xd4
,
0x86
,
0x14
,
0x81
,
0x0d
,
0x49
,
0x4a
,
0x52
,
0x92
,
0x95
,
0x8c
,
0x44
,
0x03
,
0x18
,
0xc0
,
0x07
,
0x19
,
0xc8
,
0x47
,
0x1b
,
0xd8
,
0xc7
,
0x1e
,
0xd1
,
0x8f
,
0x5c
,
0xc3
,
0x1f
,
0xd9
,};
knot/Implementations/crypto_hash/knot256v2/armcortexm_5/auxFormat.h
0 → 100644
View file @
a34b1718
#include<malloc.h>
#include"crypto_hash.h"
#include"api.h"
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#define U32BIG(x) (x)
typedef
unsigned
char
u8
;
typedef
unsigned
int
u32
;
typedef
unsigned
long
long
u64
;
void
ROUND384_Three
(
unsigned
int
*
s
,
unsigned
char
*
c
,
int
lunnum
)
;
void
unpackU96FormatToThreePacket
(
u8
*
out
,
u32
*
in
)
;
void
packU96FormatToThreePacket
(
u32
*
out
,
u8
*
in
);
void
unpackU32FormatToThreePacket
(
u8
*
out
,
u32
*
in
);
void
packU32FormatToThreePacket
(
u32
*
out
,
u8
*
in
);
#define puckU32ToThree_1(x){\
x
&=
0x49249249
;
\
x
=
(
x
|
(
x
>>
2
))
&
0xc30c30c3
;
\
x
=
(
x
|
(
x
>>
4
))
&
0x0f00f00f
;
\
x
=
(
x
|
(
x
>>
8
))
&
0xff0000ff
;
\
x
=
(
x
|
(
x
>>
16
))
&
0xfff
;
\
}
#define unpuckU32ToThree_1(x){\
x
&=
0xfff
;
\
x
=
(
x
|
(
x
<<
16
))
&
0xff0000ff
;
\
x
=
(
x
|
(
x
<<
8
))
&
0x0f00f00f
;
\
x
=
(
x
|
(
x
<<
4
))
&
0xc30c30c3
;
\
x
=
(
x
|
(
x
<<
2
))
&
0x49249249
;
\
}
////////////constant begin//
unsigned
char
constant7Format
[
80
];
#define ARC(rci) \
do
{
\
__asm__
__volatile__
(
\
"/*add round const s0 s1 s2 */
\n\t
"
\
"ands %[t1], %[rci], #0xc0
\n\t
"
\
"eors %[S_0], %[S_0], %[t1], LSR #6
\n\t
"
/*s[0] ^= (constant7Format[lunNum] >> 6) & 0x3;*/
\
"ands %[t1], %[rci], #0x38
\n\t
"
\
"eors %[S_1], %[S_1], %[t1], LSR #3
\n\t
"
/*s[0] ^= (constant7Format[lunNum] >> 6) & 0x3;*/
\
"ands %[t1], %[rci], #0x7
\n\t
"
\
"eors %[S_3], %[S_3], %[t1]
\n\t
"
/*s[2] ^= constant7Format[lunNum] & 0x7;*/
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
rci
]
"+r"
(
rci
),
\
[
S_0
]
"+r"
(
s
[
0
]),
[
S_1
]
"+r"
(
s
[
1
]),
[
S_3
]
"+r"
(
s
[
2
])
\
:
:
);
\
}
while
(
0
)
#define SBOX(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define SBOX1(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"ROR %[S_4] , #30
\n\t
"
\
"ROR %[S_6] , #14
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define SBOX2(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"ROR %[S_4] , #29
\n\t
"
\
"ROR %[S_6] , #14
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define SBOX3(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"ROR %[S_2] , #31
\n\t
"
\
"ROR %[S_4] , #29
\n\t
"
\
"ROR %[S_6] , #13
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define ROUND384_1(rci) {\
ARC
(
rci
);
\
SBOX
(
s
[
0
],
s
[
3
],
s
[
6
],
s
[
9
]
);
\
SBOX
(
s
[
1
],
s
[
4
],
s
[
7
],
s
[
10
]);
\
SBOX
(
s
[
2
],
s
[
5
],
s
[
8
],
s
[
11
]);
\
}
#define ROUND384_2(rci) {\
ARC
(
rci
);
\
SBOX1
(
s
[
0
],
s
[
4
],
s
[
8
],
s
[
10
]
);
\
SBOX2
(
s
[
1
],
s
[
5
],
s
[
6
],
s
[
11
]);
\
SBOX3
(
s
[
2
],
s
[
3
],
s
[
7
],
s
[
9
]);
\
}
#define ROUND384_3(rci) {\
ARC
(
rci
);
\
SBOX1
(
s
[
0
],
s
[
5
],
s
[
7
],
s
[
11
]);
\
SBOX2
(
s
[
1
],
s
[
3
],
s
[
8
],
s
[
9
]);
\
SBOX3
(
s
[
2
],
s
[
4
],
s
[
6
],
s
[
10
]);
\
}
#define ROUND384_4(rci) {\
ARC
(
rci
);
\
SBOX1
(
s
[
0
],
s
[
3
],
s
[
6
],
s
[
9
]);
\
SBOX2
(
s
[
1
],
s
[
4
],
s
[
7
],
s
[
10
]);
\
SBOX3
(
s
[
2
],
s
[
5
],
s
[
8
],
s
[
11
]);
\
}
#define P384_2( s, round, lunNum) {\
u32
t1
,
rci
;
\
ROUND384_Three
(
s
,
round
,
lunNum
);
\
rci
=
round
[
lunNum
*
3
+
1
];
\
ROUND384_2
(
rci
);
\
__asm__
__volatile__
(
\
"/*rotate shift left 1 bit [w9 w5 w1-> (w1,1) w9 w5] */
\n\t
"
\
"mov %[t1], %[S_4]
\n\t
"
\
"mov %[S_4], %[S_3]
\n\t
"
\
"mov %[S_3], %[S_5]
\n\t
"
\
"ROR %[S_5], %[t1] , #31
\n\t
"
\
"/*rotate shift left 8 bits [w10 w6 w2-> (w6,3) (w2,3) ( w10,2)]*/
\n\t
"
\
"mov %[t1], %[S_8]
\n\t
"
\
"ROR %[S_8], %[S_6] , #29
\n\t
"
\
"ROR %[S_6], %[S_7] , #30
\n\t
"
\
"ROR %[S_7], %[t1] , #29
\n\t
"
\
"/*rotate shift left 55 bit [w11 w7 w3-> (w3,13) (w11,14) ( w7,14)] */
\n\t
"
\
"mov %[t1], %[S_10]
\n\t
"
\
"ROR %[S_10], %[S_9] , #14
\n\t
"
\
"ROR %[S_9], %[S_11] , #14
\n\t
"
\
"ROR %[S_11], %[t1] , #13
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
\
[
S_3
]
"+r"
(
s
[
3
]),
[
S_6
]
"+r"
(
s
[
6
]),
[
S_9
]
"+r"
(
s
[
9
])
,
\
[
S_4
]
"+r"
(
s
[
4
]),
[
S_7
]
"+r"
(
s
[
7
]),
[
S_10
]
"+r"
(
s
[
10
]),
\
[
S_5
]
"+r"
(
s
[
5
]),
[
S_8
]
"+r"
(
s
[
8
]),
[
S_11
]
"+r"
(
s
[
11
])
\
:
:
);
\
}
knot/Implementations/crypto_hash/knot256v2/armcortexm_5/crypto_hash.h
0 → 100644
View file @
a34b1718
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
);
\ No newline at end of file
knot/Implementations/crypto_hash/knot256v2/armcortexm_5/hash.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
#define hash_RATE (128 / 8)
//#define PRH_ROUNDS 80
#define PRH_ROUNDS 26
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
)
{
u32
s
[
12
]
=
{
0
};
u32
dataFormat
[
6
]
=
{
0
};
u8
tempData
[
24
]
=
{
0
};
u32
t2
;
// initialization
s
[
9
]
=
0x80000000
;
//absorb
while
(
inlen
>=
hash_RATE
)
{
packU96FormatToThreePacket
(
dataFormat
,
in
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
packU32FormatToThreePacket
(
dataFormat
+
3
,
in
+
12
);
s
[
3
]
^=
dataFormat
[
3
];
s
[
4
]
^=
dataFormat
[
4
];
s
[
5
]
^=
dataFormat
[
5
];
P384_2
(
s
,
constant7Format
,
PRH_ROUNDS
);
inlen
-=
hash_RATE
;
in
+=
hash_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
in
,
inlen
*
sizeof
(
unsigned
char
));
tempData
[
inlen
]
=
0x01
;
packU96FormatToThreePacket
(
dataFormat
,
tempData
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
packU32FormatToThreePacket
(
dataFormat
+
3
,
tempData
+
12
);
s
[
3
]
^=
dataFormat
[
3
];
s
[
4
]
^=
dataFormat
[
4
];
s
[
5
]
^=
dataFormat
[
5
];
P384_2
(
s
,
constant7Format
,
PRH_ROUNDS
);
//sequeez
unpackU96FormatToThreePacket
(
out
,
s
);
unpackU32FormatToThreePacket
(
out
+
12
,
s
+
3
);
P384_2
(
s
,
constant7Format
,
PRH_ROUNDS
);
out
+=
CRYPTO_BYTES
/
2
;
unpackU96FormatToThreePacket
(
out
,
s
);
unpackU32FormatToThreePacket
(
out
+
12
,
s
+
3
);
return
0
;
}
knot/Implementations/crypto_hash/knot384/armcortexm_2/api.h
0 → 100644
View file @
a34b1718
#define CRYPTO_BYTES 48
knot/Implementations/crypto_hash/knot384/armcortexm_2/auxFormat.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
void
unpackU96FormatToThreePacket
(
u8
*
out
,
u32
*
in
)
{
u32
temp0
[
3
]
=
{
0
};
u32
temp1
[
3
]
=
{
0
};
u32
temp2
[
3
]
=
{
0
};
u32
t
[
3
]
=
{
0
};
temp0
[
0
]
=
in
[
2
]
&
0x7ff
;
temp0
[
1
]
=
in
[
1
]
&
0x7ff
;
temp0
[
2
]
=
in
[
0
]
&
0x3ff
;
temp1
[
0
]
=
(
in
[
0
]
>>
10
)
&
0x7ff
;
temp1
[
1
]
=
(
in
[
2
]
>>
11
)
&
0x7ff
;
temp1
[
2
]
=
(
in
[
1
]
>>
11
)
&
0x3ff
;
temp2
[
0
]
=
in
[
1
]
>>
21
;
temp2
[
1
]
=
in
[
0
]
>>
21
;
temp2
[
2
]
=
in
[
2
]
>>
22
;
unpuckU32ToThree_1
(
temp0
[
0
]);
unpuckU32ToThree_1
(
temp0
[
1
]);
unpuckU32ToThree_1
(
temp0
[
2
]);
t
[
0
]
=
temp0
[
0
]
|
temp0
[
1
]
<<
1
|
temp0
[
2
]
<<
2
;
unpuckU32ToThree_1
(
temp1
[
0
]);
unpuckU32ToThree_1
(
temp1
[
1
]);
unpuckU32ToThree_1
(
temp1
[
2
]);
t
[
1
]
=
temp1
[
0
]
|
temp1
[
1
]
<<
1
|
temp1
[
2
]
<<
2
;
unpuckU32ToThree_1
(
temp2
[
0
]);
unpuckU32ToThree_1
(
temp2
[
1
]);
unpuckU32ToThree_1
(
temp2
[
2
]);
t
[
2
]
=
temp2
[
0
]
|
temp2
[
1
]
<<
1
|
temp2
[
2
]
<<
2
;
memcpy
(
out
,
t
,
12
*
sizeof
(
unsigned
char
));
}
void
packU48FormatToThreePacket
(
u32
*
out
,
u8
*
in
)
{
u32
t1
=
(
u32
)
U16BIG
(
*
(
u16
*
)(
in
+
4
));
u32
temp0
[
3
]
=
{
0
};
u32
temp1
[
3
]
=
{
0
};
temp0
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
0
]);
temp0
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
1
;
temp0
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
2
;
puckU32ToThree_1
(
temp0
[
0
]);
puckU32ToThree_1
(
temp0
[
1
]);
puckU32ToThree_1
(
temp0
[
2
]);
temp1
[
0
]
=
t1
;
temp1
[
1
]
=
t1
>>
1
;
temp1
[
2
]
=
t1
>>
2
;
puckU32ToThree_1
(
temp1
[
0
]);
puckU32ToThree_1
(
temp1
[
1
]);
puckU32ToThree_1
(
temp1
[
2
]);
out
[
0
]
=
(
temp1
[
0
]
<<
10
)
|
temp0
[
2
];
out
[
1
]
=
(
temp1
[
2
]
<<
11
)
|
temp0
[
1
];
out
[
2
]
=
(
temp1
[
1
]
<<
11
)
|
temp0
[
0
];
}
unsigned
char
constant7Format
[
104
]
=
{
/*constant7Format[127]: 12*9=108*/
0x01
,
0x08
,
0x40
,
0x02
,
0x10
,
0x80
,
0x05
,
0x09
,
0x48
,
0x42
,
0x12
,
0x90
,
0x85
,
0x0c
,
0x41
,
0x0a
,
0x50
,
0x82
,
0x15
,
0x89
,
0x4d
,
0x4b
,
0x5a
,
0xd2
,
0x97
,
0x9c
,
0xc4
,
0x06
,
0x11
,
0x88
,
0x45
,
0x0b
,
0x58
,
0xc2
,
0x17
,
0x99
,
0xcd
,
0x4e
,
0x53
,
0x9a
,
0xd5
,
0x8e
,
0x54
,
0x83
,
0x1d
,
0xc9
,
0x4f
,
0x5b
,
0xda
,
0xd7
,
0x9e
,
0xd4
,
0x86
,
0x14
,
0x81
,
0x0d
,
0x49
,
0x4a
,
0x52
,
0x92
,
0x95
,
0x8c
,
0x44
,
0x03
,
0x18
,
0xc0
,
0x07
,
0x19
,
0xc8
,
0x47
,
0x1b
,
0xd8
,
0xc7
,
0x1e
,
0xd1
,
0x8f
,
0x5c
,
0xc3
,
0x1f
,
0xd9
,
0xcf
,
0x5e
,
0xd3
,
0x9f
,
0xdc
,
0xc6
,
0x16
,
0x91
,
0x8d
,
0x4c
,
0x43
,
0x1a
,
0xd0
,
0x87
,
0x1c
,
0xc1
,
0x0f
,
0x59
,
0xca
,
0x57
,
0x9b
,
0xdd
,
0xce
,
0x56
,};
void
P384
(
unsigned
int
*
s
,
unsigned
char
*
round
,
unsigned
char
lunNum
)
{
u32
rci
,
t1
,
t2
;
unsigned
char
i
;
for
(
i
=
0
;
i
<
lunNum
;
i
++
)
{
rci
=
constant7Format
[
i
];
P384_ARC_SC1
(
rci
,
s
[
3
],
s
[
6
],
s
[
9
]);
P384_2SC
(
s
[
1
],
s
[
4
],
s
[
7
],
s
[
10
],
s
[
2
],
s
[
5
],
s
[
8
],
s
[
11
]);
P384_SR
();
}
}
knot/Implementations/crypto_hash/knot384/armcortexm_2/auxFormat.h
0 → 100644
View file @
a34b1718
#include<malloc.h>
#include"crypto_hash.h"
#include"api.h"
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#define U32BIG(x) (x)
#define U16BIG(x) (x)
typedef
unsigned
char
u8
;
typedef
unsigned
short
u16
;
typedef
unsigned
int
u32
;
typedef
unsigned
long
long
u64
;
void
packU48FormatToThreePacket
(
u32
*
out
,
u8
*
in
)
;
void
P384
(
unsigned
int
*
s
,
unsigned
char
*
round
,
unsigned
char
lunNum
)
;
void
unpackU96FormatToThreePacket
(
u8
*
out
,
u32
*
in
)
;
#define puckU32ToThree_1(x){\
x
&=
0x49249249
;
\
x
=
(
x
|
(
x
>>
2
))
&
0xc30c30c3
;
\
x
=
(
x
|
(
x
>>
4
))
&
0x0f00f00f
;
\
x
=
(
x
|
(
x
>>
8
))
&
0xff0000ff
;
\
x
=
(
x
|
(
x
>>
16
))
&
0xfff
;
\
}
#define unpuckU32ToThree_1(x){\
x
&=
0xfff
;
\
x
=
(
x
|
(
x
<<
16
))
&
0xff0000ff
;
\
x
=
(
x
|
(
x
<<
8
))
&
0x0f00f00f
;
\
x
=
(
x
|
(
x
<<
4
))
&
0xc30c30c3
;
\
x
=
(
x
|
(
x
<<
2
))
&
0x49249249
;
\
}
#define P384_ARC_SC1(rci,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*add round const s0 s1 s2 */
\n\t
"
\
"ands %[t1], %[rci], #0xc0
\n\t
"
\
"eors %[S_0], %[S_0], %[t1], LSR #6
\n\t
"
/*s[0] ^= (constant7Format[lunNum] >> 6) & 0x3;*/
\
"ands %[t1], %[rci], #0x38
\n\t
"
\
"eors %[S_1], %[S_1], %[t1], LSR #3
\n\t
"
/*s[0] ^= (constant7Format[lunNum] >> 6) & 0x3;*/
\
"ands %[t1], %[rci], #0x7
\n\t
"
\
"eors %[S_3], %[S_3], %[t1]
\n\t
"
/*s[2] ^= constant7Format[lunNum] & 0x7;*/
\
"/*sbox column*/
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1],%[S_0]
\n\t
"
\
"eors %[S_0], %[t2],%[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1], %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
[
rci
]
"+r"
(
rci
),
\
[
S_0
]
"+r"
(
s
[
0
]),
[
S_1
]
"+r"
(
s
[
1
]),
[
S_3
]
"+r"
(
s
[
2
]),
\
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define P384_2SC(S1,S2,S3,S4,S5,S6,S7,S8) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1],%[S_0]
\n\t
"
\
"eors %[S_0], %[t2],%[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1], %[S_2]
\n\t
"
\
"/*sbox column*/
\n\t
"
\
"mvns %[S_1], %[S_1]
\n\t
"
\
"ands %[t1], %[S_3], %[S_1]
\n\t
"
\
"eors %[t1], %[S_5], %[t1]
\n\t
"
\
"orrs %[S_5], %[S_3], %[S_5]
\n\t
"
\
"eors %[S_1], %[S_7], %[S_1]
\n\t
"
\
"eors %[S_5], %[S_5], %[S_1]
\n\t
"
\
"eors %[t2], %[S_3], %[S_7]
\n\t
"
\
"eors %[S_7], %[S_7], %[t1]
\n\t
"
\
"ands %[S_1], %[t1],%[S_1]
\n\t
"
\
"eors %[S_1], %[t2],%[S_1]
\n\t
"
\
"ands %[S_3], %[S_5], %[t2]
\n\t
"
\
"eors %[S_3], %[t1], %[S_3]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
,
\
[
S_1
]
"+r"
(
S5
),
[
S_3
]
"+r"
(
S6
),
[
S_5
]
"+r"
(
S7
),
[
S_7
]
"+r"
(
S8
)
\
:
:
);
\
}
while
(
0
)
#define P384_SR() \
do
{
\
__asm__
__volatile__
(
\
"/*rotate shift left 1 bit [w9 w5 w1-> (w1,1) w9 w5] */
\n\t
"
\
"mov %[t1], %[S_3]
\n\t
"
\
"mov %[S_3], %[S_4]
\n\t
"
\
"mov %[S_4], %[S_5]
\n\t
"
\
"ROR %[S_5], %[t1] , #31
\n\t
"
\
"/*rotate shift left 8 bits [w10 w6 w2-> (w6,3) (w2,3) ( w10,2)]*/
\n\t
"
\
"mov %[t1], %[S_8]
\n\t
"
\
"ROR %[S_8], %[S_7] , #29
\n\t
"
\
"ROR %[S_7], %[S_6] , #29
\n\t
"
\
"ROR %[S_6], %[t1] , #30
\n\t
"
\
"/*rotate shift left 55 bit [w11 w7 w3-> (w3,13) (w11,14) ( w7,14)] */
\n\t
"
\
"mov %[t1], %[S_9]
\n\t
"
\
"ROR %[S_9], %[S_10] , #14
\n\t
"
\
"ROR %[S_10], %[S_11] , #14
\n\t
"
\
"ROR %[S_11], %[t1] , #13
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
\
[
S_3
]
"+r"
(
s
[
3
]),
[
S_6
]
"+r"
(
s
[
6
]),
[
S_9
]
"+r"
(
s
[
9
])
,
\
[
S_4
]
"+r"
(
s
[
4
]),
[
S_7
]
"+r"
(
s
[
7
]),
[
S_10
]
"+r"
(
s
[
10
]),
\
[
S_5
]
"+r"
(
s
[
5
]),
[
S_8
]
"+r"
(
s
[
8
]),
[
S_11
]
"+r"
(
s
[
11
])
\
:
:
);
\
}
while
(
0
)
unsigned
char
constant7Format
[
104
];
knot/Implementations/crypto_hash/knot384/armcortexm_2/crypto_hash.h
0 → 100644
View file @
a34b1718
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
);
\ No newline at end of file
knot/Implementations/crypto_hash/knot384/armcortexm_2/hash.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
#define hash_RATE (48 / 8)
#define PRH_ROUNDS 104
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
)
{
u32
dataFormat
[
3
]
=
{
0
};
// initialization
u32
s
[
12
]
=
{
0
};
u8
tempData
[
12
];
//absorb
while
(
inlen
>=
hash_RATE
)
{
packU48FormatToThreePacket
(
dataFormat
,
in
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
P384
(
s
,
constant7Format
,
PRH_ROUNDS
);
inlen
-=
hash_RATE
;
in
+=
hash_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
in
,
inlen
*
sizeof
(
unsigned
char
));
tempData
[
inlen
]
=
0x01
;
packU48FormatToThreePacket
(
dataFormat
,
tempData
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
P384
(
s
,
constant7Format
,
PRH_ROUNDS
);
//sequeez
unpackU96FormatToThreePacket
(
out
,
s
);
unpackU96FormatToThreePacket
(
out
+
12
,
s
+
3
);
P384
(
s
,
constant7Format
,
PRH_ROUNDS
);
out
+=
CRYPTO_BYTES
/
2
;
unpackU96FormatToThreePacket
(
out
,
s
);
unpackU96FormatToThreePacket
(
out
+
12
,
s
+
3
);
return
0
;
}
knot/Implementations/crypto_hash/knot384/armcortexm_3/api.h
0 → 100644
View file @
a34b1718
#define CRYPTO_BYTES 48
knot/Implementations/crypto_hash/knot384/armcortexm_3/auxFormat.h
0 → 100644
View file @
a34b1718
#include<malloc.h>
#include"crypto_hash.h"
#include"api.h"
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#define U32BIG(x) (x)
#define U16BIG(x) (x)
typedef
unsigned
char
u8
;
typedef
unsigned
short
u16
;
typedef
unsigned
int
u32
;
typedef
unsigned
long
long
u64
;
#define ARR_SIZE(a) (sizeof((a))/sizeof((a[0])))
#define LOTR32(x,n) (((x)<<(n))|((x)>>(32-(n))))
#define ARR_SIZE(a) (sizeof((a))/sizeof((a[0])))
#define sbox(a, b, c, d, f, g, h) \
{
\
t1
=
~
a
;
t2
=
b
&
t1
;
t3
=
c
^
t2
;
h
=
d
^
t3
;
t5
=
b
|
c
;
t6
=
d
^
t1
;
g
=
t5
^
t6
;
t8
=
b
^
d
;
t9
=
t3
&
t6
;
a
=
t8
^
t9
;
t11
=
g
&
t8
;
f
=
t3
^
t11
;
\
}
#define puckU32ToThree_1(x){\
x
&=
0x49249249
;
\
x
=
(
x
|
(
x
>>
2
))
&
0xc30c30c3
;
\
x
=
(
x
|
(
x
>>
4
))
&
0x0f00f00f
;
\
x
=
(
x
|
(
x
>>
8
))
&
0xff0000ff
;
\
x
=
(
x
|
(
x
>>
16
))
&
0xfff
;
\
}
#define unpuckU32ToThree_1(x){\
x
&=
0xfff
;
\
x
=
(
x
|
(
x
<<
16
))
&
0xff0000ff
;
\
x
=
(
x
|
(
x
<<
8
))
&
0x0f00f00f
;
\
x
=
(
x
|
(
x
<<
4
))
&
0xc30c30c3
;
\
x
=
(
x
|
(
x
<<
2
))
&
0x49249249
;
\
}
#define unpackU96FormatToThreePacket( out, in) {\
u32
temp0
[
3
]
=
{
0
};
\
u32
temp1
[
3
]
=
{
0
};
\
u32
temp2
[
3
]
=
{
0
};
\
u32
t
[
3
]
=
{
0
};
\
temp0
[
0
]
=
in
[
2
]
&
0x7ff
;
\
temp0
[
1
]
=
in
[
1
]
&
0x7ff
;
\
temp0
[
2
]
=
in
[
0
]
&
0x3ff
;
\
temp1
[
0
]
=
(
in
[
0
]
>>
10
)
&
0x7ff
;
\
temp1
[
1
]
=
(
in
[
2
]
>>
11
)
&
0x7ff
;
\
temp1
[
2
]
=
(
in
[
1
]
>>
11
)
&
0x3ff
;
\
temp2
[
0
]
=
in
[
1
]
>>
21
;
\
temp2
[
1
]
=
in
[
0
]
>>
21
;
\
temp2
[
2
]
=
in
[
2
]
>>
22
;
\
unpuckU32ToThree_1
(
temp0
[
0
]);
\
unpuckU32ToThree_1
(
temp0
[
1
]);
\
unpuckU32ToThree_1
(
temp0
[
2
]);
\
t
[
0
]
=
temp0
[
0
]
|
temp0
[
1
]
<<
1
|
temp0
[
2
]
<<
2
;
\
unpuckU32ToThree_1
(
temp1
[
0
]);
\
unpuckU32ToThree_1
(
temp1
[
1
]);
\
unpuckU32ToThree_1
(
temp1
[
2
]);
\
t
[
1
]
=
temp1
[
0
]
|
temp1
[
1
]
<<
1
|
temp1
[
2
]
<<
2
;
\
unpuckU32ToThree_1
(
temp2
[
0
]);
\
unpuckU32ToThree_1
(
temp2
[
1
]);
\
unpuckU32ToThree_1
(
temp2
[
2
]);
\
t
[
2
]
=
temp2
[
0
]
|
temp2
[
1
]
<<
1
|
temp2
[
2
]
<<
2
;
\
memcpy
(
out
,
t
,
12
*
sizeof
(
unsigned
char
));
\
}
#define packU48FormatToThreePacket( out, in) {\
u32
t1
=
(
u32
)
U16BIG
(
*
(
u16
*
)(
in
+
4
));
\
u32
temp0
[
3
]
=
{
0
};
\
u32
temp1
[
3
]
=
{
0
};
\
temp0
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
0
]);
temp0
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
1
;
temp0
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
2
;
\
puckU32ToThree_1
(
temp0
[
0
]);
\
puckU32ToThree_1
(
temp0
[
1
]);
\
puckU32ToThree_1
(
temp0
[
2
]);
\
temp1
[
0
]
=
t1
;
temp1
[
1
]
=
t1
>>
1
;
temp1
[
2
]
=
t1
>>
2
;
\
puckU32ToThree_1
(
temp1
[
0
]);
\
puckU32ToThree_1
(
temp1
[
1
]);
\
puckU32ToThree_1
(
temp1
[
2
]);
\
out
[
0
]
=
(
temp1
[
0
]
<<
10
)
|
temp0
[
2
];
\
out
[
1
]
=
(
temp1
[
2
]
<<
11
)
|
temp0
[
1
];
\
out
[
2
]
=
(
temp1
[
1
]
<<
11
)
|
temp0
[
0
];
\
}
#define U96_BIT_LOTR32_8(t0,t1,t2,t3,t4,t5){\
t3
=
LOTR32
(
t2
,
2
);
\
t4
=
LOTR32
(
t0
,
3
);
\
t5
=
LOTR32
(
t1
,
3
);
\
}
//55=3*18+1
#define U96_BIT_LOTR32_55(t0,t1,t2,t3,t4,t5){\
t3
=
LOTR32
(
t1
,
18
);
\
t4
=
LOTR32
(
t2
,
18
);
\
t5
=
LOTR32
(
t0
,
19
);
\
}
#define ROUND384(lunNum) {\
s
[
0
]
^=
(
constant7Format
[
lunNum
]
>>
6
)
&
0x3
;
\
s
[
1
]
^=
(
constant7Format
[
lunNum
]
>>
3
)
&
0x7
;
\
s
[
2
]
^=
constant7Format
[
lunNum
]
&
0x7
;
\
sbox
(
s
[
0
],
s
[
3
],
s
[
6
],
s
[
9
]
,
s_temp
[
3
],
s_temp
[
6
],
s_temp
[
9
]);
\
sbox
(
s
[
1
],
s
[
4
],
s
[
7
],
s
[
10
],
s
[
3
]
,
s_temp
[
7
],
s_temp
[
10
]);
\
sbox
(
s
[
2
],
s
[
5
],
s
[
8
],
s
[
11
],
s
[
4
]
,
s_temp
[
8
],
s_temp
[
11
]);
\
s
[
5
]
=
LOTR32
(
s_temp
[
3
],
1
);
\
U96_BIT_LOTR32_8
(
s_temp
[
6
],
s_temp
[
7
],
s_temp
[
8
],
s
[
6
],
s
[
7
],
s
[
8
]);
\
U96_BIT_LOTR32_55
(
s_temp
[
9
],
s_temp
[
10
],
s_temp
[
11
],
s
[
9
],
s
[
10
],
s
[
11
]);
\
}
knot/Implementations/crypto_hash/knot384/armcortexm_3/crypto_hash.h
0 → 100644
View file @
a34b1718
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
);
\ No newline at end of file
knot/Implementations/crypto_hash/knot384/armcortexm_3/hash.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
#define hash_RATE (48 / 8)
#define PRH_ROUNDS 104
//12*9=108
unsigned
char
constant7Format
[
104
]
=
{
/*constant7Format[127]:*/
0x01
,
0x08
,
0x40
,
0x02
,
0x10
,
0x80
,
0x05
,
0x09
,
0x48
,
0x42
,
0x12
,
0x90
,
0x85
,
0x0c
,
0x41
,
0x0a
,
0x50
,
0x82
,
0x15
,
0x89
,
0x4d
,
0x4b
,
0x5a
,
0xd2
,
0x97
,
0x9c
,
0xc4
,
0x06
,
0x11
,
0x88
,
0x45
,
0x0b
,
0x58
,
0xc2
,
0x17
,
0x99
,
0xcd
,
0x4e
,
0x53
,
0x9a
,
0xd5
,
0x8e
,
0x54
,
0x83
,
0x1d
,
0xc9
,
0x4f
,
0x5b
,
0xda
,
0xd7
,
0x9e
,
0xd4
,
0x86
,
0x14
,
0x81
,
0x0d
,
0x49
,
0x4a
,
0x52
,
0x92
,
0x95
,
0x8c
,
0x44
,
0x03
,
0x18
,
0xc0
,
0x07
,
0x19
,
0xc8
,
0x47
,
0x1b
,
0xd8
,
0xc7
,
0x1e
,
0xd1
,
0x8f
,
0x5c
,
0xc3
,
0x1f
,
0xd9
,
0xcf
,
0x5e
,
0xd3
,
0x9f
,
0xdc
,
0xc6
,
0x16
,
0x91
,
0x8d
,
0x4c
,
0x43
,
0x1a
,
0xd0
,
0x87
,
0x1c
,
0xc1
,
0x0f
,
0x59
,
0xca
,
0x57
,
0x9b
,
0xdd
,
0xce
,
0x56
,
};
#define Processing_Data(data) \
do
{
\
packU48FormatToThreePacket
(
dataFormat
,
data
);
\
s
[
0
]
^=
dataFormat
[
0
];
\
s
[
1
]
^=
dataFormat
[
1
];
\
s
[
2
]
^=
dataFormat
[
2
];
\
}
while
(
0
)
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
)
{
u32
t1
,
t2
,
t3
,
t5
,
t6
,
t8
,
t9
,
t11
;
u32
s_temp
[
12
]
=
{
0
};
u8
i
;
u32
dataFormat
[
3
]
=
{
0
};
// initialization
u32
s
[
12
]
=
{
0
};
u8
tempData
[
12
];
//absorb
while
(
inlen
>=
hash_RATE
)
{
Processing_Data
(
in
);
for
(
i
=
0
;
i
<
PRH_ROUNDS
;
i
++
)
{
ROUND384
(
i
);
}
inlen
-=
hash_RATE
;
in
+=
hash_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
in
,
inlen
*
sizeof
(
unsigned
char
));
tempData
[
inlen
]
=
0x01
;
Processing_Data
(
tempData
);
for
(
i
=
0
;
i
<
PRH_ROUNDS
;
i
++
)
{
ROUND384
(
i
);
}
//sequeez
unpackU96FormatToThreePacket
(
out
,
s
);
unpackU96FormatToThreePacket
((
out
+
12
),
(
s
+
3
));
for
(
i
=
0
;
i
<
PRH_ROUNDS
;
i
++
)
{
ROUND384
(
i
);
}
out
+=
CRYPTO_BYTES
/
2
;
unpackU96FormatToThreePacket
(
out
,
s
);
unpackU96FormatToThreePacket
((
out
+
12
),
(
s
+
3
));
return
0
;
}
knot/Implementations/crypto_hash/knot384/armcortexm_4/api.h
0 → 100644
View file @
a34b1718
#define CRYPTO_BYTES 48
knot/Implementations/crypto_hash/knot384/armcortexm_4/auxFormat.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
void
unpackU96FormatToThreePacket
(
u8
*
out
,
u32
*
in
)
{
u32
temp0
[
3
]
=
{
0
};
u32
temp1
[
3
]
=
{
0
};
u32
temp2
[
3
]
=
{
0
};
u32
t
[
3
]
=
{
0
};
temp0
[
0
]
=
in
[
2
]
&
0x7ff
;
temp0
[
1
]
=
in
[
1
]
&
0x7ff
;
temp0
[
2
]
=
in
[
0
]
&
0x3ff
;
temp1
[
0
]
=
(
in
[
0
]
>>
10
)
&
0x7ff
;
temp1
[
1
]
=
(
in
[
2
]
>>
11
)
&
0x7ff
;
temp1
[
2
]
=
(
in
[
1
]
>>
11
)
&
0x3ff
;
temp2
[
0
]
=
in
[
1
]
>>
21
;
temp2
[
1
]
=
in
[
0
]
>>
21
;
temp2
[
2
]
=
in
[
2
]
>>
22
;
unpuckU32ToThree_1
(
temp0
[
0
]);
unpuckU32ToThree_1
(
temp0
[
1
]);
unpuckU32ToThree_1
(
temp0
[
2
]);
t
[
0
]
=
temp0
[
0
]
|
temp0
[
1
]
<<
1
|
temp0
[
2
]
<<
2
;
unpuckU32ToThree_1
(
temp1
[
0
]);
unpuckU32ToThree_1
(
temp1
[
1
]);
unpuckU32ToThree_1
(
temp1
[
2
]);
t
[
1
]
=
temp1
[
0
]
|
temp1
[
1
]
<<
1
|
temp1
[
2
]
<<
2
;
unpuckU32ToThree_1
(
temp2
[
0
]);
unpuckU32ToThree_1
(
temp2
[
1
]);
unpuckU32ToThree_1
(
temp2
[
2
]);
t
[
2
]
=
temp2
[
0
]
|
temp2
[
1
]
<<
1
|
temp2
[
2
]
<<
2
;
memcpy
(
out
,
t
,
12
*
sizeof
(
unsigned
char
));
}
void
packU48FormatToThreePacket
(
u32
*
out
,
u8
*
in
)
{
u32
t1
=
(
u32
)
U16BIG
(
*
(
u16
*
)(
in
+
4
));
u32
temp0
[
3
]
=
{
0
};
u32
temp1
[
3
]
=
{
0
};
temp0
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
0
]);
temp0
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
1
;
temp0
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
2
;
puckU32ToThree_1
(
temp0
[
0
]);
puckU32ToThree_1
(
temp0
[
1
]);
puckU32ToThree_1
(
temp0
[
2
]);
temp1
[
0
]
=
t1
;
temp1
[
1
]
=
t1
>>
1
;
temp1
[
2
]
=
t1
>>
2
;
puckU32ToThree_1
(
temp1
[
0
]);
puckU32ToThree_1
(
temp1
[
1
]);
puckU32ToThree_1
(
temp1
[
2
]);
out
[
0
]
=
(
temp1
[
0
]
<<
10
)
|
temp0
[
2
];
out
[
1
]
=
(
temp1
[
2
]
<<
11
)
|
temp0
[
1
];
out
[
2
]
=
(
temp1
[
1
]
<<
11
)
|
temp0
[
0
];
}
unsigned
char
constant7Format
[
104
]
=
{
/*constant7Format[127]: 12*9=108*/
0x01
,
0x08
,
0x40
,
0x02
,
0x10
,
0x80
,
0x05
,
0x09
,
0x48
,
0x42
,
0x12
,
0x90
,
0x85
,
0x0c
,
0x41
,
0x0a
,
0x50
,
0x82
,
0x15
,
0x89
,
0x4d
,
0x4b
,
0x5a
,
0xd2
,
0x97
,
0x9c
,
0xc4
,
0x06
,
0x11
,
0x88
,
0x45
,
0x0b
,
0x58
,
0xc2
,
0x17
,
0x99
,
0xcd
,
0x4e
,
0x53
,
0x9a
,
0xd5
,
0x8e
,
0x54
,
0x83
,
0x1d
,
0xc9
,
0x4f
,
0x5b
,
0xda
,
0xd7
,
0x9e
,
0xd4
,
0x86
,
0x14
,
0x81
,
0x0d
,
0x49
,
0x4a
,
0x52
,
0x92
,
0x95
,
0x8c
,
0x44
,
0x03
,
0x18
,
0xc0
,
0x07
,
0x19
,
0xc8
,
0x47
,
0x1b
,
0xd8
,
0xc7
,
0x1e
,
0xd1
,
0x8f
,
0x5c
,
0xc3
,
0x1f
,
0xd9
,
0xcf
,
0x5e
,
0xd3
,
0x9f
,
0xdc
,
0xc6
,
0x16
,
0x91
,
0x8d
,
0x4c
,
0x43
,
0x1a
,
0xd0
,
0x87
,
0x1c
,
0xc1
,
0x0f
,
0x59
,
0xca
,
0x57
,
0x9b
,
0xdd
,
0xce
,
0x56
,};
void
P384
(
unsigned
int
*
s
,
unsigned
char
*
round
,
unsigned
char
lunNum
)
{
u32
s_temp
[
12
]
=
{
0
};
u32
t1
,
t2
,
t3
,
t5
,
t6
,
t8
,
t9
,
t11
;
unsigned
char
i
;
for
(
i
=
0
;
i
<
lunNum
;
i
++
)
{
s
[
0
]
^=
(
round
[
i
]
>>
6
)
&
0x3
;
s
[
1
]
^=
(
round
[
i
]
>>
3
)
&
0x7
;
s
[
2
]
^=
round
[
i
]
&
0x7
;
sbox
(
s
[
0
],
s
[
3
],
s
[
6
],
s
[
9
],
s_temp
[
3
],
s_temp
[
6
],
s_temp
[
9
]);
sbox
(
s
[
1
],
s
[
4
],
s
[
7
],
s
[
10
],
s
[
3
],
s_temp
[
7
],
s_temp
[
10
]);
sbox
(
s
[
2
],
s
[
5
],
s
[
8
],
s
[
11
],
s
[
4
],
s_temp
[
8
],
s_temp
[
11
]);
s
[
5
]
=
LOTR32
(
s_temp
[
3
],
1
);
U96_BIT_LOTR32_8
(
s_temp
[
6
],
s_temp
[
7
],
s_temp
[
8
],
s
[
6
],
s
[
7
],
s
[
8
]);
U96_BIT_LOTR32_55
(
s_temp
[
9
],
s_temp
[
10
],
s_temp
[
11
],
s
[
9
],
s
[
10
],
s
[
11
]);
}
}
knot/Implementations/crypto_hash/knot384/armcortexm_4/auxFormat.h
0 → 100644
View file @
a34b1718
#include<malloc.h>
#include"crypto_hash.h"
#include"api.h"
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#define U32BIG(x) (x)
#define U16BIG(x) (x)
typedef
unsigned
char
u8
;
typedef
unsigned
short
u16
;
typedef
unsigned
int
u32
;
typedef
unsigned
long
long
u64
;
void
packU48FormatToThreePacket
(
u32
*
out
,
u8
*
in
)
;
void
P384
(
unsigned
int
*
s
,
unsigned
char
*
round
,
unsigned
char
lunNum
)
;
void
unpackU96FormatToThreePacket
(
u8
*
out
,
u32
*
in
)
;
#define puckU32ToThree_1(x){\
x
&=
0x49249249
;
\
x
=
(
x
|
(
x
>>
2
))
&
0xc30c30c3
;
\
x
=
(
x
|
(
x
>>
4
))
&
0x0f00f00f
;
\
x
=
(
x
|
(
x
>>
8
))
&
0xff0000ff
;
\
x
=
(
x
|
(
x
>>
16
))
&
0xfff
;
\
}
#define unpuckU32ToThree_1(x){\
x
&=
0xfff
;
\
x
=
(
x
|
(
x
<<
16
))
&
0xff0000ff
;
\
x
=
(
x
|
(
x
<<
8
))
&
0x0f00f00f
;
\
x
=
(
x
|
(
x
<<
4
))
&
0xc30c30c3
;
\
x
=
(
x
|
(
x
<<
2
))
&
0x49249249
;
\
}
#define ARR_SIZE(a) (sizeof((a))/sizeof((a[0])))
#define LOTR32(x,n) (((x)<<(n))|((x)>>(32-(n))))
#define ARR_SIZE(a) (sizeof((a))/sizeof((a[0])))
#define sbox(a, b, c, d, f, g, h) \
{
\
t1
=
~
a
;
t2
=
b
&
t1
;
t3
=
c
^
t2
;
h
=
d
^
t3
;
t5
=
b
|
c
;
t6
=
d
^
t1
;
g
=
t5
^
t6
;
t8
=
b
^
d
;
t9
=
t3
&
t6
;
a
=
t8
^
t9
;
t11
=
g
&
t8
;
f
=
t3
^
t11
;
\
}
#define U96_BIT_LOTR32_8(t0,t1,t2,t3,t4,t5){\
t3
=
LOTR32
(
t2
,
2
);
\
t4
=
LOTR32
(
t0
,
3
);
\
t5
=
LOTR32
(
t1
,
3
);
\
}
//55=3*18+1
#define U96_BIT_LOTR32_55(t0,t1,t2,t3,t4,t5){\
t3
=
LOTR32
(
t1
,
18
);
\
t4
=
LOTR32
(
t2
,
18
);
\
t5
=
LOTR32
(
t0
,
19
);
\
}
unsigned
char
constant7Format
[
104
];
knot/Implementations/crypto_hash/knot384/armcortexm_4/crypto_hash.h
0 → 100644
View file @
a34b1718
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
);
\ No newline at end of file
knot/Implementations/crypto_hash/knot384/armcortexm_4/hash.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
#define hash_RATE (48 / 8)
#define PRH_ROUNDS 104
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
)
{
u32
dataFormat
[
3
]
=
{
0
};
// initialization
u32
s
[
12
]
=
{
0
};
u8
tempData
[
12
];
//absorb
while
(
inlen
>=
hash_RATE
)
{
packU48FormatToThreePacket
(
dataFormat
,
in
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
P384
(
s
,
constant7Format
,
PRH_ROUNDS
);
inlen
-=
hash_RATE
;
in
+=
hash_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
in
,
inlen
*
sizeof
(
unsigned
char
));
tempData
[
inlen
]
=
0x01
;
packU48FormatToThreePacket
(
dataFormat
,
tempData
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
P384
(
s
,
constant7Format
,
PRH_ROUNDS
);
//sequeez
unpackU96FormatToThreePacket
(
out
,
s
);
unpackU96FormatToThreePacket
(
out
+
12
,
s
+
3
);
P384
(
s
,
constant7Format
,
PRH_ROUNDS
);
out
+=
CRYPTO_BYTES
/
2
;
unpackU96FormatToThreePacket
(
out
,
s
);
unpackU96FormatToThreePacket
(
out
+
12
,
s
+
3
);
return
0
;
}
knot/Implementations/crypto_hash/knot384/armcortexm_5/api.h
0 → 100644
View file @
a34b1718
#define CRYPTO_BYTES 48
knot/Implementations/crypto_hash/knot384/armcortexm_5/auxFormat.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
void
unpackU96FormatToThreePacket
(
u8
*
out
,
u32
*
in
)
{
u32
temp0
[
3
]
=
{
0
};
u32
temp1
[
3
]
=
{
0
};
u32
temp2
[
3
]
=
{
0
};
u32
t
[
3
]
=
{
0
};
temp0
[
0
]
=
in
[
2
]
&
0x7ff
;
temp0
[
1
]
=
in
[
1
]
&
0x7ff
;
temp0
[
2
]
=
in
[
0
]
&
0x3ff
;
temp1
[
0
]
=
(
in
[
0
]
>>
10
)
&
0x7ff
;
temp1
[
1
]
=
(
in
[
2
]
>>
11
)
&
0x7ff
;
temp1
[
2
]
=
(
in
[
1
]
>>
11
)
&
0x3ff
;
temp2
[
0
]
=
in
[
1
]
>>
21
;
temp2
[
1
]
=
in
[
0
]
>>
21
;
temp2
[
2
]
=
in
[
2
]
>>
22
;
unpuckU32ToThree_1
(
temp0
[
0
]);
unpuckU32ToThree_1
(
temp0
[
1
]);
unpuckU32ToThree_1
(
temp0
[
2
]);
t
[
0
]
=
temp0
[
0
]
|
temp0
[
1
]
<<
1
|
temp0
[
2
]
<<
2
;
unpuckU32ToThree_1
(
temp1
[
0
]);
unpuckU32ToThree_1
(
temp1
[
1
]);
unpuckU32ToThree_1
(
temp1
[
2
]);
t
[
1
]
=
temp1
[
0
]
|
temp1
[
1
]
<<
1
|
temp1
[
2
]
<<
2
;
unpuckU32ToThree_1
(
temp2
[
0
]);
unpuckU32ToThree_1
(
temp2
[
1
]);
unpuckU32ToThree_1
(
temp2
[
2
]);
t
[
2
]
=
temp2
[
0
]
|
temp2
[
1
]
<<
1
|
temp2
[
2
]
<<
2
;
memcpy
(
out
,
t
,
12
*
sizeof
(
unsigned
char
));
}
void
packU48FormatToThreePacket
(
u32
*
out
,
u8
*
in
)
{
u32
t1
=
(
u32
)
U16BIG
(
*
(
u16
*
)(
in
+
4
));
u32
temp0
[
3
]
=
{
0
};
u32
temp1
[
3
]
=
{
0
};
temp0
[
0
]
=
U32BIG
(((
u32
*
)
in
)[
0
]);
temp0
[
1
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
1
;
temp0
[
2
]
=
U32BIG
(((
u32
*
)
in
)[
0
])
>>
2
;
puckU32ToThree_1
(
temp0
[
0
]);
puckU32ToThree_1
(
temp0
[
1
]);
puckU32ToThree_1
(
temp0
[
2
]);
temp1
[
0
]
=
t1
;
temp1
[
1
]
=
t1
>>
1
;
temp1
[
2
]
=
t1
>>
2
;
puckU32ToThree_1
(
temp1
[
0
]);
puckU32ToThree_1
(
temp1
[
1
]);
puckU32ToThree_1
(
temp1
[
2
]);
out
[
0
]
=
(
temp1
[
0
]
<<
10
)
|
temp0
[
2
];
out
[
1
]
=
(
temp1
[
2
]
<<
11
)
|
temp0
[
1
];
out
[
2
]
=
(
temp1
[
1
]
<<
11
)
|
temp0
[
0
];
}
unsigned
char
constant7Format
[
104
]
=
{
/*constant7Format[127]: 12*9=108*/
0x01
,
0x08
,
0x40
,
0x02
,
0x10
,
0x80
,
0x05
,
0x09
,
0x48
,
0x42
,
0x12
,
0x90
,
0x85
,
0x0c
,
0x41
,
0x0a
,
0x50
,
0x82
,
0x15
,
0x89
,
0x4d
,
0x4b
,
0x5a
,
0xd2
,
0x97
,
0x9c
,
0xc4
,
0x06
,
0x11
,
0x88
,
0x45
,
0x0b
,
0x58
,
0xc2
,
0x17
,
0x99
,
0xcd
,
0x4e
,
0x53
,
0x9a
,
0xd5
,
0x8e
,
0x54
,
0x83
,
0x1d
,
0xc9
,
0x4f
,
0x5b
,
0xda
,
0xd7
,
0x9e
,
0xd4
,
0x86
,
0x14
,
0x81
,
0x0d
,
0x49
,
0x4a
,
0x52
,
0x92
,
0x95
,
0x8c
,
0x44
,
0x03
,
0x18
,
0xc0
,
0x07
,
0x19
,
0xc8
,
0x47
,
0x1b
,
0xd8
,
0xc7
,
0x1e
,
0xd1
,
0x8f
,
0x5c
,
0xc3
,
0x1f
,
0xd9
,
0xcf
,
0x5e
,
0xd3
,
0x9f
,
0xdc
,
0xc6
,
0x16
,
0x91
,
0x8d
,
0x4c
,
0x43
,
0x1a
,
0xd0
,
0x87
,
0x1c
,
0xc1
,
0x0f
,
0x59
,
0xca
,
0x57
,
0x9b
,
0xdd
,
0xce
,
0x56
,};
void
ROUND384_Three
(
unsigned
int
*
s
,
unsigned
char
*
c
,
int
lunnum
)
{
\
unsigned
int
t
,
t1
,
t2
;
u32
rci
;
rci
=
c
[
0
];
ROUND384_1
(
rci
);
t
=
1
;
while
(
lunnum
--
)
{
rci
=
c
[
t
];
ROUND384_2
(
rci
);
t
++
;
rci
=
c
[
t
];
ROUND384_3
(
rci
);
t
++
;
rci
=
c
[
t
];
ROUND384_4
(
rci
);
t
++
;
}
}
knot/Implementations/crypto_hash/knot384/armcortexm_5/auxFormat.h
0 → 100644
View file @
a34b1718
#include<malloc.h>
#include"crypto_hash.h"
#include"api.h"
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#define U32BIG(x) (x)
#define U16BIG(x) (x)
typedef
unsigned
char
u8
;
typedef
unsigned
short
u16
;
typedef
unsigned
int
u32
;
typedef
unsigned
long
long
u64
;
#define puckU32ToThree_1(x){\
x
&=
0x49249249
;
\
x
=
(
x
|
(
x
>>
2
))
&
0xc30c30c3
;
\
x
=
(
x
|
(
x
>>
4
))
&
0x0f00f00f
;
\
x
=
(
x
|
(
x
>>
8
))
&
0xff0000ff
;
\
x
=
(
x
|
(
x
>>
16
))
&
0xfff
;
\
}
#define unpuckU32ToThree_1(x){\
x
&=
0xfff
;
\
x
=
(
x
|
(
x
<<
16
))
&
0xff0000ff
;
\
x
=
(
x
|
(
x
<<
8
))
&
0x0f00f00f
;
\
x
=
(
x
|
(
x
<<
4
))
&
0xc30c30c3
;
\
x
=
(
x
|
(
x
<<
2
))
&
0x49249249
;
\
}
#define ARC(rci) \
do
{
\
__asm__
__volatile__
(
\
"/*add round const s0 s1 s2 */
\n\t
"
\
"ands %[t1], %[rci], #0xc0
\n\t
"
\
"eors %[S_0], %[S_0], %[t1], LSR #6
\n\t
"
/*s[0] ^= (constant7Format[lunNum] >> 6) & 0x3;*/
\
"ands %[t1], %[rci], #0x38
\n\t
"
\
"eors %[S_1], %[S_1], %[t1], LSR #3
\n\t
"
/*s[0] ^= (constant7Format[lunNum] >> 6) & 0x3;*/
\
"ands %[t1], %[rci], #0x7
\n\t
"
\
"eors %[S_3], %[S_3], %[t1]
\n\t
"
/*s[2] ^= constant7Format[lunNum] & 0x7;*/
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
rci
]
"+r"
(
rci
),
\
[
S_0
]
"+r"
(
s
[
0
]),
[
S_1
]
"+r"
(
s
[
1
]),
[
S_3
]
"+r"
(
s
[
2
])
\
:
:
);
\
}
while
(
0
)
#define SBOX(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define SBOX1(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"ROR %[S_4] , #30
\n\t
"
\
"ROR %[S_6] , #14
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define SBOX2(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"ROR %[S_4] , #29
\n\t
"
\
"ROR %[S_6] , #14
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define SBOX3(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"ROR %[S_2] , #31
\n\t
"
\
"ROR %[S_4] , #29
\n\t
"
\
"ROR %[S_6] , #13
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define ROUND384_1(rci) {\
ARC
(
rci
);
\
SBOX
(
s
[
0
],
s
[
3
],
s
[
6
],
s
[
9
]
);
\
SBOX
(
s
[
1
],
s
[
4
],
s
[
7
],
s
[
10
]);
\
SBOX
(
s
[
2
],
s
[
5
],
s
[
8
],
s
[
11
]);
\
}
#define ROUND384_2(rci) {\
ARC
(
rci
);
\
SBOX1
(
s
[
0
],
s
[
4
],
s
[
8
],
s
[
10
]
);
\
SBOX2
(
s
[
1
],
s
[
5
],
s
[
6
],
s
[
11
]);
\
SBOX3
(
s
[
2
],
s
[
3
],
s
[
7
],
s
[
9
]);
\
}
#define ROUND384_3(rci) {\
ARC
(
rci
);
\
SBOX1
(
s
[
0
],
s
[
5
],
s
[
7
],
s
[
11
]);
\
SBOX2
(
s
[
1
],
s
[
3
],
s
[
8
],
s
[
9
]);
\
SBOX3
(
s
[
2
],
s
[
4
],
s
[
6
],
s
[
10
]);
\
}
#define ROUND384_4(rci) {\
ARC
(
rci
);
\
SBOX1
(
s
[
0
],
s
[
3
],
s
[
6
],
s
[
9
]);
\
SBOX2
(
s
[
1
],
s
[
4
],
s
[
7
],
s
[
10
]);
\
SBOX3
(
s
[
2
],
s
[
5
],
s
[
8
],
s
[
11
]);
\
}
#define P384_2( s, round, lunNum) {\
u32
t1
,
rci
;
\
ROUND384_Three
(
s
,
round
,
lunNum
);
\
rci
=
round
[
lunNum
*
3
+
1
];
\
ROUND384_2
(
rci
);
\
__asm__
__volatile__
(
\
"/*rotate shift left 1 bit [w9 w5 w1-> (w1,1) w9 w5] */
\n\t
"
\
"mov %[t1], %[S_4]
\n\t
"
\
"mov %[S_4], %[S_3]
\n\t
"
\
"mov %[S_3], %[S_5]
\n\t
"
\
"ROR %[S_5], %[t1] , #31
\n\t
"
\
"/*rotate shift left 8 bits [w10 w6 w2-> (w6,3) (w2,3) ( w10,2)]*/
\n\t
"
\
"mov %[t1], %[S_8]
\n\t
"
\
"ROR %[S_8], %[S_6] , #29
\n\t
"
\
"ROR %[S_6], %[S_7] , #30
\n\t
"
\
"ROR %[S_7], %[t1] , #29
\n\t
"
\
"/*rotate shift left 55 bit [w11 w7 w3-> (w3,13) (w11,14) ( w7,14)] */
\n\t
"
\
"mov %[t1], %[S_10]
\n\t
"
\
"ROR %[S_10], %[S_9] , #14
\n\t
"
\
"ROR %[S_9], %[S_11] , #14
\n\t
"
\
"ROR %[S_11], %[t1] , #13
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
\
[
S_3
]
"+r"
(
s
[
3
]),
[
S_6
]
"+r"
(
s
[
6
]),
[
S_9
]
"+r"
(
s
[
9
])
,
\
[
S_4
]
"+r"
(
s
[
4
]),
[
S_7
]
"+r"
(
s
[
7
]),
[
S_10
]
"+r"
(
s
[
10
]),
\
[
S_5
]
"+r"
(
s
[
5
]),
[
S_8
]
"+r"
(
s
[
8
]),
[
S_11
]
"+r"
(
s
[
11
])
\
:
:
);
\
}
unsigned
char
constant7Format
[
104
];
knot/Implementations/crypto_hash/knot384/armcortexm_5/crypto_hash.h
0 → 100644
View file @
a34b1718
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
);
\ No newline at end of file
knot/Implementations/crypto_hash/knot384/armcortexm_5/hash.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
#define hash_RATE (48 / 8)
#define PRH_ROUNDS 34
//#define PRH_ROUNDS 104 104/3=34+2
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
)
{
u32
dataFormat
[
3
]
=
{
0
},
t1
,
t2
;
// initialization
u32
s
[
12
]
=
{
0
};
u8
tempData
[
12
];
//absorb
while
(
inlen
>=
hash_RATE
)
{
packU48FormatToThreePacket
(
dataFormat
,
in
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
P384_2
(
s
,
constant7Format
,
PRH_ROUNDS
);
inlen
-=
hash_RATE
;
in
+=
hash_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
in
,
inlen
*
sizeof
(
unsigned
char
));
tempData
[
inlen
]
=
0x01
;
packU48FormatToThreePacket
(
dataFormat
,
tempData
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
P384_2
(
s
,
constant7Format
,
PRH_ROUNDS
);
//sequeez
unpackU96FormatToThreePacket
(
out
,
s
);
unpackU96FormatToThreePacket
(
out
+
12
,
s
+
3
);
P384_2
(
s
,
constant7Format
,
PRH_ROUNDS
);
out
+=
CRYPTO_BYTES
/
2
;
unpackU96FormatToThreePacket
(
out
,
s
);
unpackU96FormatToThreePacket
(
out
+
12
,
s
+
3
);
return
0
;
}
knot/Implementations/crypto_hash/knot512/armcortexm_2/api.h
0 → 100644
View file @
a34b1718
#define CRYPTO_BYTES 64
knot/Implementations/crypto_hash/knot512/armcortexm_2/auxFormat.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
void
P512
(
unsigned
int
*
s
,
unsigned
char
*
round
,
unsigned
char
rounds
)
{
u32
rci
,
t1
,
t2
,
t3
,
t9
;
unsigned
char
i
;
for
(
i
=
0
;
i
<
rounds
;
i
++
)
{
rci
=
round
[
0
];
P512_ARC_1
(
rci
);
for
(
i
=
1
;
i
<
rounds
;
i
++
)
{
P512_2SC
(
s
[
0
],
s
[
4
],
s
[
8
],
s
[
12
],
s
[
1
],
s
[
5
],
s
[
9
],
s
[
13
]);
P512_2SC
(
s
[
2
],
s
[
6
],
s
[
10
],
s
[
14
],
s
[
3
],
s
[
7
],
s
[
11
],
s
[
15
]);
P512_SR_1
();
rci
=
round
[
i
];
P512_SR_ARC_2
(
rci
);
}
P512_2SC
(
s
[
0
],
s
[
4
],
s
[
8
],
s
[
12
],
s
[
1
],
s
[
5
],
s
[
9
],
s
[
13
]);
P512_2SC
(
s
[
2
],
s
[
6
],
s
[
10
],
s
[
14
],
s
[
3
],
s
[
7
],
s
[
11
],
s
[
15
]);
P512_SR_1
();
P512_SR_2
();
}
}
void
packU64FormatToFourPacket
(
u32
*
out
,
u8
*
in
)
{
u32
t1
,
t2
,
temp1
;
t1
=
U32BIG
(((
u32
*
)
in
)[
0
]);
t2
=
U32BIG
(((
u32
*
)
in
)[
1
]);
puck32
(
t1
);
puck32
(
t1
);
puck32
(
t2
);
puck32
(
t2
);
out
[
3
]
=
((
t2
>>
16
)
&
0x0000ff00
)
|
((
t1
>>
24
));
out
[
2
]
=
((
t2
>>
8
)
&
0x0000ff00
)
|
((
t1
>>
16
)
&
0x000000ff
);
out
[
1
]
=
(
t2
&
0x0000ff00
)
|
((
t1
>>
8
)
&
0x000000ff
);
out
[
0
]
=
((
t2
<<
8
)
&
0x0000ff00
)
|
(
t1
&
0x000000ff
);
}
void
unpackU128FormatToFourPacket
(
u8
*
out
,
u32
*
in
)
{
u32
t
[
4
]
=
{
0
};
u32
r0
;
t
[
3
]
=
(
in
[
3
]
&
0xff000000
)
|
((
in
[
2
]
>>
8
)
&
0x00ff0000
)
|
((
in
[
1
]
>>
16
)
&
0x0000ff00
)
|
(
in
[
0
]
>>
24
);
t
[
2
]
=
((
in
[
3
]
<<
8
)
&
0xff000000
)
|
(
in
[
2
]
&
0x00ff0000
)
|
((
in
[
1
]
>>
8
)
&
0x0000ff00
)
|
((
in
[
0
]
>>
16
)
&
0x000000ff
);
t
[
1
]
=
((
in
[
3
]
<<
16
)
&
0xff000000
)
|
((
in
[
2
]
<<
8
)
&
0x00ff0000
)
|
(
in
[
1
]
&
0x0000ff00
)
|
((
in
[
0
]
>>
8
)
&
0x000000ff
);
t
[
0
]
=
((
in
[
3
]
<<
24
)
&
0xff000000
)
|
((
in
[
2
]
<<
16
)
&
0x00ff0000
)
|
((
in
[
1
]
<<
8
)
&
0x0000ff00
)
|
(
in
[
0
]
&
0x000000ff
);
unpuck32
(
t
[
0
]);
unpuck32
(
t
[
0
]);
unpuck32
(
t
[
1
]);
unpuck32
(
t
[
1
]);
unpuck32
(
t
[
2
]);
unpuck32
(
t
[
2
]);
unpuck32
(
t
[
3
]);
unpuck32
(
t
[
3
]);
memcpy
(
out
,
t
,
16
*
sizeof
(
unsigned
char
));
}
knot/Implementations/crypto_hash/knot512/armcortexm_2/auxFormat.h
0 → 100644
View file @
a34b1718
#include<malloc.h>
#include<stdio.h>
#include"crypto_hash.h"
#include"api.h"
#include <string.h>
#define U32BIG(x) (x)
typedef
unsigned
char
u8
;
typedef
unsigned
int
u32
;
typedef
unsigned
long
long
u64
;
#define puck32(in)\
{
\
temp1
=
(
in
^
(
in
>>
1
))
&
0x22222222
;
in
^=
temp1
^
(
temp1
<<
1
);
\
temp1
=
(
in
^
(
in
>>
2
))
&
0x0C0C0C0C
;
in
^=
temp1
^
(
temp1
<<
2
);
\
temp1
=
(
in
^
(
in
>>
4
))
&
0x00F000F0
;
in
^=
temp1
^
(
temp1
<<
4
);
\
temp1
=
(
in
^
(
in
>>
8
))
&
0x0000FF00
;
in
^=
temp1
^
(
temp1
<<
8
);
\
}
#define unpuck32(t0){\
r0
=
(
t0
^
(
t0
>>
8
))
&
0x0000FF00
,
t0
^=
r0
^
(
r0
<<
8
);
\
r0
=
(
t0
^
(
t0
>>
4
))
&
0x00F000F0
,
t0
^=
r0
^
(
r0
<<
4
);
\
r0
=
(
t0
^
(
t0
>>
2
))
&
0x0C0C0C0C
,
t0
^=
r0
^
(
r0
<<
2
);
\
r0
=
(
t0
^
(
t0
>>
1
))
&
0x22222222
,
t0
^=
r0
^
(
r0
<<
1
);
\
}
//t1
#define P512_ARC_1(rci) \
do
{
\
__asm__
__volatile__
(
\
"/*add round const s0 s1 s2 s3*/
\n\t
"
\
"ands %[t1] , %[rci], #0xc0
\n\t
"
\
"eors %[S_3], %[S_3], %[t1], LSR #6
\n\t
"
/*s[3] ^= (constant7Format_aead[lunNum] >> 6) & 0x3;*/
\
"ands %[t2] , %[rci], #0x30
\n\t
"
\
"eors %[S_2], %[S_2], %[t2], LSR #4
\n\t
"
/*s[2] ^= (constant7Format_aead[lunNum] >> 4) & 0x3;*/
\
"ands %[t3] , %[rci], #0xc
\n\t
"
\
"eors %[S_1], %[S_1], %[t3], LSR #2
\n\t
"
/*s[1] ^= (constant7Format_aead[lunNum] >> 2) & 0x3;*/
\
"ands %[t4] , %[rci], #0x3
\n\t
"
\
"eors %[S_0], %[S_0], %[t4]
\n\t
"
/*s[0] ^= constant7Format_aead[lunNum] & 0x3;*/
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
[
t3
]
"=r"
(
t3
),
[
t4
]
"=r"
(
t9
),
[
rci
]
"+r"
(
rci
),
\
[
S_0
]
"+r"
(
s
[
0
]),
[
S_1
]
"+r"
(
s
[
1
]),
[
S_2
]
"+r"
(
s
[
2
]),[
S_3
]
"+r"
(
s
[
3
])
\
:
:
);
\
}
while
(
0
)
//t1 t2
#define P512_2SC(S1,S2,S3,S4,S5,S6,S7,S8)\
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
"/*sbox column*/
\n\t
"
\
"mvns %[S_1], %[S_1]
\n\t
"
\
"ands %[t3], %[S_3], %[S_1]
\n\t
"
\
"eors %[t3], %[S_5], %[t3]
\n\t
"
\
"orrs %[S_5], %[S_3], %[S_5]
\n\t
"
\
"eors %[S_1], %[S_7], %[S_1]
\n\t
"
\
"eors %[S_5], %[S_5], %[S_1]
\n\t
"
\
"eors %[t2], %[S_3], %[S_7]
\n\t
"
\
"eors %[S_7], %[S_7], %[t3]
\n\t
"
\
"ands %[S_1], %[t3] , %[S_1]
\n\t
"
\
"eors %[S_1], %[t2] , %[S_1]
\n\t
"
\
"ands %[S_3], %[S_5], %[t2]
\n\t
"
\
"eors %[S_3], %[t3] , %[S_3]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
[
t3
]
"=r"
(
t3
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
,
\
[
S_1
]
"+r"
(
S5
),
[
S_3
]
"+r"
(
S6
),
[
S_5
]
"+r"
(
S7
),
[
S_7
]
"+r"
(
S8
)
\
:
:
);
\
}
while
(
0
)
#define P512_SR_1() \
do
{
\
__asm__
__volatile__
(
\
"/*rotate shift left 1 bit [w9 w5 w1-> (w1,1) w9 w5] */
\n\t
"
\
"mov %[t1], %[S_7]
\n\t
"
\
"mov %[S_7], %[S_6]
\n\t
"
\
"mov %[S_6], %[S_5]
\n\t
"
\
"mov %[S_5], %[S_4]
\n\t
"
\
"ROR %[S_4], %[t1] , #31
\n\t
"
\
"/*rotate shift left 8 bits [w10 w6 w2-> (w6,3) (w2,3) ( w10,2)]*/
\n\t
"
\
"ROR %[S_11], %[S_11] , #28
\n\t
"
\
"ROR %[S_10], %[S_10] , #28
\n\t
"
\
"ROR %[S_9], %[S_9] , #28
\n\t
"
\
"ROR %[S_8], %[S_8] , #28
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
\
[
S_4
]
"+r"
(
s
[
4
]),
[
S_8
]
"+r"
(
s
[
8
])
,
\
[
S_5
]
"+r"
(
s
[
5
]),
[
S_9
]
"+r"
(
s
[
9
])
,
\
[
S_6
]
"+r"
(
s
[
6
]),
[
S_10
]
"+r"
(
s
[
10
]),
\
[
S_7
]
"+r"
(
s
[
7
]),
[
S_11
]
"+r"
(
s
[
11
])
\
:
:
);
\
}
while
(
0
)
//t1 t2
#define P512_SR_ARC_2(rci) \
do
{
\
__asm__
__volatile__
(
\
"/*rotate shift left 25 bit [w11 w7 w3-> (w3,13) (w11,14) ( w7,14)] */
\n\t
"
\
"mov %[t3], %[S_15]
\n\t
"
\
"ROR %[S_15], %[S_14] , #26
\n\t
"
\
"ROR %[S_14], %[S_13] , #26
\n\t
"
\
"ROR %[S_13], %[S_12] , #26
\n\t
"
\
"ROR %[S_12], %[t3] , #25
\n\t
"
\
"/*add round const s0 s1 s2 s3*/
\n\t
"
\
"ands %[t1] , %[rci] , #0xc0
\n\t
"
\
"eors %[S_3] , %[S_3] , %[t1], LSR #6
\n\t
"
/*s[3] ^= (constant7Format_aead[lunNum] >> 6) & 0x3;*/
\
"ands %[t2] , %[rci] , #0x30
\n\t
"
\
"eors %[S_2] , %[S_2] , %[t2], LSR #4
\n\t
"
/*s[2] ^= (constant7Format_aead[lunNum] >> 4) & 0x3;*/
\
"ands %[t3] , %[rci] , #0xc
\n\t
"
\
"eors %[S_1] , %[S_1] , %[t3], LSR #2
\n\t
"
/*s[1] ^= (constant7Format_aead[lunNum] >> 2) & 0x3;*/
\
"ands %[t1] , %[rci] , #0x3
\n\t
"
\
"eors %[S_0] , %[S_0] , %[t1]
\n\t
"
/*s[0] ^= constant7Format_aead[lunNum] & 0x3;*/
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
[
t3
]
"=r"
(
t3
),
[
rci
]
"+r"
(
rci
),
\
[
S_0
]
"+r"
(
s
[
0
]),
[
S_1
]
"+r"
(
s
[
1
]),
[
S_2
]
"+r"
(
s
[
2
]),
[
S_3
]
"+r"
(
s
[
3
]),
\
[
S_12
]
"+r"
(
s
[
12
]),[
S_13
]
"+r"
(
s
[
13
]),[
S_14
]
"+r"
(
s
[
14
]),[
S_15
]
"+r"
(
s
[
15
])
\
:
:
);
\
}
while
(
0
)
//t1
#define P512_SR_2() \
do
{
\
__asm__
__volatile__
(
\
"/*rotate shift left 25 bit [w11 w7 w3-> (w3,13) (w11,14) ( w7,14)] */
\n\t
"
\
"mov %[t1], %[S_15]
\n\t
"
\
"ROR %[S_15], %[S_14] , #26
\n\t
"
\
"ROR %[S_14], %[S_13] , #26
\n\t
"
\
"ROR %[S_13], %[S_12] , #26
\n\t
"
\
"ROR %[S_12], %[t1] , #25
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
S_12
]
"+r"
(
s
[
12
]),[
S_13
]
"+r"
(
s
[
13
]),[
S_14
]
"+r"
(
s
[
14
]),[
S_15
]
"+r"
(
s
[
15
]),
\
[
t1
]
"=r"
(
t1
)
:
:
);
\
}
while
(
0
)
unsigned
char
constant8Format_hash
[
140
];
knot/Implementations/crypto_hash/knot512/armcortexm_2/crypto_hash.h
0 → 100644
View file @
a34b1718
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
);
\ No newline at end of file
knot/Implementations/crypto_hash/knot512/armcortexm_2/hash.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
#define PRH_ROUNDS 140
#define hash_RATE (64 / 8)
unsigned
char
constant8Format_hash
[
140
]
=
{
/*constant8_hash_512*/
0x1
,
0x4
,
0x10
,
0x40
,
0x3
,
0xd
,
0x35
,
0xd4
,
0x52
,
0x4a
,
0x2b
,
0xac
,
0xb0
,
0xc1
,
0x6
,
0x19
,
0x65
,
0x97
,
0x5c
,
0x72
,
0xca
,
0x2a
,
0xa8
,
0xa0
,
0x81
,
0x5
,
0x14
,
0x50
,
0x43
,
0xe
,
0x38
,
0xe1
,
0x86
,
0x18
,
0x61
,
0x87
,
0x1c
,
0x71
,
0xc7
,
0x1f
,
0x7c
,
0xf2
,
0xcb
,
0x2e
,
0xb8
,
0xe0
,
0x82
,
0x8
,
0x21
,
0x84
,
0x11
,
0x44
,
0x13
,
0x4d
,
0x36
,
0xd9
,
0x67
,
0x9e
,
0x79
,
0xe6
,
0x9b
,
0x6d
,
0xb6
,
0xd8
,
0x63
,
0x8e
,
0x39
,
0xe5
,
0x96
,
0x58
,
0x62
,
0x8a
,
0x29
,
0xa5
,
0x95
,
0x55
,
0x57
,
0x5e
,
0x7b
,
0xef
,
0xbe
,
0xf9
,
0xe7
,
0x9f
,
0x7d
,
0xf6
,
0xdb
,
0x6e
,
0xbb
,
0xed
,
0xb7
,
0xdc
,
0x73
,
0xce
,
0x3a
,
0xe8
,
0xa3
,
0x8c
,
0x30
,
0xc0
,
0x2
,
0x9
,
0x25
,
0x94
,
0x51
,
0x47
,
0x1e
,
0x78
,
0xe2
,
0x8b
,
0x2d
,
0xb5
,
0xd5
,
0x56
,
0x5a
,
0x6b
,
0xaf
,
0xbd
,
0xf4
,
0xd2
,
0x4b
,
0x2f
,
0xbc
,
0xf0
,
0xc2
,
0xb
,
0x2c
,
0xb1
,
0xc5
,
0x16
,
0x59
,
0x66
,
0x9a
,
0x69
,
0xa6
,
0x98
,
0x60
,
0x83
,
0xc
,
0x31
,
};
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
)
{
u32
dataFormat
[
4
]
=
{
0
};
// initialization
u32
s
[
16
]
=
{
0
};
u8
tempData
[
32
];
//absorb
while
(
inlen
>=
hash_RATE
)
{
packU64FormatToFourPacket
(
dataFormat
,
in
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
s
[
3
]
^=
dataFormat
[
3
];
P512
(
s
,
constant8Format_hash
,
PRH_ROUNDS
);
inlen
-=
hash_RATE
;
in
+=
hash_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
in
,
inlen
*
sizeof
(
unsigned
char
));
tempData
[
inlen
]
=
0x01
;
packU64FormatToFourPacket
(
dataFormat
,
tempData
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
s
[
3
]
^=
dataFormat
[
3
];
P512
(
s
,
constant8Format_hash
,
PRH_ROUNDS
);
//sequeez
unpackU128FormatToFourPacket
(
out
,
s
);
unpackU128FormatToFourPacket
((
out
+
16
),
(
s
+
4
));
P512
(
s
,
constant8Format_hash
,
PRH_ROUNDS
);
out
+=
CRYPTO_BYTES
/
2
;
unpackU128FormatToFourPacket
(
out
,
s
);
unpackU128FormatToFourPacket
((
out
+
16
),
(
s
+
4
));
return
0
;
}
knot/Implementations/crypto_hash/knot512/armcortexm_3/api.h
0 → 100644
View file @
a34b1718
#define CRYPTO_BYTES 64
knot/Implementations/crypto_hash/knot512/armcortexm_3/auxFormat.h
0 → 100644
View file @
a34b1718
#include"api.h"
#include <string.h>
#define U32BIG(x) (x)
#define ARR_SIZE(a) (sizeof((a))/sizeof((a[0])))
#define LOTR32(x,n) (((x)<<(n))|((x)>>(32-(n))))
unsigned
char
constant8Format_hash
[
140
];
#define sbox(a, b, c, d, f, g, h) \
{
\
t1
=
~
a
;
t2
=
b
&
t1
;
t3
=
c
^
t2
;
h
=
d
^
t3
;
t5
=
b
|
c
;
t6
=
d
^
t1
;
g
=
t5
^
t6
;
t8
=
b
^
d
;
t9
=
t3
&
t6
;
a
=
t8
^
t9
;
t11
=
g
&
t8
;
f
=
t3
^
t11
;
\
}
typedef
unsigned
char
u8
;
typedef
unsigned
int
u32
;
typedef
unsigned
long
long
u64
;
void
printU8
(
char
name
[],
u8
var
[],
long
len
,
int
offset
);
// t9
#define puck32(in)\
{
\
t9
=
(
in
^
(
in
>>
1
))
&
0x22222222
;
in
^=
t9
^
(
t9
<<
1
);
\
t9
=
(
in
^
(
in
>>
2
))
&
0x0C0C0C0C
;
in
^=
t9
^
(
t9
<<
2
);
\
t9
=
(
in
^
(
in
>>
4
))
&
0x00F000F0
;
in
^=
t9
^
(
t9
<<
4
);
\
t9
=
(
in
^
(
in
>>
8
))
&
0x0000FF00
;
in
^=
t9
^
(
t9
<<
8
);
\
}
// t9
#define unpuck32(t0){\
t9
=
(
t0
^
(
t0
>>
8
))
&
0x0000FF00
,
t0
^=
t9
^
(
t9
<<
8
);
\
t9
=
(
t0
^
(
t0
>>
4
))
&
0x00F000F0
,
t0
^=
t9
^
(
t9
<<
4
);
\
t9
=
(
t0
^
(
t0
>>
2
))
&
0x0C0C0C0C
,
t0
^=
t9
^
(
t9
<<
2
);
\
t9
=
(
t0
^
(
t0
>>
1
))
&
0x22222222
,
t0
^=
t9
^
(
t9
<<
1
);
\
}
//u32 u32 t1, t2, t3,t8,
#define unpackU128FormatToFourPacket( out, dataFormat) {\
t3
=
(
dataFormat
[
3
]
&
0xff000000
)
|
((
dataFormat
[
2
]
>>
8
)
&
0x00ff0000
)
|
((
dataFormat
[
1
]
>>
16
)
&
0x0000ff00
)
|
(
dataFormat
[
0
]
>>
24
);
\
t2
=
((
dataFormat
[
3
]
<<
8
)
&
0xff000000
)
|
(
dataFormat
[
2
]
&
0x00ff0000
)
|
((
dataFormat
[
1
]
>>
8
)
&
0x0000ff00
)
|
((
dataFormat
[
0
]
>>
16
)
&
0x000000ff
);
\
t1
=
((
dataFormat
[
3
]
<<
16
)
&
0xff000000
)
|
((
dataFormat
[
2
]
<<
8
)
&
0x00ff0000
)
|
(
dataFormat
[
1
]
&
0x0000ff00
)
|
((
dataFormat
[
0
]
>>
8
)
&
0x000000ff
);
\
t8
=
((
dataFormat
[
3
]
<<
24
)
&
0xff000000
)
|
((
dataFormat
[
2
]
<<
16
)
&
0x00ff0000
)
|
((
dataFormat
[
1
]
<<
8
)
&
0x0000ff00
)
|
(
dataFormat
[
0
]
&
0x000000ff
);
\
unpuck32
(
t8
);
unpuck32
(
t8
);
\
unpuck32
(
t1
);
unpuck32
(
t1
);
\
unpuck32
(
t2
);
unpuck32
(
t2
);
\
unpuck32
(
t3
);
unpuck32
(
t3
);
\
((
u32
*
)
out
)[
0
]
=
U32BIG
(
t8
);
\
((
u32
*
)
out
)[
1
]
=
U32BIG
(
t1
);
\
((
u32
*
)
out
)[
2
]
=
U32BIG
(
t2
);
\
((
u32
*
)
out
)[
3
]
=
U32BIG
(
t3
);
\
}
#define packU64FormatToFourPacket( out, in) {\
t1
=
U32BIG
(((
u32
*
)
in
)[
0
]);
\
t2
=
U32BIG
(((
u32
*
)
in
)[
1
]);
\
puck32
(
t1
);
\
puck32
(
t1
);
\
puck32
(
t2
);
\
puck32
(
t2
);
\
out
[
3
]
=
((
t2
>>
16
)
&
0x0000ff00
)
|
((
t1
>>
24
));
\
out
[
2
]
=
((
t2
>>
8
)
&
0x0000ff00
)
|
((
t1
>>
16
)
&
0x000000ff
);
\
out
[
1
]
=
(
t2
&
0x0000ff00
)
|
((
t1
>>
8
)
&
0x000000ff
);
\
out
[
0
]
=
((
t2
<<
8
)
&
0x0000ff00
)
|
(
t1
&
0x000000ff
);
\
}
#define BIT_LOTR32_16(t0,t1,t2,t3,t4,t5,t6,t7){\
t4
=
LOTR32
(
t0
,
4
);
\
t5
=
LOTR32
(
t1
,
4
);
\
t6
=
LOTR32
(
t2
,
4
);
\
t7
=
LOTR32
(
t3
,
4
);
\
}
#define BIT_LOTR32_25(t0,t1,t2,t3,t4,t5,t6,t7){\
t4
=
LOTR32
(
t3
,
7
);
\
t5
=
LOTR32
(
t0
,
6
);
\
t6
=
LOTR32
(
t1
,
6
);
\
t7
=
LOTR32
(
t2
,
6
);
\
}
#define ROUND512( lunNum) {\
s
[
3
]
^=
(
constant8Format_hash
[
lunNum
]
>>
6
)
&
0x3
;
\
s
[
2
]
^=
(
constant8Format_hash
[
lunNum
]
>>
4
)
&
0x3
;
\
s
[
1
]
^=
(
constant8Format_hash
[
lunNum
]
>>
2
)
&
0x3
;
\
s
[
0
]
^=
constant8Format_hash
[
lunNum
]
&
0x3
;
\
sbox
(
s
[
3
],
s
[
7
],
s
[
11
],
s
[
15
],
s_temp
[
7
],
s_temp
[
11
],
s_temp
[
15
]);
\
sbox
(
s
[
2
],
s
[
6
],
s
[
10
],
s
[
14
],
s
[
7
]
,
s_temp
[
10
],
s_temp
[
14
]);
\
sbox
(
s
[
1
],
s
[
5
],
s
[
9
],
s
[
13
],
s
[
6
]
,
s_temp
[
9
],
s_temp
[
13
]);
\
sbox
(
s
[
0
],
s
[
4
],
s
[
8
],
s
[
12
],
s
[
5
]
,
s_temp
[
8
],
s_temp
[
12
]);
\
s
[
4
]
=
LOTR32
(
s_temp
[
7
],
1
);
\
BIT_LOTR32_16
(
s_temp
[
8
],
s_temp
[
9
],
s_temp
[
10
],
s_temp
[
11
],
s
[
8
],
s
[
9
],
s
[
10
],
s
[
11
]);
\
BIT_LOTR32_25
(
s_temp
[
12
],
s_temp
[
13
],
s_temp
[
14
],
s_temp
[
15
],
s
[
12
],
s
[
13
],
s
[
14
],
s
[
15
]);
\
}
knot/Implementations/crypto_hash/knot512/armcortexm_3/crypto_hash.h
0 → 100644
View file @
a34b1718
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
);
\ No newline at end of file
knot/Implementations/crypto_hash/knot512/armcortexm_3/hash.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
#define PRH_ROUNDS 140
#define hash_RATE (64 / 8)
unsigned
char
constant8Format_hash
[
140
]
=
{
/*constant8_hash_512*/
0x01
,
0x04
,
0x10
,
0x40
,
0x03
,
0x0d
,
0x35
,
0xd4
,
0x52
,
0x4a
,
0x2b
,
0xac
,
0xb0
,
0xc1
,
0x06
,
0x19
,
0x65
,
0x97
,
0x5c
,
0x72
,
0xca
,
0x2a
,
0xa8
,
0xa0
,
0x81
,
0x05
,
0x14
,
0x50
,
0x43
,
0x0e
,
0x38
,
0xe1
,
0x86
,
0x18
,
0x61
,
0x87
,
0x1c
,
0x71
,
0xc7
,
0x1f
,
0x7c
,
0xf2
,
0xcb
,
0x2e
,
0xb8
,
0xe0
,
0x82
,
0x08
,
0x21
,
0x84
,
0x11
,
0x44
,
0x13
,
0x4d
,
0x36
,
0xd9
,
0x67
,
0x9e
,
0x79
,
0xe6
,
0x9b
,
0x6d
,
0xb6
,
0xd8
,
0x63
,
0x8e
,
0x39
,
0xe5
,
0x96
,
0x58
,
0x62
,
0x8a
,
0x29
,
0xa5
,
0x95
,
0x55
,
0x57
,
0x5e
,
0x7b
,
0xef
,
0xbe
,
0xf9
,
0xe7
,
0x9f
,
0x7d
,
0xf6
,
0xdb
,
0x6e
,
0xbb
,
0xed
,
0xb7
,
0xdc
,
0x73
,
0xce
,
0x3a
,
0xe8
,
0xa3
,
0x8c
,
0x30
,
0xc0
,
0x02
,
0x09
,
0x25
,
0x94
,
0x51
,
0x47
,
0x1e
,
0x78
,
0xe2
,
0x8b
,
0x2d
,
0xb5
,
0xd5
,
0x56
,
0x5a
,
0x6b
,
0xaf
,
0xbd
,
0xf4
,
0xd2
,
0x4b
,
0x2f
,
0xbc
,
0xf0
,
0xc2
,
0x0b
,
0x2c
,
0xb1
,
0xc5
,
0x16
,
0x59
,
0x66
,
0x9a
,
0x69
,
0xa6
,
0x98
,
0x60
,
0x83
,
0x0c
,
0x31
,
};
#define Processing_Data(data) \
do
{
\
packU64FormatToFourPacket
(
dataFormat
,
data
);
\
s
[
0
]
^=
dataFormat
[
0
];
\
s
[
1
]
^=
dataFormat
[
1
];
\
s
[
2
]
^=
dataFormat
[
2
];
\
s
[
3
]
^=
dataFormat
[
3
];
\
}
while
(
0
)
#define ABSORB(inlen,in) \
do
{
\
}
while
(
0
)
//sequeez
#define SEQUEEZ() \
{
\
unpackU128FormatToFourPacket
(
out
,
s
);
\
unpackU128FormatToFourPacket
((
out
+
16
),
(
s
+
4
));
\
for
(
i
=
0
;
i
<
PRH_ROUNDS
;
i
++
)
{
\
ROUND512
(
i
);
\
}
\
out
+=
CRYPTO_BYTES
/
2
;
\
unpackU128FormatToFourPacket
(
out
,
s
);
\
unpackU128FormatToFourPacket
((
out
+
16
),(
s
+
4
));
\
}
while
(
0
)
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
)
{
//r=64
u8
i
;
u32
dataFormat
[
4
]
=
{
0
};
u32
t1
,
t2
,
t3
,
t8
,
t9
,
t5
,
t6
,
t11
;
// initialization
u32
s
[
16
]
=
{
0
};
u8
tempData
[
32
];
u32
s_temp
[
16
]
=
{
0
};
//absorb
while
(
inlen
>=
hash_RATE
)
{
Processing_Data
(
in
);
for
(
i
=
0
;
i
<
PRH_ROUNDS
;
i
++
)
{
ROUND512
(
i
);
}
inlen
-=
hash_RATE
;
in
+=
hash_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
in
,
inlen
*
sizeof
(
unsigned
char
));
tempData
[
inlen
]
=
0x01
;
Processing_Data
(
tempData
);
for
(
i
=
0
;
i
<
PRH_ROUNDS
;
i
++
)
{
ROUND512
(
i
);
}
//sequeez
unpackU128FormatToFourPacket
(
out
,
s
);
unpackU128FormatToFourPacket
((
out
+
16
),
(
s
+
4
));
for
(
i
=
0
;
i
<
PRH_ROUNDS
;
i
++
)
{
ROUND512
(
i
);
}
out
+=
CRYPTO_BYTES
/
2
;
unpackU128FormatToFourPacket
(
out
,
s
);
unpackU128FormatToFourPacket
((
out
+
16
),
(
s
+
4
));
return
0
;
}
knot/Implementations/crypto_hash/knot512/armcortexm_4/api.h
0 → 100644
View file @
a34b1718
#define CRYPTO_BYTES 64
knot/Implementations/crypto_hash/knot512/armcortexm_4/auxFormat.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
void
P512
(
unsigned
int
*
s
,
unsigned
char
*
round
,
unsigned
char
lunNum
)
{
u32
s_temp
[
16
]
=
{
0
};
u32
t1
,
t2
,
t3
,
t5
,
t6
,
t8
,
t9
,
t11
;
unsigned
char
i
;
for
(
i
=
0
;
i
<
lunNum
;
i
++
)
{
s
[
3
]
^=
(
round
[
i
]
>>
6
)
&
0x3
;
s
[
2
]
^=
(
round
[
i
]
>>
4
)
&
0x3
;
s
[
1
]
^=
(
round
[
i
]
>>
2
)
&
0x3
;
s
[
0
]
^=
round
[
i
]
&
0x3
;
sbox
(
s
[
3
],
s
[
7
],
s
[
11
],
s
[
15
],
s_temp
[
7
],
s_temp
[
11
],
s_temp
[
15
]);
sbox
(
s
[
2
],
s
[
6
],
s
[
10
],
s
[
14
],
s
[
7
],
s_temp
[
10
],
s_temp
[
14
]);
sbox
(
s
[
1
],
s
[
5
],
s
[
9
],
s
[
13
],
s
[
6
],
s_temp
[
9
],
s_temp
[
13
]);
sbox
(
s
[
0
],
s
[
4
],
s
[
8
],
s
[
12
],
s
[
5
],
s_temp
[
8
],
s_temp
[
12
]);
s
[
4
]
=
LOTR32
(
s_temp
[
7
],
1
);
BIT_LOTR32_16
(
s_temp
[
8
],
s_temp
[
9
],
s_temp
[
10
],
s_temp
[
11
],
s
[
8
],
s
[
9
],
s
[
10
],
s
[
11
]);
BIT_LOTR32_25
(
s_temp
[
12
],
s_temp
[
13
],
s_temp
[
14
],
s_temp
[
15
],
s
[
12
],
s
[
13
],
s
[
14
],
s
[
15
]);
}
}
void
packU64FormatToFourPacket
(
u32
*
out
,
u8
*
in
)
{
u32
t1
,
t2
,
temp1
;
t1
=
U32BIG
(((
u32
*
)
in
)[
0
]);
t2
=
U32BIG
(((
u32
*
)
in
)[
1
]);
puck32
(
t1
);
puck32
(
t1
);
puck32
(
t2
);
puck32
(
t2
);
out
[
3
]
=
((
t2
>>
16
)
&
0x0000ff00
)
|
((
t1
>>
24
));
out
[
2
]
=
((
t2
>>
8
)
&
0x0000ff00
)
|
((
t1
>>
16
)
&
0x000000ff
);
out
[
1
]
=
(
t2
&
0x0000ff00
)
|
((
t1
>>
8
)
&
0x000000ff
);
out
[
0
]
=
((
t2
<<
8
)
&
0x0000ff00
)
|
(
t1
&
0x000000ff
);
}
void
unpackU128FormatToFourPacket
(
u8
*
out
,
u32
*
in
)
{
u32
t
[
4
]
=
{
0
};
u32
r0
;
t
[
3
]
=
(
in
[
3
]
&
0xff000000
)
|
((
in
[
2
]
>>
8
)
&
0x00ff0000
)
|
((
in
[
1
]
>>
16
)
&
0x0000ff00
)
|
(
in
[
0
]
>>
24
);
t
[
2
]
=
((
in
[
3
]
<<
8
)
&
0xff000000
)
|
(
in
[
2
]
&
0x00ff0000
)
|
((
in
[
1
]
>>
8
)
&
0x0000ff00
)
|
((
in
[
0
]
>>
16
)
&
0x000000ff
);
t
[
1
]
=
((
in
[
3
]
<<
16
)
&
0xff000000
)
|
((
in
[
2
]
<<
8
)
&
0x00ff0000
)
|
(
in
[
1
]
&
0x0000ff00
)
|
((
in
[
0
]
>>
8
)
&
0x000000ff
);
t
[
0
]
=
((
in
[
3
]
<<
24
)
&
0xff000000
)
|
((
in
[
2
]
<<
16
)
&
0x00ff0000
)
|
((
in
[
1
]
<<
8
)
&
0x0000ff00
)
|
(
in
[
0
]
&
0x000000ff
);
unpuck32
(
t
[
0
]);
unpuck32
(
t
[
0
]);
unpuck32
(
t
[
1
]);
unpuck32
(
t
[
1
]);
unpuck32
(
t
[
2
]);
unpuck32
(
t
[
2
]);
unpuck32
(
t
[
3
]);
unpuck32
(
t
[
3
]);
memcpy
(
out
,
t
,
16
*
sizeof
(
unsigned
char
));
}
knot/Implementations/crypto_hash/knot512/armcortexm_4/auxFormat.h
0 → 100644
View file @
a34b1718
#include<malloc.h>
#include<stdio.h>
#include"crypto_hash.h"
#include"api.h"
#include <string.h>
#define U32BIG(x) (x)
typedef
unsigned
char
u8
;
typedef
unsigned
int
u32
;
typedef
unsigned
long
long
u64
;
#define puck32(in)\
{
\
temp1
=
(
in
^
(
in
>>
1
))
&
0x22222222
;
in
^=
temp1
^
(
temp1
<<
1
);
\
temp1
=
(
in
^
(
in
>>
2
))
&
0x0C0C0C0C
;
in
^=
temp1
^
(
temp1
<<
2
);
\
temp1
=
(
in
^
(
in
>>
4
))
&
0x00F000F0
;
in
^=
temp1
^
(
temp1
<<
4
);
\
temp1
=
(
in
^
(
in
>>
8
))
&
0x0000FF00
;
in
^=
temp1
^
(
temp1
<<
8
);
\
}
#define unpuck32(t0){\
r0
=
(
t0
^
(
t0
>>
8
))
&
0x0000FF00
,
t0
^=
r0
^
(
r0
<<
8
);
\
r0
=
(
t0
^
(
t0
>>
4
))
&
0x00F000F0
,
t0
^=
r0
^
(
r0
<<
4
);
\
r0
=
(
t0
^
(
t0
>>
2
))
&
0x0C0C0C0C
,
t0
^=
r0
^
(
r0
<<
2
);
\
r0
=
(
t0
^
(
t0
>>
1
))
&
0x22222222
,
t0
^=
r0
^
(
r0
<<
1
);
\
}
#define ARR_SIZE(a) (sizeof((a))/sizeof((a[0])))
#define LOTR32(x,n) (((x)<<(n))|((x)>>(32-(n))))
#define sbox(a, b, c, d, f, g, h) \
{
\
t1
=
~
a
;
t2
=
b
&
t1
;
t3
=
c
^
t2
;
h
=
d
^
t3
;
t5
=
b
|
c
;
t6
=
d
^
t1
;
g
=
t5
^
t6
;
t8
=
b
^
d
;
t9
=
t3
&
t6
;
a
=
t8
^
t9
;
t11
=
g
&
t8
;
f
=
t3
^
t11
;
\
}
#define BIT_LOTR32_16(t0,t1,t2,t3,t4,t5,t6,t7){\
t4
=
LOTR32
(
t0
,
4
);
\
t5
=
LOTR32
(
t1
,
4
);
\
t6
=
LOTR32
(
t2
,
4
);
\
t7
=
LOTR32
(
t3
,
4
);
\
}
#define BIT_LOTR32_25(t0,t1,t2,t3,t4,t5,t6,t7){\
t4
=
LOTR32
(
t3
,
7
);
\
t5
=
LOTR32
(
t0
,
6
);
\
t6
=
LOTR32
(
t1
,
6
);
\
t7
=
LOTR32
(
t2
,
6
);
\
}
unsigned
char
constant8Format_hash
[
140
];
knot/Implementations/crypto_hash/knot512/armcortexm_4/crypto_hash.h
0 → 100644
View file @
a34b1718
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
);
\ No newline at end of file
knot/Implementations/crypto_hash/knot512/armcortexm_4/hash.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
#define PRH_ROUNDS 140
#define hash_RATE (64 / 8)
unsigned
char
constant8Format_hash
[
140
]
=
{
/*constant8_hash_512*/
0x1
,
0x4
,
0x10
,
0x40
,
0x3
,
0xd
,
0x35
,
0xd4
,
0x52
,
0x4a
,
0x2b
,
0xac
,
0xb0
,
0xc1
,
0x6
,
0x19
,
0x65
,
0x97
,
0x5c
,
0x72
,
0xca
,
0x2a
,
0xa8
,
0xa0
,
0x81
,
0x5
,
0x14
,
0x50
,
0x43
,
0xe
,
0x38
,
0xe1
,
0x86
,
0x18
,
0x61
,
0x87
,
0x1c
,
0x71
,
0xc7
,
0x1f
,
0x7c
,
0xf2
,
0xcb
,
0x2e
,
0xb8
,
0xe0
,
0x82
,
0x8
,
0x21
,
0x84
,
0x11
,
0x44
,
0x13
,
0x4d
,
0x36
,
0xd9
,
0x67
,
0x9e
,
0x79
,
0xe6
,
0x9b
,
0x6d
,
0xb6
,
0xd8
,
0x63
,
0x8e
,
0x39
,
0xe5
,
0x96
,
0x58
,
0x62
,
0x8a
,
0x29
,
0xa5
,
0x95
,
0x55
,
0x57
,
0x5e
,
0x7b
,
0xef
,
0xbe
,
0xf9
,
0xe7
,
0x9f
,
0x7d
,
0xf6
,
0xdb
,
0x6e
,
0xbb
,
0xed
,
0xb7
,
0xdc
,
0x73
,
0xce
,
0x3a
,
0xe8
,
0xa3
,
0x8c
,
0x30
,
0xc0
,
0x2
,
0x9
,
0x25
,
0x94
,
0x51
,
0x47
,
0x1e
,
0x78
,
0xe2
,
0x8b
,
0x2d
,
0xb5
,
0xd5
,
0x56
,
0x5a
,
0x6b
,
0xaf
,
0xbd
,
0xf4
,
0xd2
,
0x4b
,
0x2f
,
0xbc
,
0xf0
,
0xc2
,
0xb
,
0x2c
,
0xb1
,
0xc5
,
0x16
,
0x59
,
0x66
,
0x9a
,
0x69
,
0xa6
,
0x98
,
0x60
,
0x83
,
0xc
,
0x31
,
};
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
)
{
u32
dataFormat
[
4
]
=
{
0
};
// initialization
u32
s
[
16
]
=
{
0
};
u8
tempData
[
32
];
//absorb
while
(
inlen
>=
hash_RATE
)
{
packU64FormatToFourPacket
(
dataFormat
,
in
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
s
[
3
]
^=
dataFormat
[
3
];
P512
(
s
,
constant8Format_hash
,
PRH_ROUNDS
);
inlen
-=
hash_RATE
;
in
+=
hash_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
in
,
inlen
*
sizeof
(
unsigned
char
));
tempData
[
inlen
]
=
0x01
;
packU64FormatToFourPacket
(
dataFormat
,
tempData
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
s
[
3
]
^=
dataFormat
[
3
];
P512
(
s
,
constant8Format_hash
,
PRH_ROUNDS
);
//sequeez
unpackU128FormatToFourPacket
(
out
,
s
);
unpackU128FormatToFourPacket
((
out
+
16
),
(
s
+
4
));
P512
(
s
,
constant8Format_hash
,
PRH_ROUNDS
);
out
+=
CRYPTO_BYTES
/
2
;
unpackU128FormatToFourPacket
(
out
,
s
);
unpackU128FormatToFourPacket
((
out
+
16
),
(
s
+
4
));
return
0
;
}
knot/Implementations/crypto_hash/knot512/armcortexm_5/api.h
0 → 100644
View file @
a34b1718
#define CRYPTO_BYTES 64
knot/Implementations/crypto_hash/knot512/armcortexm_5/auxFormat.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
void
P512
(
unsigned
int
*
s
,
unsigned
char
*
round
,
unsigned
char
rounds
)
{
u32
rci
,
t1
,
t2
,
t3
,
t9
;
unsigned
char
rcNum
=
0
;
rci
=
round
[
rcNum
++
];
ARC
(
rci
);
SBOX1
(
s
[
0
],
s
[
4
],
s
[
8
],
s
[
12
]);
SBOX1
(
s
[
1
],
s
[
5
],
s
[
9
],
s
[
13
]);
SBOX1
(
s
[
2
],
s
[
6
],
s
[
10
],
s
[
14
]);
SBOX1
(
s
[
3
],
s
[
7
],
s
[
11
],
s
[
15
]);
while
(
rounds
--
)
{
rci
=
round
[
rcNum
++
];
ARC
(
rci
);
SBOX2
(
s
[
0
],
s
[
7
],
s
[
8
],
s
[
15
]);
SBOX3
(
s
[
1
],
s
[
4
],
s
[
9
],
s
[
12
]);
SBOX3
(
s
[
2
],
s
[
5
],
s
[
10
],
s
[
13
]);
SBOX3
(
s
[
3
],
s
[
6
],
s
[
11
],
s
[
14
]);
rci
=
round
[
rcNum
++
];
ARC
(
rci
);
SBOX2
(
s
[
0
],
s
[
6
],
s
[
8
],
s
[
14
]);
SBOX3
(
s
[
1
],
s
[
7
],
s
[
9
],
s
[
15
]);
SBOX3
(
s
[
2
],
s
[
4
],
s
[
10
],
s
[
12
]);
SBOX3
(
s
[
3
],
s
[
5
],
s
[
11
],
s
[
13
]);
rci
=
round
[
rcNum
++
];
ARC
(
rci
);
SBOX2
(
s
[
0
],
s
[
5
],
s
[
8
],
s
[
13
]);
SBOX3
(
s
[
1
],
s
[
6
],
s
[
9
],
s
[
14
]);
SBOX3
(
s
[
2
],
s
[
7
],
s
[
10
],
s
[
15
]);
SBOX3
(
s
[
3
],
s
[
4
],
s
[
11
],
s
[
12
]);
rci
=
round
[
rcNum
++
];
ARC
(
rci
);
SBOX2
(
s
[
0
],
s
[
4
],
s
[
8
],
s
[
12
]);
SBOX3
(
s
[
1
],
s
[
5
],
s
[
9
],
s
[
13
]);
SBOX3
(
s
[
2
],
s
[
6
],
s
[
10
],
s
[
14
]);
SBOX3
(
s
[
3
],
s
[
7
],
s
[
11
],
s
[
15
]);
}
rci
=
round
[
rcNum
++
];
ARC
(
rci
);
SBOX2
(
s
[
0
],
s
[
7
],
s
[
8
],
s
[
15
]);
SBOX3
(
s
[
1
],
s
[
4
],
s
[
9
],
s
[
12
]);
SBOX3
(
s
[
2
],
s
[
5
],
s
[
10
],
s
[
13
]);
SBOX3
(
s
[
3
],
s
[
6
],
s
[
11
],
s
[
14
]);
rci
=
round
[
rcNum
++
];
ARC
(
rci
);
SBOX2
(
s
[
0
],
s
[
6
],
s
[
8
],
s
[
14
]);
SBOX3
(
s
[
1
],
s
[
7
],
s
[
9
],
s
[
15
]);
SBOX3
(
s
[
2
],
s
[
4
],
s
[
10
],
s
[
12
]);
SBOX3
(
s
[
3
],
s
[
5
],
s
[
11
],
s
[
13
]);
rci
=
round
[
rcNum
++
];
ARC
(
rci
);
SBOX2
(
s
[
0
],
s
[
5
],
s
[
8
],
s
[
13
]);
SBOX3
(
s
[
1
],
s
[
6
],
s
[
9
],
s
[
14
]);
SBOX3
(
s
[
2
],
s
[
7
],
s
[
10
],
s
[
15
]);
SBOX3
(
s
[
3
],
s
[
4
],
s
[
11
],
s
[
12
]);
SR
(
s
[
4
],
s
[
8
],
s
[
9
],
s
[
10
],
s
[
11
],
s
[
12
],
s
[
13
],
s
[
14
],
s
[
15
]);
}
void
packU64FormatToFourPacket
(
u32
*
out
,
u8
*
in
)
{
u32
t1
,
t2
,
temp1
;
t1
=
U32BIG
(((
u32
*
)
in
)[
0
]);
t2
=
U32BIG
(((
u32
*
)
in
)[
1
]);
puck32
(
t1
);
puck32
(
t1
);
puck32
(
t2
);
puck32
(
t2
);
out
[
3
]
=
((
t2
>>
16
)
&
0x0000ff00
)
|
((
t1
>>
24
));
out
[
2
]
=
((
t2
>>
8
)
&
0x0000ff00
)
|
((
t1
>>
16
)
&
0x000000ff
);
out
[
1
]
=
(
t2
&
0x0000ff00
)
|
((
t1
>>
8
)
&
0x000000ff
);
out
[
0
]
=
((
t2
<<
8
)
&
0x0000ff00
)
|
(
t1
&
0x000000ff
);
}
void
unpackU128FormatToFourPacket
(
u8
*
out
,
u32
*
in
)
{
u32
t
[
4
]
=
{
0
};
u32
r0
;
t
[
3
]
=
(
in
[
3
]
&
0xff000000
)
|
((
in
[
2
]
>>
8
)
&
0x00ff0000
)
|
((
in
[
1
]
>>
16
)
&
0x0000ff00
)
|
(
in
[
0
]
>>
24
);
t
[
2
]
=
((
in
[
3
]
<<
8
)
&
0xff000000
)
|
(
in
[
2
]
&
0x00ff0000
)
|
((
in
[
1
]
>>
8
)
&
0x0000ff00
)
|
((
in
[
0
]
>>
16
)
&
0x000000ff
);
t
[
1
]
=
((
in
[
3
]
<<
16
)
&
0xff000000
)
|
((
in
[
2
]
<<
8
)
&
0x00ff0000
)
|
(
in
[
1
]
&
0x0000ff00
)
|
((
in
[
0
]
>>
8
)
&
0x000000ff
);
t
[
0
]
=
((
in
[
3
]
<<
24
)
&
0xff000000
)
|
((
in
[
2
]
<<
16
)
&
0x00ff0000
)
|
((
in
[
1
]
<<
8
)
&
0x0000ff00
)
|
(
in
[
0
]
&
0x000000ff
);
unpuck32
(
t
[
0
]);
unpuck32
(
t
[
0
]);
unpuck32
(
t
[
1
]);
unpuck32
(
t
[
1
]);
unpuck32
(
t
[
2
]);
unpuck32
(
t
[
2
]);
unpuck32
(
t
[
3
]);
unpuck32
(
t
[
3
]);
memcpy
(
out
,
t
,
16
*
sizeof
(
unsigned
char
));
}
knot/Implementations/crypto_hash/knot512/armcortexm_5/auxFormat.h
0 → 100644
View file @
a34b1718
#include<malloc.h>
#include<stdio.h>
#include"crypto_hash.h"
#include"api.h"
#include <string.h>
#define U32BIG(x) (x)
typedef
unsigned
char
u8
;
typedef
unsigned
int
u32
;
typedef
unsigned
long
long
u64
;
#define puck32(in)\
{
\
temp1
=
(
in
^
(
in
>>
1
))
&
0x22222222
;
in
^=
temp1
^
(
temp1
<<
1
);
\
temp1
=
(
in
^
(
in
>>
2
))
&
0x0C0C0C0C
;
in
^=
temp1
^
(
temp1
<<
2
);
\
temp1
=
(
in
^
(
in
>>
4
))
&
0x00F000F0
;
in
^=
temp1
^
(
temp1
<<
4
);
\
temp1
=
(
in
^
(
in
>>
8
))
&
0x0000FF00
;
in
^=
temp1
^
(
temp1
<<
8
);
\
}
#define unpuck32(t0){\
r0
=
(
t0
^
(
t0
>>
8
))
&
0x0000FF00
,
t0
^=
r0
^
(
r0
<<
8
);
\
r0
=
(
t0
^
(
t0
>>
4
))
&
0x00F000F0
,
t0
^=
r0
^
(
r0
<<
4
);
\
r0
=
(
t0
^
(
t0
>>
2
))
&
0x0C0C0C0C
,
t0
^=
r0
^
(
r0
<<
2
);
\
r0
=
(
t0
^
(
t0
>>
1
))
&
0x22222222
,
t0
^=
r0
^
(
r0
<<
1
);
\
}
void
P512
(
unsigned
int
*
s
,
unsigned
char
*
round
,
unsigned
char
rounds
);
void
unpackU128FormatToFourPacket
(
u8
*
out
,
u32
*
in
);
void
packU64FormatToFourPacket
(
u32
*
out
,
u8
*
in
)
;
//t1
#define ARC(rci) \
do
{
\
__asm__
__volatile__
(
\
"/*add round const s0 s1 s2 s3*/
\n\t
"
\
"ands %[t1] , %[rci], #0xc0
\n\t
"
\
"eors %[S_3], %[S_3], %[t1], LSR #6
\n\t
"
/*s[3] ^= (constant7Format_aead[lunNum] >> 6) & 0x3;*/
\
"ands %[t2] , %[rci], #0x30
\n\t
"
\
"eors %[S_2], %[S_2], %[t2], LSR #4
\n\t
"
/*s[2] ^= (constant7Format_aead[lunNum] >> 4) & 0x3;*/
\
"ands %[t3] , %[rci], #0xc
\n\t
"
\
"eors %[S_1], %[S_1], %[t3], LSR #2
\n\t
"
/*s[1] ^= (constant7Format_aead[lunNum] >> 2) & 0x3;*/
\
"ands %[t4] , %[rci], #0x3
\n\t
"
\
"eors %[S_0], %[S_0], %[t4]
\n\t
"
/*s[0] ^= constant7Format_aead[lunNum] & 0x3;*/
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
[
t3
]
"=r"
(
t3
),
[
t4
]
"=r"
(
t9
),
[
rci
]
"+r"
(
rci
),
\
[
S_0
]
"+r"
(
s
[
0
]),
[
S_1
]
"+r"
(
s
[
1
]),
[
S_2
]
"+r"
(
s
[
2
]),[
S_3
]
"+r"
(
s
[
3
])
\
:
:
);
\
}
while
(
0
)
#define SBOX2(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"ROR %[S_2] , #31
\n\t
"
\
"ROR %[S_4] , #28
\n\t
"
\
"ROR %[S_6] , #25
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define SBOX3(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"ROR %[S_4] , #28
\n\t
"
\
"ROR %[S_6] , #26
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define SBOX1(S1,S2,S3,S4) \
do
{
\
__asm__
__volatile__
(
\
"/*sbox column*/
\n\t
"
\
"mvns %[S_0], %[S_0]
\n\t
"
\
"ands %[t1], %[S_2], %[S_0]
\n\t
"
\
"eors %[t1], %[S_4], %[t1]
\n\t
"
\
"orrs %[S_4], %[S_2], %[S_4]
\n\t
"
\
"eors %[S_0], %[S_6], %[S_0]
\n\t
"
\
"eors %[S_4], %[S_4], %[S_0]
\n\t
"
\
"eors %[t2], %[S_2], %[S_6]
\n\t
"
\
"eors %[S_6], %[S_6], %[t1]
\n\t
"
\
"ands %[S_0], %[t1] , %[S_0]
\n\t
"
\
"eors %[S_0], %[t2] , %[S_0]
\n\t
"
\
"ands %[S_2], %[S_4], %[t2]
\n\t
"
\
"eors %[S_2], %[t1] , %[S_2]
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
t1
]
"=r"
(
t1
),
[
t2
]
"=r"
(
t2
),
\
[
S_0
]
"+r"
(
S1
),
[
S_2
]
"+r"
(
S2
),
[
S_4
]
"+r"
(
S3
),
[
S_6
]
"+r"
(
S4
)
\
:
:
);
\
}
while
(
0
)
#define SR(S4,S8,S9,S10,S11,S12,S13,S14,S15) \
do
{
\
__asm__
__volatile__
(
\
"ROR %[S_4] , #31
\n\t
"
\
"ROR %[S_11] , #28
\n\t
"
\
"ROR %[S_10] , #28
\n\t
"
\
"ROR %[S_9] , #28
\n\t
"
\
"ROR %[S_8] , #28
\n\t
"
\
"ROR %[S_12] , #25
\n\t
"
\
"ROR %[S_13] , #26
\n\t
"
\
"ROR %[S_14] , #26
\n\t
"
\
"ROR %[S_15] , #26
\n\t
"
\
:
/* output variables - including inputs that are changed */
\
[
S_4
]
"+r"
(
S4
),
\
[
S_12
]
"+r"
(
S12
),
[
S_8
]
"+r"
(
S8
)
,
\
[
S_13
]
"+r"
(
S13
),
[
S_9
]
"+r"
(
S9
)
,
\
[
S_14
]
"+r"
(
S14
),
[
S_10
]
"+r"
(
S10
),
\
[
S_15
]
"+r"
(
S15
),
[
S_11
]
"+r"
(
S11
)
\
:
:
);
\
}
while
(
0
)
unsigned
char
constant8Format_hash
[
140
];
knot/Implementations/crypto_hash/knot512/armcortexm_5/crypto_hash.h
0 → 100644
View file @
a34b1718
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
);
\ No newline at end of file
knot/Implementations/crypto_hash/knot512/armcortexm_5/hash.c
0 → 100644
View file @
a34b1718
#include"auxFormat.h"
//#define PRH_ROUNDS 140 /4=35
#define PRH_ROUNDS 34
#define hash_RATE (64 / 8)
unsigned
char
constant8Format_hash
[
140
]
=
{
/*constant8_hash_512*/
0x1
,
0x4
,
0x10
,
0x40
,
0x3
,
0xd
,
0x35
,
0xd4
,
0x52
,
0x4a
,
0x2b
,
0xac
,
0xb0
,
0xc1
,
0x6
,
0x19
,
0x65
,
0x97
,
0x5c
,
0x72
,
0xca
,
0x2a
,
0xa8
,
0xa0
,
0x81
,
0x5
,
0x14
,
0x50
,
0x43
,
0xe
,
0x38
,
0xe1
,
0x86
,
0x18
,
0x61
,
0x87
,
0x1c
,
0x71
,
0xc7
,
0x1f
,
0x7c
,
0xf2
,
0xcb
,
0x2e
,
0xb8
,
0xe0
,
0x82
,
0x8
,
0x21
,
0x84
,
0x11
,
0x44
,
0x13
,
0x4d
,
0x36
,
0xd9
,
0x67
,
0x9e
,
0x79
,
0xe6
,
0x9b
,
0x6d
,
0xb6
,
0xd8
,
0x63
,
0x8e
,
0x39
,
0xe5
,
0x96
,
0x58
,
0x62
,
0x8a
,
0x29
,
0xa5
,
0x95
,
0x55
,
0x57
,
0x5e
,
0x7b
,
0xef
,
0xbe
,
0xf9
,
0xe7
,
0x9f
,
0x7d
,
0xf6
,
0xdb
,
0x6e
,
0xbb
,
0xed
,
0xb7
,
0xdc
,
0x73
,
0xce
,
0x3a
,
0xe8
,
0xa3
,
0x8c
,
0x30
,
0xc0
,
0x2
,
0x9
,
0x25
,
0x94
,
0x51
,
0x47
,
0x1e
,
0x78
,
0xe2
,
0x8b
,
0x2d
,
0xb5
,
0xd5
,
0x56
,
0x5a
,
0x6b
,
0xaf
,
0xbd
,
0xf4
,
0xd2
,
0x4b
,
0x2f
,
0xbc
,
0xf0
,
0xc2
,
0xb
,
0x2c
,
0xb1
,
0xc5
,
0x16
,
0x59
,
0x66
,
0x9a
,
0x69
,
0xa6
,
0x98
,
0x60
,
0x83
,
0xc
,
0x31
,
};
int
crypto_hash
(
unsigned
char
*
out
,
const
unsigned
char
*
in
,
unsigned
long
long
inlen
)
{
u32
dataFormat
[
4
]
=
{
0
};
// initialization
u32
s
[
16
]
=
{
0
};
u8
tempData
[
32
];
//absorb
while
(
inlen
>=
hash_RATE
)
{
packU64FormatToFourPacket
(
dataFormat
,
in
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
s
[
3
]
^=
dataFormat
[
3
];
P512
(
s
,
constant8Format_hash
,
PRH_ROUNDS
);
inlen
-=
hash_RATE
;
in
+=
hash_RATE
;
}
memset
(
tempData
,
0
,
sizeof
(
tempData
));
memcpy
(
tempData
,
in
,
inlen
*
sizeof
(
unsigned
char
));
tempData
[
inlen
]
=
0x01
;
packU64FormatToFourPacket
(
dataFormat
,
tempData
);
s
[
0
]
^=
dataFormat
[
0
];
s
[
1
]
^=
dataFormat
[
1
];
s
[
2
]
^=
dataFormat
[
2
];
s
[
3
]
^=
dataFormat
[
3
];
P512
(
s
,
constant8Format_hash
,
PRH_ROUNDS
);
//sequeez
unpackU128FormatToFourPacket
(
out
,
s
);
unpackU128FormatToFourPacket
((
out
+
16
),
(
s
+
4
));
P512
(
s
,
constant8Format_hash
,
PRH_ROUNDS
);
out
+=
CRYPTO_BYTES
/
2
;
unpackU128FormatToFourPacket
(
out
,
s
);
unpackU128FormatToFourPacket
((
out
+
16
),
(
s
+
4
));
return
0
;
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment