Commit Graph

114 Commits

Author SHA1 Message Date
Joost Rijneveld
2c976d5268
Unify header guards
By prefixing with XMSS_, we hopefully prevent conflicts
2017-10-19 16:04:42 +02:00
Joost Rijneveld
b8eb8c44a1
Add UI test files to create sample signatures
This makes it easier to mix and match with other implementations
for compatibility testing.
2017-10-17 17:11:18 +02:00
Joost Rijneveld
a926fce0bd
Clean up stray params.h generator 2017-10-16 15:29:17 +02:00
Joost Rijneveld
1a7df37f59
Add accidentally omitted params.h
Previously this was generated and thus gitignored
2017-10-16 15:17:35 +02:00
Joost Rijneveld
6a8571d880
Revert to using runtime-only parameter struct
Using global defines for parameters (as seems to be typical in
academic crypto code) does not play nice with multithreading at all.
2017-10-16 12:09:07 +02:00
Joost Rijneveld
2f87bf5a1f
Simplify runtime parameter globals 2017-08-24 14:59:14 +02:00
Joost Rijneveld
9d5884e120
Refactor for more consistent style and readability 2017-08-03 17:39:37 +02:00
Joost Rijneveld
1076b37321
Remove stray zerobytes 2017-08-01 16:48:47 +02:00
Joost Rijneveld
3134fafd91
Merge branch 'master' into defined-parameters
The defined-parameters branch should be the new leading branch,
as it supersedes master. This merge is performed using --strategy ours
as there are numerous conflicting changes regarding the different ways
in which SHA3 was added. The master branch is considered to not contain
anything of value that is not contained in the defined-parameters branch.

Prior to merging, the defined-parameters branch was rebased to prevent
the cherry-picked commits from showing up twice.
2017-08-01 16:45:08 +02:00
Joost Rijneveld
7fbd28a78b
Clarify status of run-time parameter selection 2017-08-01 16:18:09 +02:00
Joost Rijneveld
9b35b00d98
Add wrapper that allows for runtime parameters 2017-08-01 16:18:09 +02:00
Joost Rijneveld
65ee8202d8
Refactor to prepare for runtime parameters 2017-08-01 16:18:09 +02:00
Joost Rijneveld
1e041f25d5
Simplify hash family parameter definition 2017-08-01 16:18:09 +02:00
Joost Rijneveld
073e093ce0
Remove unused leafaddr structures 2017-08-01 16:18:09 +02:00
Joost Rijneveld
3ea7e8ace3
Mention branch-specific purpose on README 2017-08-01 16:18:09 +02:00
Joost Rijneveld
b8ec30fc2c
Clarify compile-time parameters in README 2017-08-01 16:17:58 +02:00
Joost Rijneveld
0986ceb2b7
Add README file mentioning XDR 2017-07-22 16:41:37 +02:00
Joost Rijneveld
3c0f6668ef
Add parameter for hash alg family, support SHAKE 2017-07-22 16:27:45 +02:00
Joost Rijneveld
880cfaa2d3
Remove stray local kdev config files 2017-07-22 15:33:31 +02:00
Andreas
dd067bd23e
some old changes 2017-07-22 15:13:58 +02:00
Joost Rijneveld
8befb0d550
Add SHAKE128 and SHAKE256
This also performs numerous consistency fixes
2017-06-02 17:29:14 +02:00
Joost Rijneveld
5122ac6f73
Reduce code duplication
A large number of functions was repeated in xmss_fast; these are now
shared between the two implementations via the xmss_commons file.
Notably, we ensure compatability by sharing the verification functions.
2017-06-02 14:46:30 +02:00
Joost Rijneveld
1e00c92c18
Refactor to use compile-time parameter sets
This starts a cleanup / refactor, but there is still some low-hanging fruit.
2017-06-02 14:10:24 +02:00
Joost Rijneveld
d4bc8656e3
Fix bug in addressing during fast xmssmt key gen 2017-05-31 16:43:12 +02:00
Andreas
9f512fa8dc v06 2016-09-22 16:31:41 +02:00
Andreas
ddddfd9739 handle that most machines are little endian but addresses here are big endian... 2016-07-12 16:19:42 +02:00
Andreas
2c290d39be upgraded to draft-06 2016-07-11 11:15:16 +02:00
Andreas
2b73688b7c fixed endianess for toByte and base_w 2016-02-16 19:24:12 +01:00
Andreas
c37b9dcfca SWITCH from v01 to v03
Versions are incompatible due to different address formats and differing message compression!
2016-02-16 16:31:18 +01:00
Andreas
59a4846fbd changed version date
Merge branch 'master' of bitbucket.org:ahuelsing/xmss_ref
2016-02-10 16:00:07 +01:00
Andreas
622a9513b1 local changes 2016-02-10 15:57:16 +01:00
Joost Rijneveld
c1f0721f4a Also fix int overflow for systems with 4-byte ULs 2016-02-08 12:11:52 +01:00
Joost Rijneveld
951848fe89 Remove redundant address changes 2016-02-05 15:30:00 +01:00
Joost Rijneveld
e2f1cee548 Fix error for d=1 cases as introduced by 719cb46 2016-02-03 14:05:48 +01:00
Joost Rijneveld
1e503b665e Make codestyle more consistent, fix -Wextra warns 2016-02-02 14:11:23 +01:00
Joost Rijneveld
719cb467df Prevent allocating for a 'next' tree on top layer 2016-02-01 17:21:09 +01:00
Joost Rijneveld
8cbbfe0f05 Prevent int overflow for h >= 32 2016-02-01 07:53:27 +01:00
Joost Rijneveld
97331f09c0 Fix update bug (partially re-implement BDS)
The bug occured for cases where d=3 and indicated
a lack of updates. Re-implementing the higher-level
structure of BDS resolved this.
2016-01-28 17:52:08 +01:00
Joost Rijneveld
17c5b2842f Make address masks more explicit and strict 2016-01-27 10:18:31 +01:00
Andreas
077e57f60e fixed bug in address for WOTS Key 2015-11-09 13:36:06 +01:00
Andreas
9d9b782ff9 added support for n = m = 64 2015-10-28 15:49:46 +01:00
Joost Rijneveld
05c52526c6 Uncomment lcrypto in chacha_test 2015-10-28 14:26:08 +01:00
Joost Rijneveld
f5a5231c72 Do not perform bds_round for the last leaf 2015-10-28 13:45:05 +01:00
Joost Rijneveld
c2807695e8 Make test_xmss_fast stack large enough for pkgen 2015-10-28 11:40:26 +01:00
Andreas
cb05927c24 corrected test cases 2015-10-28 11:08:36 +01:00
Joost Rijneveld
594d67aeb9 Use proper size limits for state structures 2015-10-05 21:59:50 +02:00
Joost Rijneveld
2af61cea82 Check if a NEXT-tree exists before updating it 2015-10-05 21:57:10 +02:00
Joost Rijneveld
4c19fe61e4 Make XMSSMT also use BDS tree traversal 2015-09-21 13:24:42 +02:00
Joost Rijneveld
a075747462 Store BDS state in passable struct, not in globals 2015-08-27 09:39:06 +02:00
Joost Rijneveld
a33aef699c Adhere to more strict storage bounds 2015-08-26 15:53:50 +02:00