Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[NXP][K32W] k32w1 sdk 2.12.6 updates & k32w0 small fixes (#31924)
* [common] Remove k32w1 device_platform, use nxp instead Signed-off-by: Andrei Menzopol <[email protected]> Signed-off-by: Marius Tache <[email protected]> * [K32W1] Build, OTA, Diagnostic changes Signed-off-by: Doru Gucea <[email protected]> Signed-off-by: Marius Tache <[email protected]> Signed-off-by: Andrei Menzopol <[email protected]> * [K32W1] Rename SNT files to ELEMU * [K32W] Add OPENTHREAD_PLATFORM_CORE_CONFIG_FILE define Signed-off-by: Marius Tache <[email protected]> * [K32W1] Fix MBEDTLS build flags conflict between Matter vs. OpenThread Matter uses a multithread flavor of MBEDTLS while OpenThread uses a single thread flavor. This triggers a dangerous situation where Matter, OpenThread and MBEDTLS don't agree on the size of various data structures exchanged through the interface which later leads to memory access violations. This update fixes the build configuration so that OpenThread also uses the multithread flavor of MBEDTLS. Signed-off-by: Marian Chereji <[email protected]> * [NXP] Update ot-nxp commit-id Signed-off-by: Andrei Menzopol <[email protected]> * [K32W0] Add necessary check for env variable When computing the path for the signing script, the existence of env variable NXP_K32W0_SDK_ROOT should be checked first to avoid issues. Signed-off-by: marius-alex-tache <[email protected]> * [K32W1] Remove ResetWatermarks empty implementation Signed-off-by: Marius Tache <[email protected]> * [K32W1] Set rotating device id unique id length to max by default Signed-off-by: Marius Tache <[email protected]> * [K32W1] Fix an issue with __wrap_realloc Current memory manager is MML, which has realloc support. Removed old function that was relevant only in FreeRTOS memory manager (heap4/5) context. Signed-off-by: Marius Tache <[email protected]> * [K32W1] Accomodate low power API update PWR_AllowDeviceToSleep/PWR_DisallowDeviceToSleep API reintroduced in SDK. power.c removed from ot-nxp. Signed-off-by: Marius Tache <[email protected]> * [K32W1] Clear keys from counter area when factory resetting Signed-off-by: Marius Tache <[email protected]> * [K32W1] Use MML API for heap memory consumption statistics WTRMRK feature of the Software Diagnostic Cluster will be implemented once the memory manager will implement the needed API. Signed-off-by: Marius Tache <[email protected]> * [K32W1] Remove duplicated code in crypto PAL P256Keypair members were moved into protected scope, so derived classes (P256KeypairSSS) can access these members. Signed-off-by: Marius Tache <[email protected]> * [K32W1] Call PLATFORM_InitTimerManager before PLATFORM_InitBLE since this function won't be initializing the timer manager anymore * [K32W1] Post events from ISR correctly Signed-off-by: Marius Tache <[email protected]> * [K32W1] MML realloc should be protected from task switching Signed-off-by: Marius Tache <[email protected]> * [K32W1] Add initial FactoryDataProviderImpl Signed-off-by: Marius Tache <[email protected]> * [K32W1] Update certification declaration in apps Signed-off-by: Marius Tache <[email protected]> * [K32W1] Update README files in apps Signed-off-by: Marius Tache <[email protected]> * [K32W1] Add DAC private key convert declaration TBD Signed-off-by: Marius Tache <[email protected]> * [k32w1] Fix usage of deprecated factory data provider fields Signed-off-by: marius-alex-tache <[email protected]> * [COMMON] Add dac_key_use_sss_blob option dac_key_use_sss_blob can be used to select which data the private key area stores: plaintext/encrypted private key or an SSS exported blob. The option is False by default. Signed-off-by: Marius Tache <[email protected]> * [K32W1] Add SSS API usage Signed-off-by: Marius Tache <[email protected]> * [K32W1] Add chip_convert_dac_private_key option chip_convert_dac_private_key can be used to enable one-time-only conversion of the DAC private key to an SSS encrypted blob. Signed-off-by: Marius Tache <[email protected]> * [K32W1] Add jlink conversion script example Signed-off-by: Marius Tache <[email protected]> * [K32W1] Update readme to point to docs guide Signed-off-by: Marius Tache <[email protected]> * [K32W1] Remove unused mbedtls modules Signed-off-by: Marius Tache <[email protected]> * [K32W1] Factory data section should only be reserved in factory data context Signed-off-by: Marius Tache <[email protected]> * [K32W1] Add destructor to free SSS object context Signed-off-by: Marius Tache <[email protected]> * [K32W1] Add verbose logging for conversion steps Signed-off-by: Marius Tache <[email protected]> * [K32W1] Restore NVM sector number The underlying issue, for which the increase in NVM sectors was a workaround, was solved. Signed-off-by: Andrei Menzopol <[email protected]> * [K32W1] Add BLE ResetController function Signed-off-by: Andrei Menzopol <[email protected]> * [K32W1] Allocate OT buffers from SMU2 When using use_smu2_dynamic=true, OpenThread buffers will be allocated from a 13KB SMU2 region after a successful commissioning process until a factory reset is done. * Add SMU2 namespace in SMU2Manager.h/.cpp * Add build changes * Add allocator changes * Add necessary OpenThread config defines * Add gn parameter/defines for each SMU2 usecase Signed-off-by: Andrei Menzopol <[email protected]> * [K32W1] Offload SHA256 operations to S200 * Offload simple sha256, simple hmac sha256, update/finish sha256, update/finish hmac sha256 from Matter and OT. * Implement solution for long sha256 that uses context save/export/restore mechanism. This solution saves the intermediate data on heap and computes the hash on demand (by calling GetDigest). * Put changes under define/gn parameter use_hw_sha256 as they increase timings (due to hardware accelerator initialization time) and use a significant amount of heap. Signed-off-by: Andrei Menzopol <[email protected]> * [K32W1] Simplify HW DRBG/TRNG usage S200 TRNG is already used though otPlatEntropyGet from OT. Simplify Matter and OT DRBG usage of HW TRNG by not using mbedtls entropy. Signed-off-by: Andrei Menzopol <[email protected]> * [K32W1] Offload AES operations to S200 * Offload AES-CCM from Matter. * Offload AES-ECB from OT. * Use software AES-CCM when Additional authentical data len is zero. * Put changes under define/gn parameter use_hw_aes as they increase timings (due to hardware accelerator initialization time). Signed-off-by: Andrei Menzopol <[email protected]> * [K32W1] Fix duplicated flag Signed-off-by: Marius Tache <[email protected]> * [COMMON] Add pw RPC support The pw RPC integration should be usable by all NXP platforms that support SerialManager, since the pw_sys_io backend uses streamer_nxp.cpp for serial communication. A scope is defined in pw_rpc_server.gni to be used by all apps by forwarding the variables in the application executable scope: forward_variables_from(pw_rpc_server, "*") Logging and RPC communication share the same serial port. Logging should be inspected in chip-console, which manages the HDLC channels. Signed-off-by: Marius Tache <[email protected]> * [COMMON] Update streamer to read RX data ASAP Moved reading the RX FIFO inside the actual interrupt handler, to avoid time penalty when notifying the consumer task (RPC/App CLI). The data is instead stored in a cache buffer and read once the task is unblocked through notifying by the ISR. Signed-off-by: Marius Tache <[email protected]> * [K32W1] Enable pw RPC on lighting app To build with RPC enabled, the user should generate the files: gn gen out/debug --args='import("//with_pw_rpc.gni") treat_warnings_as_errors=false' pw RPC requires c++ 17. Some example commands are written in the README, under section `Running RPC console`. Signed-off-by: Marius Tache <[email protected]> * [COMMON] Revert streamer implementation and add UART DMA support pw RPC requires UART DMA to avoid missing commands and errors related to frame integrity checks. Applications that enable RPC support should use UART DMA (if possible). Signed-off-by: Marius Tache <[email protected]> * [K32W1] Use UART DMA for pw RPC Signed-off-by: Marius Tache <[email protected]> * k32w1: enable sit icd Signed-off-by: Doru Gucea <[email protected]> * [K32W1] Implement watermark feature using MML API Signed-off-by: Marius Tache <[email protected]> * [K32W1] Update free SMU2 region in linker script The SMU2 free region shrank due to addition of lowpower flag in NBU. This overlap might affect Matter instances placed in SMU2 region. Signed-off-by: Andrei Menzopol <[email protected]> * [K32W1] Fix TotalOperatingHours attribute reset The UpTime attribute of the GeneralDiagnostics cluster was being reset periodically due to the limited range of the LPTMR timestamp (32 bits). To fix it, support for a 64bit timestamp was added to the NXP OpenThread library and now Matter can use the "otPlatTimeGet()" API to acquire the timestamp in microseconds. Signed-off-by: Marian Chereji <[email protected]> * [K32W1] Fix LP current draw for Contact Sensor App after framework changes After framework changes with reintroducing PWR_AllowDeviceToSleep & PWR_DisallowDeviceToSleep functions, Contact Sensor application does not enter into low power anymore after BLE connection event. Adding PWR_DisallowDeviceToSleep call at connection event before PWR_AllowDeviceToSleep as framework request. Signed-off-by: Marius Vilvoi <[email protected]> * [K32W] Send a report before resetting the device during OTA State-transition event from Downloading to Applying was not successfully sent to a subscriber during OTA because the device would reset before actually sending the ReportData message. Added an explicit call to sync send a report if any events were logged. This is managed by the ReportingEnginge. Signed-off-by: marius-alex-tache <[email protected]> * [K32W] Create dedicated zap file for contact sensor Signed-off-by: Andrei Menzopol <[email protected]> * [K32W1] Switch to dedicated zap file The common zap file configuration has many optional cluster enabled that are not needed in our contact-sensor reference app Signed-off-by: Andrei Menzopol <[email protected]> * [K32W] Change lighting-app root node revision to 2 Signed-off-by: Andrei Menzopol <[email protected]> * [K32W1] Adjust rambuffer size and KVS max number of keys Signed-off-by: Andrei Menzopol <[email protected]> * [K32W1] Add CleanReset API Clean reset ensures: * Matter event loop is stopped. * Shutdown is called. * Pending operations are completed in NVM. * MCU is reset. Signed-off-by: marius-alex-tache <[email protected]> * [K32W1] Change long press SW3 action from OTA query to clean soft reset When long pressing SW3, the reference applications will call the platform manager clean soft reset API. This will reset the MCU after the Matter shutdown procedure is called and all NVM pending operations are finished. Signed-off-by: marius-alex-tache <[email protected]> * [K32W] define CHIP_ADDRESS_RESOLVE_IMPL_INCLUDE_HEADER Signed-off-by: Andrei Menzopol <[email protected]> * [K32W] Update docker image version Signed-off-by: Andrei Menzopol <[email protected]> * Restyled by whitespace * Restyled by clang-format * Restyled by prettier-markdown * Fix spelling Signed-off-by: Andrei Menzopol <[email protected]> * [K32W] Update contact-sensor-app zap files Signed-off-by: Andrei Menzopol <[email protected]> * [K32W] Remove deprecated code Signed-off-by: marius-alex-tache <[email protected]> * [K32W1] Fix gn check errors Signed-off-by: marius-alex-tache <[email protected]> * [K32W1] Fix build Signed-off-by: Andrei Menzopol <[email protected]> * Restyled by gn * [K32W1] Fix lints Signed-off-by: Andrei Menzopol <[email protected]> * [NXP] Update ot-nxp commit-id Signed-off-by: Andrei Menzopol <[email protected]> * [NXP] Update matter zap file Signed-off-by: Andrei Menzopol <[email protected]> --------- Signed-off-by: Andrei Menzopol <[email protected]> Signed-off-by: Marius Tache <[email protected]> Signed-off-by: Doru Gucea <[email protected]> Signed-off-by: Marian Chereji <[email protected]> Signed-off-by: marius-alex-tache <[email protected]> Signed-off-by: Marius Vilvoi <[email protected]> Co-authored-by: Yanis Viola <[email protected]> Co-authored-by: Marius Tache <[email protected]> Co-authored-by: Marian Chereji <[email protected]> Co-authored-by: Yassine El-aissaoui <[email protected]> Co-authored-by: Doru Gucea <[email protected]> Co-authored-by: Marius Vilvoi <[email protected]> Co-authored-by: Restyled.io <[email protected]>
- Loading branch information