Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.
Joost Rijneveld a95aaf0b37
Fix typo in WOTS comments: n-byte messages, not m
pirms 7 gadiem
test Make return code of test/xmss meaningful pirms 7 gadiem
ui Support messages that exceed the stack size pirms 7 gadiem
.gitignore Clean up tests pirms 7 gadiem
.travis.yml Add TravisCI configuration pirms 7 gadiem
LICENSE Simplify licensing using LICENSE file pirms 7 gadiem
Makefile Optionally specify number of test sigs in Makefile pirms 7 gadiem
README.md Add TravisCI badge pirms 7 gadiem
fips202.c Clean up includes pirms 7 gadiem
fips202.h Perform various reformatting / renaming pirms 7 gadiem
hash.c Clean up and simplify hash function definitions pirms 7 gadiem
hash.h Clean up and simplify hash function definitions pirms 7 gadiem
hash_address.c Rename parameters for readability and consistency pirms 7 gadiem
hash_address.h Rename parameters for readability and consistency pirms 7 gadiem
params.c Compute sk size after defining BDS k parameter pirms 7 gadiem
params.h Let xmss_core decide on secret key size pirms 7 gadiem
randombytes.c Refactor for more consistent style and readability pirms 7 gadiem
randombytes.h Perform various reformatting / renaming pirms 7 gadiem
wots.c Fix typo in WOTS comments: n-byte messages, not m pirms 7 gadiem
wots.h Fix typo in WOTS comments: n-byte messages, not m pirms 7 gadiem
xmss.c Revert to using runtime-only parameter struct pirms 7 gadiem
xmss.h Perform various reformatting / renaming pirms 7 gadiem
xmss_commons.c Clean up and simplify hash function definitions pirms 7 gadiem
xmss_commons.h Support messages that exceed the stack size pirms 7 gadiem
xmss_core.c Clean up and simplify hash function definitions pirms 7 gadiem
xmss_core.h Let xmss_core decide on secret key size pirms 7 gadiem
xmss_core_fast.c Make core_fast use the secret key for the state pirms 7 gadiem

README.md

XMSS reference code Build Status

This repository contains the reference implementation that accompanies the Internet Draft “XMSS: Extended Hash-Based Signatures”, draft-irtf-cfrg-xmss-hash-based-signatures.

This reference implementation supports all parameter sets as defined in the Draft 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.