summaryrefslogtreecommitdiff
path: root/msp340/AndreiLEDs/driverlib/MSP430FR5xx_6xx/aes256.h
diff options
context:
space:
mode:
Diffstat (limited to 'msp340/AndreiLEDs/driverlib/MSP430FR5xx_6xx/aes256.h')
-rwxr-xr-xmsp340/AndreiLEDs/driverlib/MSP430FR5xx_6xx/aes256.h418
1 files changed, 418 insertions, 0 deletions
diff --git a/msp340/AndreiLEDs/driverlib/MSP430FR5xx_6xx/aes256.h b/msp340/AndreiLEDs/driverlib/MSP430FR5xx_6xx/aes256.h
new file mode 100755
index 0000000..99e3007
--- /dev/null
+++ b/msp340/AndreiLEDs/driverlib/MSP430FR5xx_6xx/aes256.h
@@ -0,0 +1,418 @@
+/* --COPYRIGHT--,BSD
+ * Copyright (c) 2014, Texas Instruments Incorporated
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ *
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ *
+ * * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * * Neither the name of Texas Instruments Incorporated nor the names of
+ * its contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
+ * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
+ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
+ * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+ * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
+ * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
+ * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
+ * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ * --/COPYRIGHT--*/
+//*****************************************************************************
+//
+// aes256.h - Driver for the AES256 Module.
+//
+//*****************************************************************************
+
+#ifndef __MSP430WARE_AES256_H__
+#define __MSP430WARE_AES256_H__
+
+#include "inc/hw_memmap.h"
+
+#ifdef __MSP430_HAS_AES256__
+
+//*****************************************************************************
+//
+// If building with a C++ compiler, make all of the definitions in this header
+// have a C binding.
+//
+//*****************************************************************************
+#ifdef __cplusplus
+extern "C"
+{
+#endif
+
+//*****************************************************************************
+//
+// The following are values that can be passed to the keyLength parameter for
+// functions: AES256_setCipherKey(), AES256_setDecipherKey(), and
+// AES256_startSetDecipherKey().
+//
+//*****************************************************************************
+#define AES256_KEYLENGTH_128BIT 128
+#define AES256_KEYLENGTH_192BIT 192
+#define AES256_KEYLENGTH_256BIT 256
+
+//*****************************************************************************
+//
+// The following are values that can be passed toThe following are values that
+// can be returned by the AES256_getErrorFlagStatus() function.
+//
+//*****************************************************************************
+#define AES256_ERROR_OCCURRED AESERRFG
+#define AES256_NO_ERROR 0x00
+
+//*****************************************************************************
+//
+// The following are values that can be passed toThe following are values that
+// can be returned by the AES256_isBusy() function.
+//
+//*****************************************************************************
+#define AES256_BUSY AESBUSY
+#define AES256_NOT_BUSY 0x00
+
+//*****************************************************************************
+//
+// The following are values that can be passed toThe following are values that
+// can be returned by the AES256_getInterruptStatus() function.
+//
+//*****************************************************************************
+#define AES256_READY_INTERRUPT AESRDYIE
+#define AES256_NOTREADY_INTERRUPT 0x00
+
+//*****************************************************************************
+//
+// Prototypes for the APIs.
+//
+//*****************************************************************************
+
+//*****************************************************************************
+//
+//! \brief Loads a 128, 192 or 256 bit cipher key to AES256 module.
+//!
+//! This function loads a 128, 192 or 256 bit cipher key to AES256 module.
+//! Requires both a key as well as the length of the key provided. Acceptable
+//! key lengths are AES256_KEYLENGTH_128BIT, AES256_KEYLENGTH_192BIT, or
+//! AES256_KEYLENGTH_256BIT
+//!
+//! \param baseAddress is the base address of the AES256 module.
+//! \param cipherKey is a pointer to an uint8_t array with a length of 16 bytes
+//! that contains a 128 bit cipher key.
+//! \param keyLength is the length of the key.
+//! Valid values are:
+//! - \b AES256_KEYLENGTH_128BIT
+//! - \b AES256_KEYLENGTH_192BIT
+//! - \b AES256_KEYLENGTH_256BIT
+//!
+//! \return STATUS_SUCCESS or STATUS_FAIL of key loading
+//
+//*****************************************************************************
+extern uint8_t AES256_setCipherKey(uint16_t baseAddress,
+ const uint8_t *cipherKey,
+ uint16_t keyLength);
+
+//*****************************************************************************
+//
+//! \brief Encrypts a block of data using the AES256 module.
+//!
+//! The cipher key that is used for encryption should be loaded in advance by
+//! using function AES256_setCipherKey()
+//!
+//! \param baseAddress is the base address of the AES256 module.
+//! \param data is a pointer to an uint8_t array with a length of 16 bytes that
+//! contains data to be encrypted.
+//! \param encryptedData is a pointer to an uint8_t array with a length of 16
+//! bytes in that the encrypted data will be written.
+//!
+//! \return None
+//
+//*****************************************************************************
+extern void AES256_encryptData(uint16_t baseAddress,
+ const uint8_t *data,
+ uint8_t *encryptedData);
+
+//*****************************************************************************
+//
+//! \brief Decrypts a block of data using the AES256 module.
+//!
+//! This function requires a pregenerated decryption key. A key can be loaded
+//! and pregenerated by using function AES256_setDecipherKey() or
+//! AES256_startSetDecipherKey(). The decryption takes 167 MCLK.
+//!
+//! \param baseAddress is the base address of the AES256 module.
+//! \param data is a pointer to an uint8_t array with a length of 16 bytes that
+//! contains encrypted data to be decrypted.
+//! \param decryptedData is a pointer to an uint8_t array with a length of 16
+//! bytes in that the decrypted data will be written.
+//!
+//! \return None
+//
+//*****************************************************************************
+extern void AES256_decryptData(uint16_t baseAddress,
+ const uint8_t *data,
+ uint8_t *decryptedData);
+
+//*****************************************************************************
+//
+//! \brief Sets the decipher key.
+//!
+//! The API AES256_startSetDecipherKey or AES256_setDecipherKey must be invoked
+//! before invoking AES256_startDecryptData.
+//!
+//! \param baseAddress is the base address of the AES256 module.
+//! \param cipherKey is a pointer to an uint8_t array with a length of 16 bytes
+//! that contains a 128 bit cipher key.
+//! \param keyLength is the length of the key.
+//! Valid values are:
+//! - \b AES256_KEYLENGTH_128BIT
+//! - \b AES256_KEYLENGTH_192BIT
+//! - \b AES256_KEYLENGTH_256BIT
+//!
+//! \return STATUS_SUCCESS or STATUS_FAIL of key loading
+//
+//*****************************************************************************
+extern uint8_t AES256_setDecipherKey(uint16_t baseAddress,
+ const uint8_t *cipherKey,
+ uint16_t keyLength);
+
+//*****************************************************************************
+//
+//! \brief Clears the AES256 ready interrupt flag.
+//!
+//! This function clears the AES256 ready interrupt flag. This flag is
+//! automatically cleared when AES256ADOUT is read, or when AES256AKEY or
+//! AES256ADIN is written. This function should be used when the flag needs to
+//! be reset and it has not been automatically cleared by one of the previous
+//! actions.
+//!
+//! \param baseAddress is the base address of the AES256 module.
+//!
+//! Modified bits are \b AESRDYIFG of \b AESACTL0 register.
+//!
+//! \return None
+//
+//*****************************************************************************
+extern void AES256_clearInterrupt(uint16_t baseAddress);
+
+//*****************************************************************************
+//
+//! \brief Gets the AES256 ready interrupt flag status.
+//!
+//! This function checks the AES256 ready interrupt flag. This flag is
+//! automatically cleared when AES256ADOUT is read, or when AES256AKEY or
+//! AES256ADIN is written. This function can be used to confirm that this has
+//! been done.
+//!
+//! \param baseAddress is the base address of the AES256 module.
+//!
+//! \return One of the following:
+//! - \b AES256_READY_INTERRUPT
+//! - \b AES256_NOTREADY_INTERRUPT
+//! \n indicating the status of the AES256 ready status
+//
+//*****************************************************************************
+extern uint32_t AES256_getInterruptStatus(uint16_t baseAddress);
+
+//*****************************************************************************
+//
+//! \brief Enables AES256 ready interrupt.
+//!
+//! Enables AES256 ready interrupt. This interrupt is reset by a PUC, but not
+//! reset by AES256_reset.
+//!
+//! \param baseAddress is the base address of the AES256 module.
+//!
+//! Modified bits are \b AESRDYIE of \b AESACTL0 register.
+//!
+//! \return None
+//
+//*****************************************************************************
+extern void AES256_enableInterrupt(uint16_t baseAddress);
+
+//*****************************************************************************
+//
+//! \brief Disables AES256 ready interrupt.
+//!
+//! Disables AES256 ready interrupt. This interrupt is reset by a PUC, but not
+//! reset by AES256_reset.
+//!
+//! \param baseAddress is the base address of the AES256 module.
+//!
+//! Modified bits are \b AESRDYIE of \b AESACTL0 register.
+//!
+//! \return None
+//
+//*****************************************************************************
+extern void AES256_disableInterrupt(uint16_t baseAddress);
+
+//*****************************************************************************
+//
+//! \brief Resets AES256 Module immediately.
+//!
+//! This function performs a software reset on the AES256 Module, note that
+//! this does not affect the AES256 ready interrupt.
+//!
+//! \param baseAddress is the base address of the AES256 module.
+//!
+//! Modified bits are \b AESSWRST of \b AESACTL0 register.
+//!
+//! \return None
+//
+//*****************************************************************************
+extern void AES256_reset(uint16_t baseAddress);
+
+//*****************************************************************************
+//
+//! \brief Starts an encryption process on the AES256 module.
+//!
+//! The cipher key that is used for decryption should be loaded in advance by
+//! using function AES256_setCipherKey(). This is a non-blocking equivalent of
+//! AES256_encryptData(). It is recommended to use the interrupt functionality
+//! to check for procedure completion then use the AES256_getDataOut() API to
+//! retrieve the encrypted data.
+//!
+//! \param baseAddress is the base address of the AES256 module.
+//! \param data is a pointer to an uint8_t array with a length of 16 bytes that
+//! contains data to be encrypted.
+//!
+//! \return None
+//
+//*****************************************************************************
+extern void AES256_startEncryptData(uint16_t baseAddress,
+ const uint8_t *data);
+
+//*****************************************************************************
+//
+//! \brief Decrypts a block of data using the AES256 module.
+//!
+//! This is the non-blocking equivalent of AES256_decryptData(). This function
+//! requires a pregenerated decryption key. A key can be loaded and
+//! pregenerated by using function AES256_setDecipherKey() or
+//! AES256_startSetDecipherKey(). The decryption takes 167 MCLK. It is
+//! recommended to use interrupt to check for procedure completion then use the
+//! AES256_getDataOut() API to retrieve the decrypted data.
+//!
+//! \param baseAddress is the base address of the AES256 module.
+//! \param data is a pointer to an uint8_t array with a length of 16 bytes that
+//! contains encrypted data to be decrypted.
+//!
+//! \return None
+//
+//*****************************************************************************
+extern void AES256_startDecryptData(uint16_t baseAddress,
+ const uint8_t *data);
+
+//*****************************************************************************
+//
+//! \brief Sets the decipher key
+//!
+//! The API AES256_startSetDecipherKey() or AES256_setDecipherKey() must be
+//! invoked before invoking AES256_startDecryptData.
+//!
+//! \param baseAddress is the base address of the AES256 module.
+//! \param cipherKey is a pointer to an uint8_t array with a length of 16 bytes
+//! that contains a 128 bit cipher key.
+//! \param keyLength is the length of the key.
+//! Valid values are:
+//! - \b AES256_KEYLENGTH_128BIT
+//! - \b AES256_KEYLENGTH_192BIT
+//! - \b AES256_KEYLENGTH_256BIT
+//!
+//! \return STATUS_SUCCESS or STATUS_FAIL of key loading
+//
+//*****************************************************************************
+extern uint8_t AES256_startSetDecipherKey(uint16_t baseAddress,
+ const uint8_t *cipherKey,
+ uint16_t keyLength);
+
+//*****************************************************************************
+//
+//! \brief Reads back the output data from AES256 module.
+//!
+//! This function is meant to use after an encryption or decryption process
+//! that was started and finished by initiating an interrupt by use of
+//! AES256_startEncryptData or AES256_startDecryptData functions.
+//!
+//! \param baseAddress is the base address of the AES256 module.
+//! \param outputData is a pointer to an uint8_t array with a length of 16
+//! bytes in that the data will be written.
+//!
+//! \return STATUS_SUCCESS if data is valid, otherwise STATUS_FAIL
+//
+//*****************************************************************************
+extern uint8_t AES256_getDataOut(uint16_t baseAddress,
+ uint8_t *outputData);
+
+//*****************************************************************************
+//
+//! \brief Gets the AES256 module busy status.
+//!
+//! Gets the AES256 module busy status. If a key or data are written while the
+//! AES256 module is busy, an error flag will be thrown.
+//!
+//! \param baseAddress is the base address of the AES256 module.
+//!
+//! \return One of the following:
+//! - \b AES256_BUSY
+//! - \b AES256_NOT_BUSY
+//! \n indicating if the AES256 module is busy
+//
+//*****************************************************************************
+extern uint16_t AES256_isBusy(uint16_t baseAddress);
+
+//*****************************************************************************
+//
+//! \brief Clears the AES256 error flag.
+//!
+//! Clears the AES256 error flag that results from a key or data being written
+//! while the AES256 module is busy.
+//!
+//! \param baseAddress is the base address of the AES256 module.
+//!
+//! Modified bits are \b AESERRFG of \b AESACTL0 register.
+//!
+//! \return None
+//
+//*****************************************************************************
+extern void AES256_clearErrorFlag(uint16_t baseAddress);
+
+//*****************************************************************************
+//
+//! \brief Gets the AES256 error flag status.
+//!
+//! Checks the AES256 error flag that results from a key or data being written
+//! while the AES256 module is busy. If the flag is set, it needs to be cleared
+//! using AES256_clearErrorFlag.
+//!
+//! \param baseAddress is the base address of the AES256 module.
+//!
+//! \return One of the following:
+//! - \b AES256_ERROR_OCCURRED
+//! - \b AES256_NO_ERROR
+//! \n indicating the error flag status
+//
+//*****************************************************************************
+extern uint32_t AES256_getErrorFlagStatus(uint16_t baseAddress);
+
+//*****************************************************************************
+//
+// Mark the end of the C bindings section for C++ compilers.
+//
+//*****************************************************************************
+#ifdef __cplusplus
+}
+#endif
+
+#endif
+#endif // __MSP430WARE_AES256_H__