Contiki 2.5
Main Page
Related Pages
Modules
Data Structures
Files
Examples
File List
Globals
core
dev
cc2420-aes.h
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2008, Swedish Institute of Computer Science.
3
* All rights reserved.
4
*
5
* Redistribution and use in source and binary forms, with or without
6
* modification, are permitted provided that the following conditions
7
* are met:
8
* 1. Redistributions of source code must retain the above copyright
9
* notice, this list of conditions and the following disclaimer.
10
* 2. Redistributions in binary form must reproduce the above copyright
11
* notice, this list of conditions and the following disclaimer in the
12
* documentation and/or other materials provided with the distribution.
13
* 3. Neither the name of the Institute nor the names of its contributors
14
* may be used to endorse or promote products derived from this software
15
* without specific prior written permission.
16
*
17
* THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
18
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20
* ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
21
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27
* SUCH DAMAGE.
28
*
29
* This file is part of the Contiki operating system.
30
*
31
* $Id: cc2420-aes.h,v 1.3 2010/03/15 23:04:54 nifi Exp $
32
*/
33
34
/**
35
* \file
36
* Interface to the CC2420 AES encryption/decryption functions
37
* \author
38
* Adam Dunkels <adam@sics.se>
39
*/
40
41
#ifndef __CC2420_AES_H__
42
#define __CC2420_AES_H__
43
44
/**
45
* \brief Setup an AES key
46
* \param key A pointer to a 16-byte AES key
47
* \param index The key index: either 0 or 1.
48
*
49
* This function sets up an AES key with the CC2420
50
* chip. The AES key can later be used with the
51
* cc2420_aes_cipher() function to encrypt or decrypt
52
* data.
53
*
54
* The CC2420 can store two separate keys in its
55
* memory. The keys are indexed as 0 or 1 and the key
56
* index is given by the 'index' parameter.
57
*
58
*/
59
void
cc2420_aes_set_key
(
const
uint8_t *key,
int
index);
60
61
62
/**
63
* \brief Encrypt/decrypt data with AES
64
* \param data A pointer to the data to be encrypted/decrypted
65
* \param len The length of the data to be encrypted/decrypted
66
* \param key_index The key to use. The key must have previously been set up with cc2420_aes_set_key().
67
*
68
* This function encrypts/decrypts data with AES. A
69
* pointer to the data is passed as a parameter, and the
70
* function overwrites the data with the encrypted data.
71
*
72
*/
73
void
cc2420_aes_cipher
(uint8_t *data,
int
len,
int
key_index);
74
75
76
#endif
/* __CC2420_AES_H__ */
Generated on Fri Aug 30 2013 12:34:04 for Contiki 2.5 by
1.8.3.1