2013-11-28 18:12:40 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2013 Freie Universität Berlin
|
|
|
|
*
|
2014-08-23 15:43:13 +02:00
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
2013-11-28 18:12:40 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @defgroup sys_crypto Crypto
|
2015-08-26 10:42:50 +02:00
|
|
|
* @ingroup sys
|
|
|
|
*
|
2015-04-02 08:56:18 +02:00
|
|
|
* @brief RIOT provides a collection of block cipher ciphers, different
|
|
|
|
operation modes and cryptographic hash algorithms.
|
|
|
|
*
|
2015-08-26 10:42:50 +02:00
|
|
|
* @section ciphers Ciphers
|
2015-04-02 08:56:18 +02:00
|
|
|
*
|
2020-03-05 12:34:20 +01:00
|
|
|
* RIOT supports the following block ciphers:
|
2021-04-14 22:18:59 +02:00
|
|
|
* * AES-128, AES-192, AES-256
|
2015-04-02 08:56:18 +02:00
|
|
|
* * NULL
|
|
|
|
*
|
2021-04-14 22:18:59 +02:00
|
|
|
* You can use them directly by adding `crypto_aes_128`, `crypto_aes_192` or
|
|
|
|
* `crypto_aes_256` to your USEMODULE-List.
|
2015-04-02 08:56:18 +02:00
|
|
|
* While you can use the ciphers functions directly, you should resort to
|
|
|
|
* the generic API for block ciphers whenever possible.
|
|
|
|
*
|
2020-03-05 12:34:20 +01:00
|
|
|
* Depending on the selected block ciphers, a sufficient large buffer size of
|
|
|
|
* the cipher_context_t is used for en-/de-cryption operations.
|
2016-02-11 13:28:55 +01:00
|
|
|
*
|
2015-04-02 08:56:18 +02:00
|
|
|
* Example:
|
2015-08-26 10:42:50 +02:00
|
|
|
* @code
|
2015-04-02 08:56:18 +02:00
|
|
|
* #include "crypto/ciphers.h"
|
|
|
|
*
|
2016-02-11 11:44:57 +01:00
|
|
|
* cipher_t cipher;
|
|
|
|
* uint8_t key[AES_KEY_SIZE] = {0},
|
|
|
|
* plain_text[AES_BLOCK_SIZE] = {0},
|
|
|
|
* cipher_text[AES_BLOCK_SIZE] = {0};
|
2015-04-02 08:56:18 +02:00
|
|
|
*
|
2021-04-14 22:18:59 +02:00
|
|
|
* if (cipher_init(&cipher, CIPHER_AES, key, AES_KEY_SIZE) < 0)
|
2015-04-02 08:56:18 +02:00
|
|
|
* printf("Cipher init failed!\n");
|
|
|
|
*
|
|
|
|
* if (cipher_encrypt(&cipher, plain_text, cipher_text) < 0)
|
2016-02-11 11:44:57 +01:00
|
|
|
* printf("Cipher encryption failed!\n");
|
|
|
|
* else
|
|
|
|
* od_hex_dump(cipher_text, AES_BLOCK_SIZE, 0);
|
|
|
|
*
|
2015-08-26 10:42:50 +02:00
|
|
|
* @endcode
|
2015-04-02 08:56:18 +02:00
|
|
|
*
|
2018-10-16 18:12:39 +02:00
|
|
|
* Some aspects of the AES implementation can be fine tuned by pseudo-modules:
|
|
|
|
* * crypto_aes_precalculated: Use pre-calculated T-tables. This improved
|
|
|
|
* speed at the expense of increased program size. The default is to
|
|
|
|
* calculate most tables on the fly.
|
|
|
|
* * crypto_aes_unroll: enable manually-unrolled loops. The default is to not
|
|
|
|
* have them unrolled.
|
|
|
|
*
|
2015-04-02 08:56:18 +02:00
|
|
|
* If you need to encrypt data of arbitrary size take a look at the different
|
|
|
|
* operation modes like: CBC, CTR or CCM.
|
|
|
|
*
|
|
|
|
* Additional examples can be found in the test suite.
|
|
|
|
*
|
2013-11-28 18:12:40 +01:00
|
|
|
*/
|