/* $OpenBSD: xmss_hash_address.c,v 1.2 2018/02/26 03:56:44 dtucker Exp $ */ /* hash_address.c version 20160722 Andreas Hülsing Joost Rijneveld Public domain. */ #include "includes.h" #ifdef WITH_XMSS #ifdef HAVE_STDINT_H #include <stdint.h> #endif #include "xmss_hash_address.h" /* prototypes */ void setLayerADRS(uint32_t adrs[8], uint32_t layer){ adrs[0] = layer; } void setTreeADRS(uint32_t adrs[8], uint64_t tree){ adrs[1] = (uint32_t) (tree >> 32); adrs[2] = (uint32_t) tree; } void setType(uint32_t adrs[8], uint32_t type){ adrs[3] = type; int i; for(i = 4; i < 8; i++){ adrs[i] = 0; } } void setKeyAndMask(uint32_t adrs[8], uint32_t keyAndMask){ adrs[7] = keyAndMask; } // OTS void setOTSADRS(uint32_t adrs[8], uint32_t ots){ adrs[4] = ots; } void setChainADRS(uint32_t adrs[8], uint32_t chain){ adrs[5] = chain; } void setHashADRS(uint32_t adrs[8], uint32_t hash){ adrs[6] = hash; } // L-tree void setLtreeADRS(uint32_t adrs[8], uint32_t ltree){ adrs[4] = ltree; } // Hash Tree & L-tree void setTreeHeight(uint32_t adrs[8], uint32_t treeHeight){ adrs[5] = treeHeight; } void setTreeIndex(uint32_t adrs[8], uint32_t treeIndex){ adrs[6] = treeIndex; } #endif /* WITH_XMSS */ |