Files
wolfssl/doc/dox_comments/header_files/chacha.h

100 lines
3.2 KiB
C
Raw Normal View History

/*!
\ingroup ChaCha
2018-06-27 16:22:12 -06:00
\brief This function sets the initialization vector (nonce) for a ChaCha
object, initializing it for use as a cipher. It should be called after the
key has been set, using wc_Chacha_SetKey. A difference nonce should be
used for each round of encryption.
2018-06-27 16:22:12 -06:00
\return 0 Returned upon successfully setting the initialization vector
2018-06-27 16:22:12 -06:00
\return BAD_FUNC_ARG returned if there is an error processing the ctx
input argument
2018-06-27 16:22:12 -06:00
\param ctx pointer to the ChaCha structure on which to set the iv
2018-06-27 16:22:12 -06:00
\param inIv pointer to a buffer containing the 12 byte initialization
vector with which to initialize the ChaCha structure
2018-06-27 16:22:12 -06:00
\param counter the value at which the block counter should start--usually
zero.
_Example_
\code
ChaCha enc;
// initialize enc with wc_Chacha_SetKey
byte iv[12];
2018-06-27 16:22:12 -06:00
// initialize iv
if( wc_Chacha_SetIV(&enc, iv, 0) != 0) {
// error initializing ChaCha structure
}
\endcode
2018-06-27 16:22:12 -06:00
\sa wc_Chacha_SetKey
\sa wc_Chacha_Process
*/
int wc_Chacha_SetIV(ChaCha* ctx, const byte* inIv, word32 counter);
/*!
\ingroup ChaCha
2018-06-27 16:22:12 -06:00
\brief This function processes the text from the buffer input, encrypts
or decrypts it, and stores the result in the buffer output.
2018-06-27 16:22:12 -06:00
\return 0 Returned upon successfully encrypting or decrypting the input
2018-06-27 16:22:12 -06:00
\return BAD_FUNC_ARG returned if there is an error processing the ctx
input argument
2018-06-27 16:22:12 -06:00
\param ctx pointer to the ChaCha structure on which to set the iv
2018-06-27 16:22:12 -06:00
\param output pointer to a buffer in which to store the output ciphertext
or decrypted plaintext
2018-06-27 16:22:12 -06:00
\param input pointer to the buffer containing the input plaintext to
encrypt or the input ciphertext to decrypt
\param msglen length of the message to encrypt or the ciphertext to decrypt
_Example_
\code
ChaCha enc;
// initialize enc with wc_Chacha_SetKey and wc_Chacha_SetIV
byte plain[] = { // initialize plaintext };
byte cipher[sizeof(plain)];
2018-06-27 16:22:12 -06:00
if( wc_Chacha_Process(&enc, cipher, plain, sizeof(plain)) != 0) {
// error processing ChaCha cipher
}
\endcode
2018-06-27 16:22:12 -06:00
\sa wc_Chacha_SetKey
\sa wc_Chacha_Process
*/
int wc_Chacha_Process(ChaCha* ctx, byte* cipher, const byte* plain,
word32 msglen);
/*!
\ingroup ChaCha
2018-06-27 16:22:12 -06:00
\brief This function sets the key for a ChaCha object, initializing it for
use as a cipher. It should be called before setting the nonce with
wc_Chacha_SetIV, and before using it for encryption with wc_Chacha_Process.
2018-06-27 16:22:12 -06:00
\return 0 Returned upon successfully setting the key
2018-06-27 16:22:12 -06:00
\return BAD_FUNC_ARG returned if there is an error processing the ctx
input argument or if the key is not 16 or 32 bytes long
2018-06-27 16:22:12 -06:00
\param ctx pointer to the ChaCha structure in which to set the key
2018-06-27 16:22:12 -06:00
\param key pointer to a buffer containing the 16 or 32 byte key with
which to initialize the ChaCha structure
\param keySz the length of the key passed in
2018-06-27 16:22:12 -06:00
_Example_
\code
ChaCha enc;
byte key[] = { // initialize key };
2018-06-27 16:22:12 -06:00
if( wc_Chacha_SetKey(&enc, key, sizeof(key)) != 0) {
// error initializing ChaCha structure
}
\endcode
2018-06-27 16:22:12 -06:00
\sa wc_Chacha_SetIV
\sa wc_Chacha_Process
*/
int wc_Chacha_SetKey(ChaCha* ctx, const byte* key, word32 keySz);