mirror of https://github.com/openssl/openssl.git
76 lines
2.6 KiB
C
76 lines
2.6 KiB
C
|
/*
|
||
|
* Copyright 2025 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 */
|