NAME
EVP_rc2_cbc
,
EVP_rc2_ecb
, EVP_rc2_cfb64
,
EVP_rc2_cfb
, EVP_rc2_ofb
,
EVP_rc2_40_cbc
,
EVP_rc2_64_cbc
—
Rivest Cipher 2 in the EVP
framework
SYNOPSIS
#include
<openssl/evp.h>
const EVP_CIPHER *
EVP_rc2_cbc
(void);
const EVP_CIPHER *
EVP_rc2_ecb
(void);
const EVP_CIPHER *
EVP_rc2_cfb64
(void);
const EVP_CIPHER *
EVP_rc2_cfb
(void);
const EVP_CIPHER *
EVP_rc2_ofb
(void);
const EVP_CIPHER *
EVP_rc2_40_cbc
(void);
const EVP_CIPHER *
EVP_rc2_64_cbc
(void);
#include
<openssl/rc2.h>
#define RC2_BLOCK 8
#define RC2_KEY_LENGTH 16
DESCRIPTION
RC2 is a block cipher operating on blocks of
RC2_BLOCK
= 8 bytes,
equivalent to 64 bits, using a variable key length
with an additional parameter called “effective key bits” or
“effective key length”.
EVP_rc2_cbc
(),
EVP_rc2_ecb
(),
EVP_rc2_cfb64
(),
and
EVP_rc2_ofb
()
provide the RC2 encryption algorithm in CBC, ECB, CFB and OFB mode,
respectively.
EVP_rc2_cfb
()
is an alias for EVP_rc2_cfb64
(), implemented as a
macro.
By default, these functions set both the key length and the
effective key length to RC2_KEY_LENGTH
= 16 bytes, which is not a very useful value because
it is quite short.
Configuring normally requires a multi-step process:
- Create a new, empty EVP_CIPHER_CTX object with EVP_CIPHER_CTX_new(3).
- Select the operation mode by calling
EVP_EncryptInit(3) with the desired
type argument, passing
NULL
pointers for the key and iv arguments. - Select the key length by passing the desired number
of bytes to
EVP_CIPHER_CTX_set_key_length(3). Doing so overrides the
default key length of
RC2_KEY_LENGTH
= 16. Valid values for keylen are positive and less than or equal to 128. - Select the effective key length by calling
EVP_CIPHER_CTX_ctrl(3) with a type
argument of
EVP_CTRL_SET_RC2_KEY_BITS
, passing the desired number of bits in arg. Doing so overrides the default effective key length of 128 bits. Valid values for arg are positive and less than or equal to 1024. The ptr argument is ignored; passingNULL
is recommended. - Call EVP_EncryptInit(3) a second time, this time passing
NULL
for the type argument. The key argument points to an array containing the number of bytes that was passed to EVP_CIPHER_CTX_set_key_length(3), and the iv argument points to an array of eight bytes. - Finally, EVP_EncryptUpdate(3) and EVP_EncryptFinal(3) can be used in the normal way.
Once a ctx object is fully configured,
calling
EVP_CIPHER_CTX_ctrl(3) with a type
argument of EVP_CTRL_GET_RC2_KEY_BITS
interprets
ptr as a pointer to int and
stores the effective key length in bits at that location. In this case,
arg is ignored and passing 0 is recommended.
In the CFB and OFB modes, the minimum required total length in bytes of the output buffer is equal to the total number of input bytes to be encoded. In the CBC and ECB modes, the minimum required total length of the output buffer has to be rounded up to the next multiple of the block size of eight bytes.
EVP_rc2_40_cbc
()
and
EVP_rc2_64_cbc
()
are obsolete functions that provide the RC2 algorithm in CBC mode with a key
length and an effective key length of 40 and 64 bits, respectively.
RETURN VALUES
With the EVP_CIPHER objects documented in
the present manual page, EVP_CIPHER_CTX_ctrl
()
returns 1 for success or 0 if an error occurs.
SEE ALSO
evp(3), EVP_CIPHER_CTX_set_key_length(3), EVP_EncryptInit(3), RC2_encrypt(3)
HISTORY
EVP_rc2_cbc
(),
EVP_rc2_ecb
(),
EVP_rc2_cfb
(), and
EVP_rc2_ofb
() first appeared in SSLeay 0.5.2 and
have been available since OpenBSD 2.4.
EVP_rc2_40_cbc
() and
EVP_rc2_64_cbc
() first appeared in SSLeay 0.9.1 and
have been available since OpenBSD 2.6.
EVP_rc2_cfb64
() first appeared in OpenSSL
0.9.7e and has been available since OpenBSD 3.8.