|  | MCUXpresso SDK API Reference Manual
    Rev 2.16.100
    NXP Semiconductors | 
This section describes the programming interface of the CAAM Non-blocking DES driver.
| Functions | |
| status_t | CAAM_DES_EncryptEcbNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *plaintext, uint8_t *ciphertext, size_t size, const uint8_t key[CAAM_DES_KEY_SIZE]) | 
| Encrypts DES using ECB block mode.  More... | |
| status_t | CAAM_DES_DecryptEcbNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *ciphertext, uint8_t *plaintext, size_t size, const uint8_t key[CAAM_DES_KEY_SIZE]) | 
| Decrypts DES using ECB block mode.  More... | |
| status_t | CAAM_DES_EncryptCbcNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *plaintext, uint8_t *ciphertext, size_t size, const uint8_t iv[CAAM_DES_IV_SIZE], const uint8_t key[CAAM_DES_KEY_SIZE]) | 
| Encrypts DES using CBC block mode.  More... | |
| status_t | CAAM_DES_DecryptCbcNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *ciphertext, uint8_t *plaintext, size_t size, const uint8_t iv[CAAM_DES_IV_SIZE], const uint8_t key[CAAM_DES_KEY_SIZE]) | 
| Decrypts DES using CBC block mode.  More... | |
| status_t | CAAM_DES_EncryptCfbNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *plaintext, uint8_t *ciphertext, size_t size, const uint8_t iv[CAAM_DES_IV_SIZE], const uint8_t key[CAAM_DES_KEY_SIZE]) | 
| Encrypts DES using CFB block mode.  More... | |
| status_t | CAAM_DES_DecryptCfbNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *ciphertext, uint8_t *plaintext, size_t size, const uint8_t iv[CAAM_DES_IV_SIZE], const uint8_t key[CAAM_DES_KEY_SIZE]) | 
| Decrypts DES using CFB block mode.  More... | |
| status_t | CAAM_DES_EncryptOfbNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *plaintext, uint8_t *ciphertext, size_t size, const uint8_t iv[CAAM_DES_IV_SIZE], const uint8_t key[CAAM_DES_KEY_SIZE]) | 
| Encrypts DES using OFB block mode.  More... | |
| status_t | CAAM_DES_DecryptOfbNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *ciphertext, uint8_t *plaintext, size_t size, const uint8_t iv[CAAM_DES_IV_SIZE], const uint8_t key[CAAM_DES_KEY_SIZE]) | 
| Decrypts DES using OFB block mode.  More... | |
| status_t | CAAM_DES2_EncryptEcbNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *plaintext, uint8_t *ciphertext, size_t size, const uint8_t key1[CAAM_DES_KEY_SIZE], const uint8_t key2[CAAM_DES_KEY_SIZE]) | 
| Encrypts triple DES using ECB block mode with two keys.  More... | |
| status_t | CAAM_DES2_DecryptEcbNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *ciphertext, uint8_t *plaintext, size_t size, const uint8_t key1[CAAM_DES_KEY_SIZE], const uint8_t key2[CAAM_DES_KEY_SIZE]) | 
| Decrypts triple DES using ECB block mode with two keys.  More... | |
| status_t | CAAM_DES2_EncryptCbcNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *plaintext, uint8_t *ciphertext, size_t size, const uint8_t iv[CAAM_DES_IV_SIZE], const uint8_t key1[CAAM_DES_KEY_SIZE], const uint8_t key2[CAAM_DES_KEY_SIZE]) | 
| Encrypts triple DES using CBC block mode with two keys.  More... | |
| status_t | CAAM_DES2_DecryptCbcNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *ciphertext, uint8_t *plaintext, size_t size, const uint8_t iv[CAAM_DES_IV_SIZE], const uint8_t key1[CAAM_DES_KEY_SIZE], const uint8_t key2[CAAM_DES_KEY_SIZE]) | 
| Decrypts triple DES using CBC block mode with two keys.  More... | |
| status_t | CAAM_DES2_EncryptCfbNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *plaintext, uint8_t *ciphertext, size_t size, const uint8_t iv[CAAM_DES_IV_SIZE], const uint8_t key1[CAAM_DES_KEY_SIZE], const uint8_t key2[CAAM_DES_KEY_SIZE]) | 
| Encrypts triple DES using CFB block mode with two keys.  More... | |
| status_t | CAAM_DES2_DecryptCfbNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *ciphertext, uint8_t *plaintext, size_t size, const uint8_t iv[CAAM_DES_IV_SIZE], const uint8_t key1[CAAM_DES_KEY_SIZE], const uint8_t key2[CAAM_DES_KEY_SIZE]) | 
| Decrypts triple DES using CFB block mode with two keys.  More... | |
| status_t | CAAM_DES2_EncryptOfbNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *plaintext, uint8_t *ciphertext, size_t size, const uint8_t iv[CAAM_DES_IV_SIZE], const uint8_t key1[CAAM_DES_KEY_SIZE], const uint8_t key2[CAAM_DES_KEY_SIZE]) | 
| Encrypts triple DES using OFB block mode with two keys.  More... | |
| status_t | CAAM_DES2_DecryptOfbNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *ciphertext, uint8_t *plaintext, size_t size, const uint8_t iv[CAAM_DES_IV_SIZE], const uint8_t key1[CAAM_DES_KEY_SIZE], const uint8_t key2[CAAM_DES_KEY_SIZE]) | 
| Decrypts triple DES using OFB block mode with two keys.  More... | |
| status_t | CAAM_DES3_EncryptEcbNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *plaintext, uint8_t *ciphertext, size_t size, const uint8_t key1[CAAM_DES_KEY_SIZE], const uint8_t key2[CAAM_DES_KEY_SIZE], const uint8_t key3[CAAM_DES_KEY_SIZE]) | 
| Encrypts triple DES using ECB block mode with three keys.  More... | |
| status_t | CAAM_DES3_DecryptEcbNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *ciphertext, uint8_t *plaintext, size_t size, const uint8_t key1[CAAM_DES_KEY_SIZE], const uint8_t key2[CAAM_DES_KEY_SIZE], const uint8_t key3[CAAM_DES_KEY_SIZE]) | 
| Decrypts triple DES using ECB block mode with three keys.  More... | |
| status_t | CAAM_DES3_EncryptCbcNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *plaintext, uint8_t *ciphertext, size_t size, const uint8_t iv[CAAM_DES_IV_SIZE], const uint8_t key1[CAAM_DES_KEY_SIZE], const uint8_t key2[CAAM_DES_KEY_SIZE], const uint8_t key3[CAAM_DES_KEY_SIZE]) | 
| Encrypts triple DES using CBC block mode with three keys.  More... | |
| status_t | CAAM_DES3_DecryptCbcNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *ciphertext, uint8_t *plaintext, size_t size, const uint8_t iv[CAAM_DES_IV_SIZE], const uint8_t key1[CAAM_DES_KEY_SIZE], const uint8_t key2[CAAM_DES_KEY_SIZE], const uint8_t key3[CAAM_DES_KEY_SIZE]) | 
| Decrypts triple DES using CBC block mode with three keys.  More... | |
| status_t | CAAM_DES3_EncryptCfbNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *plaintext, uint8_t *ciphertext, size_t size, const uint8_t iv[CAAM_DES_IV_SIZE], const uint8_t key1[CAAM_DES_KEY_SIZE], const uint8_t key2[CAAM_DES_KEY_SIZE], const uint8_t key3[CAAM_DES_KEY_SIZE]) | 
| Encrypts triple DES using CFB block mode with three keys.  More... | |
| status_t | CAAM_DES3_DecryptCfbNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *ciphertext, uint8_t *plaintext, size_t size, const uint8_t iv[CAAM_DES_IV_SIZE], const uint8_t key1[CAAM_DES_KEY_SIZE], const uint8_t key2[CAAM_DES_KEY_SIZE], const uint8_t key3[CAAM_DES_KEY_SIZE]) | 
| Decrypts triple DES using CFB block mode with three keys.  More... | |
| status_t | CAAM_DES3_EncryptOfbNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *plaintext, uint8_t *ciphertext, size_t size, const uint8_t iv[CAAM_DES_IV_SIZE], const uint8_t key1[CAAM_DES_KEY_SIZE], const uint8_t key2[CAAM_DES_KEY_SIZE], const uint8_t key3[CAAM_DES_KEY_SIZE]) | 
| Encrypts triple DES using OFB block mode with three keys.  More... | |
| status_t | CAAM_DES3_DecryptOfbNonBlocking (CAAM_Type *base, caam_handle_t *handle, caam_desc_cipher_des_t descriptor, const uint8_t *ciphertext, uint8_t *plaintext, size_t size, const uint8_t iv[CAAM_DES_IV_SIZE], const uint8_t key1[CAAM_DES_KEY_SIZE], const uint8_t key2[CAAM_DES_KEY_SIZE], const uint8_t key3[CAAM_DES_KEY_SIZE]) | 
| Decrypts triple DES using OFB block mode with three keys.  More... | |
| status_t CAAM_DES_EncryptEcbNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | plaintext, | ||
| uint8_t * | ciphertext, | ||
| size_t | size, | ||
| const uint8_t | key[CAAM_DES_KEY_SIZE] | ||
| ) | 
Encrypts DES using ECB block mode.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| plaintext | Input plaintext to encrypt | |
| [out] | ciphertext | Output ciphertext | 
| size | Size of input and output data in bytes. Must be multiple of 8 bytes. | |
| key | Input key to use for encryption | 
| status_t CAAM_DES_DecryptEcbNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | ciphertext, | ||
| uint8_t * | plaintext, | ||
| size_t | size, | ||
| const uint8_t | key[CAAM_DES_KEY_SIZE] | ||
| ) | 
Decrypts DES using ECB block mode.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| ciphertext | Input ciphertext to decrypt | |
| [out] | plaintext | Output plaintext | 
| size | Size of input and output data in bytes. Must be multiple of 8 bytes. | |
| key | Input key to use for decryption | 
| status_t CAAM_DES_EncryptCbcNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | plaintext, | ||
| uint8_t * | ciphertext, | ||
| size_t | size, | ||
| const uint8_t | iv[CAAM_DES_IV_SIZE], | ||
| const uint8_t | key[CAAM_DES_KEY_SIZE] | ||
| ) | 
Encrypts DES using CBC block mode.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| plaintext | Input plaintext to encrypt | |
| [out] | ciphertext | Ouput ciphertext | 
| size | Size of input and output data in bytes | |
| iv | Input initial vector to combine with the first plaintext block. The iv does not need to be secret, but it must be unpredictable. | |
| key | Input key to use for encryption | 
| status_t CAAM_DES_DecryptCbcNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | ciphertext, | ||
| uint8_t * | plaintext, | ||
| size_t | size, | ||
| const uint8_t | iv[CAAM_DES_IV_SIZE], | ||
| const uint8_t | key[CAAM_DES_KEY_SIZE] | ||
| ) | 
Decrypts DES using CBC block mode.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| ciphertext | Input ciphertext to decrypt | |
| [out] | plaintext | Output plaintext | 
| size | Size of input data in bytes | |
| iv | Input initial vector to combine with the first plaintext block. The iv does not need to be secret, but it must be unpredictable. | |
| key | Input key to use for decryption | 
| status_t CAAM_DES_EncryptCfbNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | plaintext, | ||
| uint8_t * | ciphertext, | ||
| size_t | size, | ||
| const uint8_t | iv[CAAM_DES_IV_SIZE], | ||
| const uint8_t | key[CAAM_DES_KEY_SIZE] | ||
| ) | 
Encrypts DES using CFB block mode.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| plaintext | Input plaintext to encrypt | |
| size | Size of input data in bytes | |
| iv | Input initial block. | |
| key | Input key to use for encryption | |
| [out] | ciphertext | Output ciphertext | 
| status_t CAAM_DES_DecryptCfbNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | ciphertext, | ||
| uint8_t * | plaintext, | ||
| size_t | size, | ||
| const uint8_t | iv[CAAM_DES_IV_SIZE], | ||
| const uint8_t | key[CAAM_DES_KEY_SIZE] | ||
| ) | 
Decrypts DES using CFB block mode.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| ciphertext | Input ciphertext to decrypt | |
| [out] | plaintext | Output plaintext | 
| size | Size of input and output data in bytes | |
| iv | Input initial block. | |
| key | Input key to use for decryption | 
| status_t CAAM_DES_EncryptOfbNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | plaintext, | ||
| uint8_t * | ciphertext, | ||
| size_t | size, | ||
| const uint8_t | iv[CAAM_DES_IV_SIZE], | ||
| const uint8_t | key[CAAM_DES_KEY_SIZE] | ||
| ) | 
Encrypts DES using OFB block mode.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| plaintext | Input plaintext to encrypt | |
| [out] | ciphertext | Output ciphertext | 
| size | Size of input and output data in bytes | |
| iv | Input unique input vector. The OFB mode requires that the IV be unique for each execution of the mode under the given key. | |
| key | Input key to use for encryption | 
| status_t CAAM_DES_DecryptOfbNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | ciphertext, | ||
| uint8_t * | plaintext, | ||
| size_t | size, | ||
| const uint8_t | iv[CAAM_DES_IV_SIZE], | ||
| const uint8_t | key[CAAM_DES_KEY_SIZE] | ||
| ) | 
Decrypts DES using OFB block mode.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| ciphertext | Input ciphertext to decrypt | |
| [out] | plaintext | Output plaintext | 
| size | Size of input and output data in bytes. Must be multiple of 8 bytes. | |
| iv | Input unique input vector. The OFB mode requires that the IV be unique for each execution of the mode under the given key. | |
| key | Input key to use for decryption | 
| status_t CAAM_DES2_EncryptEcbNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | plaintext, | ||
| uint8_t * | ciphertext, | ||
| size_t | size, | ||
| const uint8_t | key1[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key2[CAAM_DES_KEY_SIZE] | ||
| ) | 
Encrypts triple DES using ECB block mode with two keys.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| plaintext | Input plaintext to encrypt | |
| [out] | ciphertext | Output ciphertext | 
| size | Size of input and output data in bytes. Must be multiple of 8 bytes. | |
| key1 | First input key for key bundle | |
| key2 | Second input key for key bundle | 
| status_t CAAM_DES2_DecryptEcbNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | ciphertext, | ||
| uint8_t * | plaintext, | ||
| size_t | size, | ||
| const uint8_t | key1[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key2[CAAM_DES_KEY_SIZE] | ||
| ) | 
Decrypts triple DES using ECB block mode with two keys.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| ciphertext | Input ciphertext to decrypt | |
| [out] | plaintext | Output plaintext | 
| size | Size of input and output data in bytes. Must be multiple of 8 bytes. | |
| key1 | First input key for key bundle | |
| key2 | Second input key for key bundle | 
| status_t CAAM_DES2_EncryptCbcNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | plaintext, | ||
| uint8_t * | ciphertext, | ||
| size_t | size, | ||
| const uint8_t | iv[CAAM_DES_IV_SIZE], | ||
| const uint8_t | key1[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key2[CAAM_DES_KEY_SIZE] | ||
| ) | 
Encrypts triple DES using CBC block mode with two keys.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| plaintext | Input plaintext to encrypt | |
| [out] | ciphertext | Output ciphertext | 
| size | Size of input and output data in bytes | |
| iv | Input initial vector to combine with the first plaintext block. The iv does not need to be secret, but it must be unpredictable. | |
| key1 | First input key for key bundle | |
| key2 | Second input key for key bundle | 
| status_t CAAM_DES2_DecryptCbcNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | ciphertext, | ||
| uint8_t * | plaintext, | ||
| size_t | size, | ||
| const uint8_t | iv[CAAM_DES_IV_SIZE], | ||
| const uint8_t | key1[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key2[CAAM_DES_KEY_SIZE] | ||
| ) | 
Decrypts triple DES using CBC block mode with two keys.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| ciphertext | Input ciphertext to decrypt | |
| [out] | plaintext | Output plaintext | 
| size | Size of input and output data in bytes | |
| iv | Input initial vector to combine with the first plaintext block. The iv does not need to be secret, but it must be unpredictable. | |
| key1 | First input key for key bundle | |
| key2 | Second input key for key bundle | 
| status_t CAAM_DES2_EncryptCfbNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | plaintext, | ||
| uint8_t * | ciphertext, | ||
| size_t | size, | ||
| const uint8_t | iv[CAAM_DES_IV_SIZE], | ||
| const uint8_t | key1[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key2[CAAM_DES_KEY_SIZE] | ||
| ) | 
Encrypts triple DES using CFB block mode with two keys.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| plaintext | Input plaintext to encrypt | |
| [out] | ciphertext | Output ciphertext | 
| size | Size of input and output data in bytes | |
| iv | Input initial block. | |
| key1 | First input key for key bundle | |
| key2 | Second input key for key bundle | 
| status_t CAAM_DES2_DecryptCfbNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | ciphertext, | ||
| uint8_t * | plaintext, | ||
| size_t | size, | ||
| const uint8_t | iv[CAAM_DES_IV_SIZE], | ||
| const uint8_t | key1[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key2[CAAM_DES_KEY_SIZE] | ||
| ) | 
Decrypts triple DES using CFB block mode with two keys.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| ciphertext | Input ciphertext to decrypt | |
| [out] | plaintext | Output plaintext | 
| size | Size of input and output data in bytes | |
| iv | Input initial block. | |
| key1 | First input key for key bundle | |
| key2 | Second input key for key bundle | 
| status_t CAAM_DES2_EncryptOfbNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | plaintext, | ||
| uint8_t * | ciphertext, | ||
| size_t | size, | ||
| const uint8_t | iv[CAAM_DES_IV_SIZE], | ||
| const uint8_t | key1[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key2[CAAM_DES_KEY_SIZE] | ||
| ) | 
Encrypts triple DES using OFB block mode with two keys.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| plaintext | Input plaintext to encrypt | |
| [out] | ciphertext | Output ciphertext | 
| size | Size of input and output data in bytes | |
| iv | Input unique input vector. The OFB mode requires that the IV be unique for each execution of the mode under the given key. | |
| key1 | First input key for key bundle | |
| key2 | Second input key for key bundle | 
| status_t CAAM_DES2_DecryptOfbNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | ciphertext, | ||
| uint8_t * | plaintext, | ||
| size_t | size, | ||
| const uint8_t | iv[CAAM_DES_IV_SIZE], | ||
| const uint8_t | key1[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key2[CAAM_DES_KEY_SIZE] | ||
| ) | 
Decrypts triple DES using OFB block mode with two keys.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| ciphertext | Input ciphertext to decrypt | |
| [out] | plaintext | Output plaintext | 
| size | Size of input and output data in bytes | |
| iv | Input unique input vector. The OFB mode requires that the IV be unique for each execution of the mode under the given key. | |
| key1 | First input key for key bundle | |
| key2 | Second input key for key bundle | 
| status_t CAAM_DES3_EncryptEcbNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | plaintext, | ||
| uint8_t * | ciphertext, | ||
| size_t | size, | ||
| const uint8_t | key1[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key2[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key3[CAAM_DES_KEY_SIZE] | ||
| ) | 
Encrypts triple DES using ECB block mode with three keys.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| plaintext | Input plaintext to encrypt | |
| [out] | ciphertext | Output ciphertext | 
| size | Size of input and output data in bytes. Must be multiple of 8 bytes. | |
| key1 | First input key for key bundle | |
| key2 | Second input key for key bundle | |
| key3 | Third input key for key bundle | 
| status_t CAAM_DES3_DecryptEcbNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | ciphertext, | ||
| uint8_t * | plaintext, | ||
| size_t | size, | ||
| const uint8_t | key1[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key2[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key3[CAAM_DES_KEY_SIZE] | ||
| ) | 
Decrypts triple DES using ECB block mode with three keys.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| ciphertext | Input ciphertext to decrypt | |
| [out] | plaintext | Output plaintext | 
| size | Size of input and output data in bytes. Must be multiple of 8 bytes. | |
| key1 | First input key for key bundle | |
| key2 | Second input key for key bundle | |
| key3 | Third input key for key bundle | 
| status_t CAAM_DES3_EncryptCbcNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | plaintext, | ||
| uint8_t * | ciphertext, | ||
| size_t | size, | ||
| const uint8_t | iv[CAAM_DES_IV_SIZE], | ||
| const uint8_t | key1[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key2[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key3[CAAM_DES_KEY_SIZE] | ||
| ) | 
Encrypts triple DES using CBC block mode with three keys.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| plaintext | Input plaintext to encrypt | |
| [out] | ciphertext | Output ciphertext | 
| size | Size of input data in bytes | |
| iv | Input initial vector to combine with the first plaintext block. The iv does not need to be secret, but it must be unpredictable. | |
| key1 | First input key for key bundle | |
| key2 | Second input key for key bundle | |
| key3 | Third input key for key bundle | 
| status_t CAAM_DES3_DecryptCbcNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | ciphertext, | ||
| uint8_t * | plaintext, | ||
| size_t | size, | ||
| const uint8_t | iv[CAAM_DES_IV_SIZE], | ||
| const uint8_t | key1[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key2[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key3[CAAM_DES_KEY_SIZE] | ||
| ) | 
Decrypts triple DES using CBC block mode with three keys.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| ciphertext | Input ciphertext to decrypt | |
| [out] | plaintext | Output plaintext | 
| size | Size of input and output data in bytes | |
| iv | Input initial vector to combine with the first plaintext block. The iv does not need to be secret, but it must be unpredictable. | |
| key1 | First input key for key bundle | |
| key2 | Second input key for key bundle | |
| key3 | Third input key for key bundle | 
| status_t CAAM_DES3_EncryptCfbNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | plaintext, | ||
| uint8_t * | ciphertext, | ||
| size_t | size, | ||
| const uint8_t | iv[CAAM_DES_IV_SIZE], | ||
| const uint8_t | key1[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key2[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key3[CAAM_DES_KEY_SIZE] | ||
| ) | 
Encrypts triple DES using CFB block mode with three keys.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| plaintext | Input plaintext to encrypt | |
| [out] | ciphertext | Output ciphertext | 
| size | Size of input and ouput data in bytes | |
| iv | Input initial block. | |
| key1 | First input key for key bundle | |
| key2 | Second input key for key bundle | |
| key3 | Third input key for key bundle | 
| status_t CAAM_DES3_DecryptCfbNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | ciphertext, | ||
| uint8_t * | plaintext, | ||
| size_t | size, | ||
| const uint8_t | iv[CAAM_DES_IV_SIZE], | ||
| const uint8_t | key1[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key2[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key3[CAAM_DES_KEY_SIZE] | ||
| ) | 
Decrypts triple DES using CFB block mode with three keys.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| ciphertext | Input ciphertext to decrypt | |
| [out] | plaintext | Output plaintext | 
| size | Size of input data in bytes | |
| iv | Input initial block. | |
| key1 | First input key for key bundle | |
| key2 | Second input key for key bundle | |
| key3 | Third input key for key bundle | 
| status_t CAAM_DES3_EncryptOfbNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | plaintext, | ||
| uint8_t * | ciphertext, | ||
| size_t | size, | ||
| const uint8_t | iv[CAAM_DES_IV_SIZE], | ||
| const uint8_t | key1[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key2[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key3[CAAM_DES_KEY_SIZE] | ||
| ) | 
Encrypts triple DES using OFB block mode with three keys.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| plaintext | Input plaintext to encrypt | |
| [out] | ciphertext | Output ciphertext | 
| size | Size of input and output data in bytes | |
| iv | Input unique input vector. The OFB mode requires that the IV be unique for each execution of the mode under the given key. | |
| key1 | First input key for key bundle | |
| key2 | Second input key for key bundle | |
| key3 | Third input key for key bundle | 
| status_t CAAM_DES3_DecryptOfbNonBlocking | ( | CAAM_Type * | base, | 
| caam_handle_t * | handle, | ||
| caam_desc_cipher_des_t | descriptor, | ||
| const uint8_t * | ciphertext, | ||
| uint8_t * | plaintext, | ||
| size_t | size, | ||
| const uint8_t | iv[CAAM_DES_IV_SIZE], | ||
| const uint8_t | key1[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key2[CAAM_DES_KEY_SIZE], | ||
| const uint8_t | key3[CAAM_DES_KEY_SIZE] | ||
| ) | 
Decrypts triple DES using OFB block mode with three keys.
| base | CAAM peripheral base address | |
| handle | Handle used for this request. Specifies jobRing. | |
| [out] | descriptor | memory for CAAM commands | 
| ciphertext | Input ciphertext to decrypt | |
| [out] | plaintext | Output plaintext | 
| size | Size of input and output data in bytes | |
| iv | Input unique input vector. The OFB mode requires that the IV be unique for each execution of the mode under the given key. | |
| key1 | First input key for key bundle | |
| key2 | Second input key for key bundle | |
| key3 | Third input key for key bundle |