2017-07-03 01:32:46 +02:00
|
|
|
/**
|
|
|
|
* @defgroup pkg_tinydtls TinyDTLS for RIOT
|
|
|
|
* @ingroup pkg
|
2019-07-30 16:03:30 +02:00
|
|
|
* @ingroup net net_dtls
|
2017-07-03 01:32:46 +02:00
|
|
|
* @brief Provides the Eclipse TinyDTLS to RIOT
|
|
|
|
* @see https://projects.eclipse.org/projects/iot.tinydtls
|
2019-07-30 20:08:28 +02:00
|
|
|
*
|
|
|
|
* Usage
|
|
|
|
* -----
|
|
|
|
*
|
|
|
|
* Add as a package in the Makefile of your application:
|
|
|
|
*
|
|
|
|
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ {.mk}
|
|
|
|
* USEPKG += tinydtls
|
2020-08-14 17:24:39 +02:00
|
|
|
* # a cryptographically secure implementation of PRNG is needed
|
|
|
|
* USEMODULE += prng_sha1prng
|
2019-07-30 20:08:28 +02:00
|
|
|
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
*
|
|
|
|
* Supported Cipher Suites
|
|
|
|
* -----------------------
|
|
|
|
*
|
|
|
|
* TinyDTLS only has support for `TLS_PSK_WITH_AES_128_CCM_8` and
|
|
|
|
* `TLS_ECDHE_ECDSA_WITH_AES_128_CCM_8`. To choose which cipher suite
|
|
|
|
* to use, add one of the following to your Makefile:
|
|
|
|
*
|
|
|
|
* For `TLS_PSK_WITH_AES_128_CCM_8` support (default):
|
|
|
|
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ {.mk}
|
2019-12-18 18:15:30 +01:00
|
|
|
* CFLAGS += -DCONFIG_DTLS_PSK
|
2019-07-30 20:08:28 +02:00
|
|
|
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
*
|
|
|
|
* For `TLS_ECDHE_ECDSA_WITH_AES_128_CCM_8` support:
|
|
|
|
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ {.mk}
|
2019-12-18 18:15:30 +01:00
|
|
|
* CFLAGS += -DCONFIG_DTLS_ECC
|
2019-07-30 20:08:28 +02:00
|
|
|
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @defgroup tinydtls_config Tinydtls compile time configuration
|
|
|
|
* @ingroup pkg_tinydtls config
|
|
|
|
* @brief Provides compile-time configuration for tinydtls
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Adds support for TLS_PSK_WITH_AES_128_CCM_8 when defined
|
2019-12-18 18:15:30 +01:00
|
|
|
* @note Activated by default if @ref CONFIG_DTLS_ECC is not defined
|
2019-07-30 20:08:28 +02:00
|
|
|
*/
|
2019-12-18 18:15:30 +01:00
|
|
|
#ifndef CONFIG_DTLS_PSK
|
|
|
|
#define CONFIG_DTLS_PSK
|
2019-07-30 20:08:28 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Adds support for TLS_ECDHE_ECDSA_WITH_AES_128_CCM_8 when defined
|
|
|
|
*/
|
2019-12-18 18:15:30 +01:00
|
|
|
#ifndef CONFIG_DTLS_ECC
|
|
|
|
#define CONFIG_DTLS_ECC
|
2019-07-30 20:08:28 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief The maximum number of DTLS context at the same time
|
|
|
|
*/
|
2019-12-18 18:15:30 +01:00
|
|
|
#ifndef CONFIG_DTLS_CONTEXT_MAX
|
|
|
|
#define CONFIG_DTLS_CONTEXT_MAX (2)
|
2019-07-30 20:08:28 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief The maximum number DTLS peers (i.e. sessions)
|
|
|
|
*/
|
2019-12-18 18:15:30 +01:00
|
|
|
#ifndef CONFIG_DTLS_PEER_MAX
|
|
|
|
#define CONFIG_DTLS_PEER_MAX (1)
|
2019-07-30 20:08:28 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief The maximum number of concurrent DTLS handshakes
|
|
|
|
*/
|
2019-12-18 18:15:30 +01:00
|
|
|
#ifndef CONFIG_DTLS_HANDSHAKE_MAX
|
|
|
|
#define CONFIG_DTLS_HANDSHAKE_MAX (2)
|
2019-07-30 20:08:28 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief The maximum number of concurrently used cipher keys
|
|
|
|
*/
|
|
|
|
#ifndef DTLS_SECURITY_MAX
|
2019-12-18 18:15:30 +01:00
|
|
|
#define DTLS_SECURITY_MAX (CONFIG_DTLS_HANDSHAKE_MAX + CONFIG_DTLS_PEER_MAX)
|
2019-07-30 20:08:28 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief The maximum number of hash functions that can be used in parallel
|
|
|
|
*/
|
|
|
|
#ifndef DTLS_HASH_MAX
|
2019-12-18 18:15:30 +01:00
|
|
|
#define DTLS_HASH_MAX (3 * CONFIG_DTLS_PEER_MAX)
|
2019-07-30 20:08:28 +02:00
|
|
|
#endif
|
|
|
|
/** @} */
|