From 90a3f4b929609892b442305eeed6c3cfbf5d2a49 Mon Sep 17 00:00:00 2001 From: Chaitanya Tata Date: Mon, 2 Dec 2024 22:03:54 +0530 Subject: [PATCH] samples: wifi: radio_test: Add a single domain combo radio test With the introduction of 54L15 SoC where the complete BLE stack runs on the CPUAPP itself, reorg the radio test directories based on domains. Single domain radio test is primarily for 54L15 (and other similar SoCs) which basically combines Wi-Fi and Peripheral radio test samples in to one. Signed-off-by: Chaitanya Tata --- .../{ => multi_domain}/CMakeLists.txt | 0 .../{ => multi_domain}/Kconfig.sysbuild | 0 .../radio_test/{ => multi_domain}/README.rst | 0 .../boards/thingy91x_nrf9151_ns.overlay | 0 .../radio_test/{ => multi_domain}/ficr.rst | 0 .../inc/nrf_wifi_radio_test_shell.h | 0 .../radio_test/{ => multi_domain}/prj.conf | 0 .../radio_test_subcommands.rst | 0 .../radio_test/{ => multi_domain}/sample.yaml | 0 .../{ => multi_domain}/sample_description.rst | 0 .../src/nrf_wifi_radio_ficr_shell.c | 0 .../src/nrf_wifi_radio_test_main.c | 0 .../src/nrf_wifi_radio_test_shell.c | 0 .../{ => multi_domain}/sysbuild.conf | 0 .../radio_test/single_domain/CMakeLists.txt | 23 + samples/wifi/radio_test/single_domain/Kconfig | 27 + .../wifi/radio_test/single_domain/README.rst | 20 + .../boards/nrf54l15dk_nrf54l15_cpuapp.conf | 12 + .../boards/nrf54l15pdk_nrf54l15_cpuapp.conf | 12 + .../wifi/radio_test/single_domain/ficr.rst | 104 + .../inc/nrf_wifi_radio_test_shell.h | 24 + .../single_domain/peripheral_radio_test.rst | 305 ++ .../wifi/radio_test/single_domain/prj.conf | 52 + .../single_domain/radio_test_subcommands.rst | 287 ++ .../wifi/radio_test/single_domain/sample.yaml | 16 + .../single_domain/sample_description.rst | 657 +++++ .../wifi/radio_test/single_domain/src/main.c | 105 + .../src/nrf_wifi_radio_ficr_shell.c | 528 ++++ .../src/nrf_wifi_radio_test_shell.c | 2535 +++++++++++++++++ .../radio_test/single_domain/src/radio_cmd.c | 1497 ++++++++++ .../radio_test/single_domain/src/radio_test.c | 1180 ++++++++ .../radio_test/single_domain/src/radio_test.h | 235 ++ .../radio_test/single_domain/sysbuild.conf | 8 + 33 files changed, 7627 insertions(+) rename samples/wifi/radio_test/{ => multi_domain}/CMakeLists.txt (100%) rename samples/wifi/radio_test/{ => multi_domain}/Kconfig.sysbuild (100%) rename samples/wifi/radio_test/{ => multi_domain}/README.rst (100%) rename samples/wifi/radio_test/{ => multi_domain}/boards/thingy91x_nrf9151_ns.overlay (100%) rename samples/wifi/radio_test/{ => multi_domain}/ficr.rst (100%) rename samples/wifi/radio_test/{ => multi_domain}/inc/nrf_wifi_radio_test_shell.h (100%) rename samples/wifi/radio_test/{ => multi_domain}/prj.conf (100%) rename samples/wifi/radio_test/{ => multi_domain}/radio_test_subcommands.rst (100%) rename samples/wifi/radio_test/{ => multi_domain}/sample.yaml (100%) rename samples/wifi/radio_test/{ => multi_domain}/sample_description.rst (100%) rename samples/wifi/radio_test/{ => multi_domain}/src/nrf_wifi_radio_ficr_shell.c (100%) rename samples/wifi/radio_test/{ => multi_domain}/src/nrf_wifi_radio_test_main.c (100%) rename samples/wifi/radio_test/{ => multi_domain}/src/nrf_wifi_radio_test_shell.c (100%) rename samples/wifi/radio_test/{ => multi_domain}/sysbuild.conf (100%) create mode 100644 samples/wifi/radio_test/single_domain/CMakeLists.txt create mode 100644 samples/wifi/radio_test/single_domain/Kconfig create mode 100644 samples/wifi/radio_test/single_domain/README.rst create mode 100644 samples/wifi/radio_test/single_domain/boards/nrf54l15dk_nrf54l15_cpuapp.conf create mode 100644 samples/wifi/radio_test/single_domain/boards/nrf54l15pdk_nrf54l15_cpuapp.conf create mode 100644 samples/wifi/radio_test/single_domain/ficr.rst create mode 100644 samples/wifi/radio_test/single_domain/inc/nrf_wifi_radio_test_shell.h create mode 100644 samples/wifi/radio_test/single_domain/peripheral_radio_test.rst create mode 100644 samples/wifi/radio_test/single_domain/prj.conf create mode 100644 samples/wifi/radio_test/single_domain/radio_test_subcommands.rst create mode 100644 samples/wifi/radio_test/single_domain/sample.yaml create mode 100644 samples/wifi/radio_test/single_domain/sample_description.rst create mode 100644 samples/wifi/radio_test/single_domain/src/main.c create mode 100644 samples/wifi/radio_test/single_domain/src/nrf_wifi_radio_ficr_shell.c create mode 100644 samples/wifi/radio_test/single_domain/src/nrf_wifi_radio_test_shell.c create mode 100644 samples/wifi/radio_test/single_domain/src/radio_cmd.c create mode 100644 samples/wifi/radio_test/single_domain/src/radio_test.c create mode 100644 samples/wifi/radio_test/single_domain/src/radio_test.h create mode 100644 samples/wifi/radio_test/single_domain/sysbuild.conf diff --git a/samples/wifi/radio_test/CMakeLists.txt b/samples/wifi/radio_test/multi_domain/CMakeLists.txt similarity index 100% rename from samples/wifi/radio_test/CMakeLists.txt rename to samples/wifi/radio_test/multi_domain/CMakeLists.txt diff --git a/samples/wifi/radio_test/Kconfig.sysbuild b/samples/wifi/radio_test/multi_domain/Kconfig.sysbuild similarity index 100% rename from samples/wifi/radio_test/Kconfig.sysbuild rename to samples/wifi/radio_test/multi_domain/Kconfig.sysbuild diff --git a/samples/wifi/radio_test/README.rst b/samples/wifi/radio_test/multi_domain/README.rst similarity index 100% rename from samples/wifi/radio_test/README.rst rename to samples/wifi/radio_test/multi_domain/README.rst diff --git a/samples/wifi/radio_test/boards/thingy91x_nrf9151_ns.overlay b/samples/wifi/radio_test/multi_domain/boards/thingy91x_nrf9151_ns.overlay similarity index 100% rename from samples/wifi/radio_test/boards/thingy91x_nrf9151_ns.overlay rename to samples/wifi/radio_test/multi_domain/boards/thingy91x_nrf9151_ns.overlay diff --git a/samples/wifi/radio_test/ficr.rst b/samples/wifi/radio_test/multi_domain/ficr.rst similarity index 100% rename from samples/wifi/radio_test/ficr.rst rename to samples/wifi/radio_test/multi_domain/ficr.rst diff --git a/samples/wifi/radio_test/inc/nrf_wifi_radio_test_shell.h b/samples/wifi/radio_test/multi_domain/inc/nrf_wifi_radio_test_shell.h similarity index 100% rename from samples/wifi/radio_test/inc/nrf_wifi_radio_test_shell.h rename to samples/wifi/radio_test/multi_domain/inc/nrf_wifi_radio_test_shell.h diff --git a/samples/wifi/radio_test/prj.conf b/samples/wifi/radio_test/multi_domain/prj.conf similarity index 100% rename from samples/wifi/radio_test/prj.conf rename to samples/wifi/radio_test/multi_domain/prj.conf diff --git a/samples/wifi/radio_test/radio_test_subcommands.rst b/samples/wifi/radio_test/multi_domain/radio_test_subcommands.rst similarity index 100% rename from samples/wifi/radio_test/radio_test_subcommands.rst rename to samples/wifi/radio_test/multi_domain/radio_test_subcommands.rst diff --git a/samples/wifi/radio_test/sample.yaml b/samples/wifi/radio_test/multi_domain/sample.yaml similarity index 100% rename from samples/wifi/radio_test/sample.yaml rename to samples/wifi/radio_test/multi_domain/sample.yaml diff --git a/samples/wifi/radio_test/sample_description.rst b/samples/wifi/radio_test/multi_domain/sample_description.rst similarity index 100% rename from samples/wifi/radio_test/sample_description.rst rename to samples/wifi/radio_test/multi_domain/sample_description.rst diff --git a/samples/wifi/radio_test/src/nrf_wifi_radio_ficr_shell.c b/samples/wifi/radio_test/multi_domain/src/nrf_wifi_radio_ficr_shell.c similarity index 100% rename from samples/wifi/radio_test/src/nrf_wifi_radio_ficr_shell.c rename to samples/wifi/radio_test/multi_domain/src/nrf_wifi_radio_ficr_shell.c diff --git a/samples/wifi/radio_test/src/nrf_wifi_radio_test_main.c b/samples/wifi/radio_test/multi_domain/src/nrf_wifi_radio_test_main.c similarity index 100% rename from samples/wifi/radio_test/src/nrf_wifi_radio_test_main.c rename to samples/wifi/radio_test/multi_domain/src/nrf_wifi_radio_test_main.c diff --git a/samples/wifi/radio_test/src/nrf_wifi_radio_test_shell.c b/samples/wifi/radio_test/multi_domain/src/nrf_wifi_radio_test_shell.c similarity index 100% rename from samples/wifi/radio_test/src/nrf_wifi_radio_test_shell.c rename to samples/wifi/radio_test/multi_domain/src/nrf_wifi_radio_test_shell.c diff --git a/samples/wifi/radio_test/sysbuild.conf b/samples/wifi/radio_test/multi_domain/sysbuild.conf similarity index 100% rename from samples/wifi/radio_test/sysbuild.conf rename to samples/wifi/radio_test/multi_domain/sysbuild.conf diff --git a/samples/wifi/radio_test/single_domain/CMakeLists.txt b/samples/wifi/radio_test/single_domain/CMakeLists.txt new file mode 100644 index 000000000000..6c5f0c01e025 --- /dev/null +++ b/samples/wifi/radio_test/single_domain/CMakeLists.txt @@ -0,0 +1,23 @@ +# +# Copyright (c) 2022 Nordic Semiconductor ASA +# +# SPDX-License-Identifier: LicenseRef-Nordic-5-Clause +# + +cmake_minimum_required(VERSION 3.20.0) + +find_package(Zephyr REQUIRED HINTS $ENV{ZEPHYR_BASE}) +project(wifi_ble_radio_test) + +target_include_directories(app PRIVATE + inc +) + +# Application sources +FILE(GLOB app_sources src/*.c) + +# NORDIC SDK APP START +target_sources(app PRIVATE + ${app_sources} +) +# NORDIC SDK APP END diff --git a/samples/wifi/radio_test/single_domain/Kconfig b/samples/wifi/radio_test/single_domain/Kconfig new file mode 100644 index 000000000000..ee84a021c4cb --- /dev/null +++ b/samples/wifi/radio_test/single_domain/Kconfig @@ -0,0 +1,27 @@ +# +# Copyright (c) 2020 Nordic Semiconductor +# +# SPDX-License-Identifier: LicenseRef-Nordic-5-Clause +# + +mainmenu "Nordic Wi-Fi BLE Radio test sample" + +config RADIO_TEST_POWER_CONTROL_AUTOMATIC + bool "Automatic power control" + depends on FEM + default y + help + Set SoC output power and front-end module gain to achieve Tx output power requested + by user. If the exact value cannot be achieved, power is set to closest value which does + not exceed the limits. If this option is disabled, user has to set SoC output power and + fem gain with separate commands. + +config RADIO_TEST_RX_TIMEOUT + int "RX packet reception timeout" + default 10 + help + Specifies the time in seconds that the application waits for the first packet to be + received in RX mode when a specified number of packets are set to be received. + If the timeout is reached before the first packet is received, the radio will be disabled. + +source "Kconfig.zephyr" diff --git a/samples/wifi/radio_test/single_domain/README.rst b/samples/wifi/radio_test/single_domain/README.rst new file mode 100644 index 000000000000..a4b990ede145 --- /dev/null +++ b/samples/wifi/radio_test/single_domain/README.rst @@ -0,0 +1,20 @@ +.. _wifi_radio_test: + +Wi-Fi BLE Radio Test Sample +########################### + +The Wi-Fi BLE Radio Test sample demonstrates how to use the radio test for both Wi-Fi and BLE protocols using a single domain image i.e., both running on the same core. +The sample demonstrates how to use the radio test subcommands to configure the radio test parameters and run the radio test. + +The Wi-Fi Radio test also supports programming the Factory Information Configuration Registers (FICR) fields defined in the nRF7002 one-time programmable (OTP) memory. + +See the subpages for detailed documentation on the sample and its features. + +.. toctree:: + :maxdepth: 1 + :caption: Subpages: + + sample_description.rst + peripheral_radio_test.rst + radio_test_subcommands.rst + ficr.rst diff --git a/samples/wifi/radio_test/single_domain/boards/nrf54l15dk_nrf54l15_cpuapp.conf b/samples/wifi/radio_test/single_domain/boards/nrf54l15dk_nrf54l15_cpuapp.conf new file mode 100644 index 000000000000..e029d65ce7bf --- /dev/null +++ b/samples/wifi/radio_test/single_domain/boards/nrf54l15dk_nrf54l15_cpuapp.conf @@ -0,0 +1,12 @@ +# +# Copyright (c) 2024 Nordic Semiconductor +# +# SPDX-License-Identifier: LicenseRef-Nordic-5-Clause +# + +# Disable the unsupported driver +CONFIG_NRFX_TIMER0=n + +# Enable the necessary drivers +CONFIG_NRFX_TIMER10=y +CONFIG_NRFX_GPPI=y diff --git a/samples/wifi/radio_test/single_domain/boards/nrf54l15pdk_nrf54l15_cpuapp.conf b/samples/wifi/radio_test/single_domain/boards/nrf54l15pdk_nrf54l15_cpuapp.conf new file mode 100644 index 000000000000..482eca1189d6 --- /dev/null +++ b/samples/wifi/radio_test/single_domain/boards/nrf54l15pdk_nrf54l15_cpuapp.conf @@ -0,0 +1,12 @@ +# +# Copyright (c) 2023 Nordic Semiconductor +# +# SPDX-License-Identifier: LicenseRef-Nordic-5-Clause +# + +# Disable the unsupported driver +CONFIG_NRFX_TIMER0=n + +# Enable the necessary drivers +CONFIG_NRFX_TIMER10=y +CONFIG_NRFX_GPPI=y diff --git a/samples/wifi/radio_test/single_domain/ficr.rst b/samples/wifi/radio_test/single_domain/ficr.rst new file mode 100644 index 000000000000..aa3b80857716 --- /dev/null +++ b/samples/wifi/radio_test/single_domain/ficr.rst @@ -0,0 +1,104 @@ +.. _wifi_ficr_prog: + +FICR programming subcommands +############################ + +.. contents:: + :local: + :depth: 2 + +``wifi_radio_ficr_prog`` is the Wi-Fi® radio FICR programming command and it supports the following subcommands. + +.. _wifi_radio_ficr_prog_subcmds: + +Wi-Fi radio FICR subcommands +**************************** + +.. list-table:: Wi-Fi radio FICR subcommands + :widths: 15 15 10 30 70 + :header-rows: 1 + + * - Subcommand + - Register + - Offset + - Argument(s) + - Description + * - otp_get_status + - N/A + - N/A + - N/A + - Reads out the OTP status of user region and status of each field (programmed or not). + * - otp_read_params + - N/A + - N/A + - N/A + - Reads out all the OTP parameters (excluding QSPI_KEY which cannot be read). + * - otp_read_retrim_version + - PRODRETEST.PROGVERSION + - N/A + - N/A + - Reads out program version of Retrim parameters. + * - otp_read_retrim_params + - PRODRETEST.TRIM[n] + - N/A + - N/A + - Reads out all the Retrim parameters. + * - otp_write_params + - REGION_PROTECT + - 0x100 + - arg + - | arg = 0x50FA50FA : Enable R/W permission + | arg = 0x00000000 : Lock Region from Writing + | arg = Others : Invalid + | All four REGION_PROTECT registers are written with this 32-bit argument. + * - otp_write_params + - QSPI_KEY + - 0x110 + - arg1 arg2 arg3 arg4 + - | All four key arguments are 32-bit values forming the required 128-bit (Q)SPI key for encryption. + | For example, if QSPI key is "112233445566778899aabbccddeeff00" then arg1=0x44332211 arg2=0x88776655 arg3=0xccbbaa99 arg4=0x00ffeedd + * - otp_write_params + - MAC_ADDRESS0 + - 0x120 + - arg1 arg2 + - If MAC address is AA:BB:CC:DD:EE:FF, then arg1=0xDDCCBBAA and arg2=0xFFEE. + * - otp_write_params + - MAC_ADDRESS1 + - 0x128 + - arg1 arg2 + - If MAC address is AA:BB:CC:DD:EE:FF, then arg1=0xDDCCBBAA and arg2=0xFFEE. + * - otp_write_params + - CALIB_XO + - 0x130 + - arg + - arg is 7-bit unsigned XO value. Bits [31:7] unused. Adjusts capacitor bank, 0 : Lowest capacitance (Highest frequency), 127 : Highest capacitance (Lowest frequency). + * - otp_write_params + - REGION_DEFAULTS + - 0x154 + - arg + - | Register default enable control. + | arg is 32-bit value where a specific bit is set to ``0`` implies that the corresponding OTP field is programmed. The following list shows the bit and field mapping: + | + | bit 0 : QSPI_KEY + | bit 1 : MAC0 Address + | bit 2 : MAC1 Address + | bit 3 : CALIB_XO + | bit 4 : Reserved + | bit 5 : Reserved + | bit 6 : Reserved + | bit 7 : Reserved + | bit 8 : Reserved + | bit 9 : Reserved + | bit 10 : Reserved + | bit 11 : Reserved + | bit 12-31 : Reserved + * - otp_write_retrim_version + - PRODRETEST.PROGVERSION + - N/A + - arg + - arg is 32-bit data. + * - otp_write_retrim_params + - PRODRETEST.TRIM[n] + - index between (0-14) + - arg + - arg is 32-bit data. When index = 5, PRODRETEST.TRIM[5] is written with 32-bit argument. diff --git a/samples/wifi/radio_test/single_domain/inc/nrf_wifi_radio_test_shell.h b/samples/wifi/radio_test/single_domain/inc/nrf_wifi_radio_test_shell.h new file mode 100644 index 000000000000..cb7497aa5889 --- /dev/null +++ b/samples/wifi/radio_test/single_domain/inc/nrf_wifi_radio_test_shell.h @@ -0,0 +1,24 @@ +/* + * Copyright (c) 2022 Nordic Semiconductor ASA + * + * SPDX-License-Identifier: LicenseRef-Nordic-5-Clause + */ + +/* @file + * @brief nRF Wi-Fi radio-test mode shell module + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include "rpu_hw_if.h" + +struct nrf_wifi_ctx_zep_rt { + struct nrf_wifi_fmac_priv *fmac_priv; + struct rpu_conf_params conf_params; +}; diff --git a/samples/wifi/radio_test/single_domain/peripheral_radio_test.rst b/samples/wifi/radio_test/single_domain/peripheral_radio_test.rst new file mode 100644 index 000000000000..2f4a440a802a --- /dev/null +++ b/samples/wifi/radio_test/single_domain/peripheral_radio_test.rst @@ -0,0 +1,305 @@ +.. _radio_test: + +Radio test (short-range) +######################## + +.. contents:: + :local: + :depth: 2 + +The Radio test sample demonstrates how to configure the 2.4 GHz short-range radio (Bluetooth® LE, IEEE 802.15.4 and proprietary) in a specific mode and then test its performance. +The sample provides a set of predefined commands that allow you to configure the radio in three modes: + +* Constant RX or TX carrier +* Modulated TX carrier +* RX or TX sweep + +Requirements +************ + +The sample supports the following development kits: + +.. table-from-sample-yaml:: + +You can use any one of the development kits listed above. + +.. note:: + On nRF5340 DK and nRF7002 DK, the sample is designed to run on the network core and requires the :ref:`nrf5340_remote_shell` running on the application core. + This sample uses the :ref:`shell_ipc_readme` library to forward shell data through the physical UART interface of the application core. + +The sample also requires one of the following testing devices: + + * Another development kit with the same sample. + See :ref:`radio_test_testing_board`. + * Another development kit connected to a PC with the `RSSI Viewer app`_ (available in the `nRF Connect for Desktop`_). + See :ref:`radio_test_testing_rssi`. + +.. note:: + You can perform the radio test also using a spectrum analyzer. + This method of testing is not covered by this documentation. + +nRF21540 front-end module +========================= + +.. include:: /includes/sample_dtm_radio_test_fem.txt + +You can configure the nRF21540 front-end module (FEM) transmitted power control, antenna output and activation delay using the main shell commands of the :ref:`radio_test_ui`. + +Skyworks front-end module +========================= + +.. include:: /includes/sample_dtm_radio_test_skyworks.txt + +You can configure the Skyworks front-end module (FEM) antenna output and activation delay using the main shell commands of the :ref:`radio_test_ui`. + +Overview +******** + +To run the tests, connect to the development kit through the serial port and send shell commands. +Zephyr's :ref:`zephyr:shell_api` module is used to handle the commands. +At any time during the tests, you can dynamically set the radio parameters, such as output power, bit rate, and channel. +In sweep mode, you can set the time for which the radio scans each channel from one millisecond to 99 milliseconds, in steps of one millisecond. +The sample also allows you to send a data pattern to another development kit. + +The sample first enables the high frequency crystal oscillator and configures the shell. +You can then start running commands to set up and control the radio. +See :ref:`radio_test_ui` for a list of available commands. + +.. note:: + For the IEEE 802.15.4 mode, the start channel and the end channel must be within the channel range of 11 to 26. + Use the ``start_channel`` and ``end_channel`` commands to control this setting. + + +.. _radio_test_ui: + +User interface +************** +.. list-table:: Main shell commands (in alphabetical order) + :header-rows: 1 + + * - Command + - Argument + - Description + * - cancel + - + - Cancel the sweep or the carrier. + * - data_rate + - + - Set the data rate. + * - end_channel + - + - End channel for the sweep (in MHz, as difference from 2400 MHz). + * - fem + - + - Set front-end module (FEM) parameters. + * - output_power + - + - Output power set. + If a front-end module is attached and the :ref:`CONFIG_RADIO_TEST_POWER_CONTROL_AUTOMATIC ` Kconfig option is enabled, it has the same effect as the ``total_output_power`` command. + * - parameters_print + - + - Print current delay, channel, and other parameters. + * - print_rx + - + - Print the received RX payload. + * - start_channel + - + - Start channel for the sweep or the channel for the constant carrier (in MHz, as difference from 2400 MHz). + * - start_duty_cycle_modulated_tx + - + - Duty cycle in percent (two decimal digits, between 01 and 90). + * - start_rx + - + - Start RX (continuous RX mode is used if no argument is provided). + * - start_rx_sweep + - + - Start the RX sweep. + * - start_tx_carrier + - + - Start the TX carrier. + * - start_tx_modulated_carrier + - + - Start the modulated TX carrier (continuous TX mode is used if no argument is provided). + * - start_tx_sweep + - + - Start the TX sweep. + * - time_on_channel + -