A Port of TI's Webserver for the CC3000

Dependencies:   mbed

Committer:
dflet
Date:
Mon Sep 16 18:37:14 2013 +0000
Revision:
2:e6a185df9e4c
Parent:
0:6ad60d78b315
ADC and Leds now work on board and config.html page.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
dflet 0:6ad60d78b315 1 /*****************************************************************************
dflet 0:6ad60d78b315 2 *
dflet 0:6ad60d78b315 3 * security.h - CC3000 Host Driver Implementation.
dflet 0:6ad60d78b315 4 * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/
dflet 0:6ad60d78b315 5 *
dflet 0:6ad60d78b315 6 * Redistribution and use in source and binary forms, with or without
dflet 0:6ad60d78b315 7 * modification, are permitted provided that the following conditions
dflet 0:6ad60d78b315 8 * are met:
dflet 0:6ad60d78b315 9 *
dflet 0:6ad60d78b315 10 * Redistributions of source code must retain the above copyright
dflet 0:6ad60d78b315 11 * notice, this list of conditions and the following disclaimer.
dflet 0:6ad60d78b315 12 *
dflet 0:6ad60d78b315 13 * Redistributions in binary form must reproduce the above copyright
dflet 0:6ad60d78b315 14 * notice, this list of conditions and the following disclaimer in the
dflet 0:6ad60d78b315 15 * documentation and/or other materials provided with the
dflet 0:6ad60d78b315 16 * distribution.
dflet 0:6ad60d78b315 17 *
dflet 0:6ad60d78b315 18 * Neither the name of Texas Instruments Incorporated nor the names of
dflet 0:6ad60d78b315 19 * its contributors may be used to endorse or promote products derived
dflet 0:6ad60d78b315 20 * from this software without specific prior written permission.
dflet 0:6ad60d78b315 21 *
dflet 0:6ad60d78b315 22 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
dflet 0:6ad60d78b315 23 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
dflet 0:6ad60d78b315 24 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
dflet 0:6ad60d78b315 25 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
dflet 0:6ad60d78b315 26 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
dflet 0:6ad60d78b315 27 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
dflet 0:6ad60d78b315 28 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
dflet 0:6ad60d78b315 29 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
dflet 0:6ad60d78b315 30 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
dflet 0:6ad60d78b315 31 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
dflet 0:6ad60d78b315 32 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
dflet 0:6ad60d78b315 33 *
dflet 0:6ad60d78b315 34 *****************************************************************************/
dflet 0:6ad60d78b315 35 #ifndef __SECURITY__
dflet 0:6ad60d78b315 36 #define __SECURITY__
dflet 0:6ad60d78b315 37
dflet 0:6ad60d78b315 38 #include "nvmem.h"
dflet 0:6ad60d78b315 39
dflet 0:6ad60d78b315 40 //*****************************************************************************
dflet 0:6ad60d78b315 41 //
dflet 0:6ad60d78b315 42 // If building with a C++ compiler, make all of the definitions in this header
dflet 0:6ad60d78b315 43 // have a C binding.
dflet 0:6ad60d78b315 44 //
dflet 0:6ad60d78b315 45 //*****************************************************************************
dflet 0:6ad60d78b315 46 #ifdef __cplusplus
dflet 0:6ad60d78b315 47 extern "C" {
dflet 0:6ad60d78b315 48 #endif
dflet 0:6ad60d78b315 49
dflet 0:6ad60d78b315 50
dflet 0:6ad60d78b315 51 #define AES128_KEY_SIZE 16
dflet 0:6ad60d78b315 52
dflet 0:6ad60d78b315 53 #ifndef CC3000_UNENCRYPTED_SMART_CONFIG
dflet 0:6ad60d78b315 54
dflet 0:6ad60d78b315 55
dflet 0:6ad60d78b315 56 //*****************************************************************************
dflet 0:6ad60d78b315 57 //
dflet 0:6ad60d78b315 58 //! aes_encrypt
dflet 0:6ad60d78b315 59 //!
dflet 0:6ad60d78b315 60 //! @param[in] key AES128 key of size 16 bytes
dflet 0:6ad60d78b315 61 //! @param[in\out] state 16 bytes of plain text and cipher text
dflet 0:6ad60d78b315 62 //!
dflet 0:6ad60d78b315 63 //! @return none
dflet 0:6ad60d78b315 64 //!
dflet 0:6ad60d78b315 65 //! @brief AES128 encryption:
dflet 0:6ad60d78b315 66 //! Given AES128 key and 16 bytes plain text, cipher text of 16 bytes
dflet 0:6ad60d78b315 67 //! is computed. The AES implementation is in mode ECB (Electronic
dflet 0:6ad60d78b315 68 //! Code Book).
dflet 0:6ad60d78b315 69 //!
dflet 0:6ad60d78b315 70 //!
dflet 0:6ad60d78b315 71 //*****************************************************************************
dflet 0:6ad60d78b315 72 extern void aes_encrypt(unsigned char *state, unsigned char *key);
dflet 0:6ad60d78b315 73
dflet 0:6ad60d78b315 74 //*****************************************************************************
dflet 0:6ad60d78b315 75 //
dflet 0:6ad60d78b315 76 //! aes_decrypt
dflet 0:6ad60d78b315 77 //!
dflet 0:6ad60d78b315 78 //! @param[in] key AES128 key of size 16 bytes
dflet 0:6ad60d78b315 79 //! @param[in\out] state 16 bytes of cipher text and plain text
dflet 0:6ad60d78b315 80 //!
dflet 0:6ad60d78b315 81 //! @return none
dflet 0:6ad60d78b315 82 //!
dflet 0:6ad60d78b315 83 //! @brief AES128 decryption:
dflet 0:6ad60d78b315 84 //! Given AES128 key and 16 bytes cipher text, plain text of 16 bytes
dflet 0:6ad60d78b315 85 //! is computed The AES implementation is in mode ECB
dflet 0:6ad60d78b315 86 //! (Electronic Code Book).
dflet 0:6ad60d78b315 87 //!
dflet 0:6ad60d78b315 88 //!
dflet 0:6ad60d78b315 89 //*****************************************************************************
dflet 0:6ad60d78b315 90 extern void aes_decrypt(unsigned char *state, unsigned char *key);
dflet 0:6ad60d78b315 91
dflet 0:6ad60d78b315 92
dflet 0:6ad60d78b315 93 //*****************************************************************************
dflet 0:6ad60d78b315 94 //
dflet 0:6ad60d78b315 95 //! aes_read_key
dflet 0:6ad60d78b315 96 //!
dflet 0:6ad60d78b315 97 //! @param[out] key AES128 key of size 16 bytes
dflet 0:6ad60d78b315 98 //!
dflet 0:6ad60d78b315 99 //! @return on success 0, error otherwise.
dflet 0:6ad60d78b315 100 //!
dflet 0:6ad60d78b315 101 //! @brief Reads AES128 key from EEPROM
dflet 0:6ad60d78b315 102 //! Reads the AES128 key from fileID #12 in EEPROM
dflet 0:6ad60d78b315 103 //! returns an error if the key does not exist.
dflet 0:6ad60d78b315 104 //!
dflet 0:6ad60d78b315 105 //!
dflet 0:6ad60d78b315 106 //*****************************************************************************
dflet 0:6ad60d78b315 107 extern signed long aes_read_key(unsigned char *key);
dflet 0:6ad60d78b315 108
dflet 0:6ad60d78b315 109 //*****************************************************************************
dflet 0:6ad60d78b315 110 //
dflet 0:6ad60d78b315 111 //! aes_write_key
dflet 0:6ad60d78b315 112 //!
dflet 0:6ad60d78b315 113 //! @param[out] key AES128 key of size 16 bytes
dflet 0:6ad60d78b315 114 //!
dflet 0:6ad60d78b315 115 //! @return on success 0, error otherwise.
dflet 0:6ad60d78b315 116 //!
dflet 0:6ad60d78b315 117 //! @brief writes AES128 key from EEPROM
dflet 0:6ad60d78b315 118 //! Writes the AES128 key to fileID #12 in EEPROM
dflet 0:6ad60d78b315 119 //!
dflet 0:6ad60d78b315 120 //!
dflet 0:6ad60d78b315 121 //*****************************************************************************
dflet 0:6ad60d78b315 122 extern signed long aes_write_key(unsigned char *key);
dflet 0:6ad60d78b315 123
dflet 0:6ad60d78b315 124 #endif //CC3000_UNENCRYPTED_SMART_CONFIG
dflet 0:6ad60d78b315 125
dflet 0:6ad60d78b315 126 #ifdef __cplusplus
dflet 0:6ad60d78b315 127 }
dflet 0:6ad60d78b315 128 #endif // __cplusplus
dflet 0:6ad60d78b315 129
dflet 0:6ad60d78b315 130 #endif
dflet 0:6ad60d78b315 131