| /* |
| * Copyright 2024 The OpenSSL Project Authors. All Rights Reserved. |
| * |
| * Licensed under the Apache License 2.0 (the "License"). You may not use |
| * this file except in compliance with the License. You can obtain a copy |
| * in the file LICENSE in the source distribution or at |
| * https://www.openssl.org/source/license.html |
| */ |
| |
| /* |
| * Internal LMS/LM_OTS functions for other submodules, |
| * not for application use |
| * |
| * Refer to RFC 8554 Sections 5.4 & 4.5 for information related to |
| * LMS Signatures & LM_OTS Signature Generation respectively. |
| */ |
| |
| #ifndef OSSL_CRYPTO_LMS_SIG_H |
| # define OSSL_CRYPTO_LMS_SIG_H |
| # pragma once |
| # ifndef OPENSSL_NO_LMS |
| # include "lms.h" |
| # include "internal/packet.h" |
| |
| /* The values defined for 8 byte TAGS */ |
| extern const uint16_t OSSL_LMS_D_PBLC; /* 8080 */ |
| extern const uint16_t OSSL_LMS_D_MESG; /* 8181 */ |
| extern const uint16_t OSSL_LMS_D_LEAF; /* 8282 */ |
| extern const uint16_t OSSL_LMS_D_INTR; /* 8383 */ |
| |
| /* Used by OTS signature when calculating Q || Cksm(Q) */ |
| # define LMS_SIZE_CHECKSUM 2 |
| # define LMS_SIZE_QSUM 2 |
| |
| /* |
| * An object for storing a One-Time Signature |
| * See RFC 8554 Section 4.5 |
| */ |
| typedef struct lm_ots_sig_st { |
| const LM_OTS_PARAMS *params; |
| /* For verify operations the following pointers are not allocated */ |
| unsigned char *C; /* A salt value of size n */ |
| unsigned char *y; /* The trailing part of a signature of size p * n */ |
| } LM_OTS_SIG; |
| |
| /* |
| * An object for storing a LMS signature |
| * See RFC 8554 Section 5.4 |
| */ |
| typedef struct lms_signature_st { |
| uint32_t q; |
| LM_OTS_SIG sig; |
| const LMS_PARAMS *params; /* contains the LMS type */ |
| unsigned char *paths; /* size is h * m */ |
| } LMS_SIG; |
| |
| LMS_SIG *ossl_lms_sig_new(void); |
| void ossl_lms_sig_free(LMS_SIG *sig); |
| LMS_SIG *ossl_lms_sig_from_pkt(PACKET *pkt, const LMS_KEY *pub); |
| int ossl_lms_sig_decode(LMS_SIG **out, LMS_KEY *pub, |
| const unsigned char *sig, size_t siglen); |
| int ossl_lms_sig_verify(const LMS_SIG *lms_sig, const LMS_KEY *pub, |
| const EVP_MD *md, |
| const unsigned char *msg, size_t msglen); |
| |
| int ossl_lm_ots_compute_pubkey(EVP_MD_CTX *ctx, EVP_MD_CTX *ctxIq, |
| const LM_OTS_SIG *sig, const LM_OTS_PARAMS *pub, |
| const unsigned char *Id, uint32_t q, |
| const unsigned char *msg, size_t msglen, |
| unsigned char *Kc); |
| uint16_t ossl_lm_ots_params_checksum(const LM_OTS_PARAMS *params, |
| const unsigned char *S); |
| |
| # endif /* OPENSSL_NO_LMS */ |
| #endif /* OSSL_CRYPTO_LMS_SIG_H */ |