Go to file
2019-04-15 09:19:45 +02:00
test Prevent overrunning stack for large benchmarks 2018-09-11 16:00:05 +02:00
ui Fix OID parsing 2018-02-15 17:45:19 -05:00
.gitignore Clean up tests 2017-10-26 18:06:15 +02:00
.travis.yml Add TravisCI configuration 2017-10-31 17:32:05 +01:00
fips202.c Clean up includes 2017-10-19 17:38:26 +02:00
fips202.h Perform various reformatting / renaming 2017-10-23 14:10:39 +02:00
hash_address.c Make addr type switching not zero out remainder 2017-11-01 16:49:52 +01:00
hash_address.h Rename parameters for readability and consistency 2017-10-24 17:51:56 +02:00
hash.c Fix prf when n != 32 2017-11-01 16:07:06 +01:00
hash.h Rename hash functions to tweaked hashes 2017-11-01 15:16:17 +01:00
LICENSE Simplify licensing using LICENSE file 2017-10-19 17:38:34 +02:00
Makefile Add benchmarking binary/target 2018-09-03 13:23:55 +09:00
params.c Allow more flexible parameter selection 2018-09-03 16:53:45 +09:00
params.h Allow more flexible parameter selection 2018-09-03 16:53:45 +09:00
randombytes.c Refactor for more consistent style and readability 2017-08-03 17:39:37 +02:00
randombytes.h Perform various reformatting / renaming 2017-10-23 14:10:39 +02:00
README.md Update README to point to RFC 2019-04-15 09:19:45 +02:00
utils.c Move ull-byte-conversions to separate utils file 2017-11-01 14:59:33 +01:00
utils.h Move ull-byte-conversions to separate utils file 2017-11-01 14:59:33 +01:00
wots.c Rename hash functions to tweaked hashes 2017-11-01 15:16:17 +01:00
wots.h Fix typo in WOTS comments: n-byte messages, not m 2017-11-01 13:35:58 +01:00
xmss_commons.c More explicitly label pk parts in verification 2017-12-06 15:14:50 +01:00
xmss_commons.h Do not expose l_tree function 2017-12-06 15:13:07 +01:00
xmss_core_fast.c Change order of SK elements to match RFC 2018-12-17 16:25:08 +01:00
xmss_core.c Change order of SK elements to match RFC 2018-12-17 16:25:08 +01:00
xmss_core.h Allow more flexible parameter selection 2018-09-03 16:53:45 +09:00
xmss.c Store OID in bigendian notation in pk and sk 2018-01-30 08:42:22 +00:00
xmss.h Perform various reformatting / renaming 2017-10-23 14:10:39 +02:00

XMSS reference code Build Status

This repository contains the reference implementation that accompanies RFC 8391: "XMSS: eXtended Merkle Signature Scheme".

This reference implementation supports all parameter sets as defined in the RFC at run-time (specified by prefixing the public and private keys with a 32-bit oid). Implementations that want to use compile-time parameter sets can remove the struct xmss_params function parameter.

When using the current code base, please be careful, expect changes and watch this document for further documentation. In particular, xmss_core_fast.c is long due for a serious clean-up. While this will not change its public API or output, it may affect the storage format of the BDS state (i.e. part of the secret key).

Dependencies

For the SHA-2 hash functions (i.e. SHA-256 and SHA-512), we rely on OpenSSL. Make sure to install the OpenSSL development headers. On Debian-based systems, this is achieved by installing the OpenSSL development package libssl-dev.

License

This reference implementation was written by Andreas Hülsing and Joost Rijneveld. All included code is available under the CC0 1.0 Universal Public Domain Dedication.