2017-11-22 14:13:00 +01:00
|
|
|
# dtls_echo example
|
2016-10-27 15:58:04 +02:00
|
|
|
|
2017-11-22 14:13:00 +01:00
|
|
|
This example shows how to use TinyDTLS with sock_udp.
|
2016-10-27 15:58:04 +02:00
|
|
|
|
2017-11-22 14:13:00 +01:00
|
|
|
## SOCK vs. Socket
|
2016-10-27 15:58:04 +02:00
|
|
|
|
2017-11-22 14:13:00 +01:00
|
|
|
This example is configured to use socks instead of sockets (over GNRC).
|
|
|
|
It's possible to use sockets, which give a more similar approach to the original
|
|
|
|
Linux version of TinyDTLS. However, this is not tested yet.
|
2016-10-27 15:58:04 +02:00
|
|
|
|
|
|
|
## Fast configuration (Between RIOT instances):
|
|
|
|
|
|
|
|
Preparing the logical interfaces:
|
|
|
|
|
2019-07-23 13:31:33 +02:00
|
|
|
sudo ./../../dist/tools/tapsetup/tapsetup --create 2
|
2016-10-27 15:58:04 +02:00
|
|
|
|
|
|
|
For the server instance:
|
|
|
|
|
|
|
|
make all; PORT=tap1 make term
|
|
|
|
dtlss start
|
|
|
|
ifconfig
|
|
|
|
|
|
|
|
Do not forget to copy the IPv6 addresses!
|
|
|
|
|
|
|
|
For the client:
|
|
|
|
|
|
|
|
PORT=tap0 make term
|
2017-11-22 14:13:00 +01:00
|
|
|
dtlsc <IPv6's server address[%netif]> "DATA to send under encrypted channel!"
|
2016-10-27 15:58:04 +02:00
|
|
|
|
|
|
|
# Testings
|
|
|
|
## Boards
|
|
|
|
|
2017-11-22 14:13:00 +01:00
|
|
|
Boards that do not support the `../gnrc_networking` example are included
|
|
|
|
in the `BOARD_INSUFFICIENT_MEMORY`, plus the board `cc2650stk`.
|
2016-10-27 15:58:04 +02:00
|
|
|
|
2017-11-22 14:13:00 +01:00
|
|
|
The code has been tested in the FIT IOT-LAB tesbed with the remote
|
|
|
|
`iotlab-m3` and `iotlab-a8-m3` boards and with local `samr21-xpro` boards.
|
2016-10-27 15:58:04 +02:00
|
|
|
|
2017-11-22 14:13:00 +01:00
|
|
|
## Handling the static memory allocation
|
2016-10-27 15:58:04 +02:00
|
|
|
|
2017-11-22 14:13:00 +01:00
|
|
|
TinyDTLS for RIOT is using the `sys/memarray` module and therefore there
|
|
|
|
are certain limits. Said resources are defined in
|
|
|
|
`tinydtls/platform-specific/riot_boards.h`, but can be overwritten at
|
|
|
|
compile time. Their default values are considered for having two DTLS
|
|
|
|
contexts (for purpose of DTLS renegotiation).
|
2016-10-27 15:58:04 +02:00
|
|
|
|
2017-11-22 14:13:00 +01:00
|
|
|
The resources handled by memarray are:
|
2019-12-18 18:15:30 +01:00
|
|
|
* `CONFIG_DTLS_CONTEXT_MAX` (default 2) The maximum number of DTLS context at the
|
2017-11-22 14:13:00 +01:00
|
|
|
same time.
|
2019-12-18 18:15:30 +01:00
|
|
|
* `CONFIG_DTLS_PEER_MAX` (default 1) The maximum number DTLS peers (i.e. sessions).
|
|
|
|
* `CONFIG_DTLS_HANDSHAKE_MAX` (default 1) The maximum number of concurrent DTLS handshakes.
|
2017-11-22 14:13:00 +01:00
|
|
|
* `DTLS_SECURITY_MAX` (the sum of the previous two) The maximum number of
|
|
|
|
concurrently used cipher keys.
|
2019-12-18 18:15:30 +01:00
|
|
|
* `DTLS_HASH_MAX` (Default: `3 * CONFIG_DTLS_PEER_MAX`) The maximum number of hash
|
2017-11-22 14:13:00 +01:00
|
|
|
functions that can be used in parallel.
|
2016-10-27 15:58:04 +02:00
|
|
|
|
2017-11-22 14:13:00 +01:00
|
|
|
## Handling retransmissions
|
2016-10-27 15:58:04 +02:00
|
|
|
|
2017-11-22 14:13:00 +01:00
|
|
|
By default, the number of transmissions of any DTLS record is settled to just
|
|
|
|
one. This can be handled by `DTLS_DEFAULT_MAX_RETRANSMIT` (defined in
|
|
|
|
`tinydtls/platform-specific/riot_boards.h`).
|