#include <LoRaMacCrypto.h>
| Public Member Functions | |
| LoRaMacCrypto () | |
| Constructor.  More... | |
| ~LoRaMacCrypto () | |
| Destructor.  More... | |
| int | compute_mic (const uint8_t *buffer, uint16_t size, const uint8_t *key, uint32_t key_length, uint32_t address, uint8_t dir, uint32_t seq_counter, uint32_t *mic) | 
| Computes the LoRaMAC frame MIC field.  More... | |
| int | encrypt_payload (const uint8_t *buffer, uint16_t size, const uint8_t *key, uint32_t key_length, uint32_t address, uint8_t dir, uint32_t seq_counter, uint8_t *enc_buffer) | 
| Performs payload encryption.  More... | |
| int | decrypt_payload (const uint8_t *buffer, uint16_t size, const uint8_t *key, uint32_t key_length, uint32_t address, uint8_t dir, uint32_t seq_counter, uint8_t *dec_buffer) | 
| Performs payload decryption.  More... | |
| int | compute_join_frame_mic (const uint8_t *buffer, uint16_t size, const uint8_t *key, uint32_t key_length, uint32_t *mic) | 
| Computes the LoRaMAC Join Request frame MIC field.  More... | |
| int | decrypt_join_frame (const uint8_t *buffer, uint16_t size, const uint8_t *key, uint32_t key_length, uint8_t *dec_buffer) | 
| Computes the LoRaMAC join frame decryption.  More... | |
| int | compute_skeys_for_join_frame (const uint8_t *key, uint32_t key_length, const uint8_t *app_nonce, uint16_t dev_nonce, uint8_t *nwk_skey, uint8_t *app_skey) | 
| Computes the LoRaMAC join frame decryption.  More... | |
Description: LoRa MAC Crypto implementation
License: Revised BSD License, see LICENSE.TXT file include in the project
Maintainer: Miguel Luis ( Semtech ), Gregory Cristian ( Semtech ) and Daniel Jaeckle ( STACKFORCE )
Copyright (c) 2017, Arm Limited and affiliates.
SPDX-License-Identifier: BSD-3-Clause
Definition at line 38 of file LoRaMacCrypto.h.
| LoRaMacCrypto | ( | ) | 
Constructor.
| ~LoRaMacCrypto | ( | ) | 
Destructor.
| int compute_join_frame_mic | ( | const uint8_t * | buffer, | 
| uint16_t | size, | ||
| const uint8_t * | key, | ||
| uint32_t | key_length, | ||
| uint32_t * | mic | ||
| ) | 
Computes the LoRaMAC Join Request frame MIC field.
| [in] | buffer | - Data buffer | 
| [in] | size | - Data buffer size | 
| [in] | key | - AES key to be used | 
| [in] | key_length | - Length of the key (bits) | 
| [out] | mic | - Computed MIC field | 
| int compute_mic | ( | const uint8_t * | buffer, | 
| uint16_t | size, | ||
| const uint8_t * | key, | ||
| uint32_t | key_length, | ||
| uint32_t | address, | ||
| uint8_t | dir, | ||
| uint32_t | seq_counter, | ||
| uint32_t * | mic | ||
| ) | 
Computes the LoRaMAC frame MIC field.
| [in] | buffer | - Data buffer | 
| [in] | size | - Data buffer size | 
| [in] | key | - AES key to be used | 
| [in] | key_length | - Length of the key (bits) | 
| [in] | address | - Frame address | 
| [in] | dir | - Frame direction [0: uplink, 1: downlink] | 
| [in] | seq_counter | - Frame sequence counter | 
| [out] | mic | - Computed MIC field | 
| int compute_skeys_for_join_frame | ( | const uint8_t * | key, | 
| uint32_t | key_length, | ||
| const uint8_t * | app_nonce, | ||
| uint16_t | dev_nonce, | ||
| uint8_t * | nwk_skey, | ||
| uint8_t * | app_skey | ||
| ) | 
Computes the LoRaMAC join frame decryption.
| [in] | key | - AES key to be used | 
| [in] | key_length | - Length of the key (bits) | 
| [in] | app_nonce | - Application nonce | 
| [in] | dev_nonce | - Device nonce | 
| [out] | nwk_skey | - Network session key | 
| [out] | app_skey | - Application session key | 
| int decrypt_join_frame | ( | const uint8_t * | buffer, | 
| uint16_t | size, | ||
| const uint8_t * | key, | ||
| uint32_t | key_length, | ||
| uint8_t * | dec_buffer | ||
| ) | 
Computes the LoRaMAC join frame decryption.
| [in] | buffer | - Data buffer | 
| [in] | size | - Data buffer size | 
| [in] | key | - AES key to be used | 
| [in] | key_length | - Length of the key (bits) | 
| [out] | dec_buffer | - Decrypted buffer | 
| int decrypt_payload | ( | const uint8_t * | buffer, | 
| uint16_t | size, | ||
| const uint8_t * | key, | ||
| uint32_t | key_length, | ||
| uint32_t | address, | ||
| uint8_t | dir, | ||
| uint32_t | seq_counter, | ||
| uint8_t * | dec_buffer | ||
| ) | 
Performs payload decryption.
| [in] | buffer | - Data buffer | 
| [in] | size | - Data buffer size | 
| [in] | key | - AES key to be used | 
| [in] | key_length | - Length of the key (bits) | 
| [in] | address | - Frame address | 
| [in] | dir | - Frame direction [0: uplink, 1: downlink] | 
| [in] | seq_counter | - Frame sequence counter | 
| [out] | dec_buffer | - Decrypted buffer | 
| int encrypt_payload | ( | const uint8_t * | buffer, | 
| uint16_t | size, | ||
| const uint8_t * | key, | ||
| uint32_t | key_length, | ||
| uint32_t | address, | ||
| uint8_t | dir, | ||
| uint32_t | seq_counter, | ||
| uint8_t * | enc_buffer | ||
| ) | 
Performs payload encryption.
| [in] | buffer | - Data buffer | 
| [in] | size | - Data buffer size | 
| [in] | key | - AES key to be used | 
| [in] | key_length | - Length of the key (bits) | 
| [in] | address | - Frame address | 
| [in] | dir | - Frame direction [0: uplink, 1: downlink] | 
| [in] | seq_counter | - Frame sequence counter | 
| [out] | enc_buffer | - Encrypted buffer |