mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
release-notes.txt: add 2020.07 release notes
This commit is contained in:
parent
f9798d98d3
commit
ddb7cfe346
@ -1,3 +1,783 @@
|
|||||||
|
RIOT-2020.07 - Release Notes
|
||||||
|
============================
|
||||||
|
RIOT is a multi-threading operating system which enables soft real-time
|
||||||
|
capabilities and comes with support for a range of devices that are typically
|
||||||
|
found in the Internet of Things: 8-bit and 16-bit microcontrollers as well as
|
||||||
|
light-weight 32-bit processors.
|
||||||
|
|
||||||
|
RIOT is based on the following design principles: energy-efficiency, soft
|
||||||
|
real-time capabilities, small memory footprint, modularity, and uniform API
|
||||||
|
access, independent of the underlying hardware (with partial POSIX compliance).
|
||||||
|
|
||||||
|
RIOT is developed by an international open-source community which is
|
||||||
|
independent of specific vendors (e.g. similarly to the Linux community) and is
|
||||||
|
licensed with a non-viral copyleft license (LGPLv2.1), which allows indirect
|
||||||
|
business models around the free open-source software platform provided by RIOT.
|
||||||
|
|
||||||
|
|
||||||
|
About this release:
|
||||||
|
===================
|
||||||
|
|
||||||
|
The 2020.07 release puts a focus on the improvement of automated testing. In
|
||||||
|
that vein, various new CI integrations such as CircleCI for documentation
|
||||||
|
building and online presentation, and Github Actions to check the tooling of
|
||||||
|
RIOT when merged. The `riotctrl_shell` python module allows to abstract shell
|
||||||
|
commands as python methods for testing using the newly created `riotctrl`
|
||||||
|
python package [1]. Kconfig migration reached phase 2 with various board
|
||||||
|
features being exposed to Kconfig. New network protocols were ported for RIOT
|
||||||
|
such as MQTT (in form of the `paho-mqtt` package) and the lookup client
|
||||||
|
component for CoRE RD `cord_lc`. The OpenWSN network stack with 6TiSCH support
|
||||||
|
was reintegrated into RIOT. Support for several new boards and new sensors was
|
||||||
|
added. Additionally, this release contains a number of bug fixes and test
|
||||||
|
improvements.
|
||||||
|
|
||||||
|
546 pull requests, composed of 10452 commits, have been merged since the
|
||||||
|
last release, and 84 issues have been solved. 64 people contributed with
|
||||||
|
code in 106 days. 2371 files have been touched with 822149 (+) insertions and
|
||||||
|
700313 deletions (-).
|
||||||
|
|
||||||
|
[1]: https://pypi.org/project/riotctrl/
|
||||||
|
|
||||||
|
Notations used below:
|
||||||
|
=====================
|
||||||
|
|
||||||
|
+ means new feature/item
|
||||||
|
* means modified feature/item
|
||||||
|
- means removed feature/item
|
||||||
|
|
||||||
|
New features and changes
|
||||||
|
========================
|
||||||
|
|
||||||
|
Core
|
||||||
|
----
|
||||||
|
* core: make idle thread optional
|
||||||
|
+ macros/units: add unit conversion helper macros
|
||||||
|
+ msg: add message bus
|
||||||
|
* panic: launch USB bootloader on crash for easy recovery
|
||||||
|
|
||||||
|
System libraries
|
||||||
|
----------------
|
||||||
|
* auto_init: automatically determine auto_init_*.c
|
||||||
|
* base64: Clean up / improve implementation
|
||||||
|
+ hashes: add sha224 and reuse sha256 code
|
||||||
|
+ luid: provide luid_get_lb()
|
||||||
|
+ phydat: added phydat to JSON converter
|
||||||
|
+ posix: initial import of select() function (only support sockets for now)
|
||||||
|
* ps: show free stack space in addition to used and total
|
||||||
|
* shell:
|
||||||
|
+ add optional hooks for shell commands
|
||||||
|
* native: stop RIOT when the shell reads EOF
|
||||||
|
* refactor readline function
|
||||||
|
* refactor tokenizer code
|
||||||
|
+ shell_commands:
|
||||||
|
* alias ping=ping6
|
||||||
|
+ provide command to reboot to bootloader
|
||||||
|
+ stdio_semihosting: Initial include of Semihosting-based STDIO
|
||||||
|
+ touch_dev: add generic API for touch device
|
||||||
|
+ trace: add trace module
|
||||||
|
+ pm: Add pm_get_blocker()
|
||||||
|
* random:
|
||||||
|
+ add option to use HWRNG as source of randomness
|
||||||
|
* optimize sha1prng
|
||||||
|
* usb:
|
||||||
|
* allow for boards to define default custom VID/PID
|
||||||
|
* warn on test-ID usage in a unified location
|
||||||
|
+ xtimer: xtimer_rmutex_lock_timeout
|
||||||
|
* ztimer:
|
||||||
|
+ add power management for ztimer clocks
|
||||||
|
* expose ZTIMER_MSEC/USEC_BASE
|
||||||
|
|
||||||
|
Networking
|
||||||
|
----------
|
||||||
|
+ cord: add CoRE RD lookup client implementation
|
||||||
|
+ gcoap: add CoAP ping request
|
||||||
|
* gnrc:
|
||||||
|
+ gnrc_ipv6_ext_opt: initial import of hop-by-hop and destination option
|
||||||
|
handling
|
||||||
|
* gnrc_netif:
|
||||||
|
+ add IPv6 event bus
|
||||||
|
+ add option for non-std 6lo MTU
|
||||||
|
+ add support for internal event loop
|
||||||
|
* use gnrc_netif-submodules to pull in upper-layer struct members
|
||||||
|
* gnrc_nettype: indirect NETTYPE definition via pseudo-modules
|
||||||
|
* gnrc_pktdump: fix dependencies
|
||||||
|
* gnrc_tcp:
|
||||||
|
+ add retransmission timer
|
||||||
|
* rewrite API internal messaging
|
||||||
|
* rewrite recv buffer allocation/returning
|
||||||
|
* use exponent to configure message queue sizes
|
||||||
|
* nanocoap: allow coap_opt_add_string() for non-zero-terminated strings
|
||||||
|
+ netif: add functions to get and get by identifier
|
||||||
|
+ sock_dtls: provide getter function for UDP sock
|
||||||
|
* sock_util: add interface descriptor parsing to str2ep
|
||||||
|
|
||||||
|
Packages
|
||||||
|
--------
|
||||||
|
* pkg: rework checkout process
|
||||||
|
* avoid copying Makefiles in package source when possible
|
||||||
|
* store packages sources in a global package directory
|
||||||
|
* pkg: cleanup build system integration for
|
||||||
|
- cryptoauthlib, openthread, semtech-loramac, tinydtls, wakaama, u8g2,
|
||||||
|
ucglib, wolfssl
|
||||||
|
* pkg: tools: ensure cmake based packages/tools are built out-of-source
|
||||||
|
+ cryptoauthlib: wake pulse implementation for CPUs supporting
|
||||||
|
`periph_i2c_reconfigure`
|
||||||
|
+ emlearn: add support to RIOT
|
||||||
|
* gecko_sdk: update to v2.7.6
|
||||||
|
* lwip:
|
||||||
|
* add IPv4 support for `netdev_tap`
|
||||||
|
* add support for nrf802154
|
||||||
|
* enable IPv4/IPv6 dual stack mode
|
||||||
|
+ lwip_sock: provide implementation for `sock_*_recv_buf()`
|
||||||
|
- lua: remove unnecessary patch
|
||||||
|
+ paho-mqtt: add package and example
|
||||||
|
* nimble:
|
||||||
|
+ add static connection manager `statconn`
|
||||||
|
* netif:
|
||||||
|
* set host thread prio to 1
|
||||||
|
* simplify mbuf pool initialization
|
||||||
|
* update NimBLE ver (cd7d7aa286) + timing param cleanup
|
||||||
|
+ openwsn: re-integrate the network stack as a package
|
||||||
|
* tinydtls:
|
||||||
|
+ add `sock_async` support for `sock_dtls`
|
||||||
|
+ use latest development version (eda63f000c)
|
||||||
|
* ucglib: refactoring and fixes
|
||||||
|
|
||||||
|
Boards
|
||||||
|
------
|
||||||
|
+ cc1352p-launchpad: add support
|
||||||
|
* common/blxxxpill:
|
||||||
|
+ provide periph_rtt
|
||||||
|
* improve adc
|
||||||
|
+ dwm1001: add support to Decawave DWM1001 dev board
|
||||||
|
+ mcb2388: misc enhancements
|
||||||
|
+ nrf52840-dongle: add support
|
||||||
|
+ nrf52840dk: Add MTD configuration
|
||||||
|
+ nucleo-g474re: add support
|
||||||
|
* pic32-clicker: rename to 6lowpan-clicker
|
||||||
|
+ samr30-xpro: add SPI dev for ext pin header
|
||||||
|
+ samr3x-xpro: add riotboot feature
|
||||||
|
+ serpente: add support
|
||||||
|
+ sltb001a: enable CCS811 sensor
|
||||||
|
+ sodaq-sff: add support for SODAQ SFF
|
||||||
|
+ stm32f429i-disco: add support
|
||||||
|
+ weact-f411ce: add support
|
||||||
|
+ wemos-zero: add support
|
||||||
|
|
||||||
|
CPU
|
||||||
|
---
|
||||||
|
* arm7_common: Update to inlineable IRQ API
|
||||||
|
* atmega_common: Update to inlineable IRQ API
|
||||||
|
* cortexm:
|
||||||
|
+ allow to define reserved fields in CortexM vector table
|
||||||
|
* "free" SVC
|
||||||
|
* cc26x2_cc13x2:
|
||||||
|
* add oscillator switching functions
|
||||||
|
* add periph_i2c implementation
|
||||||
|
* trim device registers on `cpu_init`
|
||||||
|
* esp32:
|
||||||
|
* support of multiple heaps for newlib malloc
|
||||||
|
* replace RTC implementation by RTT implementation
|
||||||
|
* fe310: migrate to inlined IRQ API
|
||||||
|
+ kinetis: implement power modes for pm_layered
|
||||||
|
* lpc2387:
|
||||||
|
* pm: enable SLEEP & POWERDOWN mode
|
||||||
|
* timer: use lpc2387_pclk_scale()
|
||||||
|
+ mips_pic32_common: Implement GPIO IRQ
|
||||||
|
+ native:
|
||||||
|
+ add periph_eeprom driver implementation
|
||||||
|
* rename trace -> backtrace
|
||||||
|
+ nrf52:
|
||||||
|
+ add black magic probe config
|
||||||
|
+ add missing vendor files
|
||||||
|
+ implement EasyDMA-based SPI peripheral implementation
|
||||||
|
+ nrf52811: initial support
|
||||||
|
* nrf5x_common:
|
||||||
|
* add configurable RTT_FREQUENCY
|
||||||
|
* enable bias correction in hwrng
|
||||||
|
* sam0_common:
|
||||||
|
+ add DMA peripheral driver
|
||||||
|
+ add PWM support for saml21, samd5x
|
||||||
|
+ implement periph/dac
|
||||||
|
* make SPI peripheral DMA compatible
|
||||||
|
* move PWM to common code
|
||||||
|
* spi: move clk pin muxing into spi_acquire / spi_release
|
||||||
|
+ UART: implement inverted RX & TX
|
||||||
|
* samd21: PWM don't hard-code number of channels to 3
|
||||||
|
* samd5x: allow to use XOSC as clock source
|
||||||
|
* saml1x: pm: set deep flag
|
||||||
|
+ stm32:
|
||||||
|
+ add QDEC support for CPU_FAM_STM32F1
|
||||||
|
+ add non-blocking UART
|
||||||
|
* decrease latency in SPI DMA path
|
||||||
|
+ implement reset to bootloader
|
||||||
|
* filter availability of RNG by CPU not by board
|
||||||
|
* stm32_common: make RTT_FREQUENCY configurable
|
||||||
|
+ stm32f4: Add DMA config for SPI
|
||||||
|
+ stm32g4: add support
|
||||||
|
|
||||||
|
Device Drivers
|
||||||
|
--------------
|
||||||
|
+ atwinc15x0: add WiFi netdev driver
|
||||||
|
+ at: Add at_urc_isr module to process URCs upon arrival
|
||||||
|
+ at24cxxx: MTD wrapper for at24cxxx
|
||||||
|
+ at86rf215:
|
||||||
|
+ implement MR-O-QPSK
|
||||||
|
+ implement MR-OFDM
|
||||||
|
+ at86rf2xx: add support for high data rates
|
||||||
|
+ dfplayer: New driver for the DFPlayer Mini MP3 player
|
||||||
|
* ethos: use luid_get_eui48()
|
||||||
|
+ edbg_eui: add driver to get MAC address from Atmel EDBG
|
||||||
|
+ mhz19: initial support
|
||||||
|
+ mrf24j40: add Turbo Mode
|
||||||
|
+ mtd_spi_eeprom: add MTD wrapper for AT25XXX EEPROMs
|
||||||
|
+ pca9633: add new driver
|
||||||
|
+ periph/timer: add timer_set_periodic()
|
||||||
|
+ periph/i2c: add periph_i2c_reconfigure feature & implementation for sam0
|
||||||
|
+ periph/rtt: introduce RTT_MIN_OFFSET
|
||||||
|
+ periph/spi: add periph_spi_reconfigure feature & implementation for sam0
|
||||||
|
* pulse_counter: Use C11 atomics & bugfix
|
||||||
|
+ sdp3x : Add driver for sdp3x sensor
|
||||||
|
|
||||||
|
Build System / Tooling
|
||||||
|
----------------------
|
||||||
|
+ make:
|
||||||
|
+ add code generator targets
|
||||||
|
+ add JLink support for stm32
|
||||||
|
* docker.inc.mk: add and use generic docker_run_make
|
||||||
|
+ allow multiple external board dirs
|
||||||
|
+ info-global.inc.mk: add info-boards-features-blacklisted
|
||||||
|
* resolve dependencies before Makefile.include
|
||||||
|
+ riotctrl_shell:
|
||||||
|
+ initial import of shell interaction spawn
|
||||||
|
+ provide ipv6_nib interactions and parsers
|
||||||
|
+ provide netif interactions and parsers
|
||||||
|
+ tools:
|
||||||
|
+ add script to run radvd on a tun interface
|
||||||
|
+ provide tool to parse `pktbuf` output
|
||||||
|
* kconfiglib:
|
||||||
|
* add riot_kconfig to override default behaviours
|
||||||
|
* kconfiglib: bump to v14.1.0
|
||||||
|
|
||||||
|
Testing
|
||||||
|
-------
|
||||||
|
+ fuzzing framework:
|
||||||
|
+ add AFL-based fuzzing setup for network modules
|
||||||
|
+ add fuzzing application for gcoap
|
||||||
|
+ ci: setup github actions
|
||||||
|
+ sys/test_utils/dummy_thread: initial commit
|
||||||
|
+ tests/irq_disable_restore: Add test for irq_disable() / irq_restore()
|
||||||
|
+ tests/periph_spi: add benchmark for acquire / release
|
||||||
|
+ tests/periph_spi_dma: Add test for SPI with DMA
|
||||||
|
+ uncrustify: add auto uncrustify with blacklist
|
||||||
|
|
||||||
|
Kconfig migration
|
||||||
|
-----------------
|
||||||
|
+ armv7_m/cortexm: declare CPU_ARCH and CPU_CORE
|
||||||
|
+ boards: Model features in Kconfig
|
||||||
|
+ arduino-leonardo, arduino-mega2560, atmega128x-based, atmega256rfr2-based,
|
||||||
|
atmega328p-based, cc2538-based, cc26xx_cc13xx-based, efm32-based, esp-based,
|
||||||
|
fe310-based, kinetis-based, msp430-based, samr21-xpro, slwstk6220a
|
||||||
|
* kconfig: Declare common feature symbols
|
||||||
|
+ drivers: Expose Configurations to Kconfig
|
||||||
|
+ ads101x, at, at86rf215, bmx055, cc110x, dose.h, fxos8700, hdc1000, isl29020,
|
||||||
|
l3g4200d, lpsxxx, mag3110, mma8x5x, motor_driver, mtd_sdcard, opt3001,
|
||||||
|
pn532, rn2xx3, slipdev, sps30, tcs37727, tmp00x
|
||||||
|
+ networking: Expose configurations to Kconfig
|
||||||
|
+ asymcute, coap, csma
|
||||||
|
+ gnrc:
|
||||||
|
+ gomach, lwmac, mac, pktdump, pktbuf, rpl, tcp
|
||||||
|
+ usbus/cdc/ecm: Expose configurations to Kconfig
|
||||||
|
|
||||||
|
API Changes
|
||||||
|
===========
|
||||||
|
- cpu/sam0_common: drop prescaler from timer config
|
||||||
|
- cpu/sam0_common: PWM config now requires GCLK source
|
||||||
|
- drivers/mtd: Change API to return 0 on success
|
||||||
|
- drivers/mtd_mapper: count offset in sectors
|
||||||
|
- net/sock_dtls: provide getter function for UDP sock
|
||||||
|
- net/sock_dtls: add timeout to sock_dtls_send and add sock_dtls_session_init
|
||||||
|
|
||||||
|
diff --git a/sys/include/net/sock/dtls.h b/sys/include/net/sock/dtls.h
|
||||||
|
index 96569723fc..6e66048bd4 100644
|
||||||
|
--- a/sys/include/net/sock/dtls.h
|
||||||
|
+++ b/sys/include/net/sock/dtls.h
|
||||||
|
@@ -476,6 +485,13 @@
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
+#ifndef DTLS_HANDSHAKE_BUFSIZE
|
||||||
|
+#define DTLS_HANDSHAKE_BUFSIZE (256) /**< Size buffer used in handshake to
|
||||||
|
+ hold credentials */
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
+#define SOCK_DTLS_HANDSHAKE (EXDEV) /**< Return value for a successful
|
||||||
|
+ handshake */
|
||||||
|
+
|
||||||
|
/**
|
||||||
|
* @brief DTLS version number
|
||||||
|
@@ -546,26 +564,26 @@ void sock_dtls_init(void);
|
||||||
|
int sock_dtls_create(sock_dtls_t *sock, sock_udp_t *udp_sock,
|
||||||
|
credman_tag_t tag, unsigned version, unsigned role);
|
||||||
|
|
||||||
|
+
|
||||||
|
/**
|
||||||
|
- * @brief Creates a new DTLS session
|
||||||
|
+ * @brief Initialize session handshake.
|
||||||
|
*
|
||||||
|
- * Initializes handshake process with a DTLS server at @p ep.
|
||||||
|
- *
|
||||||
|
- * @param[in] sock DLTS sock to use
|
||||||
|
- * @param[in] ep Remote endpoint of the session
|
||||||
|
- * @param[out] remote The created session, cannot be NULL
|
||||||
|
+ * Sends a ClientHello message to initialize the handshake. Call
|
||||||
|
+ * @ref sock_dtls_recv() to finish the handshake.
|
||||||
|
*
|
||||||
|
- * @return 0 on success
|
||||||
|
- * @return -EAGAIN, if DTLS_HANDSHAKE_TIMEOUT is `0` and no data is available.
|
||||||
|
- * @return -EADDRNOTAVAIL, if the local endpoint of @p sock is not set.
|
||||||
|
- * @return -EINVAL, if @p remote is invalid or @p sock is not properly
|
||||||
|
- * initialized (or closed while sock_udp_recv() blocks).
|
||||||
|
- * @return -ENOBUFS, if buffer space is not large enough to store received
|
||||||
|
- * credentials.
|
||||||
|
- * @return -ETIMEDOUT, if timed out when trying to create session.
|
||||||
|
+ * @param[in] sock DTLS sock to use
|
||||||
|
+ * @param[in] ep Remote endpoint to start a handshake with
|
||||||
|
+ * @param[out] remote Resulting session
|
||||||
|
+ *
|
||||||
|
+ * @return 1, if new handshake is started
|
||||||
|
+ * @return 0, if there is an existing session
|
||||||
|
+ * @return -ENOMEM, not enough memory to allocate for new peer
|
||||||
|
+ * @return -EADDRNOTAVAIL, if the local endpoint of @p sock is not set.
|
||||||
|
+ * @return -EINVAL, if @p remote is invalid or @p sock is not properly
|
||||||
|
+ * initialized (or closed while sock_udp_recv() blocks).
|
||||||
|
*/
|
||||||
|
-int sock_dtls_session_create(sock_dtls_t *sock, const sock_udp_ep_t *ep,
|
||||||
|
- sock_dtls_session_t *remote);
|
||||||
|
+int sock_dtls_session_init(sock_dtls_t *sock, const sock_udp_ep_t *ep,
|
||||||
|
+ sock_dtls_session_t *remote);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Destroys an existing DTLS session
|
||||||
|
@@ -578,7 +596,7 @@ int sock_dtls_session_create(sock_dtls_t *sock, const sock_udp_ep_t *ep,
|
||||||
|
void sock_dtls_session_destroy(sock_dtls_t *sock, sock_dtls_session_t *remote);
|
||||||
|
|
||||||
|
/**
|
||||||
|
- * @brief Decrypts and reads a message from a remote peer.
|
||||||
|
+ * @brief Receive handshake messages and application data from remote peer.
|
||||||
|
*
|
||||||
|
* @param[in] sock DTLS sock to use.
|
||||||
|
* @param[out] remote Remote DTLS session of the received data.
|
||||||
|
@@ -593,7 +611,8 @@ void sock_dtls_session_destroy(sock_dtls_t *sock, sock_dtls_session_t *remote);
|
||||||
|
*
|
||||||
|
* @note Function may block if data is not available and @p timeout != 0
|
||||||
|
*
|
||||||
|
- * @return The number of bytes received on success
|
||||||
|
+ * @return The number of bytes received on success
|
||||||
|
+ * @return -SOCK_DTLS_HANDSHAKE when new handshake is completed
|
||||||
|
* @return -EADDRNOTAVAIL, if the local endpoint of @p sock is not set.
|
||||||
|
* @return -EAGAIN, if @p timeout is `0` and no data is available.
|
||||||
|
* @return -EINVAL, if @p remote is invalid or @p sock is not properly
|
||||||
|
@@ -657,28 +676,32 @@ ssize_t sock_dtls_recv_buf(sock_dtls_t *sock, sock_dtls_session_t *remote,
|
||||||
|
* if no session exist between client and server.
|
||||||
|
* @param[in] data Pointer where the data to be send are stored
|
||||||
|
* @param[in] len Length of @p data to be send
|
||||||
|
+ * @param[in] timeout Handshake timeout in microseconds.
|
||||||
|
+ * If `timeout > 0`, will start a new handshake if no
|
||||||
|
+ * session exists yet. The function will block until
|
||||||
|
+ * handshake completed or timed out.
|
||||||
|
+ * May be SOCK_NO_TIMEOUT to block indefinitely until
|
||||||
|
+ * handshake complete.
|
||||||
|
*
|
||||||
|
- * @note Function may block until a session is created if there is no
|
||||||
|
- * existing session with @p remote.
|
||||||
|
- *
|
||||||
|
- * @note Initiating a session through this function will require
|
||||||
|
- * @ref sock_dtls_recv() called from another thread to receive the handshake
|
||||||
|
- * messages.
|
||||||
|
+ * @note When blocking, we will need an extra thread to call
|
||||||
|
+ * @ref sock_dtls_recv() function to handle the incoming handshake
|
||||||
|
+ * messages.
|
||||||
|
*
|
||||||
|
* @return The number of bytes sent on success
|
||||||
|
+ * @return -ENOTCONN, if `timeout == 0` and no existing session exists with
|
||||||
|
+ * @p remote
|
||||||
|
* @return -EADDRINUSE, if sock_dtls_t::udp_sock has no local end-point.
|
||||||
|
* @return -EAFNOSUPPORT, if `remote->ep != NULL` and
|
||||||
|
* sock_dtls_session_t::ep::family of @p remote is != AF_UNSPEC and
|
||||||
|
* not supported.
|
||||||
|
- * @return -EHOSTUNREACH, if sock_dtls_session_t::ep of @p remote is not
|
||||||
|
- * reachable.
|
||||||
|
* @return -EINVAL, if sock_udp_ep_t::addr of @p remote->ep is an
|
||||||
|
* invalid address.
|
||||||
|
* @return -EINVAL, if sock_udp_ep_t::port of @p remote->ep is 0.
|
||||||
|
* @return -ENOMEM, if no memory was available to send @p data.
|
||||||
|
+ * @return -ETIMEDOUT, `0 < timeout < SOCK_NO_TIMEOUT` and timed out.
|
||||||
|
*/
|
||||||
|
ssize_t sock_dtls_send(sock_dtls_t *sock, sock_dtls_session_t *remote,
|
||||||
|
- const void *data, size_t len);
|
||||||
|
+ const void *data, size_t len, uint32_t timeout);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Closes a DTLS sock
|
||||||
|
@@ -694,6 +717,47 @@ ssize_t sock_dtls_send(sock_dtls_t *sock, sock_dtls_session_t *remote,
|
||||||
|
*/
|
||||||
|
void sock_dtls_close(sock_dtls_t *sock);
|
||||||
|
|
||||||
|
+/**
|
||||||
|
+ * @brief Creates a new DTLS session
|
||||||
|
+ *
|
||||||
|
+ * Initiates a handshake with a DTLS server at @p ep and wait until it
|
||||||
|
+ * completes or timed out.
|
||||||
|
+ *
|
||||||
|
+ * @deprecated Will not be available after the 2020.10 release.
|
||||||
|
+ * Please use @ref sock_dtls_session_init() and
|
||||||
|
+ * @ref sock_dtls_recv() instead.
|
||||||
|
+ *
|
||||||
|
+ * @param[in] sock DLTS sock to use
|
||||||
|
+ * @param[in] ep Remote endpoint of the session
|
||||||
|
+ * @param[out] remote The created session, cannot be NULL
|
||||||
|
+ * @param[in] timeout Timeout to wait for handshake to finish.
|
||||||
|
+ * Returns immediately if 0.
|
||||||
|
+ * May be SOCK_NO_TIMEOUT to wait indefinitely until
|
||||||
|
+ * handshake complete.
|
||||||
|
+ *
|
||||||
|
+ * @return 0 on success
|
||||||
|
+ * @return -ENOMEM, if no memory to allocate for new peer
|
||||||
|
+ * @return -EADDRNOTAVAIL, if the local endpoint of @p sock is not set.
|
||||||
|
+ * @return -EINVAL, if @p remote is invalid or @p sock is not properly
|
||||||
|
+ * initialized (or closed while sock_udp_recv() blocks).
|
||||||
|
+ */
|
||||||
|
+static inline int sock_dtls_session_create(sock_dtls_t *sock, const sock_udp_ep_t *ep,
|
||||||
|
+ sock_dtls_session_t *remote, unsigned timeout)
|
||||||
|
+{
|
||||||
|
+ int res;
|
||||||
|
+ uint8_t buf[DTLS_HANDSHAKE_BUFSIZE];
|
||||||
|
+
|
||||||
|
+ assert(sock);
|
||||||
|
+ assert(remote);
|
||||||
|
+
|
||||||
|
+ res = sock_dtls_session_init(sock, ep, remote);
|
||||||
|
+ if (res <= 0) {
|
||||||
|
+ return res;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return sock_dtls_recv(sock, remote, buf, sizeof(buf), timeout);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
#include "sock_dtls_types.h"
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
|
||||||
|
|
||||||
|
Deprecations
|
||||||
|
============
|
||||||
|
|
||||||
|
Warnings
|
||||||
|
--------
|
||||||
|
- GNRC_MAC_ENABLE_DUTYCYCLE_RECORD: Will be removed after 2021.01 release. Use
|
||||||
|
inverse CONFIG_GNRC_MAC_DISABLE_DUTYCYCLE_RECORD instead.
|
||||||
|
- saul_reg_rm(): will be removed at a future date
|
||||||
|
- sock_dtls_session_create(): will be removed after 2020.10 release. Please
|
||||||
|
use sock_dtls_session_init() and sock_dtls_recv() instead
|
||||||
|
- pkg/nordic_softdevice_ble: will be removed after the 2020.10 release
|
||||||
|
|
||||||
|
Removals
|
||||||
|
--------
|
||||||
|
- netdev: remove NETOPT_IPV6_IID support for network devices
|
||||||
|
|
||||||
|
|
||||||
|
Known issues
|
||||||
|
============
|
||||||
|
|
||||||
|
Networking related issues (44)
|
||||||
|
------------------------------
|
||||||
|
#13997: ping6 is failing when testing with cc2538dk
|
||||||
|
#13745: ethos: Unable to choose global source address.
|
||||||
|
#13496: cpu/stm32/eth, board/nucleo-f767z1: ethernet buffering issue (ping >1s)
|
||||||
|
after debug break
|
||||||
|
#13493: ethernet: Missing multicast addr assignment
|
||||||
|
#13490: cpu/stm32/eth, board/nucleo-f767z1: ethernet initialisation fails
|
||||||
|
sometimes
|
||||||
|
#13280: nrf52: Not able to add global or ULA address to interface
|
||||||
|
#13088: Riot-os freezes with lwip + enc28j60 + stm32L4
|
||||||
|
#12943: driver/mrf24j40: blocks shell input with auto_init_gnrc_netif
|
||||||
|
#12884: examples/cord_ep: Dead lock when (re-)registering in callback function
|
||||||
|
#12857: examples/gnrc_networking_mac broken on ATmega
|
||||||
|
#12761: samr30 xpro doesn't seem to use its radio ok
|
||||||
|
#12642: Emcute cannot create a double-byte name
|
||||||
|
#12565: gnrc_icmpv6_echo: flood-pinging another node leads to leaks in own
|
||||||
|
packet buffer
|
||||||
|
#12264: ethos: Unable to handle fragmented IPv6 packets from Linux kernel
|
||||||
|
#12210: stale border router does not get replaced
|
||||||
|
#11988: ethos: fails to respond to first message.
|
||||||
|
#11860: send data with UDP at 10HZ, the program die
|
||||||
|
#11852: scan-build errors found during 2019.07 testing
|
||||||
|
#11405: nrfmin: communication not possible after multicast ping with no interval
|
||||||
|
#11033: 6lo: RIOT does not receive packets from Linux when short_addr is set
|
||||||
|
#10969: net: netdev_driver_t::send() doc unclear
|
||||||
|
#10861: cpu/esp8266: Tracking open problems of esp_wifi netdev driver
|
||||||
|
#10809: openthread: does not build on current Arch
|
||||||
|
#10410: Missing drop implementations in netdev_driver_t::recv
|
||||||
|
#10389: gnrc_sock_udp: Possible Race condition on copy in application buffer
|
||||||
|
#10380: netdev_ieee802154: Mismatch between radio ll address and in memory
|
||||||
|
address
|
||||||
|
#10370: gomach: Resetting netif with cli doesn't return
|
||||||
|
#10338: xbee: setting PAN ID sometimes fails
|
||||||
|
#9709: examples: failed assertion in dtls-echo example
|
||||||
|
#9656: gnrc/netif: various problems after resetting interface a second time
|
||||||
|
#8779: CC2538 RF overlapping PIN usage
|
||||||
|
#8752: mrf24j40: does not link for examples/default
|
||||||
|
#8271: app/netdev: application stops working after receiving frames with
|
||||||
|
assertion or completely without error
|
||||||
|
#8242: at86rf2xx: Dead lock when sending while receiving
|
||||||
|
#8199: gcoap example request on tap I/F fails with NIB issue
|
||||||
|
#7737: pkg: libcoap is partially broken and outdated
|
||||||
|
#7474: 6lo gnrc fragmentation expects driver to block on TX
|
||||||
|
#7304: General 802.15.4/CC2538 RF driver dislikes fast ACKs
|
||||||
|
#6018: nRF52: gnrc_6lowpan_ble: memory leak with nordic_softdevice_ble
|
||||||
|
#5863: OSX + SAMR21-xpro: shell cannot handle command inputs larger than 64
|
||||||
|
chars
|
||||||
|
#5486: at86rf2xx: lost interrupts
|
||||||
|
#5230: gnrc ipv6: multicast packets are not dispatched to the upper layers
|
||||||
|
#5051: Forwarding a packet back to its link layer source should not be allowed
|
||||||
|
#4527: gnrc_ipv6: Multicast is not forwarded if routing node listens to the
|
||||||
|
address
|
||||||
|
|
||||||
|
Timer related issues (17)
|
||||||
|
-------------------------
|
||||||
|
#14217: tests/periph_timer_periodic is failing
|
||||||
|
#13321: Sleep mode for Arduino
|
||||||
|
#13204: xtimer problem with nucleo32 boards
|
||||||
|
#13072: periph/timer: `timer_set()` underflow safety check (tracking issue)
|
||||||
|
#10545: periph_timer: systematic proportional error in timer_set
|
||||||
|
#10523: saml21 system time vs rtc
|
||||||
|
#10510: xtimer_set_msg: crash when using same message for 2 timers
|
||||||
|
#10073: xtimer_usleep wrong delay time
|
||||||
|
#9187: sys/newlib: gettimeofday() returns time since boot, not current wall
|
||||||
|
time.
|
||||||
|
#9052: misc issues with tests/trickle
|
||||||
|
#9049: xtimer mis-scaling with long sleep times
|
||||||
|
#8746: stm32_common/periph/rtc: current implementation broken/poor accuracy
|
||||||
|
#8251: MSP430: periph_timer clock config wrong
|
||||||
|
#7347: xtimer_usleep stuck for small values
|
||||||
|
#7114: xtimer: add's items to the wrong list if the timer overflows between
|
||||||
|
_xtimer_now() and irq_disable()
|
||||||
|
#6442: cpu/native: timer interrupt issue
|
||||||
|
#6052: tests: xtimer_drift gets stuck on native
|
||||||
|
|
||||||
|
Drivers related issues (13)
|
||||||
|
---------------------------
|
||||||
|
#14506: mdt_erase success, but vfs_format resets board (esp32-heltec-lora32-v2)
|
||||||
|
#14439: (almost solved) SPI SD-Card driver: SPI initialisation freeze until
|
||||||
|
timeout
|
||||||
|
#14424: adc is not a ADC-Driver but a analog pin abstraction
|
||||||
|
#13527: examples/dtls-wolfssl not working on pba-d-01-kw2x
|
||||||
|
#13444: Potential security and safety race conditions on attached devices
|
||||||
|
#13079: drivers/srf04: incorrect values on ATmega based platforms
|
||||||
|
#12445: driver/hts221: Temperature and Humidity readings incorrect
|
||||||
|
#12371: fail to send data to can bus
|
||||||
|
#12057: ESP32 + DHT + SAUL reading two endpoints causes freeze.
|
||||||
|
#12045: floats and doubles being used all over the place.
|
||||||
|
#11104: STM32: SPI clock not returning to idle state and generating additional
|
||||||
|
clock cycles
|
||||||
|
#9419: cpu/msp430: GPIO driver doesn't work properly
|
||||||
|
#4876: at86rf2xx: Simultaneous use of different transceiver types is not
|
||||||
|
supported
|
||||||
|
|
||||||
|
Native related issues (3)
|
||||||
|
-------------------------
|
||||||
|
#13501: SDL2 does not work due to missing getpid
|
||||||
|
#5796: native: tlsf: early malloc will lead to a crash
|
||||||
|
#495: native not float safe
|
||||||
|
|
||||||
|
Other platforms related issues (19)
|
||||||
|
-----------------------------------
|
||||||
|
#14572: tests/mpu_noexec_ram: fails on i-nucleo-lrwan1
|
||||||
|
#14410: MIPS: toolchain objcopy doesn't work and no .bin can be generated
|
||||||
|
#14237: esp32-wroom-32: tests/netstats_l2 failing sometimes
|
||||||
|
#14015: stm32152re: hardfault when DBGMCU_CR_DBG* bits are set and branch after
|
||||||
|
__WFI()
|
||||||
|
#13606: gcoap/esp8266: Stack overflow with gcoap example
|
||||||
|
#13390: Cannot use LLVM with Cortex-M boards
|
||||||
|
#13267: Failing tests on MSP430 (z1)
|
||||||
|
#13104: boards/hifive1: flashing issue
|
||||||
|
#13086: Failing tests on FE310 (Hifive1b)
|
||||||
|
#12763: [TRACKING] Fixes for automatic tests of ESP32 boards.
|
||||||
|
#12651: Failing tests on AVR (tested with atmega256rfr2-xpro)
|
||||||
|
#12168: pkg/libb2: blake2s doesn't work on AVR
|
||||||
|
#11885: arm7: printf() with float/double not working
|
||||||
|
#10258: Incorrect default $PORT building for esp32-wroom-32 on macOS
|
||||||
|
#10122: Indeterministic hard fault in _mutex_lock(), with nRF52 SoftDevice
|
||||||
|
#10076: cpu/cortexm_common: irq_enable returns the current state of interrupts
|
||||||
|
(not previous)
|
||||||
|
#8408: pkg/fatfs: linker error when build tests/pkg_fatfs_vfs for msb430 based
|
||||||
|
boards
|
||||||
|
#6567: periph/spi: Switching between CPOL=0,1 problems on Kinetis with software
|
||||||
|
CS
|
||||||
|
#4954: chronos: compiling with -O0 breaks
|
||||||
|
|
||||||
|
Build system related issues (13)
|
||||||
|
--------------------------------
|
||||||
|
#14504: BUILD_IN_DOCKER ignores USEMODULE
|
||||||
|
#14288: pkg/ccn-lite: unable to `make -j -C examples/ccn-lite-relay`
|
||||||
|
#14264: make: ccache leads to differing binaries
|
||||||
|
#13492: make -j flash broken on esp* (will always flash the previous binary)
|
||||||
|
#12771: dist/tools/cppcheck/cppchck.sh: errors when running with Cppcheck 1.89
|
||||||
|
#10850: Tracking: remove harmful use of `export` in make and immediate
|
||||||
|
evaluation
|
||||||
|
#9913: Build dependencies - processing order issues
|
||||||
|
#9742: `buildtest` uses wrong build directory
|
||||||
|
#9645: Different build behavior between `murdock` and `riot/riotbuild:latest`
|
||||||
|
image
|
||||||
|
#8913: make: use of immediate value of variables before they have their final
|
||||||
|
value
|
||||||
|
#8122: doxygen: riot.css modified by 'make doc'
|
||||||
|
#6120: Windows AVR Mega development makefile Error
|
||||||
|
#4053: macros: RIOT_FILE_RELATIVE printing wrong file name for headers
|
||||||
|
|
||||||
|
Other issues (41)
|
||||||
|
-----------------
|
||||||
|
#14578: tests/cpp11_%: failing on i-nucleo-lrwan1
|
||||||
|
#14576: riotboot/nrf52840dk: flashing slot1 with JLINK fails
|
||||||
|
#14568: tests/pkg_libfixmath_unittests: failing on multiple platforms
|
||||||
|
#14548: edbg: long lines flooded over serial become garbled
|
||||||
|
#14520: examples / tests: LoRa tests fail on platforms that don't support LoRa
|
||||||
|
#14514: Uncrustify enforces deviation of coding convention
|
||||||
|
#14466: Linking C++
|
||||||
|
#14390: gcoap: Suspected crosstalk between requests (possible NULL call)
|
||||||
|
#14315: DTLS examples cannot send message to localhost
|
||||||
|
#14169: Gcoap does not handle separate responses
|
||||||
|
#14167: Gcoap drops long packages instead of gracefully erring out
|
||||||
|
#13918: cpu/stm32f1: CPU hangs after wake-up from STOP power mode
|
||||||
|
#13541: Order of auto_init functions
|
||||||
|
#13345: sys/xtimer: segmentation fault: in function xtimer_msg_received_timeout
|
||||||
|
#13285: Bug: openocd 0.10.0-6 Ubuntu dies while debugging with -rtos auto
|
||||||
|
#13277: Y2038 tracking issue / strategy
|
||||||
|
#13133: tests/pkg_tensorflow-lite: tests randomly failing on nrf52dk and
|
||||||
|
esp32-wroom-32
|
||||||
|
#13120: tests: broken with stdio_rtt if auto_init is disabled
|
||||||
|
#13044: _NVIC_SystemReset stuck in infinite loop when calling pm_reboot through
|
||||||
|
shell after flashing with J-Link
|
||||||
|
#12897: Can't build relic with benchmarks or tests
|
||||||
|
#12889: CC2538DK board docs: broken links
|
||||||
|
#12732: tests: some tests don't work with `newlib` lock functions.
|
||||||
|
#12621: Potential race condition in compile_and_test_for_board.py
|
||||||
|
#12108: `make term` output is inconsistent between boards, `ethos` and `native`
|
||||||
|
#12105: [TRACKING] sys/shell refactoring.
|
||||||
|
#11243: sys/riotboot: documentation issues
|
||||||
|
#10751: Possible memset optimized out in crypto code
|
||||||
|
#10731: nanocoap: incomplete response to /.well-known/core request
|
||||||
|
#10639: sys/stdio_uart: dropped data when received at once
|
||||||
|
#10121: RIOT cannot compile with the latest version of macOS (10.14) and Xcode
|
||||||
|
10
|
||||||
|
#9882: sys/tsrb is not thread safe
|
||||||
|
#9518: periph/i2c: tracking bugs and untested acks
|
||||||
|
#9371: assert: c99 static_assert macro doesn't function for multiple
|
||||||
|
static_asserts in the same scope
|
||||||
|
#7365: scheduler: priority inversion problem
|
||||||
|
#7220: sys/fmt: Missing tests for fmt_float, fmt_lpad
|
||||||
|
#6533: tests/lwip target board for python test is hardcoded to native
|
||||||
|
#5009: RIOT is saw-toothing in energy consumption (even when idling)
|
||||||
|
#4866: periph: GPIO drivers are not thread safe
|
||||||
|
#4488: Making the newlib thread-safe
|
||||||
|
#3256: make: Setting constants on compile time doesn't really set them
|
||||||
|
everywhere
|
||||||
|
#2346: Tracker: Reduce scope on unintended COMMON variables
|
||||||
|
|
||||||
|
There are 150 known issues in this release
|
||||||
|
|
||||||
|
Fixed Issues since the last release (2020.04)
|
||||||
|
=============================================
|
||||||
|
|
||||||
|
#14521: tests/test_tools: fails on `iotlab-m3` due to `core`/`cpu` regression
|
||||||
|
#14415: Flashing nrf52dk with bmp breaks board
|
||||||
|
#14409: doc/search: hitting return while searching on api.riot-os.org reloads
|
||||||
|
current page
|
||||||
|
#14407: gnrc/RPL: instance ID not updated on reconnect
|
||||||
|
#14399: cord_ep example timed out when registering to a resource directory
|
||||||
|
#14380: dist/tools/flatc: cloning of the tool sporadically fails on the CI
|
||||||
|
#14361: Bug : bad assertion in cpu/stm32/periph/pwm.c
|
||||||
|
#14330: Improve driver implementation documentation
|
||||||
|
#14328: sam0_common: make debug broken for boards using EDBG
|
||||||
|
#14184: Part of puts/printf output is skipped
|
||||||
|
#14164: Failed assertion when using netdev_ieee802154_mr_fsk
|
||||||
|
#14158: kconfig is broken on case-insensitive file systems
|
||||||
|
#14074: Memory read beyond input buffer boundaries in nanocoap packet parser
|
||||||
|
#14035: I can't use w5100 to work on Release-2020.04 by using
|
||||||
|
RIOT/examples/emcute_mqttsn/.
|
||||||
|
#14034: gcoap server breaks or becomes very unresponsive (sock_async related?)
|
||||||
|
#13984: tests/pkg_ubasic: failing on esp32-wroom-32
|
||||||
|
#13920: stm32: ztimer RTT backend overflow
|
||||||
|
#13838: Global Address remains in state TNT[3] forever
|
||||||
|
#13834: DHCPv6 client ends up in busy loop after a while
|
||||||
|
#13419: Can't use nimble as prefix for modules
|
||||||
|
#13209: examples/gnrc_border_router is crashing after some time
|
||||||
|
#12909: Bug: Unexpected behavior with xtimer_periodic_wakeup() for large periods
|
||||||
|
on Nucleo-f401re
|
||||||
|
#12858: KW2XRF: Broken network communication without netstats-l2
|
||||||
|
#12205: core: atomic: Unable to compile starting with gcc 9.1.0
|
||||||
|
#11859: examples: dtls-echo fails silently when DTLS_ECC flag enabled
|
||||||
|
#11795: gnrc_tftp: string functions on non-null terminated input
|
||||||
|
#11523: xtimer_periodic_wakeup crashing at high frequencies on frdm-kw41z
|
||||||
|
#11472: Warnings from objcopy and size (binutils 2.32)
|
||||||
|
#11388: SD card initialization: timeouts effectively blocking
|
||||||
|
#11212: POSIX sockets + lwIP: bad file descriptor
|
||||||
|
#11149: xtimer: hang on xtimer_spin_until (corner case)
|
||||||
|
#10367: sam0.inc.mk: Did not find a device with serial ATML21xxxxxxxx
|
||||||
|
#8589: Why using -F in avrdude?
|
||||||
|
#8436: Kinetis PhyNode: failed to flash binary > 256K
|
||||||
|
#8172: gnrc_netif, gnrc_uhcpc: Replacing prefix on border router results in no
|
||||||
|
configured prefix
|
||||||
|
#8086: gnrc_rpl_p2p: port to nib and fix compile errors
|
||||||
|
#8045: stm32/periph/uart: extra byte transmitted on first transmission
|
||||||
|
#7753: pic32-wifire: race-condition when linking in concurrent build
|
||||||
|
#5775: cpu: cortex-m: compiling vectors.c with LTO triggers compiler bug
|
||||||
|
#5774: cpu: cortexm_common: context switching code breaks when compiling with
|
||||||
|
LTO
|
||||||
|
#5769: Possible problem in scheduler
|
||||||
|
#5748: gnrc: nodes crashing with too small packet buffer
|
||||||
|
|
||||||
|
42 fixed issues since last release (2020.04)
|
||||||
|
|
||||||
|
|
||||||
|
Acknowledgements
|
||||||
|
================
|
||||||
|
We would like to thank all companies that provided us with hardware for porting
|
||||||
|
and testing RIOT-OS. Further thanks go to companies and institutions that
|
||||||
|
directly sponsored development time. And finally, big thanks to all of you
|
||||||
|
contributing in so many different ways to make RIOT worthwhile!
|
||||||
|
|
||||||
|
More information
|
||||||
|
================
|
||||||
|
http://www.riot-os.org
|
||||||
|
|
||||||
|
Mailing lists
|
||||||
|
-------------
|
||||||
|
* RIOT OS kernel developers list
|
||||||
|
devel@riot-os.org (http://lists.riot-os.org/mailman/listinfo/devel)
|
||||||
|
* RIOT OS users list
|
||||||
|
users@riot-os.org (http://lists.riot-os.org/mailman/listinfo/users)
|
||||||
|
* RIOT commits
|
||||||
|
commits@riot-os.org (http://lists.riot-os.org/mailman/listinfo/commits)
|
||||||
|
* Github notifications
|
||||||
|
notifications@riot-os.org (http://lists.riot-os.org/mailman/listinfo/notifications)
|
||||||
|
|
||||||
|
IRC
|
||||||
|
---
|
||||||
|
* Join the RIOT IRC channel at: irc.freenode.net, #riot-os
|
||||||
|
|
||||||
|
License
|
||||||
|
=======
|
||||||
|
* The code developed by the RIOT community is licensed under the GNU Lesser
|
||||||
|
General Public License (LGPL) version 2.1 as published by the Free Software
|
||||||
|
Foundation.
|
||||||
|
* Some external sources and packages are published under a separate license.
|
||||||
|
|
||||||
|
All code files contain licensing information.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
RIOT-2020.04 - Release Notes
|
RIOT-2020.04 - Release Notes
|
||||||
============================
|
============================
|
||||||
RIOT is a multi-threading operating system which enables soft real-time
|
RIOT is a multi-threading operating system which enables soft real-time
|
||||||
|
Loading…
Reference in New Issue
Block a user