Knight KE / Mbed OS Game_Master
Embed: (wiki syntax)

« Back to documentation index

CryptoCell HMAC Key Derivation APIs

CryptoCell HMAC Key Derivation APIs

Modules

 HMAC Key Derivation specific errors

Enumerations

enum  CRYS_HKDF_HASH_OpMode_t {
  CRYS_HKDF_HASH_SHA1_mode = 0, CRYS_HKDF_HASH_SHA224_mode = 1, CRYS_HKDF_HASH_SHA256_mode = 2, CRYS_HKDF_HASH_SHA384_mode = 3,
  CRYS_HKDF_HASH_SHA512_mode = 4, CRYS_HKDF_HASH_NumOfModes, CRYS_HKDF_HASH_OpModeLast = 0x7FFFFFFF
}

Functions

CEXPORT_C CRYSError_t CRYS_HKDF_KeyDerivFunc (CRYS_HKDF_HASH_OpMode_t HKDFhashMode, uint8_t *Salt_ptr, size_t SaltLen, uint8_t *Ikm_ptr, uint32_t IkmLen, uint8_t *Info, uint32_t InfoLen, uint8_t *Okm, uint32_t OkmLen, SaSiBool IsStrongKey)
 CRYS_HKDF_KeyDerivFunc performs the HMAC-based key derivation, according to RFC5869.

Enumeration Type Documentation

Enum defining HKDF HASH available modes.

Enumerator:
CRYS_HKDF_HASH_SHA1_mode 

SHA1 mode.

CRYS_HKDF_HASH_SHA224_mode 

SHA224 mode.

CRYS_HKDF_HASH_SHA256_mode 

SHA256 mode.

CRYS_HKDF_HASH_SHA384_mode 

SHA384 mode.

CRYS_HKDF_HASH_SHA512_mode 

SHA512 mode.

CRYS_HKDF_HASH_NumOfModes 

Maximal number of HASH modes.

CRYS_HKDF_HASH_OpModeLast 

Reserved

Definition at line 65 of file crys_hkdf.h.


Function Documentation

CEXPORT_C CRYSError_t CRYS_HKDF_KeyDerivFunc ( CRYS_HKDF_HASH_OpMode_t  HKDFhashMode,
uint8_t *  Salt_ptr,
size_t  SaltLen,
uint8_t *  Ikm_ptr,
uint32_t  IkmLen,
uint8_t *  Info,
uint32_t  InfoLen,
uint8_t *  Okm,
uint32_t  OkmLen,
SaSiBool  IsStrongKey 
)

CRYS_HKDF_KeyDerivFunc performs the HMAC-based key derivation, according to RFC5869.

Returns:
CRYS_OK on success.
A non-zero value on failure as defined crys_kdf_error.h, crys_hash_error or crys_hmac_error.h
Parameters:
[in]HKDFhashModeThe HKDF identifier of hash function to be used.
[in]Salt_ptrA pointer to a non secret random value. can be NULL.
[in]SaltLenThe size of the salt_ptr.
[in]Ikm_ptrA pointer to a input key message.
[in]IkmLenThe size of the input key message
[in]InfoA pointer to an optional context and application specific information. can be NULL
[in]InfoLenThe size of the info.
[in]OkmA pointer to a output key material.
[in]OkmLenThe size of the output key material.
[in]IsStrongKeyif TRUE , then no need to perform the extraction phase.