EFR32 Mighty Gecko 1 Software Documentation  efr32mg1-doc-5.1.2
CRYPTO

Detailed Description

Cryptography accelerator peripheral API.

In order for cryptographic support, users are recommended to consider the crypto APIs of the mbedTLS library provided by Silicon Labs instead of the interface provided in em_crypto.h. The mbedTLS library provides a much richer crypto API, including hardware acceleration of several functions.

The main purpose of em_crypto.h is to implement a thin software interface for the CRYPTO hardware functions especially for the accelerated APIs of the mbedTLS library. Additionally em_crypto.h implement the AES API of the em_aes.h (supported by classic EFM32) for backwards compatibility. The following list summarizes the em_crypto.h inteface:


AES

The AES APIs include support for AES-128 and AES-256 with block cipher modes:

For the AES APIs Input/output data (plaintext, ciphertext, key etc) are treated as byte arrays, starting with most significant byte. Ie, 32 bytes of plaintext (B0...B31) is located in memory in the same order, with B0 at the lower address and B31 at the higher address.

Byte arrays must always be a multiple of AES block size, ie. a multiple of 16. Padding, if required, is done at the end of the byte array.

Byte arrays should be word (32 bit) aligned for performance considerations, since the array is accessed with 32 bit access type. The core MCUs supports unaligned accesses, but with a performance penalty.

It is possible to specify the same output buffer as input buffer as long as they point to the same address. In that case the provided input buffer is replaced with the encrypted/decrypted output. Notice that the buffers must be exactly overlapping. If partly overlapping, the behavior is undefined.

It is up to the user to use a cipher mode according to its requirements in order to not break security. Please refer to specific cipher mode theory for details.

References:


SHA

The SHA APIs include support for

The SHA-1 implementation is FIPS-180-1 compliant, ref:

The SHA-256 implementation is FIPS-180-2 compliant, ref:


CRYPTO_Mul

CRYPTO_Mul is a function for multiplying big integers that are bigger than the operand size of the MUL instruction which is 128 bits. CRYPTO_Mul multiplies all partial operands of the input operands using MUL to form a resulting number which may be twice the size of the operands.

CRPYTO_Mul is typically used by RSA implementations which perform a huge amount of multiplication and square operations in order to implement modular exponentiation. Some RSA implementations use a number representation including arrays of 32bit words of variable size. The user should compile with -D USE_VARIABLE_SIZED_DATA_LOADS in order to load these numbers directly into CRYPTO without converting the number representation.


Load and Execute Instruction Sequences

The functions for loading data and executing instruction sequences can be used to implement complex algorithms like elliptic curve cryptography (ECC)) and authenticated encryption algorithms. There are two typical modes of operation:

In multi sequence mode the software starts by loading input data, then an instruction sequence, execute, and finally read the result. This process is repeated until the full crypto operation is complete.

When using a single static instruction sequence, there is just one instruction sequence which is loaded initially. The sequence can be setup to run multiple times. The data can be loaded during the execution of the sequence by using DMA, BUFC and/or programmed I/O directly from the MCU core. For details on how to program the instruction sequences please refer to the reference manual of the particular Silicon Labs device.

In order to load input data to the CRYPTO module use any of the following functions:

In order to read output data from the CRYPTO module use any of the following functions:

In order to load an instruction sequence to the CRYPTO module use CRYPTO_InstructionSequenceLoad.

In order to execute the current instruction sequence in the CRYPTO module use CRYPTO_InstructionSequenceExecute.

In order to check whether an instruction sequence has completed use CRYPTO_InstructionSequenceDone.

In order to wait for an instruction sequence to complete use CRYPTO_InstructionSequenceWait.

In order to optimally load (with regards to speed) and execute an instruction sequence use any of the CRYPTO_EXECUTE_X macros (where X is in the range 1-20) defined in em_crypto.h. E.g. CRYPTO_EXECUTE_19.

Macros

#define CRYPTO_INSTRUCTIONSEQUENSE_DEFAULT
 
#define CRYPTO_MAX_SEQUENCE_INSTRUCTIONS   (20)
 

Typedefs

typedef void(* CRYPTO_AES_CtrFuncPtr_TypeDef) (uint8_t *ctr)
 AES counter modification function pointer. More...
 
typedef uint32_t CRYPTO_Data260_TypeDef[CRYPTO_DATA260_SIZE_IN_32BIT_WORDS]
 
typedef uint32_t CRYPTO_Data_TypeDef[CRYPTO_DATA_SIZE_IN_32BIT_WORDS]
 
typedef volatile uint32_t * CRYPTO_DataReg_TypeDef
 
typedef uint32_t CRYPTO_DData_TypeDef[CRYPTO_DDATA_SIZE_IN_32BIT_WORDS]
 
typedef volatile uint32_t * CRYPTO_DDataReg_TypeDef
 
typedef uint8_t CRYPTO_InstructionSequence_TypeDef[CRYPTO_MAX_SEQUENCE_INSTRUCTIONS]
 
typedef uint32_t CRYPTO_KeyBuf_TypeDef[CRYPTO_KEYBUF_SIZE_IN_32BIT_WORDS]
 
typedef uint32_t CRYPTO_QData_TypeDef[CRYPTO_QDATA_SIZE_IN_32BIT_WORDS]
 
typedef volatile uint32_t * CRYPTO_QDataReg_TypeDef
 
typedef uint8_t CRYPTO_SHA1_Digest_TypeDef[CRYPTO_SHA1_DIGEST_SIZE_IN_BYTES]
 
typedef uint8_t CRYPTO_SHA256_Digest_TypeDef[CRYPTO_SHA256_DIGEST_SIZE_IN_BYTES]
 

Enumerations

enum  CRYPTO_IncWidth_TypeDef {
  cryptoInc1byte = CRYPTO_CTRL_INCWIDTH_INCWIDTH1,
  cryptoInc2byte = CRYPTO_CTRL_INCWIDTH_INCWIDTH2,
  cryptoInc3byte = CRYPTO_CTRL_INCWIDTH_INCWIDTH3,
  cryptoInc4byte = CRYPTO_CTRL_INCWIDTH_INCWIDTH4
}
 
enum  CRYPTO_KeyWidth_TypeDef {
  cryptoKey128Bits = 8,
  cryptoKey256Bits = 16
}
 
enum  CRYPTO_ModulusId_TypeDef {
  cryptoModulusBin256 = CRYPTO_WAC_MODULUS_BIN256,
  cryptoModulusBin128 = CRYPTO_WAC_MODULUS_BIN128,
  cryptoModulusGcmBin128 = CRYPTO_WAC_MODULUS_GCMBIN128,
  cryptoModulusEccB233 = CRYPTO_WAC_MODULUS_ECCBIN233P,
  cryptoModulusEccB163 = CRYPTO_WAC_MODULUS_ECCBIN163P,
  cryptoModulusEccP256 = CRYPTO_WAC_MODULUS_ECCPRIME256P,
  cryptoModulusEccP224 = CRYPTO_WAC_MODULUS_ECCPRIME224P,
  cryptoModulusEccP192 = CRYPTO_WAC_MODULUS_ECCPRIME192P,
  cryptoModulusEccB233Order = CRYPTO_WAC_MODULUS_ECCBIN233N,
  cryptoModulusEccB233KOrder = CRYPTO_WAC_MODULUS_ECCBIN233KN,
  cryptoModulusEccB163Order = CRYPTO_WAC_MODULUS_ECCBIN163N,
  cryptoModulusEccB163KOrder = CRYPTO_WAC_MODULUS_ECCBIN163KN,
  cryptoModulusEccP256Order = CRYPTO_WAC_MODULUS_ECCPRIME256N,
  cryptoModulusEccP224Order = CRYPTO_WAC_MODULUS_ECCPRIME224N,
  cryptoModulusEccP192Order = CRYPTO_WAC_MODULUS_ECCPRIME192N
}
 
enum  CRYPTO_MulOperandWidth_TypeDef {
  cryptoMulOperand256Bits = CRYPTO_WAC_MULWIDTH_MUL256,
  cryptoMulOperand128Bits = CRYPTO_WAC_MULWIDTH_MUL128,
  cryptoMulOperandModulusBits = CRYPTO_WAC_MULWIDTH_MULMOD
}
 
enum  CRYPTO_ResultWidth_TypeDef {
  cryptoResult128Bits = CRYPTO_WAC_RESULTWIDTH_128BIT,
  cryptoResult256Bits = CRYPTO_WAC_RESULTWIDTH_256BIT,
  cryptoResult260Bits = CRYPTO_WAC_RESULTWIDTH_260BIT
}
 

Functions

__STATIC_INLINE void AES_CBC128 (uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, const uint8_t *iv, bool encrypt)
 AES Cipher-block chaining (CBC) cipher mode encryption/decryption, 128 bit key. More...
 
__STATIC_INLINE void AES_CBC256 (uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, const uint8_t *iv, bool encrypt)
 AES Cipher-block chaining (CBC) cipher mode encryption/decryption, 256 bit key. More...
 
__STATIC_INLINE void AES_CFB128 (uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, const uint8_t *iv, bool encrypt)
 AES Cipher feedback (CFB) cipher mode encryption/decryption, 128 bit key. More...
 
__STATIC_INLINE void AES_CFB256 (uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, const uint8_t *iv, bool encrypt)
 AES Cipher feedback (CFB) cipher mode encryption/decryption, 256 bit key. More...
 
__STATIC_INLINE void AES_CTR128 (uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, uint8_t *ctr, CRYPTO_AES_CtrFuncPtr_TypeDef ctrFunc)
 AES Counter (CTR) cipher mode encryption/decryption, 128 bit key. More...
 
__STATIC_INLINE void AES_CTR256 (uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, uint8_t *ctr, CRYPTO_AES_CtrFuncPtr_TypeDef ctrFunc)
 AES Counter (CTR) cipher mode encryption/decryption, 256 bit key. More...
 
__STATIC_INLINE void AES_CTRUpdate32Bit (uint8_t *ctr)
 Update last 32 bits of 128 bit counter, by incrementing with 1. More...
 
__STATIC_INLINE void AES_DecryptKey128 (uint8_t *out, const uint8_t *in)
 Generate 128 bit AES decryption key from 128 bit encryption key. The decryption key is used for some cipher modes when decrypting. More...
 
__STATIC_INLINE void AES_DecryptKey256 (uint8_t *out, const uint8_t *in)
 Generate 256 bit AES decryption key from 256 bit encryption key. The decryption key is used for some cipher modes when decrypting. More...
 
__STATIC_INLINE void AES_ECB128 (uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, bool encrypt)
 AES Electronic Codebook (ECB) cipher mode encryption/decryption, 128 bit key. More...
 
__STATIC_INLINE void AES_ECB256 (uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, bool encrypt)
 AES Electronic Codebook (ECB) cipher mode encryption/decryption, 256 bit key. More...
 
__STATIC_INLINE void AES_OFB128 (uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, const uint8_t *iv)
 AES Output feedback (OFB) cipher mode encryption/decryption, 128 bit key. More...
 
__STATIC_INLINE void AES_OFB256 (uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, const uint8_t *iv)
 AES Output feedback (OFB) cipher mode encryption/decryption, 256 bit key. More...
 
void CRYPTO_AES_CBC128 (CRYPTO_TypeDef *crypto, uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, const uint8_t *iv, bool encrypt)
 AES Cipher-block chaining (CBC) cipher mode encryption/decryption, 128 bit key. More...
 
void CRYPTO_AES_CBC256 (CRYPTO_TypeDef *crypto, uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, const uint8_t *iv, bool encrypt)
 AES Cipher-block chaining (CBC) cipher mode encryption/decryption, 256 bit key. More...
 
static void CRYPTO_AES_CBCx (CRYPTO_TypeDef *crypto, uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, const uint8_t *iv, bool encrypt, CRYPTO_KeyWidth_TypeDef keyWidth)
 Cipher-block chaining (CBC) cipher mode encryption/decryption, 128/256 bit key. More...
 
void CRYPTO_AES_CFB128 (CRYPTO_TypeDef *crypto, uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, const uint8_t *iv, bool encrypt)
 AES Cipher feedback (CFB) cipher mode encryption/decryption, 128 bit key. More...
 
void CRYPTO_AES_CFB256 (CRYPTO_TypeDef *crypto, uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, const uint8_t *iv, bool encrypt)
 AES Cipher feedback (CFB) cipher mode encryption/decryption, 256 bit key. More...
 
static void CRYPTO_AES_CFBx (CRYPTO_TypeDef *crypto, uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, const uint8_t *iv, bool encrypt, CRYPTO_KeyWidth_TypeDef keyWidth)
 Cipher feedback (CFB) cipher mode encryption/decryption, 128/256 bit key. More...
 
void CRYPTO_AES_CTR128 (CRYPTO_TypeDef *crypto, uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, uint8_t *ctr, CRYPTO_AES_CtrFuncPtr_TypeDef ctrFunc)
 AES Counter (CTR) cipher mode encryption/decryption, 128 bit key. More...
 
void CRYPTO_AES_CTR256 (CRYPTO_TypeDef *crypto, uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, uint8_t *ctr, CRYPTO_AES_CtrFuncPtr_TypeDef ctrFunc)
 AES Counter (CTR) cipher mode encryption/decryption, 256 bit key. More...
 
void CRYPTO_AES_CTRUpdate32Bit (uint8_t *ctr)
 Update last 32 bits of 128 bit counter, by incrementing with 1. More...
 
static void CRYPTO_AES_CTRx (CRYPTO_TypeDef *crypto, uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, uint8_t *ctr, CRYPTO_AES_CtrFuncPtr_TypeDef ctrFunc, CRYPTO_KeyWidth_TypeDef keyWidth)
 Counter (CTR) cipher mode encryption/decryption, 128/256 bit key. More...
 
void CRYPTO_AES_DecryptKey128 (CRYPTO_TypeDef *crypto, uint8_t *out, const uint8_t *in)
 Generate 128 bit AES decryption key from 128 bit encryption key. The decryption key is used for some cipher modes when decrypting. More...
 
void CRYPTO_AES_DecryptKey256 (CRYPTO_TypeDef *crypto, uint8_t *out, const uint8_t *in)
 Generate 256 bit AES decryption key from 256 bit encryption key. The decryption key is used for some cipher modes when decrypting. More...
 
void CRYPTO_AES_ECB128 (CRYPTO_TypeDef *crypto, uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, bool encrypt)
 AES Electronic Codebook (ECB) cipher mode encryption/decryption, 128 bit key. More...
 
void CRYPTO_AES_ECB256 (CRYPTO_TypeDef *crypto, uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, bool encrypt)
 AES Electronic Codebook (ECB) cipher mode encryption/decryption, 256 bit key. More...
 
static void CRYPTO_AES_ECBx (CRYPTO_TypeDef *crypto, uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, bool encrypt, CRYPTO_KeyWidth_TypeDef keyWidth)
 Electronic Codebook (ECB) cipher mode encryption/decryption, 128/256 bit key. More...
 
void CRYPTO_AES_OFB128 (CRYPTO_TypeDef *crypto, uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, const uint8_t *iv)
 AES Output feedback (OFB) cipher mode encryption/decryption, 128 bit key. More...
 
void CRYPTO_AES_OFB256 (CRYPTO_TypeDef *crypto, uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, const uint8_t *iv)
 AES Output feedback (OFB) cipher mode encryption/decryption, 256 bit key. More...
 
static void CRYPTO_AES_OFBx (CRYPTO_TypeDef *crypto, uint8_t *out, const uint8_t *in, unsigned int len, const uint8_t *key, const uint8_t *iv, CRYPTO_KeyWidth_TypeDef keyWidth)
 Output feedback (OFB) cipher mode encryption/decryption, 128/256 bit key. More...
 
static void CRYPTO_AES_ProcessLoop (CRYPTO_TypeDef *crypto, uint32_t len, CRYPTO_DataReg_TypeDef inReg, uint32_t *in, CRYPTO_DataReg_TypeDef outReg, uint32_t *out)
 Function performs generic AES loop. More...
 
__STATIC_INLINE void CRYPTO_BurstFromCrypto (volatile uint32_t *reg, uint32_t *val)
 Read a 128 bit value from a crypto register. More...
 
__STATIC_INLINE void CRYPTO_BurstToCrypto (volatile uint32_t *reg, const uint32_t *val)
 Write a 128 bit value into a crypto register. More...
 
__STATIC_INLINE bool CRYPTO_CarryIsSet (CRYPTO_TypeDef *crypto)
 Quick read access of the Carry bit from arithmetic operations. More...
 
__STATIC_INLINE void CRYPTO_DataRead (CRYPTO_DataReg_TypeDef dataReg, CRYPTO_Data_TypeDef val)
 Read 128 bits of data from a DATAX register in the CRYPTO module. More...
 
__STATIC_INLINE void CRYPTO_DataWrite (CRYPTO_DataReg_TypeDef dataReg, const CRYPTO_Data_TypeDef val)
 Write 128 bits of data to a DATAX register in the CRYPTO module. More...
 
__STATIC_INLINE uint8_t CRYPTO_DData0_4LSBitsRead (CRYPTO_TypeDef *crypto)
 Quick read access of the 4 LSbits of the DDATA0 register. More...
 
__STATIC_INLINE void CRYPTO_DData0Read260 (CRYPTO_TypeDef *crypto, CRYPTO_Data260_TypeDef val)
 Read 260 bits from the DDATA0 register. More...
 
__STATIC_INLINE void CRYPTO_DData0Write260 (CRYPTO_TypeDef *crypto, const CRYPTO_Data260_TypeDef val)
 Write 260 bits to the DDATA0 register. More...
 
__STATIC_INLINE bool CRYPTO_DData1_MSBitRead (CRYPTO_TypeDef *crypto)
 Quick read the MSbit of the DDATA1 register. More...
 
__STATIC_INLINE void CRYPTO_DDataRead (CRYPTO_DDataReg_TypeDef ddataReg, CRYPTO_DData_TypeDef val)
 Read 256 bits of data from a DDATAX register in the CRYPTO module. More...
 
__STATIC_INLINE void CRYPTO_DDataWrite (CRYPTO_DDataReg_TypeDef ddataReg, const CRYPTO_DData_TypeDef val)
 Write 256 bits of data to a DDATAX register in the CRYPTO module. More...
 
__STATIC_INLINE void CRYPTO_IncWidthSet (CRYPTO_TypeDef *crypto, CRYPTO_IncWidth_TypeDef incWidth)
 Set the width of the DATA1 increment instruction DATA1INC. More...
 
__STATIC_INLINE bool CRYPTO_InstructionSequenceDone (CRYPTO_TypeDef *crypto)
 Check whether the execution of an instruction sequence has completed. More...
 
__STATIC_INLINE void CRYPTO_InstructionSequenceExecute (CRYPTO_TypeDef *crypto)
 Execute the current programmed instruction sequence. More...
 
__STATIC_INLINE void CRYPTO_InstructionSequenceLoad (CRYPTO_TypeDef *crypto, const CRYPTO_InstructionSequence_TypeDef instructionSequence)
 Load a sequence of instructions to be executed on the current values in the data registers. More...
 
__STATIC_INLINE void CRYPTO_InstructionSequenceWait (CRYPTO_TypeDef *crypto)
 Wait for completion of the current sequence of instructions. More...
 
__STATIC_INLINE void CRYPTO_InstructionWait (CRYPTO_TypeDef *crypto)
 Wait for completion of the current command. More...
 
__STATIC_INLINE void CRYPTO_IntClear (CRYPTO_TypeDef *crypto, uint32_t flags)
 Clear one or more pending CRYPTO interrupts. More...
 
__STATIC_INLINE void CRYPTO_IntDisable (CRYPTO_TypeDef *crypto, uint32_t flags)
 Disable one or more CRYPTO interrupts. More...
 
__STATIC_INLINE void CRYPTO_IntEnable (CRYPTO_TypeDef *crypto, uint32_t flags)
 Enable one or more CRYPTO interrupts. More...
 
__STATIC_INLINE uint32_t CRYPTO_IntGet (CRYPTO_TypeDef *crypto)
 Get pending CRYPTO interrupt flags. More...
 
__STATIC_INLINE uint32_t CRYPTO_IntGetEnabled (CRYPTO_TypeDef *crypto)
 Get enabled and pending CRYPTO interrupt flags. Useful for handling more interrupt sources in the same interrupt handler. More...
 
__STATIC_INLINE void CRYPTO_IntSet (CRYPTO_TypeDef *crypto, uint32_t flags)
 Set one or more pending CRYPTO interrupts from SW. More...
 
__STATIC_INLINE void CRYPTO_KeyBuf128Write (CRYPTO_TypeDef *crypto, const uint32_t *val)
 Quick write 128 bit key to the CRYPTO module. More...
 
__STATIC_INLINE void CRYPTO_KeyBufWrite (CRYPTO_TypeDef *crypto, CRYPTO_KeyBuf_TypeDef val, CRYPTO_KeyWidth_TypeDef keyWidth)
 Set the key value to be used by the CRYPTO module. More...
 
void CRYPTO_KeyRead (CRYPTO_TypeDef *crypto, CRYPTO_KeyBuf_TypeDef val, CRYPTO_KeyWidth_TypeDef keyWidth)
 Read the key value currently used by the CRYPTO module. More...
 
void CRYPTO_ModulusSet (CRYPTO_TypeDef *crypto, CRYPTO_ModulusId_TypeDef modType)
 Set the modulus type used for wide arithmetic operations. More...
 
void CRYPTO_Mul (CRYPTO_TypeDef *crypto, uint32_t *A, int aSize, uint32_t *B, int bSize, uint32_t *R, int rSize)
 Multiply two big integers. More...
 
__STATIC_INLINE void CRYPTO_MulOperandWidthSet (CRYPTO_TypeDef *crypto, CRYPTO_MulOperandWidth_TypeDef mulOperandWidth)
 Set the number of bits in the operands of the MUL instruction. More...
 
__STATIC_INLINE void CRYPTO_QDataRead (CRYPTO_QDataReg_TypeDef qdataReg, CRYPTO_QData_TypeDef val)
 Read 512 bits of data from a QDATAX register in the CRYPTO module. More...
 
__STATIC_INLINE void CRYPTO_QDataWrite (CRYPTO_QDataReg_TypeDef qdataReg, CRYPTO_QData_TypeDef val)
 Write 512 bits of data to a QDATAX register in the CRYPTO module. More...
 
__STATIC_INLINE void CRYPTO_ResultWidthSet (CRYPTO_TypeDef *crypto, CRYPTO_ResultWidth_TypeDef resultWidth)
 Set the width of the results of the non-modulus instructions. More...
 
void CRYPTO_SHA_1 (CRYPTO_TypeDef *crypto, const uint8_t *msg, uint64_t msgLen, CRYPTO_SHA1_Digest_TypeDef msgDigest)
 Perform a SHA-1 hash operation on a message. More...
 
void CRYPTO_SHA_256 (CRYPTO_TypeDef *crypto, const uint8_t *msg, uint64_t msgLen, CRYPTO_SHA256_Digest_TypeDef msgDigest)
 Perform a SHA-256 hash operation on a message. More...
 
__STATIC_INLINE void cryptoBigintIncrement (uint32_t *words32bits, int num32bitWords)
 Increment value of 32bit word array by one. More...
 
__STATIC_INLINE void cryptoBigintZeroize (uint32_t *words32bits, int num32bitWords)
 Set 32bit word array to zero. More...
 

Macro Definition Documentation

#define CRYPTO_INSTRUCTIONSEQUENSE_DEFAULT
Value:
CRYPTO_CMD_INSTR_END, CRYPTO_CMD_INSTR_END, CRYPTO_CMD_INSTR_END, \
CRYPTO_CMD_INSTR_END, CRYPTO_CMD_INSTR_END, CRYPTO_CMD_INSTR_END, \
CRYPTO_CMD_INSTR_END, CRYPTO_CMD_INSTR_END, CRYPTO_CMD_INSTR_END, \
CRYPTO_CMD_INSTR_END, CRYPTO_CMD_INSTR_END, CRYPTO_CMD_INSTR_END, \
CRYPTO_CMD_INSTR_END, CRYPTO_CMD_INSTR_END, CRYPTO_CMD_INSTR_END, \
CRYPTO_CMD_INSTR_END, CRYPTO_CMD_INSTR_END}
#define CRYPTO_CMD_INSTR_END

Default instruction sequence consisting of all ENDs. The user can initialize the instruction sequence with this default value set, and fill in the desired operations from step 1. The first END instruction marks the end of the sequence.

Definition at line 552 of file em_crypto.h.

#define CRYPTO_MAX_SEQUENCE_INSTRUCTIONS   (20)

The max number of crypto instructions in an instruction sequence

Definition at line 537 of file em_crypto.h.

Typedef Documentation

typedef void(* CRYPTO_AES_CtrFuncPtr_TypeDef) (uint8_t *ctr)

AES counter modification function pointer.

Note
This is defined in order for backwards compatibility with EFM32 em_aes.h. The CRYPTO implementation of Counter mode does not support counter update callbacks.
Parameters
[in]ctrCounter value to be modified.

Definition at line 578 of file em_crypto.h.

typedef uint32_t CRYPTO_Data260_TypeDef[CRYPTO_DATA260_SIZE_IN_32BIT_WORDS]

CRYPTO data type used for data load functions. This data type is capable of storing a 260 bits value as used by the CRYPTO_DData0Write260 function.

Note that this data type is multiple of 32 bit words, so the actual storage used by this type is 32x9=288 bits.

Definition at line 451 of file em_crypto.h.

typedef uint32_t CRYPTO_Data_TypeDef[CRYPTO_DATA_SIZE_IN_32BIT_WORDS]

CRYPTO data types used for data load functions. This data type is capable of storing a 128 bits value as used in the crypto DATA registers

Definition at line 423 of file em_crypto.h.

typedef volatile uint32_t* CRYPTO_DataReg_TypeDef

CRYPTO 128 bit Data register pointer type. The 128 bit registers are used to load 128 bit values as input and output data for cryptographic and big integer arithmetic functions of the CRYPTO module.

Definition at line 464 of file em_crypto.h.

typedef uint32_t CRYPTO_DData_TypeDef[CRYPTO_DDATA_SIZE_IN_32BIT_WORDS]

CRYPTO data type used for data load functions. This data type is capable of storing a 256 bits value as used in the crypto DDATA registers

Definition at line 430 of file em_crypto.h.

typedef volatile uint32_t* CRYPTO_DDataReg_TypeDef

CRYPTO 256 bit DData (Double Data) register pointer type. The 256 bit registers are used to load 256 bit values as input and output data for cryptographic and big integer arithmetic functions of the CRYPTO module.

Definition at line 471 of file em_crypto.h.

typedef uint8_t CRYPTO_InstructionSequence_TypeDef[CRYPTO_MAX_SEQUENCE_INSTRUCTIONS]

Instruction sequence type. The user should fill in the desired operations from step1, then step2 etc. The CRYPTO_CMD_INSTR_END marks the end of the sequence. Bit fields are used to format the memory layout of the struct equal to the sequence registers in the CRYPTO module.

Definition at line 546 of file em_crypto.h.

typedef uint32_t CRYPTO_KeyBuf_TypeDef[CRYPTO_KEYBUF_SIZE_IN_32BIT_WORDS]

CRYPTO data type used for data load functions. This data type is capable of storing 256 bits as used in the crypto KEYBUF register.

Definition at line 457 of file em_crypto.h.

typedef uint32_t CRYPTO_QData_TypeDef[CRYPTO_QDATA_SIZE_IN_32BIT_WORDS]

CRYPTO data type used for data load functions. This data type is capable of storing a 512 bits value as used in the crypto QDATA registers

Definition at line 441 of file em_crypto.h.

typedef volatile uint32_t* CRYPTO_QDataReg_TypeDef

CRYPTO 512 bit QData (Quad data) register pointer type. The 512 bit registers are used to load 512 bit values as input and output data for cryptographic and big integer arithmetic functions of the CRYPTO module.

Definition at line 478 of file em_crypto.h.

typedef uint8_t CRYPTO_SHA1_Digest_TypeDef[CRYPTO_SHA1_DIGEST_SIZE_IN_BYTES]

SHA-1 Digest type.

Definition at line 562 of file em_crypto.h.

typedef uint8_t CRYPTO_SHA256_Digest_TypeDef[CRYPTO_SHA256_DIGEST_SIZE_IN_BYTES]

SHA-256 Digest type.

Definition at line 565 of file em_crypto.h.

Enumeration Type Documentation

CRYPTO result widths for MUL operations.

Enumerator
cryptoInc1byte 

inc width is 1 byte

cryptoInc2byte 

inc width is 2 byte

cryptoInc3byte 

inc width is 3 byte

cryptoInc4byte 

inc width is 4 byte

Definition at line 519 of file em_crypto.h.

CRYPTO key width.

Enumerator
cryptoKey128Bits 

Key width is 128 bits

cryptoKey256Bits 

Key width is 256 bits

Definition at line 528 of file em_crypto.h.

CRYPTO modulus identifiers.

Enumerator
cryptoModulusBin256 

Generic 256 bit modulus 2^256

cryptoModulusBin128 

Generic 128 bit modulus 2^128

cryptoModulusGcmBin128 

GCM 128 bit modulus = 2^128 + 2^7 + 2^2 + 2 + 1

cryptoModulusEccB233 

ECC B233 prime modulus = 2^233 + 2^74 + 1

cryptoModulusEccB163 

ECC B163 prime modulus = 2^163 + 2^7 + 2^6 + 2^3 + 1

cryptoModulusEccP256 

ECC P256 prime modulus = 2^256 - 2^224 + 2^192 + 2^96 - 1

cryptoModulusEccP224 

ECC P224 prime modulus = 2^224 - 2^96 - 1

cryptoModulusEccP192 

ECC P192 prime modulus = 2^192 - 2^64 - 1

cryptoModulusEccB233Order 

ECC B233 order modulus

cryptoModulusEccB233KOrder 

ECC B233K order modulus

cryptoModulusEccB163Order 

ECC B163 order modulus

cryptoModulusEccB163KOrder 

ECC B163K order modulus

cryptoModulusEccP256Order 

ECC P256 order modulus

cryptoModulusEccP224Order 

ECC P224 order modulus

cryptoModulusEccP192Order 

ECC P192 order modulus

Definition at line 481 of file em_crypto.h.

CRYPTO multiplication widths for wide arithmetic operations.

Enumerator
cryptoMulOperand256Bits 

256 bits operands

cryptoMulOperand128Bits 

128 bits operands

cryptoMulOperandModulusBits 

MUL operand width is specified by the modulus type.

Definition at line 501 of file em_crypto.h.

CRYPTO result widths for MUL operations.

Enumerator
cryptoResult128Bits 

Multiplication result width is 128 bits

cryptoResult256Bits 

Multiplication result width is 256 bits

cryptoResult260Bits 

Multiplication result width is 260 bits

Definition at line 511 of file em_crypto.h.

Function Documentation

__STATIC_INLINE void AES_CBC128 ( uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
const uint8_t *  iv,
bool  encrypt 
)

AES Cipher-block chaining (CBC) cipher mode encryption/decryption, 128 bit key.

Deprecated:
This function is present to preserve backwards compatibility. Use CRYPTO_AES_CBC128 instead.

Definition at line 1338 of file em_crypto.h.

References CRYPTO, and CRYPTO_AES_CBC128().

__STATIC_INLINE void AES_CBC256 ( uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
const uint8_t *  iv,
bool  encrypt 
)

AES Cipher-block chaining (CBC) cipher mode encryption/decryption, 256 bit key.

Deprecated:
This function is present to preserve backwards compatibility. Use CRYPTO_AES_CBC256 instead.

Definition at line 1357 of file em_crypto.h.

References CRYPTO, and CRYPTO_AES_CBC256().

__STATIC_INLINE void AES_CFB128 ( uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
const uint8_t *  iv,
bool  encrypt 
)

AES Cipher feedback (CFB) cipher mode encryption/decryption, 128 bit key.

Deprecated:
This function is present to preserve backwards compatibility. Use CRYPTO_AES_CFB128 instead.

Definition at line 1375 of file em_crypto.h.

References CRYPTO, and CRYPTO_AES_CFB128().

__STATIC_INLINE void AES_CFB256 ( uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
const uint8_t *  iv,
bool  encrypt 
)

AES Cipher feedback (CFB) cipher mode encryption/decryption, 256 bit key.

Deprecated:
This function is present to preserve backwards compatibility. Use CRYPTO_AES_CFB256 instead.

Definition at line 1393 of file em_crypto.h.

References CRYPTO, and CRYPTO_AES_CFB256().

__STATIC_INLINE void AES_CTR128 ( uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
uint8_t *  ctr,
CRYPTO_AES_CtrFuncPtr_TypeDef  ctrFunc 
)

AES Counter (CTR) cipher mode encryption/decryption, 128 bit key.

Deprecated:
This function is present to preserve backwards compatibility. Use CRYPTO_AES_CTR128 instead.

Definition at line 1411 of file em_crypto.h.

References CRYPTO, and CRYPTO_AES_CTR128().

__STATIC_INLINE void AES_CTR256 ( uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
uint8_t *  ctr,
CRYPTO_AES_CtrFuncPtr_TypeDef  ctrFunc 
)

AES Counter (CTR) cipher mode encryption/decryption, 256 bit key.

Deprecated:
This function is present to preserve backwards compatibility. Use CRYPTO_AES_CTR256 instead.

Definition at line 1429 of file em_crypto.h.

References CRYPTO, and CRYPTO_AES_CTR256().

__STATIC_INLINE void AES_CTRUpdate32Bit ( uint8_t *  ctr)

Update last 32 bits of 128 bit counter, by incrementing with 1.

Deprecated:
This function is present to preserve backwards compatibility. Use CRYPTO_AES_CTRUpdate32Bit instead.

Definition at line 1447 of file em_crypto.h.

References CRYPTO_AES_CTRUpdate32Bit().

__STATIC_INLINE void AES_DecryptKey128 ( uint8_t *  out,
const uint8_t *  in 
)

Generate 128 bit AES decryption key from 128 bit encryption key. The decryption key is used for some cipher modes when decrypting.

Deprecated:
This function is present to preserve backwards compatibility. Use CRYPTO_AES_DecryptKey128 instead.

Definition at line 1461 of file em_crypto.h.

References CRYPTO, and CRYPTO_AES_DecryptKey128().

__STATIC_INLINE void AES_DecryptKey256 ( uint8_t *  out,
const uint8_t *  in 
)

Generate 256 bit AES decryption key from 256 bit encryption key. The decryption key is used for some cipher modes when decrypting.

Deprecated:
This function is present to preserve backwards compatibility. Use CRYPTO_AES_DecryptKey256 instead.

Definition at line 1475 of file em_crypto.h.

References CRYPTO, and CRYPTO_AES_DecryptKey256().

__STATIC_INLINE void AES_ECB128 ( uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
bool  encrypt 
)

AES Electronic Codebook (ECB) cipher mode encryption/decryption, 128 bit key.

Deprecated:
This function is present to preserve backwards compatibility. Use CRYPTO_AES_ECB128 instead.

Definition at line 1489 of file em_crypto.h.

References CRYPTO, and CRYPTO_AES_ECB128().

__STATIC_INLINE void AES_ECB256 ( uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
bool  encrypt 
)

AES Electronic Codebook (ECB) cipher mode encryption/decryption, 256 bit key.

Deprecated:
This function is present to preserve backwards compatibility. Use CRYPTO_AES_ECB256 instead.

Definition at line 1507 of file em_crypto.h.

References CRYPTO, and CRYPTO_AES_ECB256().

__STATIC_INLINE void AES_OFB128 ( uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
const uint8_t *  iv 
)

AES Output feedback (OFB) cipher mode encryption/decryption, 128 bit key.

Deprecated:
This function is present to preserve backwards compatibility. Use CRYPTO_AES_OFB128 instead.

Definition at line 1524 of file em_crypto.h.

References CRYPTO, and CRYPTO_AES_OFB128().

__STATIC_INLINE void AES_OFB256 ( uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
const uint8_t *  iv 
)

AES Output feedback (OFB) cipher mode encryption/decryption, 256 bit key.

Deprecated:
This function is present to preserve backwards compatibility. Use CRYPTO_AES_OFB256 instead.

Definition at line 1541 of file em_crypto.h.

References CRYPTO, and CRYPTO_AES_OFB256().

void CRYPTO_AES_CBC128 ( CRYPTO_TypeDef crypto,
uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
const uint8_t *  iv,
bool  encrypt 
)

AES Cipher-block chaining (CBC) cipher mode encryption/decryption, 128 bit key.

Encryption:

*           Plaintext                  Plaintext
*               |                          |
*               V                          V
* InitVector ->XOR        +-------------->XOR
*               |         |                |
*               V         |                V
*       +--------------+  |        +--------------+
* Key ->| Block cipher |  |  Key ->| Block cipher |
*       |  encryption  |  |        |  encryption  |
*       +--------------+  |        +--------------+
*               |---------+                |
*               V                          V
*           Ciphertext                 Ciphertext
* 

Decryption:

*         Ciphertext                 Ciphertext
*              |----------+                |
*              V          |                V
*       +--------------+  |        +--------------+
* Key ->| Block cipher |  |  Key ->| Block cipher |
*       |  decryption  |  |        |  decryption  |
*       +--------------+  |        +--------------+
*               |         |                |
*               V         |                V
* InitVector ->XOR        +-------------->XOR
*               |                          |
*               V                          V
*           Plaintext                  Plaintext
* 

Please refer to general comments on layout and byte ordering of parameters.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[out]outBuffer to place encrypted/decrypted data. Must be at least len long. It may be set equal to in, in which case the input buffer is overwritten.
[in]inBuffer holding data to encrypt/decrypt. Must be at least len long.
[in]lenNumber of bytes to encrypt/decrypt. Must be a multiple of 16.
[in]keyWhen doing encryption, this is the 128 bit encryption key. When doing decryption, this is the 128 bit decryption key. The decryption key may be generated from the encryption key with CRYPTO_AES_DecryptKey128(). If this argument is null, the key will not be loaded, as it is assumed the key has been loaded into KEYHA previously.
[in]iv128 bit initialization vector to use.
[in]encryptSet to true to encrypt, false to decrypt.

Definition at line 800 of file em_crypto.c.

References CRYPTO_AES_CBCx(), CRYPTO_CTRL_AES_AES128, cryptoKey128Bits, and CRYPTO_TypeDef::CTRL.

Referenced by AES_CBC128().

void CRYPTO_AES_CBC256 ( CRYPTO_TypeDef crypto,
uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
const uint8_t *  iv,
bool  encrypt 
)

AES Cipher-block chaining (CBC) cipher mode encryption/decryption, 256 bit key.

Please see CRYPTO_AES_CBC128() for CBC figure.

Please refer to general comments on layout and byte ordering of parameters.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[out]outBuffer to place encrypted/decrypted data. Must be at least len long. It may be set equal to in, in which case the input buffer is overwritten.
[in]inBuffer holding data to encrypt/decrypt. Must be at least len long.
[in]lenNumber of bytes to encrypt/decrypt. Must be a multiple of 16.
[in]keyWhen doing encryption, this is the 256 bit encryption key. When doing decryption, this is the 256 bit decryption key. The decryption key may be generated from the encryption key with CRYPTO_AES_DecryptKey256().
[in]iv128 bit initialization vector to use.
[in]encryptSet to true to encrypt, false to decrypt.

Definition at line 846 of file em_crypto.c.

References CRYPTO_AES_CBCx(), CRYPTO_CTRL_AES_AES256, cryptoKey256Bits, and CRYPTO_TypeDef::CTRL.

Referenced by AES_CBC256().

static void CRYPTO_AES_CBCx ( CRYPTO_TypeDef crypto,
uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
const uint8_t *  iv,
bool  encrypt,
CRYPTO_KeyWidth_TypeDef  keyWidth 
)
static

Cipher-block chaining (CBC) cipher mode encryption/decryption, 128/256 bit key.

Please see CRYPTO_AES_CBC128() for CBC figure.

Please refer to general comments on layout and byte ordering of parameters.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[out]outBuffer to place encrypted/decrypted data. Must be at least len long. It may be set equal to in, in which case the input buffer is overwritten.
[in]inBuffer holding data to encrypt/decrypt. Must be at least len long.
[in]lenNumber of bytes to encrypt/decrypt. Must be a multiple of 16.
[in]keyWhen doing encryption, this is the 256 bit encryption key. When doing decryption, this is the 256 bit decryption key. The decryption key may be generated from the encryption key with CRYPTO_AES_DecryptKey256().
[in]iv128 bit initialization vector to use.
[in]encryptSet to true to encrypt, false to decrypt.
[in]keyWidthSet to cryptoKey128Bits or cryptoKey256Bits.

Definition at line 1453 of file em_crypto.c.

References _CRYPTO_SEQ0_INSTR0_SHIFT, _CRYPTO_SEQ0_INSTR1_SHIFT, _CRYPTO_SEQ0_INSTR2_SHIFT, _CRYPTO_SEQ0_INSTR3_SHIFT, CRYPTO_AES_ProcessLoop(), CRYPTO_CMD_INSTR_AESDEC, CRYPTO_CMD_INSTR_AESENC, CRYPTO_CMD_INSTR_DATA1TODATA0, CRYPTO_CMD_INSTR_DATA1TODATA0XOR, CRYPTO_CMD_INSTR_DATA1TODATA2, CRYPTO_CMD_INSTR_DATA2TODATA0XOR, CRYPTO_DataWrite(), CRYPTO_KeyBufWrite(), CRYPTO_TypeDef::DATA0, CRYPTO_TypeDef::DATA1, CRYPTO_TypeDef::DATA2, CRYPTO_TypeDef::SEQ0, CRYPTO_TypeDef::SEQ1, and CRYPTO_TypeDef::WAC.

Referenced by CRYPTO_AES_CBC128(), and CRYPTO_AES_CBC256().

void CRYPTO_AES_CFB128 ( CRYPTO_TypeDef crypto,
uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
const uint8_t *  iv,
bool  encrypt 
)

AES Cipher feedback (CFB) cipher mode encryption/decryption, 128 bit key.

Encryption:

*           InitVector    +----------------+
*               |         |                |
*               V         |                V
*       +--------------+  |        +--------------+
* Key ->| Block cipher |  |  Key ->| Block cipher |
*       |  encryption  |  |        |  encryption  |
*       +--------------+  |        +--------------+
*               |         |                |
*               V         |                V
*  Plaintext ->XOR        |   Plaintext ->XOR
*               |---------+                |
*               V                          V
*           Ciphertext                 Ciphertext
* 

Decryption:

*          InitVector     +----------------+
*               |         |                |
*               V         |                V
*       +--------------+  |        +--------------+
* Key ->| Block cipher |  |  Key ->| Block cipher |
*       |  encryption  |  |        |  encryption  |
*       +--------------+  |        +--------------+
*               |         |                |
*               V         |                V
*              XOR<- Ciphertext           XOR<- Ciphertext
*               |                          |
*               V                          V
*           Plaintext                  Plaintext
* 

Please refer to general comments on layout and byte ordering of parameters.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[out]outBuffer to place encrypted/decrypted data. Must be at least len long. It may be set equal to in, in which case the input buffer is overwritten.
[in]inBuffer holding data to encrypt/decrypt. Must be at least len long.
[in]lenNumber of bytes to encrypt/decrypt. Must be a multiple of 16.
[in]key128 bit encryption key is used for both encryption and decryption modes.
[in]iv128 bit initialization vector to use.
[in]encryptSet to true to encrypt, false to decrypt.

Definition at line 919 of file em_crypto.c.

References CRYPTO_AES_CFBx(), CRYPTO_CTRL_AES_AES128, cryptoKey128Bits, and CRYPTO_TypeDef::CTRL.

Referenced by AES_CFB128().

void CRYPTO_AES_CFB256 ( CRYPTO_TypeDef crypto,
uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
const uint8_t *  iv,
bool  encrypt 
)

AES Cipher feedback (CFB) cipher mode encryption/decryption, 256 bit key.

Please see CRYPTO_AES_CFB128() for CFB figure.

Please refer to general comments on layout and byte ordering of parameters.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[out]outBuffer to place encrypted/decrypted data. Must be at least len long. It may be set equal to in, in which case the input buffer is overwritten.
[in]inBuffer holding data to encrypt/decrypt. Must be at least len long.
[in]lenNumber of bytes to encrypt/decrypt. Must be a multiple of 16.
[in]key256 bit encryption key is used for both encryption and decryption modes.
[in]iv128 bit initialization vector to use.
[in]encryptSet to true to encrypt, false to decrypt.

Definition at line 962 of file em_crypto.c.

References CRYPTO_AES_CFBx(), CRYPTO_CTRL_AES_AES256, cryptoKey256Bits, and CRYPTO_TypeDef::CTRL.

Referenced by AES_CFB256().

static void CRYPTO_AES_CFBx ( CRYPTO_TypeDef crypto,
uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
const uint8_t *  iv,
bool  encrypt,
CRYPTO_KeyWidth_TypeDef  keyWidth 
)
static

Cipher feedback (CFB) cipher mode encryption/decryption, 128/256 bit key.

Please see CRYPTO_AES_CFB128() for CFB figure.

Please refer to general comments on layout and byte ordering of parameters.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[out]outBuffer to place encrypted/decrypted data. Must be at least len long. It may be set equal to in, in which case the input buffer is overwritten.
[in]inBuffer holding data to encrypt/decrypt. Must be at least len long.
[in]lenNumber of bytes to encrypt/decrypt. Must be a multiple of 16.
[in]key256 bit encryption key is used for both encryption and decryption modes.
[in]iv128 bit initialization vector to use.
[in]encryptSet to true to encrypt, false to decrypt.
[in]keyWidthSet to cryptoKey128Bits or cryptoKey256Bits.

Definition at line 1537 of file em_crypto.c.

References _CRYPTO_SEQ0_INSTR0_SHIFT, _CRYPTO_SEQ0_INSTR1_SHIFT, _CRYPTO_SEQ0_INSTR2_SHIFT, _CRYPTO_SEQ0_INSTR3_SHIFT, CRYPTO_AES_ProcessLoop(), CRYPTO_CMD_INSTR_AESENC, CRYPTO_CMD_INSTR_DATA1TODATA0XOR, CRYPTO_CMD_INSTR_DATA1TODATA2, CRYPTO_CMD_INSTR_DATA2TODATA0, CRYPTO_DataWrite(), CRYPTO_KeyBufWrite(), CRYPTO_TypeDef::DATA0, CRYPTO_TypeDef::DATA1, CRYPTO_TypeDef::DATA2, CRYPTO_TypeDef::SEQ0, CRYPTO_TypeDef::SEQ1, and CRYPTO_TypeDef::WAC.

Referenced by CRYPTO_AES_CFB128(), and CRYPTO_AES_CFB256().

void CRYPTO_AES_CTR128 ( CRYPTO_TypeDef crypto,
uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
uint8_t *  ctr,
CRYPTO_AES_CtrFuncPtr_TypeDef  ctrFunc 
)

AES Counter (CTR) cipher mode encryption/decryption, 128 bit key.

Encryption:

*           Counter                    Counter
*              |                          |
*              V                          V
*       +--------------+           +--------------+
* Key ->| Block cipher |     Key ->| Block cipher |
*       |  encryption  |           |  encryption  |
*       +--------------+           +--------------+
*              |                          |
* Plaintext ->XOR            Plaintext ->XOR
*              |                          |
*              V                          V
*         Ciphertext                 Ciphertext
* 

Decryption:

*           Counter                    Counter
*              |                          |
*              V                          V
*       +--------------+           +--------------+
* Key ->| Block cipher |     Key ->| Block cipher |
*       |  encryption  |           |  encryption  |
*       +--------------+           +--------------+
*               |                          |
* Ciphertext ->XOR           Ciphertext ->XOR
*               |                          |
*               V                          V
*           Plaintext                  Plaintext
* 

Please refer to general comments on layout and byte ordering of parameters.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[out]outBuffer to place encrypted/decrypted data. Must be at least len long. It may be set equal to in, in which case the input buffer is overwritten.
[in]inBuffer holding data to encrypt/decrypt. Must be at least len long.
[in]lenNumber of bytes to encrypt/decrypt. Must be a multiple of 16.
[in]key128 bit encryption key. If this argument is null, the key will not be loaded, as it is assumed the key has been loaded into KEYHA previously.
[in,out]ctr128 bit initial counter value. The counter is updated after each AES block encoding through use of ctrFunc.
[in]ctrFuncFunction used to update counter value. Not supported by CRYPTO. This parameter is included in order for backwards compatibility with the EFM32 em_aes.h API.

Definition at line 1038 of file em_crypto.c.

References CRYPTO_AES_CTRx(), CRYPTO_CTRL_AES_AES128, cryptoKey128Bits, and CRYPTO_TypeDef::CTRL.

Referenced by AES_CTR128().

void CRYPTO_AES_CTR256 ( CRYPTO_TypeDef crypto,
uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
uint8_t *  ctr,
CRYPTO_AES_CtrFuncPtr_TypeDef  ctrFunc 
)

AES Counter (CTR) cipher mode encryption/decryption, 256 bit key.

Please see CRYPTO_AES_CTR128() for CTR figure.

Please refer to general comments on layout and byte ordering of parameters.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[out]outBuffer to place encrypted/decrypted data. Must be at least len long. It may be set equal to in, in which case the input buffer is overwritten.
[in]inBuffer holding data to encrypt/decrypt. Must be at least len long.
[in]lenNumber of bytes to encrypt/decrypt. Must be a multiple of 16.
[in]key256 bit encryption key.
[in,out]ctr128 bit initial counter value. The counter is updated after each AES block encoding through use of ctrFunc.
[in]ctrFuncFunction used to update counter value. Not supported by CRYPTO. This parameter is included in order for backwards compatibility with the EFM32 em_aes.h API.

Definition at line 1084 of file em_crypto.c.

References CRYPTO_AES_CTRx(), CRYPTO_CTRL_AES_AES256, cryptoKey256Bits, and CRYPTO_TypeDef::CTRL.

Referenced by AES_CTR256().

void CRYPTO_AES_CTRUpdate32Bit ( uint8_t *  ctr)

Update last 32 bits of 128 bit counter, by incrementing with 1.

Notice that no special consideration is given to possible wrap around. If 32 least significant bits are 0xFFFFFFFF, they will be updated to 0x00000000, ignoring overflow.

Please refer to general comments on layout and byte ordering of parameters.

Parameters
[in,out]ctrBuffer holding 128 bit counter to be updated.

Definition at line 1110 of file em_crypto.c.

Referenced by AES_CTRUpdate32Bit().

static void CRYPTO_AES_CTRx ( CRYPTO_TypeDef crypto,
uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
uint8_t *  ctr,
CRYPTO_AES_CtrFuncPtr_TypeDef  ctrFunc,
CRYPTO_KeyWidth_TypeDef  keyWidth 
)
static

Counter (CTR) cipher mode encryption/decryption, 128/256 bit key.

Please see CRYPTO_AES_CTR128() for CTR figure.

Please refer to general comments on layout and byte ordering of parameters.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[out]outBuffer to place encrypted/decrypted data. Must be at least len long. It may be set equal to in, in which case the input buffer is overwritten.
[in]inBuffer holding data to encrypt/decrypt. Must be at least len long.
[in]lenNumber of bytes to encrypt/decrypt. Must be a multiple of 16.
[in]key256 bit encryption key.
[in,out]ctr128 bit initial counter value. The counter is updated after each AES block encoding through use of ctrFunc.
[in]ctrFuncFunction used to update counter value. Not supported by CRYPTO. This parameter is included in order for backwards compatibility with the EFM32 em_aes.h API.
[in]keyWidthSet to cryptoKey128Bits or cryptoKey256Bits.

Definition at line 1625 of file em_crypto.c.

References _CRYPTO_SEQ0_INSTR0_SHIFT, _CRYPTO_SEQ0_INSTR1_SHIFT, _CRYPTO_SEQ0_INSTR2_SHIFT, _CRYPTO_SEQ0_INSTR3_SHIFT, _CRYPTO_SEQ1_INSTR4_SHIFT, CRYPTO_AES_ProcessLoop(), CRYPTO_CMD_INSTR_AESENC, CRYPTO_CMD_INSTR_DATA0TODATA3, CRYPTO_CMD_INSTR_DATA1INC, CRYPTO_CMD_INSTR_DATA1TODATA0, CRYPTO_CMD_INSTR_DATA2TODATA0XOR, CRYPTO_CTRL_INCWIDTH_INCWIDTH4, CRYPTO_DataRead(), CRYPTO_DataWrite(), CRYPTO_KeyBufWrite(), CRYPTO_TypeDef::CTRL, CRYPTO_TypeDef::DATA0, CRYPTO_TypeDef::DATA1, CRYPTO_TypeDef::DATA2, CRYPTO_TypeDef::SEQ0, CRYPTO_TypeDef::SEQ1, and CRYPTO_TypeDef::WAC.

Referenced by CRYPTO_AES_CTR128(), and CRYPTO_AES_CTR256().

void CRYPTO_AES_DecryptKey128 ( CRYPTO_TypeDef crypto,
uint8_t *  out,
const uint8_t *  in 
)

Generate 128 bit AES decryption key from 128 bit encryption key. The decryption key is used for some cipher modes when decrypting.

Please refer to general comments on layout and byte ordering of parameters.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[out]outBuffer to place 128 bit decryption key. Must be at least 16 bytes long. It may be set equal to in, in which case the input buffer is overwritten.
[in]inBuffer holding 128 bit encryption key. Must be at least 16 bytes long.

Definition at line 1135 of file em_crypto.c.

References CRYPTO_TypeDef::CMD, CRYPTO_BurstFromCrypto(), CRYPTO_BurstToCrypto(), CRYPTO_CMD_INSTR_AESENC, CRYPTO_CTRL_AES_AES128, CRYPTO_TypeDef::CTRL, CRYPTO_TypeDef::KEY, and CRYPTO_TypeDef::KEYBUF.

Referenced by AES_DecryptKey128().

void CRYPTO_AES_DecryptKey256 ( CRYPTO_TypeDef crypto,
uint8_t *  out,
const uint8_t *  in 
)

Generate 256 bit AES decryption key from 256 bit encryption key. The decryption key is used for some cipher modes when decrypting.

Please refer to general comments on layout and byte ordering of parameters.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[out]outBuffer to place 256 bit decryption key. Must be at least 32 bytes long. It may be set equal to in, in which case the input buffer is overwritten.
[in]inBuffer holding 256 bit encryption key. Must be at least 32 bytes long.

Definition at line 1173 of file em_crypto.c.

References CRYPTO_TypeDef::CMD, CRYPTO_BurstFromCrypto(), CRYPTO_BurstToCrypto(), CRYPTO_CMD_INSTR_AESENC, CRYPTO_CTRL_AES_AES256, CRYPTO_TypeDef::CTRL, CRYPTO_TypeDef::KEY, and CRYPTO_TypeDef::KEYBUF.

Referenced by AES_DecryptKey256().

void CRYPTO_AES_ECB128 ( CRYPTO_TypeDef crypto,
uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
bool  encrypt 
)

AES Electronic Codebook (ECB) cipher mode encryption/decryption, 128 bit key.

Encryption:

*          Plaintext                  Plaintext
*              |                          |
*              V                          V
*       +--------------+           +--------------+
* Key ->| Block cipher |     Key ->| Block cipher |
*       |  encryption  |           |  encryption  |
*       +--------------+           +--------------+
*              |                          |
*              V                          V
*         Ciphertext                 Ciphertext
* 

Decryption:

*         Ciphertext                 Ciphertext
*              |                          |
*              V                          V
*       +--------------+           +--------------+
* Key ->| Block cipher |     Key ->| Block cipher |
*       |  decryption  |           |  decryption  |
*       +--------------+           +--------------+
*              |                          |
*              V                          V
*          Plaintext                  Plaintext
* 

Please refer to general comments on layout and byte ordering of parameters.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[out]outBuffer to place encrypted/decrypted data. Must be at least len long. It may be set equal to in, in which case the input buffer is overwritten.
[in]inBuffer holding data to encrypt/decrypt. Must be at least len long.
[in]lenNumber of bytes to encrypt/decrypt. Must be a multiple of 16.
[in]keyWhen doing encryption, this is the 128 bit encryption key. When doing decryption, this is the 128 bit decryption key. The decryption key may be generated from the encryption key with CRYPTO_AES_DecryptKey128().
[in]encryptSet to true to encrypt, false to decrypt.

Definition at line 1250 of file em_crypto.c.

References CRYPTO_AES_ECBx(), CRYPTO_CTRL_AES_AES128, cryptoKey128Bits, and CRYPTO_TypeDef::CTRL.

Referenced by AES_ECB128().

void CRYPTO_AES_ECB256 ( CRYPTO_TypeDef crypto,
uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
bool  encrypt 
)

AES Electronic Codebook (ECB) cipher mode encryption/decryption, 256 bit key.

Please see CRYPTO_AES_ECB128() for ECB figure.

Please refer to general comments on layout and byte ordering of parameters.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[out]outBuffer to place encrypted/decrypted data. Must be at least len long. It may be set equal to in, in which case the input buffer is overwritten.
[in]inBuffer holding data to encrypt/decrypt. Must be at least len long.
[in]lenNumber of bytes to encrypt/decrypt. Must be a multiple of 16.
[in]keyWhen doing encryption, this is the 256 bit encryption key. When doing decryption, this is the 256 bit decryption key. The decryption key may be generated from the encryption key with CRYPTO_AES_DecryptKey256().
[in]encryptSet to true to encrypt, false to decrypt.

Definition at line 1292 of file em_crypto.c.

References CRYPTO_AES_ECBx(), CRYPTO_CTRL_AES_AES256, cryptoKey256Bits, and CRYPTO_TypeDef::CTRL.

Referenced by AES_ECB256().

static void CRYPTO_AES_ECBx ( CRYPTO_TypeDef crypto,
uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
bool  encrypt,
CRYPTO_KeyWidth_TypeDef  keyWidth 
)
static

Electronic Codebook (ECB) cipher mode encryption/decryption, 128/256 bit key.

Please see CRYPTO_AES_ECB128() for ECB figure.

Please refer to general comments on layout and byte ordering of parameters.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[out]outBuffer to place encrypted/decrypted data. Must be at least len long. It may be set equal to in, in which case the input buffer is overwritten.
[in]inBuffer holding data to encrypt/decrypt. Must be at least len long.
[in]lenNumber of bytes to encrypt/decrypt. Must be a multiple of 16.
[in]keyWhen doing encryption, this is the 256 bit encryption key. When doing decryption, this is the 256 bit decryption key. The decryption key may be generated from the encryption key with CRYPTO_AES_DecryptKey256().
[in]encryptSet to true to encrypt, false to decrypt.
[in]keyWidthSet to cryptoKey128Bits or cryptoKey256Bits.

Definition at line 1693 of file em_crypto.c.

References _CRYPTO_SEQ0_INSTR0_SHIFT, _CRYPTO_SEQ0_INSTR1_SHIFT, CRYPTO_AES_ProcessLoop(), CRYPTO_CMD_INSTR_AESDEC, CRYPTO_CMD_INSTR_AESENC, CRYPTO_CMD_INSTR_DATA0TODATA1, CRYPTO_KeyBufWrite(), CRYPTO_TypeDef::DATA0, CRYPTO_TypeDef::DATA1, CRYPTO_TypeDef::SEQ0, and CRYPTO_TypeDef::WAC.

Referenced by CRYPTO_AES_ECB128(), and CRYPTO_AES_ECB256().

void CRYPTO_AES_OFB128 ( CRYPTO_TypeDef crypto,
uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
const uint8_t *  iv 
)

AES Output feedback (OFB) cipher mode encryption/decryption, 128 bit key.

Encryption:

*          InitVector    +----------------+
*              |         |                |
*              V         |                V
*       +--------------+ |        +--------------+
* Key ->| Block cipher | |  Key ->| Block cipher |
*       |  encryption  | |        |  encryption  |
*       +--------------+ |        +--------------+
*              |         |                |
*              |---------+                |
*              V                          V
* Plaintext ->XOR            Plaintext ->XOR
*              |                          |
*              V                          V
*         Ciphertext                 Ciphertext
* 

Decryption:

*          InitVector    +----------------+
*              |         |                |
*              V         |                V
*       +--------------+ |        +--------------+
* Key ->| Block cipher | |  Key ->| Block cipher |
*       |  encryption  | |        |  encryption  |
*       +--------------+ |        +--------------+
*              |         |                |
*              |---------+                |
*              V                          V
* Ciphertext ->XOR           Ciphertext ->XOR
*              |                          |
*              V                          V
*          Plaintext                  Plaintext
* 

Please refer to general comments on layout and byte ordering of parameters.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[out]outBuffer to place encrypted/decrypted data. Must be at least len long. It may be set equal to in, in which case the input buffer is overwritten.
[in]inBuffer holding data to encrypt/decrypt. Must be at least len long.
[in]lenNumber of bytes to encrypt/decrypt. Must be a multiple of 16.
[in]key128 bit encryption key.
[in]iv128 bit initialization vector to use.

Definition at line 1363 of file em_crypto.c.

References CRYPTO_AES_OFBx(), CRYPTO_CTRL_AES_AES128, cryptoKey128Bits, and CRYPTO_TypeDef::CTRL.

Referenced by AES_OFB128().

void CRYPTO_AES_OFB256 ( CRYPTO_TypeDef crypto,
uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
const uint8_t *  iv 
)

AES Output feedback (OFB) cipher mode encryption/decryption, 256 bit key.

Please see CRYPTO_AES_OFB128() for OFB figure.

Please refer to general comments on layout and byte ordering of parameters.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[out]outBuffer to place encrypted/decrypted data. Must be at least len long. It may be set equal to in, in which case the input buffer is overwritten.
[in]inBuffer holding data to encrypt/decrypt. Must be at least len long.
[in]lenNumber of bytes to encrypt/decrypt. Must be a multiple of 16.
[in]key256 bit encryption key.
[in]iv128 bit initialization vector to use.

Definition at line 1402 of file em_crypto.c.

References CRYPTO_AES_OFBx(), CRYPTO_CTRL_AES_AES256, cryptoKey256Bits, and CRYPTO_TypeDef::CTRL.

Referenced by AES_OFB256().

static void CRYPTO_AES_OFBx ( CRYPTO_TypeDef crypto,
uint8_t *  out,
const uint8_t *  in,
unsigned int  len,
const uint8_t *  key,
const uint8_t *  iv,
CRYPTO_KeyWidth_TypeDef  keyWidth 
)
static

Output feedback (OFB) cipher mode encryption/decryption, 128/256 bit key.

Please see CRYPTO_AES_OFB128() for OFB figure.

Please refer to general comments on layout and byte ordering of parameters.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[out]outBuffer to place encrypted/decrypted data. Must be at least len long. It may be set equal to in, in which case the input buffer is overwritten.
[in]inBuffer holding data to encrypt/decrypt. Must be at least len long.
[in]lenNumber of bytes to encrypt/decrypt. Must be a multiple of 16.
[in]key256 bit encryption key.
[in]iv128 bit initialization vector to use.
[in]keyWidthSet to cryptoKey128Bits or cryptoKey256Bits.

Definition at line 1756 of file em_crypto.c.

References _CRYPTO_SEQ0_INSTR0_SHIFT, _CRYPTO_SEQ0_INSTR1_SHIFT, _CRYPTO_SEQ0_INSTR2_SHIFT, _CRYPTO_SEQ0_INSTR3_SHIFT, _CRYPTO_SEQ1_INSTR4_SHIFT, _CRYPTO_SEQ1_INSTR5_SHIFT, CRYPTO_AES_ProcessLoop(), CRYPTO_CMD_INSTR_AESENC, CRYPTO_CMD_INSTR_DATA0TODATA1, CRYPTO_CMD_INSTR_DATA0TODATA2, CRYPTO_CMD_INSTR_DATA1TODATA0XOR, CRYPTO_CMD_INSTR_DATA2TODATA0, CRYPTO_DataWrite(), CRYPTO_KeyBufWrite(), CRYPTO_TypeDef::DATA0, CRYPTO_TypeDef::DATA1, CRYPTO_TypeDef::DATA2, CRYPTO_TypeDef::SEQ0, CRYPTO_TypeDef::SEQ1, and CRYPTO_TypeDef::WAC.

Referenced by CRYPTO_AES_OFB128(), and CRYPTO_AES_OFB256().

static void CRYPTO_AES_ProcessLoop ( CRYPTO_TypeDef crypto,
uint32_t  len,
CRYPTO_DataReg_TypeDef  inReg,
uint32_t *  in,
CRYPTO_DataReg_TypeDef  outReg,
uint32_t *  out 
)
inlinestatic

Function performs generic AES loop.

Function loads given register with provided input data. Triggers CRYPTO to perform sequence of instructions and read specified output register to output buffer.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[in]lenNumber of bytes to encrypt/decrypt. Must be a multiple of 16.
[in]inRegInput register - one of DATA0,DATA1,DATA2,DATA3
[in]inBuffer holding data to encrypt/decrypt. Must be at least len long.
[in]outRegOutput register - one of DATA0,DATA1,DATA2,DATA3
[out]outBuffer to place encrypted/decrypted data. Must be at least len long. It may be set equal to in, in which case the input buffer is overwritten.

Definition at line 1814 of file em_crypto.c.

References _CRYPTO_SEQCTRL_LENGTHA_SHIFT, CRYPTO_TypeDef::CMD, CRYPTO_CMD_SEQSTART, CRYPTO_DataRead(), CRYPTO_DataWrite(), and CRYPTO_TypeDef::SEQCTRL.

Referenced by CRYPTO_AES_CBCx(), CRYPTO_AES_CFBx(), CRYPTO_AES_CTRx(), CRYPTO_AES_ECBx(), and CRYPTO_AES_OFBx().

__STATIC_INLINE void CRYPTO_BurstFromCrypto ( volatile uint32_t *  reg,
uint32_t *  val 
)

Read a 128 bit value from a crypto register.

Note
This function provide a low-level api for reading one of the multi-word registers in the crypto peripheral. Applications should prefer to use CRYPTO_DataRead, CRYPTO_DDataRead or CRYPTO_QDataRead for reading the value of the DATA, DDATA and QDATA registers.
Parameters
[in]regPointer to the crypto register.
[out]valThis is a pointer to an array that is capable of holding 4 32 bit integers that will be filled with the 128 bit value from the crypto register.

Definition at line 714 of file em_crypto.h.

Referenced by CRYPTO_AES_DecryptKey128(), CRYPTO_AES_DecryptKey256(), CRYPTO_DataRead(), CRYPTO_DDataRead(), CRYPTO_KeyRead(), and CRYPTO_QDataRead().

__STATIC_INLINE void CRYPTO_BurstToCrypto ( volatile uint32_t *  reg,
const uint32_t *  val 
)

Write a 128 bit value into a crypto register.

Note
This function provide a low-level api for writing to the multi-word registers in the crypto peripheral. Applications should prefer to use CRYPTO_DataWrite, CRYPTO_DDataWrite or CRYPTO_QDataWrite for writing to the DATA, DDATA and QDATA registers.
Parameters
[in]regPointer to the crypto register.
[in]valThis is a pointer to 4 32 bit integers that contains the 128 bit value which will be written to the crypto register.

Definition at line 682 of file em_crypto.h.

Referenced by CRYPTO_AES_DecryptKey128(), CRYPTO_AES_DecryptKey256(), CRYPTO_DataWrite(), CRYPTO_DDataWrite(), CRYPTO_KeyBuf128Write(), CRYPTO_KeyBufWrite(), and CRYPTO_QDataWrite().

__STATIC_INLINE bool CRYPTO_CarryIsSet ( CRYPTO_TypeDef crypto)

Quick read access of the Carry bit from arithmetic operations.

This function reads the carry bit of the CRYPTO ALU.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
Returns
Returns 'true' if carry is 1, and 'false' if carry is 0.

Definition at line 915 of file em_crypto.h.

References _CRYPTO_DSTATUS_CARRY_MASK, _CRYPTO_DSTATUS_CARRY_SHIFT, and CRYPTO_TypeDef::DSTATUS.

Referenced by CRYPTO_Mul().

__STATIC_INLINE void CRYPTO_DataRead ( CRYPTO_DataReg_TypeDef  dataReg,
CRYPTO_Data_TypeDef  val 
)

Read 128 bits of data from a DATAX register in the CRYPTO module.

Read 128 bits of data from a DATAX register in the crypto module. The data value is typically output from a big integer operation (see crypto instructions)

Parameters
[in]dataRegThe 128 bit DATA register.
[out]valLocation where to store the value in memory.

Definition at line 758 of file em_crypto.h.

References CRYPTO_BurstFromCrypto().

Referenced by CRYPTO_AES_CTRx(), CRYPTO_AES_ProcessLoop(), and CRYPTO_Mul().

__STATIC_INLINE void CRYPTO_DataWrite ( CRYPTO_DataReg_TypeDef  dataReg,
const CRYPTO_Data_TypeDef  val 
)

Write 128 bits of data to a DATAX register in the CRYPTO module.

Write 128 bits of data to a DATAX register in the crypto module. The data value is typically input to a big integer operation (see crypto instructions).

Parameters
[in]dataRegThe 128 bit DATA register.
[in]valValue of the data to write to the DATA register.

Definition at line 740 of file em_crypto.h.

References CRYPTO_BurstToCrypto().

Referenced by CRYPTO_AES_CBCx(), CRYPTO_AES_CFBx(), CRYPTO_AES_CTRx(), CRYPTO_AES_OFBx(), CRYPTO_AES_ProcessLoop(), and CRYPTO_Mul().

__STATIC_INLINE uint8_t CRYPTO_DData0_4LSBitsRead ( CRYPTO_TypeDef crypto)

Quick read access of the 4 LSbits of the DDATA0 register.

This function quickly retrieves the 4 least significant bits of the DDATA0 register via the DDATA0LSBS bit field in the DSTATUS register.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
Returns
Returns the 4 LSbits of DDATA0.

Definition at line 935 of file em_crypto.h.

References _CRYPTO_DSTATUS_DDATA0LSBS_MASK, _CRYPTO_DSTATUS_DDATA0LSBS_SHIFT, and CRYPTO_TypeDef::DSTATUS.

__STATIC_INLINE void CRYPTO_DData0Read260 ( CRYPTO_TypeDef crypto,
CRYPTO_Data260_TypeDef  val 
)

Read 260 bits from the DDATA0 register.

This functions reads 260 bits from the DDATA0 register in the CRYPTO module. The data value is typically output from a big integer operation (see crypto instructions) when the result width is set to 260 bits by calling CRYPTO_ResultWidthSet(cryptoResult260Bits);

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[out]valLocation where to store the value in memory.

Definition at line 957 of file em_crypto.h.

References _CRYPTO_DSTATUS_DDATA0MSBS_MASK, _CRYPTO_DSTATUS_DDATA0MSBS_SHIFT, CRYPTO_DDataRead(), CRYPTO_TypeDef::DDATA0, and CRYPTO_TypeDef::DSTATUS.

__STATIC_INLINE void CRYPTO_DData0Write260 ( CRYPTO_TypeDef crypto,
const CRYPTO_Data260_TypeDef  val 
)

Write 260 bits to the DDATA0 register.

This functions writes 260 bits to the DDATA0 register in the CRYPTO module. The data value is typically input to a big integer operation (see crypto instructions) when the result width is set to 260 bits by calling CRYPTO_ResultWidthSet(cryptoResult260Bits);

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[out]valLocation where of the value in memory.

Definition at line 981 of file em_crypto.h.

References _CRYPTO_DDATA0BYTE32_DDATA0BYTE32_MASK, CRYPTO_DDataWrite(), CRYPTO_TypeDef::DDATA0, and CRYPTO_TypeDef::DDATA0BYTE32.

__STATIC_INLINE bool CRYPTO_DData1_MSBitRead ( CRYPTO_TypeDef crypto)

Quick read the MSbit of the DDATA1 register.

This function reads the most significant bit (bit 255) of the DDATA1 register via the DDATA1MSB bit field in the DSTATUS register. This can be used to quickly check the signedness of a big integer resident in the CRYPTO module.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
Returns
Returns 'true' if MSbit is 1, and 'false' if MSbit is 0.

Definition at line 1004 of file em_crypto.h.

References _CRYPTO_DSTATUS_DDATA1MSB_MASK, _CRYPTO_DSTATUS_DDATA1MSB_SHIFT, and CRYPTO_TypeDef::DSTATUS.

__STATIC_INLINE void CRYPTO_DDataRead ( CRYPTO_DDataReg_TypeDef  ddataReg,
CRYPTO_DData_TypeDef  val 
)

Read 256 bits of data from a DDATAX register in the CRYPTO module.

Read 256 bits of data from a DDATAX (Double Data) register in the crypto module. The data value is typically output from a big integer operation (see crypto instructions).

Parameters
[in]ddataRegThe 256 bit DDATA register.
[out]valLocation where to store the value in memory.

Definition at line 795 of file em_crypto.h.

References CRYPTO_BurstFromCrypto().

Referenced by CRYPTO_DData0Read260(), and CRYPTO_SHA_256().

__STATIC_INLINE void CRYPTO_DDataWrite ( CRYPTO_DDataReg_TypeDef  ddataReg,
const CRYPTO_DData_TypeDef  val 
)

Write 256 bits of data to a DDATAX register in the CRYPTO module.

Write 256 bits of data into a DDATAX (Double Data) register in the crypto module. The data value is typically input to a big integer operation (see crypto instructions).

Parameters
[in]ddataRegThe 256 bit DDATA register.
[in]valValue of the data to write to the DDATA register.

Definition at line 776 of file em_crypto.h.

References CRYPTO_BurstToCrypto().

Referenced by CRYPTO_DData0Write260(), CRYPTO_KeyBufWrite(), CRYPTO_SHA_1(), and CRYPTO_SHA_256().

__STATIC_INLINE void CRYPTO_IncWidthSet ( CRYPTO_TypeDef crypto,
CRYPTO_IncWidth_TypeDef  incWidth 
)

Set the width of the DATA1 increment instruction DATA1INC.

This function sets the width of the DATA1 increment instruction CRYPTO_CMD_INSTR_DATA1INC.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[in]incWidthincrementation width.

Definition at line 658 of file em_crypto.h.

References _CRYPTO_CTRL_INCWIDTH_MASK, and CRYPTO_TypeDef::CTRL.

__STATIC_INLINE bool CRYPTO_InstructionSequenceDone ( CRYPTO_TypeDef crypto)

Check whether the execution of an instruction sequence has completed.

This function checks whether an instruction sequence has completed.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
Returns
Returns 'true' if the instruction sequence is done, and 'false' if not.

Definition at line 1069 of file em_crypto.h.

References CRYPTO_STATUS_INSTRRUNNING, CRYPTO_STATUS_SEQRUNNING, and CRYPTO_TypeDef::STATUS.

Referenced by CRYPTO_InstructionSequenceWait().

__STATIC_INLINE void CRYPTO_InstructionSequenceExecute ( CRYPTO_TypeDef crypto)

Execute the current programmed instruction sequence.

This function starts the execution of the current instruction sequence in the CRYPTO module.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.

Definition at line 1050 of file em_crypto.h.

References CRYPTO_TypeDef::CMD, and CRYPTO_CMD_SEQSTART.

Referenced by CRYPTO_Mul().

__STATIC_INLINE void CRYPTO_InstructionSequenceLoad ( CRYPTO_TypeDef crypto,
const CRYPTO_InstructionSequence_TypeDef  instructionSequence 
)

Load a sequence of instructions to be executed on the current values in the data registers.

This function loads a sequence of instructions to the crypto module. The instructions will be executed when the CRYPTO_InstructionSequenceExecute function is called. The first END marks the end of the sequence.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[in]instructionSequenceInstruction sequence to load.

Definition at line 1027 of file em_crypto.h.

References CRYPTO_TypeDef::SEQ0, CRYPTO_TypeDef::SEQ1, CRYPTO_TypeDef::SEQ2, CRYPTO_TypeDef::SEQ3, and CRYPTO_TypeDef::SEQ4.

__STATIC_INLINE void CRYPTO_InstructionSequenceWait ( CRYPTO_TypeDef crypto)

Wait for completion of the current sequence of instructions.

This function "busy"-waits until the execution of the ongoing instruction sequence has completed.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.

Definition at line 1087 of file em_crypto.h.

References CRYPTO_InstructionSequenceDone().

__STATIC_INLINE void CRYPTO_InstructionWait ( CRYPTO_TypeDef crypto)

Wait for completion of the current command.

This function "busy"-waits until the execution of the ongoing instruction has completed.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.

Definition at line 1104 of file em_crypto.h.

References CRYPTO_IF_INSTRDONE, CRYPTO_TypeDef::IF, and CRYPTO_TypeDef::IFC.

__STATIC_INLINE void CRYPTO_IntClear ( CRYPTO_TypeDef crypto,
uint32_t  flags 
)

Clear one or more pending CRYPTO interrupts.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[in]flagsPending CRYPTO interrupt source to clear. Use a bitwise logic OR combination of valid interrupt flags for the CRYPTO module (CRYPTO_IF_nnn).

Definition at line 1218 of file em_crypto.h.

References CRYPTO_TypeDef::IFC.

__STATIC_INLINE void CRYPTO_IntDisable ( CRYPTO_TypeDef crypto,
uint32_t  flags 
)

Disable one or more CRYPTO interrupts.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[in]flagsCRYPTO interrupt sources to disable. Use a bitwise logic OR combination of valid interrupt flags for the CRYPTO module (CRYPTO_IF_nnn).

Definition at line 1234 of file em_crypto.h.

References CRYPTO_TypeDef::IEN.

__STATIC_INLINE void CRYPTO_IntEnable ( CRYPTO_TypeDef crypto,
uint32_t  flags 
)

Enable one or more CRYPTO interrupts.

Note
Depending on the use, a pending interrupt may already be set prior to enabling the interrupt. Consider using CRYPTO_IntClear() prior to enabling if such a pending interrupt should be ignored.
Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[in]flagsCRYPTO interrupt sources to enable. Use a bitwise logic OR combination of valid interrupt flags for the CRYPTO module (CRYPTO_IF_nnn).

Definition at line 1255 of file em_crypto.h.

References CRYPTO_TypeDef::IEN.

__STATIC_INLINE uint32_t CRYPTO_IntGet ( CRYPTO_TypeDef crypto)

Get pending CRYPTO interrupt flags.

Note
The event bits are not cleared by the use of this function.
Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
Returns
CRYPTO interrupt sources pending. A bitwise logic OR combination of valid interrupt flags for the CRYPTO module (CRYPTO_IF_nnn).

Definition at line 1274 of file em_crypto.h.

References CRYPTO_TypeDef::IF.

__STATIC_INLINE uint32_t CRYPTO_IntGetEnabled ( CRYPTO_TypeDef crypto)

Get enabled and pending CRYPTO interrupt flags. Useful for handling more interrupt sources in the same interrupt handler.

Note
Interrupt flags are not cleared by the use of this function.
Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
Returns
Pending and enabled CRYPTO interrupt sources The return value is the bitwise AND of
  • the enabled interrupt sources in CRYPTO_IEN and
  • the pending interrupt flags CRYPTO_IF

Definition at line 1296 of file em_crypto.h.

References CRYPTO_TypeDef::IEN, and CRYPTO_TypeDef::IF.

__STATIC_INLINE void CRYPTO_IntSet ( CRYPTO_TypeDef crypto,
uint32_t  flags 
)

Set one or more pending CRYPTO interrupts from SW.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[in]flagsCRYPTO interrupt sources to set to pending. Use a bitwise logic OR combination of valid interrupt flags for the CRYPTO module (CRYPTO_IF_nnn).

Definition at line 1319 of file em_crypto.h.

References CRYPTO_TypeDef::IFS.

__STATIC_INLINE void CRYPTO_KeyBuf128Write ( CRYPTO_TypeDef crypto,
const uint32_t *  val 
)

Quick write 128 bit key to the CRYPTO module.

Quick write 128 bit key to the KEYBUF register in the CRYPTO module.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[in]valValue of the data to write to the KEYBUF register.

Definition at line 896 of file em_crypto.h.

References CRYPTO_BurstToCrypto(), and CRYPTO_TypeDef::KEYBUF.

__STATIC_INLINE void CRYPTO_KeyBufWrite ( CRYPTO_TypeDef crypto,
CRYPTO_KeyBuf_TypeDef  val,
CRYPTO_KeyWidth_TypeDef  keyWidth 
)

Set the key value to be used by the CRYPTO module.

Write 128 or 256 bit key to the KEYBUF register in the crypto module.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[in]valValue of the data to write to the KEYBUF register.
[in]keyWidthKey width - 128 or 256 bits

Definition at line 860 of file em_crypto.h.

References _CRYPTO_CTRL_AES_AES128, _CRYPTO_CTRL_AES_AES256, _CRYPTO_CTRL_AES_SHIFT, BUS_RegBitWrite(), CRYPTO_BurstToCrypto(), CRYPTO_DDataWrite(), cryptoKey256Bits, CRYPTO_TypeDef::CTRL, CRYPTO_TypeDef::DDATA4, and CRYPTO_TypeDef::KEYBUF.

Referenced by CRYPTO_AES_CBCx(), CRYPTO_AES_CFBx(), CRYPTO_AES_CTRx(), CRYPTO_AES_ECBx(), and CRYPTO_AES_OFBx().

void CRYPTO_KeyRead ( CRYPTO_TypeDef crypto,
CRYPTO_KeyBuf_TypeDef  val,
CRYPTO_KeyWidth_TypeDef  keyWidth 
)

Read the key value currently used by the CRYPTO module.

Read 128 bits or 256 bits from KEY register in the CRYPTO module.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[in]valValue of the data to write to the KEYBUF register.
[in]keyWidthKey width - 128 or 256 bits

Definition at line 244 of file em_crypto.c.

References CRYPTO_BurstFromCrypto(), cryptoKey256Bits, and CRYPTO_TypeDef::KEY.

void CRYPTO_ModulusSet ( CRYPTO_TypeDef crypto,
CRYPTO_ModulusId_TypeDef  modulusId 
)

Set the modulus type used for wide arithmetic operations.

Set the modulus used for wide modular operations.

This function sets the modulus type to be used by the Modulus instructions of the CRYPTO module.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[in]modTypeModulus type.

This function sets the modulus to be used by the modular instructions of the CRYPTO module.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[in]modulusIdModulus identifier.

Definition at line 190 of file em_crypto.c.

References _CRYPTO_WAC_MODOP_MASK, _CRYPTO_WAC_MODULUS_MASK, CRYPTO_WAC_MODOP_BINARY, CRYPTO_WAC_MODOP_REGULAR, cryptoModulusBin128, cryptoModulusBin256, cryptoModulusEccB163, cryptoModulusEccB163KOrder, cryptoModulusEccB163Order, cryptoModulusEccB233, cryptoModulusEccB233KOrder, cryptoModulusEccB233Order, cryptoModulusEccP192, cryptoModulusEccP192Order, cryptoModulusEccP224, cryptoModulusEccP224Order, cryptoModulusEccP256, cryptoModulusEccP256Order, cryptoModulusGcmBin128, and CRYPTO_TypeDef::WAC.

void CRYPTO_Mul ( CRYPTO_TypeDef crypto,
uint32_t *  A,
int  aSize,
uint32_t *  B,
int  bSize,
uint32_t *  R,
int  rSize 
)

Multiply two big integers.

This function uses the CRYPTO unit to multiply two big integer operands. If USE_VARIABLE_SIZED_DATA_LOADS is defined, the sizes of the operands may be any multiple of 32 bits. If USE_VARIABLE_SIZED_DATA_LOADS is not defined, the sizes of the operands must be a multiple of 128 bits.

Parameters
[in]Aoperand A
[in]aSizesize of operand A in bits
[in]Boperand B
[in]bSizesize of operand B in bits
[out]Rresult of multiplication
[in]rSizesize of result buffer R in bits

Definition at line 558 of file em_crypto.c.

References CRYPTO_TypeDef::CMD, CRYPTO_CarryIsSet(), CRYPTO_CMD_INSTR_ADDIC, CRYPTO_CMD_INSTR_CCLR, CRYPTO_CMD_INSTR_CLR, CRYPTO_CMD_INSTR_DATA1TODATA0, CRYPTO_CMD_INSTR_DATATODMA0, CRYPTO_CMD_INSTR_DDATA0TODDATA2, CRYPTO_CMD_INSTR_DDATA2TODDATA1, CRYPTO_CMD_INSTR_DMA0TODATA, CRYPTO_CMD_INSTR_DMA1TODATA, CRYPTO_CMD_INSTR_MULO, CRYPTO_CMD_INSTR_SELDDATA0DDATA2, CRYPTO_CMD_INSTR_SELDDATA1DDATA3, CRYPTO_CMD_INSTR_SELDDATA2DDATA3, CRYPTO_CTRL_DMA0MODE_FULL, CRYPTO_CTRL_DMA0RSEL_DATA0, CRYPTO_CTRL_DMA1MODE_FULL, CRYPTO_CTRL_DMA1RSEL_DATA1, CRYPTO_DataRead(), CRYPTO_DataWrite(), CRYPTO_InstructionSequenceExecute(), CRYPTO_SEQCTRL_BLOCKSIZE_16BYTES, CRYPTO_WAC_MULWIDTH_MUL128, CRYPTO_WAC_RESULTWIDTH_256BIT, cryptoBigintIncrement(), cryptoBigintZeroize(), CRYPTO_TypeDef::CTRL, CRYPTO_TypeDef::DATA0, CRYPTO_TypeDef::DATA1, CRYPTO_TypeDef::DATA2, CRYPTO_TypeDef::SEQCTRL, and CRYPTO_TypeDef::WAC.

__STATIC_INLINE void CRYPTO_MulOperandWidthSet ( CRYPTO_TypeDef crypto,
CRYPTO_MulOperandWidth_TypeDef  mulOperandWidth 
)

Set the number of bits in the operands of the MUL instruction.

This function sets the number of bits to be used in the operands of the MUL instruction.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[in]mulOperandWidthMultiplication width in bits.

Definition at line 616 of file em_crypto.h.

References _CRYPTO_WAC_MULWIDTH_MASK, and CRYPTO_TypeDef::WAC.

__STATIC_INLINE void CRYPTO_QDataRead ( CRYPTO_QDataReg_TypeDef  qdataReg,
CRYPTO_QData_TypeDef  val 
)

Read 512 bits of data from a QDATAX register in the CRYPTO module.

Read 512 bits of data from a QDATAX register in the crypto module. The data value is typically input to a big integer operation (see crypto instructions).

Parameters
[in]qdataRegThe 512 bits QDATA register.
[in]valValue of the data to write to the QDATA register.

Definition at line 835 of file em_crypto.h.

References CRYPTO_BurstFromCrypto().

__STATIC_INLINE void CRYPTO_QDataWrite ( CRYPTO_QDataReg_TypeDef  qdataReg,
CRYPTO_QData_TypeDef  val 
)

Write 512 bits of data to a QDATAX register in the CRYPTO module.

Write 512 bits of data into a QDATAX (Quad Data) register in the crypto module The data value is typically input to a big integer operation (see crypto instructions).

Parameters
[in]qdataRegThe 512 bits QDATA register.
[in]valValue of the data to write to the QDATA register.

Definition at line 814 of file em_crypto.h.

References CRYPTO_BurstToCrypto().

Referenced by CRYPTO_SHA_1(), and CRYPTO_SHA_256().

__STATIC_INLINE void CRYPTO_ResultWidthSet ( CRYPTO_TypeDef crypto,
CRYPTO_ResultWidth_TypeDef  resultWidth 
)

Set the width of the results of the non-modulus instructions.

This function sets the result width of the non-modulus instructions.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[in]resultWidthResult width of non-modulus instructions.

Definition at line 637 of file em_crypto.h.

References _CRYPTO_WAC_RESULTWIDTH_MASK, and CRYPTO_TypeDef::WAC.

Referenced by CRYPTO_SHA_1(), and CRYPTO_SHA_256().

void CRYPTO_SHA_1 ( CRYPTO_TypeDef crypto,
const uint8_t *  msg,
uint64_t  msgLen,
CRYPTO_SHA1_Digest_TypeDef  msgDigest 
)

Perform a SHA-1 hash operation on a message.

This function performs a SHA-1 hash operation on the message specified by msg with length msgLen, and returns the message digest in msgDigest.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[in]msgMessage to hash.
[in]msgLenLength of message in bytes.
[out]msgDigestMessage digest.

Definition at line 277 of file em_crypto.c.

References CRYPTO_CMD_INSTR_DDATA0TODDATA1, CRYPTO_CMD_INSTR_DDATA1TODDATA0, CRYPTO_CMD_INSTR_MADD32, CRYPTO_CMD_INSTR_SELDDATA0DDATA1, CRYPTO_CMD_INSTR_SHA, CRYPTO_CTRL_SHA_SHA1, CRYPTO_DDataWrite(), CRYPTO_QDataWrite(), CRYPTO_ResultWidthSet(), cryptoResult256Bits, CRYPTO_TypeDef::CTRL, CRYPTO_TypeDef::DDATA0BIG, CRYPTO_TypeDef::DDATA1, CRYPTO_TypeDef::QDATA1BIG, CRYPTO_TypeDef::SEQCTRL, and CRYPTO_TypeDef::SEQCTRLB.

void CRYPTO_SHA_256 ( CRYPTO_TypeDef crypto,
const uint8_t *  msg,
uint64_t  msgLen,
CRYPTO_SHA256_Digest_TypeDef  msgDigest 
)

Perform a SHA-256 hash operation on a message.

This function performs a SHA-256 hash operation on the message specified by msg with length msgLen, and returns the message digest in msgDigest.

Parameters
[in]cryptoPointer to CRYPTO peripheral register block.
[in]msgMessage to hash.
[in]msgLenLength of message in bytes.
[out]msgDigestMessage digest.

Definition at line 407 of file em_crypto.c.

References CRYPTO_CMD_INSTR_DDATA0TODDATA1, CRYPTO_CMD_INSTR_DDATA1TODDATA0, CRYPTO_CMD_INSTR_MADD32, CRYPTO_CMD_INSTR_SELDDATA0DDATA1, CRYPTO_CMD_INSTR_SHA, CRYPTO_CTRL_SHA_SHA2, CRYPTO_DDataRead(), CRYPTO_DDataWrite(), CRYPTO_QDataWrite(), CRYPTO_ResultWidthSet(), cryptoResult256Bits, CRYPTO_TypeDef::CTRL, CRYPTO_TypeDef::DDATA0BIG, CRYPTO_TypeDef::DDATA1, CRYPTO_TypeDef::QDATA1BIG, CRYPTO_TypeDef::SEQCTRL, and CRYPTO_TypeDef::SEQCTRLB.

__STATIC_INLINE void cryptoBigintIncrement ( uint32_t *  words32bits,
int  num32bitWords 
)

Increment value of 32bit word array by one.

Parameters
[in]words32bitsPointer to 32bit word array
[in]num32bitWordsNumber of 32bit words in array

Definition at line 531 of file em_crypto.c.

Referenced by CRYPTO_Mul().

__STATIC_INLINE void cryptoBigintZeroize ( uint32_t *  words32bits,
int  num32bitWords 
)

Set 32bit word array to zero.

Parameters
[in]words32bitsPointer to 32bit word array
[in]num32bitWordsNumber of 32bit words in array

Definition at line 517 of file em_crypto.c.

Referenced by CRYPTO_Mul().