2019-05-27 09:55:01 +03:00
/* SPDX-License-Identifier: GPL-2.0-or-later */
2016-06-22 19:49:15 +03:00
/*
* ECDH params to be used with kpp API
*
* Copyright ( c ) 2016 , Intel Corporation
* Authors : Salvatore Benedetto < salvatore . benedetto @ intel . com >
*/
# ifndef _CRYPTO_ECDH_
# define _CRYPTO_ECDH_
2016-10-21 05:58:20 +03:00
/**
* DOC : ECDH Helper Functions
*
* To use ECDH with the KPP cipher API , the following data structure and
* functions should be used .
*
* The ECC curves known to the ECDH implementation are specified in this
* header file .
*
* To use ECDH with KPP , the following functions should be used to operate on
* an ECDH private key . The packet private key that can be set with
* the KPP API function call of crypto_kpp_set_secret .
*/
2016-06-22 19:49:15 +03:00
/* Curves IDs */
# define ECC_CURVE_NIST_P192 0x0001
# define ECC_CURVE_NIST_P256 0x0002
2016-10-21 05:58:20 +03:00
/**
* struct ecdh - define an ECDH private key
*
* @ curve_id : ECC curve the key is based on .
* @ key : Private ECDH key
* @ key_size : Size of the private ECDH key
*/
2016-06-22 19:49:15 +03:00
struct ecdh {
unsigned short curve_id ;
char * key ;
unsigned short key_size ;
} ;
2016-10-21 05:58:20 +03:00
/**
* crypto_ecdh_key_len ( ) - Obtain the size of the private ECDH key
* @ params : private ECDH key
*
* This function returns the packet ECDH key size . A caller can use that
* with the provided ECDH private key reference to obtain the required
* memory size to hold a packet key .
*
* Return : size of the key in bytes
*/
2017-09-29 12:13:08 +03:00
unsigned int crypto_ecdh_key_len ( const struct ecdh * params ) ;
2016-10-21 05:58:20 +03:00
/**
* crypto_ecdh_encode_key ( ) - encode the private key
* @ buf : Buffer allocated by the caller to hold the packet ECDH
* private key . The buffer should be at least crypto_ecdh_key_len
* bytes in size .
* @ len : Length of the packet private key buffer
* @ p : Buffer with the caller - specified private key
*
* The ECDH implementations operate on a packet representation of the private
* key .
*
* Return : - EINVAL if buffer has insufficient size , 0 on success
*/
2016-06-22 19:49:15 +03:00
int crypto_ecdh_encode_key ( char * buf , unsigned int len , const struct ecdh * p ) ;
2016-10-21 05:58:20 +03:00
/**
* crypto_ecdh_decode_key ( ) - decode a private key
* @ buf : Buffer holding a packet key that should be decoded
2017-05-25 10:18:03 +03:00
* @ len : Length of the packet private key buffer
2016-10-21 05:58:20 +03:00
* @ p : Buffer allocated by the caller that is filled with the
2017-05-25 10:18:03 +03:00
* unpacked ECDH private key .
2016-10-21 05:58:20 +03:00
*
* The unpacking obtains the private key by pointing @ p to the correct location
* in @ buf . Thus , both pointers refer to the same memory .
*
* Return : - EINVAL if buffer has insufficient size , 0 on success
*/
2016-06-22 19:49:15 +03:00
int crypto_ecdh_decode_key ( const char * buf , unsigned int len , struct ecdh * p ) ;
# endif