zephyr/doc/releases/release-notes-3.6.rst
Declan Snyder 5a3c77e746 doc: release-notes-3.6: MDIO changes
Add changes to 3.6 release notes for MDIO drivers

Signed-off-by: Declan Snyder <declan.snyder@nxp.com>
2024-02-17 14:17:55 +01:00

1255 lines
50 KiB
ReStructuredText

:orphan:
.. _zephyr_3.6:
Zephyr 3.6.0 (Working Draft)
############################
We are pleased to announce the release of Zephyr version 3.6.0.
Major enhancements with this release include:
An overview of the changes required or recommended when migrating your application from Zephyr
v3.5.0 to Zephyr v3.6.0 can be found in the separate :ref:`migration guide<migration_3.6>`.
The following sections provide detailed lists of changes by component.
Security Vulnerability Related
******************************
The following CVEs are addressed by this release:
More detailed information can be found in:
https://docs.zephyrproject.org/latest/security/vulnerabilities.html
Kernel
******
Architectures
*************
* ARC
* ARM
* ARM64
* RISC-V
* Xtensa
* Removed the unused Kconfig option ``CONFIG_XTENSA_NO_IPC``.
* Added userspace support via MMU.
* x86
* POSIX
Bluetooth
*********
* Audio
* Changed ``bt_bap_scan_delegator_subgroup`` to :c:struct:`bt_bap_bass_subgroup` and
made it independent of :kconfig:option:`CONFIG_BT_BAP_SCAN_DELEGATOR`.
* Modified :c:func:`bt_bap_stream_send` to no longer take a timestamp as parameter,
and added :c:func:`bt_bap_stream_send_ts` that does.
* Modified :c:func:`bt_cap_stream_send` to no longer take a timestamp as parameter,
and added :c:func:`bt_cap_stream_send_ts` that does.
* Assigned number values have been moved from :file:`include/zephyr/bluetooth/audio/lc3.h` to
:file:`include/zephyr/bluetooth/audio/audio.h` and the ``LC3`` infix have been removed.
* The CAP initiator APIs have been streamlined and follow the same parameter pattern.
* Added Kconfig options to make MCC functionality optional to reduce memory usage for simple
clients.
* Added CAP Commander change volume and change volume offset.
* Added proper support for doing decoding in the application instead of in the controller by
modifying how the ISO data path is configured.
* Added :c:func:`bt_csip_set_member_unregister` to unregister a CSIS instance.
* Added helper functions to get and set assigned number values in codec configuration and
codec capabilities.
* Added support for the new mono audio location.
* Added ISO state callbacks for streams so the user knows the state of the CIS.
* Added :c:func:`bt_pacs_set_available_contexts_for_conn` to set available context per connection
* Refactored the :c:struct:`bt_bap_base` to be an abstract struct with new helper functions,
so that Zephyr supports all BASEs regardless of the size.
* Direction Finding
* Host
* Added ``recycled()`` callback to :c:struct:`bt_conn_cb`, which notifies listeners when a
connection object has been freed, so it can be utilized for different purposes. No guarantees
are made to what listener will be granted the object, as only the first claim is served.
* Modified :c:func:`bt_iso_chan_send` to no longer take a timestamp as parameter,
and added :c:func:`bt_iso_chan_send_ts` that does.
* Mesh
* Added the delayable messages functionality to apply random delays for
the transmitted responses on the Access layer.
The functionality is enabled by the :kconfig:option:`CONFIG_BT_MESH_ACCESS_DELAYABLE_MSG`
Kconfig option.
* The Bluetooth Mesh Protocol 1.1 is now supported by default.
* Controller
* Added deinit implementation for ESP32 controller.
* HCI Driver
* Split ST HCI SPI Bluetooth driver from the Zephyr one to provide more features
based on ST SPI protocols V1 and V2. As a result, :dtcompatible:`st,hci-spi-v1` and
:dtcompatible:`st,hci-spi-v2` were introduced.
Boards & SoC Support
********************
* Added support for these SoC series:
* Added support for Renesas R-Car Gen4 series
* Added support for STM32F303xB SoC variants
* Added support for STM32H7B0xx SoC variants
* Added support for STM32L010xx SoC variants
* Added support for STM32L081xx SoC variants
* Added support for STM32U5A9xx SoC variants
* Removed support for these SoC series:
* Made these changes in other SoC series:
* Nordic SoCs now imply :kconfig:option:`CONFIG_XIP` instead of selecting it, this allows for
creating RAM-based applications by disabling it.
* BLE is now supported on STM32WBA series.
* Added support for these ARC boards:
* Added support for these ARM boards:
* Added support for Adafruit QTPy RP2040 board: ``adafruit_qt_py_rp2040``
* Added support for FANKE FK7B0M1-VBT6 board: ``fk7b0m1_vbt6``
* Added support for Renesas R-Car Spider board CR52: ``rcar_spider_cr52``
* Added support for ST Nucleo F722ZE board: ``nucleo_f722ze``
* Added support for ST STM32H750B Discovery Kit: ``stm32h750b_dk``
* Added support for ST STM32L4R9I Discovery board: ``stm32l4r9i_disco``
* Added support for ST STM32U5A9J-DK discovery kit: ``stm32u5a9j_dk``
* Added support for ST Nucleo WBA55CG board: ``nucleo_wba55cg``
* Added support for ST STM32WB5MM-DK Discovery board: ``stm32wb5mm_dk``
* Added support for Wiznet W5500 Evaluation Pico board: ``w5500_evb_pico``
* Added support for ADI boards: ``adi_sdp_k1``, ``adi_eval_adin1110ebz``,
``adi_eval_adin2111ebz``
* Added support for these ARM64 boards:
* Added support for these RISC-V boards:
* Added support for these X86 boards:
* Added support for these Xtensa boards:
* Added Heltec Wireless Stick Lite (V3) board: ``heltec_wireless_stick_lite_v3``
* Added KINCONY-KC868-A32 board: ``kincony_kc868_a32``
* Added Lolin ESP32-S2 Mini board: ``esp32s2_lolin_mini``
* Added M5Stack AtomS3 board: ``m5stack_atoms3``
* Added M5Stack AtomS3-Lite board: ``m5stack_atoms3_lite``
* Added M5Stack StampS3 board: ``m5stack_stamps3``
* Added support for these POSIX boards:
* Made these changes for ARC boards:
* Made these changes for ARM boards:
* Made these changes for ARM64 boards:
* Made these changes for RISC-V boards:
* ``longan_nano``: Enabled ADC support.
* Made these changes for X86 boards:
* Made these changes for Xtensa boards:
* Made these changes for native/POSIX boards:
* The :ref:`simulated nrf5340 targets<nrf5340bsim>` now include the IPC and MUTEX peripherals,
and support OpenAMP to communicate between the cores.
It is now possible to run the BLE controller or 802.15.4 driver in the net core, and application
and BT host in the app core.
* The nrf*_bsim simulated targets now include models of the UART peripheral. It is now possible
to connect a :ref:`nrf52_bsim<nrf52_bsim>` UART to another, or a UART in loopback, utilizing
both the new and legacy nRFx UART drivers, in any mode.
* For the native simulator based targets it is now possible to set via Kconfig command line
options which will be handled by the executable as if they were provided from the invoking
shell.
* For all native boards boards, the native logger backend will also be used even if the UART is
enabled.
* Several bugfixes and other minor additions to the nRF5x HW models.
* Multiple documentation updates and fixes for all native boards.
* Removed support for these ARC boards:
* Removed support for these ARM boards:
* Removed support for these ARM64 boards:
* Removed support for these RISC-V boards:
* Removed support for these X86 boards:
* Removed support for these Xtensa boards:
* Made these changes in other boards:
* Added support for these following shields:
* M5Stack-Core2 base
* MikroElektronika ACCEL 13 Click
* Waveshare Pico UPS-B
* X-NUCLEO-BNRG2A1: BLE expansion board
* X-NUCLEO-IKS4A1: MEMS Inertial and Environmental Multi sensor
Build system and infrastructure
*******************************
* Added functionality for Link Time Optimization.
This change includes interrupt script generator rebuilding and adding following options:
- :kconfig:option:`CONFIG_ISR_TABLES_LOCAL_DECLARATION` Kconfig option:
LTO compatible interrupt tables parser,
- :kconfig:option:`CONFIG_LTO` Kconfig option: Enable Link Time Optimization.
Currently the LTO compatible interrupt tables parser is only supported by ARM architectures and
GCC compiler/linker.
See `pull request :github:`66392` for details.
* Dropped the ``COMPAT_INCLUDES`` option, it was unused since 3.0.
* Fixed an issue whereby board revision ``0`` did not include overlay files for that revision.
* Added ``PRE_IMAGE_CMAKE`` and ``POST_IMAGE_CMAKE`` hooks to sysbuild modules, which allows for
modules to run code after and before each image's cmake invocation.
* Added :kconfig:option:`CONFIG_ROM_END_OFFSET` option which allows reducing the size of an image,
this is intended for use with firmware signing scripts which add additional data to the end of
images outside of the build itself.
* Added MCUboot image size reduction to sysbuild images which include MCUboot which prevents
issues with building firmware images that are too large for MCUboot to swap.
* Deprecated :kconfig:option:`CONFIG_BOOTLOADER_SRAM_SIZE`, users of this should transition to
having RAM set up properly in their board devicetree files.
* Fixed an issue whereby shields were processed in order of the root they resided in rather than
the order they were supplied to cmake in.
* Fixed an issue whereby using some shields with sysbuild would cause a cmake Kconfig error.
* Fixed an issue where the macros ``_POSIX_C_SOURCE`` and ``_XOPEN_SOURCE`` would be defined
globally when building with Picolibc or for the native (``ARCH_POSIX``) targets.
After this change users may need to define them for their own applications or libraries if they
require them.
* Added support for sysbuild setting a signing script (``SIGNING_SCRIPT``), see
:ref:`west-extending-signing` for details.
* Added support for ``FILE_SUFFIX`` in the build system which allows for adding suffixes to
application Kconfig fragment file names and devicetree overlay file names, see
:ref:`application-file-suffixes` and :ref:`sysbuild_file_suffixes` for details.
* Deprecated ``CONF_FILE`` ``prj_<build>.conf`` build type.
Drivers and Sensors
*******************
* ADC
* Power Management for ADC is now supported on STM32 devices.
* STM32 ADC driver now supports mixing shared and separate IRQs (for instance on STM32G473
which has 5 ADCs, ADC1 and ADC2 share one IRQ while ADC3, ADC4 and ADC5 each have unique IRQs).
Enabling all instances in same application is not possible on such devices as of now.
* Auxiliary Display
* Added Sparkfun SerLCD driver.
* Battery backed up RAM
* STM32WL devices now support BBRAM.
* CAN
* Added system call :c:func:`can_get_mode()` for getting the current operation mode of a CAN
controller.
* Add system call :c:func:`can_get_transceiver()` for getting the CAN transceiver associated with
a CAN controller.
* Added accessor functions for the CAN statistics.
* Added common bit error counter to the CAN statistics.
* Added CAN statistics support to the following drivers:
* :dtcompatible:`microchip,mcp2515`
* :dtcompatible:`espressif,esp32-twai`
* :dtcompatible:`kvaser,pcican`
* Added CAN controller driver for the Nuvoton NuMaker series
(:dtcompatible:`nuvoton,numaker-canfd`).
* Added CAN controller driver for the Infineon XMC4xxx family
(:dtcompatible:`infineon,xmc4xxx-can` and :dtcompatible:`infineon,xmc4xxx-can-node`).
* Added support for the NXP S32K1xx family to the :dtcompatible:`nxp,flexcan` driver.
* Use named IRQs "int0" and "int1" in all Bosch M_CAN-based front-end drivers.
* The :dtcompatible:`zephyr,native-linux-can` driver now supports being built with embedded C
libraries.
* Added support for setting "raw" timing values from the :ref:`CAN shell <can_shell>`.
* Clock control
* Renesas R-Car clock control driver now supports Gen4 SoCs
* Renamed ``CONFIG_CLOCK_CONTROL_RA`` to :kconfig:option:`CONFIG_CLOCK_CONTROL_RENESAS_RA`
* On STM32 devices, :dtcompatible:`st,stm32-hse-clock` now allows setting a ``css-enabled``
property which enables HSE clock security system (CSS).
* Counter
* The nRFx counter driver now works with simulated nrf*_bsim targets.
* counter_native_posix driver: Added support for top value configuration, and a bugfix.
* Crypto
* STM32WB devices now support crypto API through AES block
* DAC
* Display
* Introduce frame buffer config to STM32 LTDC driver.
* DMA
* STM32WBA Devices now support GPDMA
* Entropy
* The "native_posix" entropy driver now accepts a new command line option ``seed-random``.
When used, the random generator will be seeded from ``/dev/urandom``
* On STM32devices, RNG block is now suspended when pool is full to save power.
* Ethernet
* The "native_posix" ethernet driver now supports being built with embedded C libraries.
* Enabled HW checksum offloading for STM32H7.
* Added implementation of Open Alliance's TC6 T1S driver.
* Added xmc4xxx driver.
* Added NXP enet driver with PTP support.
* Added KSZ8081 PHY driver.
* Added proper IPv4 multicast support to NXP mcux driver.
* Added LAN8651 T1S support.
* Added DSA support to STM32.
* Added tja1103 PHY support.
* Added Nuvoton numaker support.
* Fixed lan865x driver. Transmission speed improvements, IRQ handling fixes.
* Fixed s32_gmac driver. Link up/down handling fixes.
* Fixed phy_mii driver. The invalid phy id was incorrectly checked.
* Fixed sam_gmac driver. PTP clock adjustment was wrong for negative values.
* Fixed adin2111 driver. Initialization was done incorrectly when working with adin2110.
* Fixed ksz8081 driver. Logging changes, RMII clock fixes, GPIO pin fixes.
* Flash
* Atmel SAM: Redesign controller to fully utilize flash page layout.
* ``spi_nor`` driver now sleeps between polls in ``spi_nor_wait_until_ready``. If this is not
desired (For example due to ROM constraints in a bootloader),
:kconfig:option:`CONFIG_SPI_NOR_SLEEP_WHILE_WAITING_UNTIL_READY` can be disabled.
* Flash readout protection configuration was added on STM32G4 and STM32L4 series.
* ``nordic_qspi_nor`` driver now supports user-configurable QSPI timeout with
:kconfig:option:`CONFIG_NORDIC_QSPI_NOR_TIMEOUT_MS`.
* GNSS
* Added GNSS device driver API and subsystem for parsing and publishing location,
datetime, and satellite information, enabled by
:kconfig:option:`CONFIG_GNSS` and :kconfig:option:`CONFIG_GNSS_SATELLITES`.
The GNSS subsystem and device drivers are based on the :ref:`modem` subsystem,
using the ``modem_pipe`` module, modem backends, and ``modem_chat`` module to
communicate with the modems. For systems which already contain a cellular modem,
adding a GNSS modem is very efficient due to the reuse of subsystems.
* Added GNSS specific, safe, string to integer parsing utilities, enabled by
:kconfig:option:`CONFIG_GNSS_PARSE`.
* Added NMEA0183 parsing utilities, enabled by
:kconfig:option:`CONFIG_GNSS_NMEA0183`.
* Added extensive GNSS data logging, enabled by
:kconfig:option:`CONFIG_GNSS_DUMP_TO_LOG`.
* Added generic NMEA0183 over UART based modem device driver, matching the
devicetree compatible :dtcompatible:`gnss-nmea-generic`.
* Added fully featured device driver for the Quectel LCX6G series GNSS modems,
matching the devicetree compatibles :dtcompatible:`quectel,lc26g`,
:dtcompatible:`quectel,lc76g` and :dtcompatible:`quectel,lc86g`.
* GPIO
* Renesas R-Car GPIO driver now supports Gen4 SoCs
* Renamed ``CONFIG_GPIO_RA`` to :kconfig:option:`CONFIG_GPIO_RENESAS_RA`
* I2C
* :c:func:`i2c_get_config` is now supported on STM32 driver.
* I2S
* STM32H7 devices now support I2S.
* I3C
* The Legacy Virtual Register defines have been renamed from ``I3C_DCR_I2C_*``
to ``I3C_LVR_I2C_*``.
* Added the ability to specify a start address when searching for a free I3C
address to be reserved. This requires a new function argument to
:c:func:`i3c_addr_slots_next_free_find`.
* Added a field named ``num_xfer`` in :c:struct:`i3c_msg` and
:c:struct:`i3c_ccc_taget_payload` as an output to indicate the actual
number of bytes transferred.
* Cadence I3C driver (:file:`drivers/i3c/i3c_cdns.c`):
* Added support to handle controller abort where target does not emit
end of data for register read but continues sending data.
* Updated the timeout calculation to be coupled with CPU speed instead of
a fixed number of retries.
* NXP MCUX I3C driver (:file:`drivers/i3c/i3c_mcux.c`):
* Fixed ``mcux_i3c_config_get()`` of not returning the configuration to caller.
* Sped up the FIFO read routine to support higher transfer rate.
* Removed the infinite wait for MCTRLDONE in auto IBI.
* Added ``disable-open-drain-high-pp`` property to
:dtcompatible:`nxp,mcux-i3c`, which allows alternative high time for
open-drain clock.
* IEEE 802.15.4
* Removed :kconfig:option:`CONFIG_IEEE802154_SELECTIVE_TXPOWER` Kconfig option.
* Interrupt Controller
* Input
* The ``short-codes`` property of :dtcompatible:`zephyr,input-longpress` is
now optional, the node can be used by specifying only input and long codes.
* Added support for keyboard matrix drivers, including a new
:dtcompatible:`gpio-kbd-matrix` and :dtcompatible:`input-keymap` drivers,
see :ref:`gpio-kbd` for more details.
* Added a pair of input codes to HID codes translation functions, see
:c:func:`input_to_hid_code` and :c:func:`input_to_hid_modifier`.
* Added power management support to :dtcompatible:`gpio-keys`
:dtcompatible:`focaltech,ft5336`.
* Added a :dtcompatible:`zephyr,native-linux-evdev` device node for getting
input events from a Linux evdev device node.
* Added support for optical encoders and power management to :dtcompatible:`gpio-qdec`.
* New driver :dtcompatible:`analog-axis`.
* Added ESP32 touch sensor driver including a :dtcompatible:`espressif,esp32-touch`.
* MDIO
* Fixed initialization priorities of NXP s32 NETC drivers.
* Fixed SAM GMAC transfer timeout errors caused by MDIO clock not being initialized.
* Fixed ESP32 MDIO driver being enabled when node was not status okay.
* Added support for C22 and C45 APIs on S32 GMAC.
* Added MDIO driver for NXP ENET peripheral.
* Added xmc4xxx MDIO drivers.
* Fixed build errors caused by mdio.h driver header not including errno.h
* PCIE
* Fixed MMIO size calculation by disabling IO/memory decoding beforehand.
* Modified to use PNP ID for PRT retrieval.
* ACPI
* Pin control
* Renesas R-Car pinctrl driver now supports Gen4 SoCs
* Renamed ``CONFIG_PINCTRL_RA`` to :kconfig:option:`CONFIG_PINCTRL_RENESAS_RA`
* Renesas R-Car pinctrl driver now supports voltage control for R8A77951 and
R8A77961 SoCs
* Added driver for ZynqMP / Mercury XU
* Added driver for i.MX8QM/QXP
* Added driver for Renesas RZ/T2M
* On STM32 devices, pins assigned to JTAG/SW port can now be put to analog state when
:kconfig:option:`CONFIG_PM` enabled and :kconfig:option:`CONFIG_DEBUG` disabled.
* PWM
* Fixed ESP32S3 low frequency PWM issue.
* Regulators
* Reset
* Retained memory
* Retained memory driver backend for registers has been added.
* Retained memory API status changed from experimental to unstable.
* RTC
* Atmel SAM: Added RTC driver.
* SMBUS:
* SMBUS is now supported on STM32 devices
* SDHC
* Added SDHC driver for Cadence SDHC IP
* Added SDHC driver for Infineon CAT1 IP
* Added support for SDIO commands to iMX USDHC SDHC driver
* Sensor
* Fixed arithmetic overflow in the LTRF216A driver.
* Fixed negative temperature calculation in MAX31865 driver.
* Added TI TMAG5273 3D Hall sensor driver.
* Added Vishay VCNL36825T proximity sensor driver.
* Added BMA4xx accelerometer sensor emulator.
* Added white channel support to the VEML7700 ambient light sensor driver.
* Added ST LIS2DE12 accelerometer sensor driver.
* Added Bosch BMP581 pressure sensor driver.
* Added support for triggering multiple sensor devices in the sensor shell.
* Added Aosong AGS10 TVOC air quality gas sensor driver.
* Extended MAX31865 temperature sensor driver to support changing three-wire
mode at runtime.
* Fixed Bosch BMI160 gyro range calculation and added support for getting
attributes.
* Optimized Bosch BMA4xx accelerometer sample calculation, improving
accuracy.
* Removed floating point arithmetic from the TI BQ274xx gauge driver.
* Fixed ST drivers Kconfig dependency to the HAL_ST module.
* Added Bosch BMA4xx accelerometer sensor driver.
* Added ST LIS2DU12 accelerometer sensor driver.
* Extended NTC thermistor driver to support TDK NTCG103JF103FT1.
* Added NXP S32 quadrature decoder driver.
* Fixed LSM6DSV16x gyro range table.
* Fixed missing return value checks in ADLTC2990, TSL2540, MAX17055 drivers.
* Added ST LPS28DFW pressure sensor driver.
* Fixed interrupt in BMI323 driver.
* Added devicetree properties macros to various ST sensor drivers.
* Added Renesas HS300x temperature/humidity sensor driver.
* Added Gas Sensing Solutions' ExplorIR-M CO2 sensor driver.
* Fixed self test delay in ADXL367 accelerometer sensor driver.
* Added ST LPS22DF pressure sensor driver.
* Added new streaming APIs and implemented in the ICM42688 driver.
* Added trigger support to the ADXL367 accelerometer sensor driver.
* Added PM suspend and resume support to the LSM6DSL accelerometer sensor
driver.
* Added AMS TSL2561 light sensor driver.
* Extended BQ274xx driver to support configuring and confirming the chemistry
profile.
* Extended LIS2DH and LSM6DSV16x drivers to support configuring INT1/INT2 in
devicetree.
* Added die temperature measurement support to NPM1300 charger driver.
* Added ADLTC2990 sensor emulator.
* Extended MPU6050 driver to support MPU6886 variant.
* Added ADXL367 accelerometer sensor driver.
* Added LiteOn LTR-F216A illuminance sensor driver.
* Added Memsic MC3419 accelerometer sensor driver.
* Added AMD SB temperature sensor driver.
* Added ESP32S3 internal temperature sensor driver.
* Serial
* Added drivers to support UART on Renesas RA and RZ/T2M.
* Added support for higher baud rate for ITE IT8xxx2.
* Added driver to support Intel Lightweight UART.
* Added UART asynchronous RX helper.
* Added support for async API on NS16550 driver.
* Updated ``uart_esp32`` to use serial port configuration from devicetree.
* Added an adaptation API to provide interrupt driven API for drivers
which have only implemented async API.
* Emulated UART driver (:file:`drivers/serial/uart_emul.c`):
* Added emulated interrupt based TX.
* Added emulated error for testing.
* Modified to use local work queue for data transfer.
* Modified FIFO size and its handling to be more aligned with real hardware.
* On STM32 devices, it is now possible to enable FIFO by setting a ``fifo-enable``
property in targeted serial node, with the following benefits:
In TX, FIFO allows to work in burst mode, easing scheduling of loaded applications.
It also allows more reliable communication with UART devices sensitive to variation of inter-frames delays.
In RX, FIFO reduces overrun occurences.
* SPI
* On STM32H7 devices, ``fifo-enable`` property allows using SPI block FIFO. This
feature is still experimental and requires maturation.
* On STM32 devices impacted by BSY bit erratum, a workaround is implemented.
* Timer
* USB
* On STM2G0 devices, property ``crs-usb-sof`` in ``clk_hsi48`` node enables support
for Clock Recovery System allowing a more stable HSI48 clock and hence resilient USB
connection.
* On compatible STM32 devices, isochronous endpoint are now functional thanks to the
use of double buffering.
* W1
* Added 1-Wire GPIO master driver. See the :dtcompatible:`zephyr,w1-gpio`
devicetree binding for more information.
* Wi-Fi
* Added Infineon airoc driver.
* Fixed esp32 driver. Decreased minimum heap size, disabled automatic reconnection on leaving.
* Fixed esp_at driver. Allow building without IPv4 support. Passive Receive mode fixes. Depend on UART runtime configuration.
* Fixed winc1500 driver. Disconnect result event was not returned when disconnecting.
Networking
**********
* CoAP:
* Added support for Echo and Request-Tag CoAP options (RFC 9175).
* Changed :c:func:`coap_remove_observer` API function return type to bool.
* Introduced CoAP service library, which simplifies implementation of CoAP
server functionality.
* Updated CoAP server example to use CoAP service library.
* Added shell module for CoAP server.
* Fixed NULL pointer dereference in :c:func:`coap_packet_remove_option`
* Added CoAP observer/service network events using the Network Event subsystem.
* Changed :c:func:`coap_pending_init` API function to take
:c:struct:`coap_transmission_parameters` instead of retry count.
* Added new API functions:
* :c:func:`coap_get_transmission_parameters`
* :c:func:`coap_set_transmission_parameters`
* :c:func:`coap_handle_request_len`
* :c:func:`coap_well_known_core_get_len`
* :c:func:`coap_uri_path_match`
* :c:func:`coap_packet_is_request`
* :c:func:`coap_find_observer`
* :c:func:`coap_find_observer_by_token`
* :c:func:`coap_pendings_count`
* :c:func:`coap_header_set_code`
* Connection Manager:
* Added a generic Wi-Fi connectivity backend.
* DHCP:
* Added missing DHCPv6 state structure initialization when initializing
network interface.
* DHCP-assigned IPv4 address is now removed when interface goes down.
* Added DHCPv4 server implementation.
* Rearranged DHCPv4 file structure, all DHCPv4 related files are now grouped
within ``subsys/net/lib/dhcpv4``.
* Moved DHCPv6 files to ``subsys/net/lib/dhcpv6`` to align with DHCPv4.
* DNS:
* Added support for enabling mDNS listener on all network interfaces.
* Added VLAN support to the ``mdns_responder`` sample.
* Fixed TTL/hop limit set on DNS packets.
* Added :kconfig:option:`CONFIG_DNS_RESOLVER_AUTO_INIT` which allows to disable
automatic initialization of the default DNS context on boot.
* Ethernet:
* Allow manual registration of ARP entries.
* Added PHY mode selection to device tree.
* Added TX-Injection mode support.
* gPTP:
* Use local port identity when forwarding sync messages.
* Fix double converted byte order of BMCA info.
* Always use GM PRIO root system id for announce messages.
* Create gPTP handler thread stack size Kconfig option.
* Invert the priority of outgoing packets.
* ICMP:
* Fixed an error being emitted when unhandled ICMP message was received.
* Fixed a bug, where ICMP Echo Reply could be sent without proper source IP
address set.
* Fixed a packet leak in ICMP Echo Request handlers, in case priority check
failed.
* Improved thread safety of the module handling Neighbor Discovery.
* Added support for IPv6 Neighbor reachability hints, allowing to reduce
ICMPv6 traffic for active connections.
* IP:
* Fixed L3/L4 checksum calculation/validation for IP-fragmented packets on
interfaces that support checksum offload.
* Fixed net_context not being set on IP fragmented packets, preventing send
callback from being called.
* It is now possible to have separate IPv4 TTL value and IPv6 hop limit value for
unicast and multicast packets. This can be controlled in each socket via
:c:func:`setsockopt` API.
* Improved source IP address verification in the IP stack. Addresses received
to/from loopback address on non-loopback interfaces are dropped.
* Added new functions to verify if IPv6 address is site local or global.
* Added support for setting peer IP address in :c:struct:`net_pkt` structure
for offloaded interfaces. This allows for :c:func:`recvfrom` to return a
valid address in offloaded case.
* LwM2M:
* Added :kconfig:option:`CONFIG_LWM2M_UPDATE_PERIOD` which allows to configure LwM2M
Update period regardless of the lifetime value.
* Fixed composite read/write access rights check.
* Added shell command to delete object and resource instances.
* Fixed a bug in block-wise transfer, where block-wise ACKs were sent with
wrong response code.
* Fixed object version reporting for LwM2M version 1.1.
* Added support for DTLS Connection Identifier in LwM2M engine.
* Added support for LwM2M Server Disable executable resource.
* Implemented fallback mechanism for LwM2M server selection during registration
phase. The engine will now try to choose different server if the current one
becomes unavailable or disabled.
* Added support for storing LwM2M error list in settings.
* Fixed pmin observer attribute handling in tickless mode.
* Added support for notifying the application about ongoing CoAP transmissions
with ``set_socket_state()`` callback.
* Deprecated unsigned 64-bit integer value type, as it's not represented in the spec.
Use signed 64-bit integer instead.
* Added a callback for LwM2M Gateway object, which allows to handle LwM2M messages
with prefixed path.
* Added LwM2M-specific macros for object initialization during boot.
* Several other minor bugfixes ans improvements.
* Misc:
* Added support for compile time network event handlers using the macro
:c:macro:`NET_MGMT_REGISTER_EVENT_HANDLER`.
* The :kconfig:option:`CONFIG_NET_MGMT_EVENT_WORKER` choice is added to
allow emitting network events using the system work queue or synchronously.
* Removed redundant Network Connectivity API documentation page.
* Improved thread safety of the network connections subsystem.
* Removed ``eth_native_posix`` sample.
* Removed redundant ``arb`` and ``fv2015`` fields from
``struct net_pkt_cb_ieee802154``.
* Introduced a separate mutex for TX at the network interface level, to prevent
concurrent access on TX to drivers that are not re-entrant.
* Fixed netmask not being registered for loopback address.
* Added support for binding to a specific network interface at the net_context
level.
* Added IGMPv3 support.
* Added a new network event, ``NET_EVENT_HOSTNAME_CHANGED``, triggered upon
hostname change.
* Refactored net_context option getters/setters to reduce code duplication.
* Fixed a possible packet leak at the ARP level, in case of errors during ARP
packet creation.
* Added support for analyzing SNTP time uncertainty.
* Fixed network interface being brought up even when underlying device is not
ready.
* Added start/stop functions for dummy interfaces.
* Added a detailed :ref:`network configuration <network_configuration_guide>`
guide to the documentation.
* Added :kconfig:option:`CONFIG_NET_HOSTNAME_DYNAMIC` option, which allows to
enable setting hostname at runtime.
* MQTT-SN:
* Added :c:func:`mqtt_sn_get_topic_name` API function.
* Fixed handling of incoming Register messages when wildcard subscription is used.
* OpenThread:
* Implemented the following OpenThread platform APIs:
* ``otPlatRadioSetRxOnWhenIdle()``
* ``otPlatResetToBootloader()``
* ``otPlatCryptoPbkdf2GenerateKey()``
* Updated OpenThread platform UART driver, so that it no longer waits for
communication with host to start during boot.
* Added BLE TCAT implementation in OpenThread platform.
* Updated Crypto PSA backend for OpenThread with additional algorithms.
* Fixed ``otPlatAssertFail()``, so that it prints the location of the actual
assert instead of the function itself.
* PPP:
* Fixed PPP connection termination when interface goes down.
* Shell:
* Refactored networking shell module, so that instead of large single file, it
is split into submodules, at per command basis.
* Fixed unexpected timeout message when executing loopback ping.
* Added ``net sockets`` command to print information about open sockets and
socket services.
* Join IPv4/IPv6 multicast groups, if needed, when adding IPv4/IPv6 multicast
addresses via shell.
* Fixed ``tcp connect`` command operation (TCP context released prematurely).
* Added support for Echo option in telnet shell backend.
* Fixed unnecessary connection close in telnet shell backend in case of
non-fatal EAGAIN or ENOBUFS errors.
* Fixed double packet dereference in ping reply handler.
* Fixed possible deadlock when executing ``net arp`` command.
* Added more detailed Ethernet statistics printout for ``net stats`` command.
* Added ``net dhcpv4 server`` commands for DHCPv4 server management.
* Added shell module to manage TLS credentials.
* Sockets:
* Added support for v4-mapping-to-v6, which allows IPv4 and IPv6 to share the
same port space.
* Added support for :c:macro:`IPV6_V6ONLY` socket option.
* Added support for :c:macro:`SO_ERROR` socket option.
* Fixed :c:func:`select` not setting ``writefds`` in case of errors.
* Added support for object core, which allows to track networks sockets and
their statistics.
* Added support for :c:func:`recvmsg`.
* Added support for :c:macro:`IP_PKTINFO` and :c:macro:`IPV6_RECVPKTINFO`
socket options.
* Added support for :c:macro:`IP_TTL` socket option.
* Added support for IPv4 multicast :c:macro:`IP_ADD_MEMBERSHIP` and
:c:macro:`IP_DROP_MEMBERSHIP` socket options.
* Added support for IPv6 multicast :c:macro:`IPV6_ADD_MEMBERSHIP` and
:c:macro:`IPV6_DROP_MEMBERSHIP` socket options.
* Improved doxygen documentation of BSD socket API.
* Fixed POLLERR error reporting in TLS sockets.
* Fixed DTLS handshake processing during :c:func:`poll`.
* Aligned DTLS socket :c:func:`connect` behavior with regular TLS (handshake
during connect call).
* Added Socket Service library, which allows to register multiple socket based
network services, and process them within a single thread.
* Added a new ``echo_service`` sample for Socket Service.
* Added support for :c:macro:`SO_DOMAIN` socket option.
* Fixed DTLS connection timeout when monitoring socket with :c:func:`poll`.
* Fixed NULL link layer address pointer dereference on packet socket, in case
of packet loopback.
* Several other minor bugfixes ans improvements.
* TCP:
* TCP stack now replies with RST packet in response to connection attempt on
a closed port.
* Fixed remote address passed in :c:func:`accept` call.
* Fixed reference counting during active handshake, to prevent TCP context
being released prematurely.
* Fixed compilation with :kconfig:option:`CONFIG_NET_TCP_CONGESTION_AVOIDANCE`
disabled.
* Reworked TCP data queueing API, to prevent TCP stack from overflowing TX window.
* Fixed possible race condition between TCP workqueue and other threads, when
releasing TCP context.
* Fixed possible race condition between input thread and TCP workqueue.
* Added support for TCP Keep-Alive feature.
* Fixed a bug, where TCP state machine could get stuck in LAST_ACK state
during passive connection close.
* Fixed a bug, where TCP state machine could get stuck in FIN_WAIT_1 state
in case peer did not respond.
* Several other minor bugfixes ans improvements.
* TFTP:
* Fixed potential buffer overflow when copying TFTP error message.
* Improved logging in case of errors.
* Wi-Fi:
* Added Wi-Fi driver version information to Wi-Fi shell.
* Added AP (Access Point) mode support to Wi-Fi shell.
* Added Regulatory channel information.
* Added Wi-Fi bindings to connection manager.
* Fixed Wi-Fi shell. SSID print fixes. Help text fixes. Channel validation fixes.
* Fixed TWT functionality. Teardown status was not updated. Powersave fixes.
* zperf:
* Improved IP address binding. Zperf will bind to any address by default and
allow to override this with Kconfig/API provided address.
* Fixed TCP packet counting when transmitting.
* Refactored UDP/TCP received to use Socket Service to save memory.
* Fixed zperf session leak on interrupted downloads.
* Fixed the calculation ratio between Mbps, Kbps and bps.
* Allow network code relocation to RAM in zperf sample for platforms that
support it.
USB
***
Devicetree
**********
API
===
Bindings
========
* Introduced new SPI properties ``spi-cpol``, ``spi-cpha``, and ``spi-hold-cs`` to be used by
the macro :c:macro:`SPI_CONFIG_DT` in order to set SPI mode in a Devicetree file.
Libraries / Subsystems
**********************
* Management
* Fixed an issue in MCUmgr image management whereby erasing an already erased slot would return
an unknown error, it now returns success.
* Fixed MCUmgr UDP transport structs being statically initialised, this results in about a
~5KiB flash saving.
* Fixed an issue in MCUmgr which would cause a user data buffer overflow if the UDP transport was
enabled on IPv4 only but IPv6 support was enabled in the kernel.
* Implemented datetime functionality in MCUmgr OS management group, this makes use of the RTC
driver API.
* Fixed an issue in MCUmgr console UART input whereby the FIFO would be read outside of an ISR,
which is not supported in the next USB stack.
* Fixed an issue whereby the ``mcuboot erase`` DFU shell command could be used to erase the
MCUboot or currently running application slot.
* Fixed an issue whereby messages that were too large to be sent over the UDP transport would
wrongly return :c:enum:`MGMT_ERR_EINVAL` instead of :c:enum:`MGMT_ERR_EMSGSIZE`.
* Fixed an issue where confirming an image in Direct XIP mode would always confirm the image in
the primary slot even when executing from the secondary slot, now the currently active image is
always confirmed.
* Added support for retrieving registered command groups, to support registering and deregistering
default command groups at runtime, allowing an application to support multiple implementations
for the same command group.
* Fixed an issue in MCUmgr FS management whereby the semaphore lock would not be given if an
error was returned, leading to a possible deadlock.
* Added support for custom payload MCUmgr handlers, this can be enabled with
:kconfig:option:`CONFIG_MCUMGR_MGMT_CUSTOM_PAYLOAD`.
* Fixed an issue in MCUmgr image management whereby an error would be returned if a command was
sent to erase the slot which was already erased.
* Added support for image slot size checking to ensure an update can be utilised by MCUboot,
this can be performed by using sysbuild when building both application and MCUboot by enabling
:kconfig:option:`CONFIG_MCUMGR_GRP_IMG_TOO_LARGE_SYSBUILD` or by use of bootloader information
sharing from MCUboot by enabling
:kconfig:option:`CONFIG_MCUMGR_GRP_IMG_TOO_LARGE_BOOTLOADER_INFO`.
* File systems
* Logging
* Added option to remove string literals from the binary when dictionary based logging is used.
* Optimized the most common logging messages (strings with up to 2 numeric arguments). Optimization
is done for code size (significant gain seen on riscv32) and performance.
* Extended logging frontend API to optionally implement dedicated functions for optimized messages.
Optional API is enabled by :kconfig:option:`CONFIG_LOG_FRONTEND_OPT_API`.
* Added support for runtime message filtering for the logging frontend.
* Add option to have multiple instances of the UART logging backend.
* Fixed userspace issue for :c:func:`printk` when :kconfig:option:`CONFIG_LOG_PRINTK` is enabled.
* Added compile time detection of logging messages which are using character pointers for ``%p``.
It must be avoided when dictionary based logging is used and strings are stripped from the
binary. When erroneous case is detected then user message is replaced with error message which
suggests that pointer casting must be added.
* Removed remaining references to v2 logging. :c:func:`log2_generic` renamed to :c:func:`log_generic`.
* Modem modules
* Added ``TRANSMIT_IDLE`` event to the ``modem_pipe`` module which notifies the user of the pipe
that the backend has transmitted all bytes placed in its buffer using
:c:func:`modem_pipe_transmit()`.
The event greatly increases the efficiency of transmitting large quantities of data if used to
dynamically manage the delay between calls to :c:func:`modem_pipe_transmit()`.
* Implemented ``TRANSMIT_IDLE`` event in all modem backends.
* Extended all modem modules to utilize the ``TRANSMIT_IDLE`` event to dynamically manage the delay
between calls to :c:func:`modem_pipe_transmit()`. This addition reduced the utilization of the
system workqueue while transmitting large, continuous quantities of data, by 86%, while only
reducing the throughput by 12%. This optimization additionally allows lower priority threads,
like the deferred logging thread, to run during the transmission (it was blocked by the
relentless, continuous calls to :c:func:`modem_pipe_transmit()`).
* Improved ``modem_pipe`` event dispatching. The ``modem_pipe`` module now invokes the
``RECEIVE_READY`` event every time the pipe is attached using :c:func:`modem_pipe_attach()`
if it has data ready to be read, and always invokes ``TRANSMIT_IDLE`` when the pipe is
either opened or attached. This ensures event driven users of the modem pipe module can
rely solely on the events to start read/transmit work. A test suite has been added to
complement the improvements.
* Extended ``modem_cmux`` module to support acting both as DTE (user application) and DCE (modem).
With this addition, two zephyr applications can communicate with each other through their
respective ``modem_cmux`` instances.
* Picolibc
* Update to version 1.8.6. This removes the :c:macro:`_POSIX_C_SOURCE` definition from the build
system, so applications will need to add this if they use APIs outside of the Zephyr
requirements.
* Add new :c:func:`printf` modes, :kconfig:option:`CONFIG_PICOLIBC_IO_LONG_LONG` and
:kconfig:option:`CONFIG_PICOLIBC_IO_MINIMAL`. These provide applications with finer grained
control over the level of support provided by the library to control text space usage. By
default, the correct level of support is selected based upon other configuration parameters.
* Add :kconfig:option:`CONFIG_PICOLIBC_ASSERT_VERBOSE`. This option, which is false by default,
controls whether the :c:func:`assert` function displays verbose information, including the file
name, line number, function name and failing expression txt, when the assertion fails. Leaving
this disabled saves text space.
* Allow :kconfig:option:`CONFIG_THREAD_LOCAL_STORAGE` to be disabled while using Picolibc. This is
very helpful in diagnosing issues when using Picolibc as those are often caused by enabling TLS
and not caused by using the library itself.
* Numerous improvements in the library including code-size reductions in areas like printf and
ctype and various fixes in the math library.
* Power management
* Atmel SAM: introduced SUPC functions to allow wakeup sources and poweroff.
* STM32F4 devices now support stop mode thanks to the use of a RTC based idle timer which
keeps track of tick evolution while cortex systick is off.
* :c:func:`pm_device_runtime_put_async()` got a parameter to specify a minimum delay to
the operation. This is useful to avoid multiple states transitions when a device is used.
* Devices that don't need to block when suspending or resuming can now be defined as ISR
safe (``PM_DEVICE_ISR_SAFE``). For those devices, Zephyr is able to reduces RAM consumption
and runtime device power management can be safely used from interruptions.
* Optimizations in device runtime power management. :c:func:`pm_device_runtime_get` and
:c:func:`pm_device_runtime_put` no longer wait for a pending operation to be concluded if it is still
in the work queue. In this case the pending work is just canceled and the device state updated.
* The Kconfig options bellow were added to customize the initialization priority of different
power domains.
* :kconfig:option:`CONFIG_POWER_DOMAIN_GPIO_INIT_PRIORITY`
* :kconfig:option:`CONFIG_POWER_DOMAIN_GPIO_MONITOR_INIT_PRIORITY`
* :kconfig:option:`CONFIG_POWER_DOMAIN_INTEL_ADSP_INIT_PRIORITY`
* Random
* Crypto
* mbedTLS updated to 3.5.2. Full release notes can be found in:
https://github.com/Mbed-TLS/mbedtls/releases/tag/v3.5.2
* Retention
* Fixed issue whereby :kconfig:option:`CONFIG_RETENTION_BUFFER_SIZE` values over 256 would cause
an infinite loop due to use of 8-bit variables.
* SD
* Added support for SDIO devices
* Storage
* File systems: LittleFS module has been updated to version 2.8.1.
* Following Flash Map API macros, marked in 3.2 as deprecated, have been removed:
``FLASH_AREA_ID``, ``FLASH_AREA_OFFSET``, ``FLASH_AREA_SIZE``,
``FLASH_AREA_LABEL_EXISTS`` and ``FLASH_AREA_DEVICE``.
* Binary descriptors
* POSIX API
* conformance: complete support for ``POSIX_THREADS_EXT``, ``XSI_THREADS_EXT``,
``POSIX_CLOCK_SELECTION``, and ``POSIX_SEMAPHORES`` Option Groups.
* conformance: complete support for ``_POSIX_MESSAGE_PASSING`` and
``_POSIX_PRIORITY_SCHEDULING`` Options.
* coverity: fix CID 211585, 334906, 334909, and 340851
* documentation: improve structure and accuracy of POSIX docs
* menuconfig: improved navigation and organization of POSIX options
* pthread: allocate and free stacks with pthread_attr_t, embed attr in thread structure
* pthread: support deferred and asynchronous thread cancellation
* pthread: support stack sizes up to 8MB
* samples: add dining philosophers sample app
* semaphores: add support for named semaphores
* shell: add a top-level ``posix`` command in the Zephyr shell. Zephyr shell utilities for
the POSIX API can be added as subcommands (e.g. ``posix uname -a``)
* timers: use async thread cancellation, add support for ``SIGEV_THREAD``, ``CLOCK_REALTIME``
* unistd: add compile-time-constant sysconf() implementation
* LoRa/LoRaWAN
* Added LoRaWAN remote multicast support with :kconfig:option:`CONFIG_LORAWAN_REMOTE_MULTICAST`
in preparation for OTA firmware upgrade support.
* RTIO
* ZBus
* Renamed ``CONFIG_ZBUS_MSG_SUBSCRIBER_NET_BUF_DYNAMIC`` and
``CONFIG_ZBUS_MSG_SUBSCRIBER_NET_BUF_STATIC``
to :kconfig:option:`CONFIG_ZBUS_MSG_SUBSCRIBER_BUF_ALLOC_DYNAMIC` and
:kconfig:option:`CONFIG_ZBUS_MSG_SUBSCRIBER_BUF_ALLOC_STATIC`
HALs
****
* STM32
* stm32cube: updated STM32F1 to cube version V1.8.5.
* stm32cube: updated STM32F7 to cube version V1.17.1
* stm32cube: updated STM32H7 to cube version V1.11.1
* stm32cube: updated STM32L4 to cube version V1.18.0
* stm32cube: updated STM32U5 to cube version V1.4.0
* stm32cube: updated STM32WBA to cube version V1.2.0
* stm32cube: updated STM32WB to cube version V1.18.0
MCUboot
*******
* Fixed compatible sector checking in bootutil.
* Fixed Kconfig issue with saving encrypted TLVs not depending on encryption being enabled.
* Fixed issue with missing condition check for applications in sysflash include file.
* Fixed issue with single slot encrypted image listing support in boot_serial.
* Fixed issue with allowing MBEDTLS Kconfig selection when tinycrypt is used.
* Fixed missing response if echo command was disabled in boot_serial.
* Fixed issue with USB configurations not generating usable images.
* Added debug logging for boot status write in bootutil.
* Added estimated image overhead size to cache in sysbuild.
* Added firmware loader operating mode which allows for a dedicated secondary slot image that
is used to update the primary image.
* Added error if main thread is not pre-emptible when USB CDC serial recovery is enabled.
* Added error if USB CDC and console are both enabled and set to the same device.
* Removed the deprecated ``CONFIG_ZEPHYR_TRY_MASS_ERASE`` Kconfig option.
* Updated zcbor to version 0.8.1 and re-generated boot_serial files.
* Moved IO functions out of main to separate file.
* Made ``align`` parameter of imgtool optional.
* The MCUboot version in this release is version ``2.1.0+0-dev``.
Nanopb
******
zcbor
*****
zcbor has been updated from 0.7.0 to 0.8.1.
Full release notes can be found at:
https://github.com/zephyrproject-rtos/zcbor/blob/0.8.0/RELEASE_NOTES.md and
https://github.com/zephyrproject-rtos/zcbor/blob/0.8.1/RELEASE_NOTES.md
Highlights:
* Add support for unordered maps
* Performance improvements
* Naming improvements for generated code
* Bugfixes
LVGL
****
LVGL has been updated from 8.3.7 to 8.3.11.
Detailed release notes can be found at:
https://github.com/zephyrproject-rtos/lvgl/blob/zephyr/docs/CHANGELOG.md
Additionally the following changes in Zephyr were done:
* Added the :dtcompatible:`zephyr,lvgl-keypad-input` compatible for keypad input.
* Fixed issue with the Zephyr log levels not mapping properly to LVGL log levels.
* Fixed issue where setting :kconfig:option:`CONFIG_LV_Z_FULL_REFRESH` did not
set :kconfig:option:`CONFIG_LV_Z_VDB_SIZE` to 100 percent.
Trusted Firmware-A
******************
Documentation
*************
Tests and Samples
*****************
* :ref:`native_sim<native_sim>` has replaced :ref:`native_posix<native_posix>` as the default
test platform.
:ref:`native_posix<native_posix>` remains supported and used in testing but will be deprecated
in a future release.
* Bluetooth split stacks tests, where the BT host and controller are run in separate MCUs, are
now run in CI based on the :ref:`nrf5340_bsim<nrf5340bsim>` targets.
Several other runtime AMP tests based on these targets have been added to CI, including tests
of OpenAMP, the mbox and IPC drivers/subsystem, and the logger multidomain functionality.
* Runtime UART tests have been added to CI based on the :ref:`nrf52_bsim<nrf52_bsim>` target.
These include tests of the nRFx UART driver and networked BT stack tests with the host and
controller in separate devices communicating over the HCI UART driver.
* Fixed an issue in :zephyr:code-sample:`smp-svr` sample whereby if USB was already initialised,
application would fail to boot properly.
* Added a LVGL sample :zephyr:code-sample:`lvgl-accelerometer-chart` showcasing displaying of live
sensor data in a chart widget.
* Added ESP32-S3 IPM support in :zephyr:code-sample:`ipm-esp32`.
* Added ESP32 memory-mapped flash access sample in :zephyr:code-sample:`esp32-flash-memory-mapped`.
* Added ESP32 PWM loopback test case