Blame include/openssl/fips_rand.h

Packit c4476c
/* ====================================================================
Packit c4476c
 * Copyright (c) 2003 The OpenSSL Project.  All rights reserved.
Packit c4476c
 *
Packit c4476c
 * Redistribution and use in source and binary forms, with or without
Packit c4476c
 * modification, are permitted provided that the following conditions
Packit c4476c
 * are met:
Packit c4476c
 *
Packit c4476c
 * 1. Redistributions of source code must retain the above copyright
Packit c4476c
 *    notice, this list of conditions and the following disclaimer. 
Packit c4476c
 *
Packit c4476c
 * 2. Redistributions in binary form must reproduce the above copyright
Packit c4476c
 *    notice, this list of conditions and the following disclaimer in
Packit c4476c
 *    the documentation and/or other materials provided with the
Packit c4476c
 *    distribution.
Packit c4476c
 *
Packit c4476c
 * 3. All advertising materials mentioning features or use of this
Packit c4476c
 *    software must display the following acknowledgment:
Packit c4476c
 *    "This product includes software developed by the OpenSSL Project
Packit c4476c
 *    for use in the OpenSSL Toolkit. (http://www.openssl.org/)"
Packit c4476c
 *
Packit c4476c
 * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
Packit c4476c
 *    endorse or promote products derived from this software without
Packit c4476c
 *    prior written permission. For written permission, please contact
Packit c4476c
 *    openssl-core@openssl.org.
Packit c4476c
 *
Packit c4476c
 * 5. Products derived from this software may not be called "OpenSSL"
Packit c4476c
 *    nor may "OpenSSL" appear in their names without prior written
Packit c4476c
 *    permission of the OpenSSL Project.
Packit c4476c
 *
Packit c4476c
 * 6. Redistributions of any form whatsoever must retain the following
Packit c4476c
 *    acknowledgment:
Packit c4476c
 *    "This product includes software developed by the OpenSSL Project
Packit c4476c
 *    for use in the OpenSSL Toolkit (http://www.openssl.org/)"
Packit c4476c
 *
Packit c4476c
 * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
Packit c4476c
 * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
Packit c4476c
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
Packit c4476c
 * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE OpenSSL PROJECT OR
Packit c4476c
 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
Packit c4476c
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
Packit c4476c
 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
Packit c4476c
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
Packit c4476c
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
Packit c4476c
 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
Packit c4476c
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
Packit c4476c
 * OF THE POSSIBILITY OF SUCH DAMAGE.
Packit c4476c
 *
Packit c4476c
 */
Packit c4476c
Packit c4476c
#ifndef HEADER_FIPS_RAND_H
Packit c4476c
# define HEADER_FIPS_RAND_H
Packit c4476c
Packit c4476c
# include <openssl/aes.h>
Packit c4476c
# include <openssl/evp.h>
Packit c4476c
# include <openssl/hmac.h>
Packit c4476c
# include <openssl/rand.h>
Packit c4476c
Packit c4476c
# ifdef OPENSSL_FIPS
Packit c4476c
Packit c4476c
#  ifdef  __cplusplus
Packit c4476c
extern "C" {
Packit c4476c
#  endif
Packit c4476c
Packit c4476c
/*
Packit c4476c
 * IMPORTANT NOTE:
Packit c4476c
 * All functions in this header file are deprecated and should not be used
Packit c4476c
 * as they use the old FIPS_drbg implementation that is not FIPS validated
Packit c4476c
 * anymore.
Packit c4476c
 * To provide backwards compatibility for applications that need FIPS compliant
Packit c4476c
 * RNG number generation and use FIPS_drbg_generate, this function was
Packit c4476c
 * re-wired to call the FIPS validated DRBG instance instead through
Packit c4476c
 * the RAND_bytes() call.
Packit c4476c
 *
Packit c4476c
 * All these functions will be removed in future.
Packit c4476c
 */
Packit c4476c
Packit c4476c
    typedef struct drbg_ctx_st DRBG_CTX;
Packit c4476c
/* DRBG external flags */
Packit c4476c
/* Flag for CTR mode only: use derivation function ctr_df */
Packit c4476c
#  define DRBG_FLAG_CTR_USE_DF            0x1
Packit c4476c
/* PRNG is in test state */
Packit c4476c
#  define DRBG_FLAG_TEST                  0x2
Packit c4476c
Packit c4476c
    DRBG_CTX *FIPS_drbg_new(int type, unsigned int flags);
Packit c4476c
    int FIPS_drbg_init(DRBG_CTX *dctx, int type, unsigned int flags);
Packit c4476c
    int FIPS_drbg_instantiate(DRBG_CTX *dctx,
Packit c4476c
                              const unsigned char *pers, size_t perslen);
Packit c4476c
    int FIPS_drbg_reseed(DRBG_CTX *dctx, const unsigned char *adin,
Packit c4476c
                         size_t adinlen);
Packit c4476c
    int FIPS_drbg_generate(DRBG_CTX *dctx, unsigned char *out, size_t outlen,
Packit c4476c
                           int prediction_resistance,
Packit c4476c
                           const unsigned char *adin, size_t adinlen);
Packit c4476c
Packit c4476c
    int FIPS_drbg_uninstantiate(DRBG_CTX *dctx);
Packit c4476c
    void FIPS_drbg_free(DRBG_CTX *dctx);
Packit c4476c
Packit c4476c
    int FIPS_drbg_set_callbacks(DRBG_CTX *dctx,
Packit c4476c
                                size_t (*get_entropy) (DRBG_CTX *ctx,
Packit c4476c
                                                       unsigned char **pout,
Packit c4476c
                                                       int entropy,
Packit c4476c
                                                       size_t min_len,
Packit c4476c
                                                       size_t max_len),
Packit c4476c
                                void (*cleanup_entropy) (DRBG_CTX *ctx,
Packit c4476c
                                                         unsigned char *out,
Packit c4476c
                                                         size_t olen),
Packit c4476c
                                size_t entropy_blocklen,
Packit c4476c
                                size_t (*get_nonce) (DRBG_CTX *ctx,
Packit c4476c
                                                     unsigned char **pout,
Packit c4476c
                                                     int entropy,
Packit c4476c
                                                     size_t min_len,
Packit c4476c
                                                     size_t max_len),
Packit c4476c
                                void (*cleanup_nonce) (DRBG_CTX *ctx,
Packit c4476c
                                                       unsigned char *out,
Packit c4476c
                                                       size_t olen));
Packit c4476c
Packit c4476c
    int FIPS_drbg_set_rand_callbacks(DRBG_CTX *dctx,
Packit c4476c
                                     size_t (*get_adin) (DRBG_CTX *ctx,
Packit c4476c
                                                         unsigned char
Packit c4476c
                                                         **pout),
Packit c4476c
                                     void (*cleanup_adin) (DRBG_CTX *ctx,
Packit c4476c
                                                           unsigned char *out,
Packit c4476c
                                                           size_t olen),
Packit c4476c
                                     int (*rand_seed_cb) (DRBG_CTX *ctx,
Packit c4476c
                                                          const void *buf,
Packit c4476c
                                                          int num),
Packit c4476c
                                     int (*rand_add_cb) (DRBG_CTX *ctx,
Packit c4476c
                                                         const void *buf,
Packit c4476c
                                                         int num,
Packit c4476c
                                                         double entropy));
Packit c4476c
Packit c4476c
    void *FIPS_drbg_get_app_data(DRBG_CTX *ctx);
Packit c4476c
    void FIPS_drbg_set_app_data(DRBG_CTX *ctx, void *app_data);
Packit c4476c
    size_t FIPS_drbg_get_blocklength(DRBG_CTX *dctx);
Packit c4476c
    int FIPS_drbg_get_strength(DRBG_CTX *dctx);
Packit c4476c
    void FIPS_drbg_set_check_interval(DRBG_CTX *dctx, int interval);
Packit c4476c
    void FIPS_drbg_set_reseed_interval(DRBG_CTX *dctx, int interval);
Packit c4476c
Packit c4476c
    int FIPS_drbg_health_check(DRBG_CTX *dctx);
Packit c4476c
Packit c4476c
    DRBG_CTX *FIPS_get_default_drbg(void);
Packit c4476c
    const RAND_METHOD *FIPS_drbg_method(void);
Packit c4476c
Packit c4476c
    int FIPS_rand_set_method(const RAND_METHOD *meth);
Packit c4476c
    const RAND_METHOD *FIPS_rand_get_method(void);
Packit c4476c
Packit c4476c
    void FIPS_rand_set_bits(int nbits);
Packit c4476c
Packit c4476c
    int FIPS_rand_strength(void);
Packit c4476c
Packit c4476c
/* 1.0.0 compat functions */
Packit c4476c
    int FIPS_rand_seed(const void *buf, int num);
Packit c4476c
    int FIPS_rand_bytes(unsigned char *out, int outlen);
Packit c4476c
    void FIPS_rand_reset(void);
Packit c4476c
    int FIPS_rand_status(void);
Packit c4476c
#  ifdef  __cplusplus
Packit c4476c
}
Packit c4476c
#  endif
Packit c4476c
# endif
Packit c4476c
#endif