Skip to content

Commit

Permalink
samples: wifi: radio_test: Add a single domain combo radio test
Browse files Browse the repository at this point in the history
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 <[email protected]>
  • Loading branch information
krish2718 committed Dec 17, 2024
1 parent bb2f537 commit 377e240
Show file tree
Hide file tree
Showing 40 changed files with 8,050 additions and 6 deletions.
1 change: 1 addition & 0 deletions doc/nrf/samples/wifi.rst
Original file line number Diff line number Diff line change
Expand Up @@ -17,5 +17,6 @@ This section lists the available |NCS| samples for the :ref:`Wi-Fi® <ug_wifi>`
:glob:

../../../samples/wifi/*/README
wifi_radiotest
wifi_provisioning
wifi_zephyr
4 changes: 2 additions & 2 deletions doc/nrf/samples/wifi_provisioning.rst
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
.. _wifi_provisioning_samples:

Wi-Fi: provisioning samples
Wi-Fi: Provisioning samples
###########################

The following samples demonstrate how to provision Wi-Fi® credentials to a Wi-Fi-capable Nordic Semiconductor's device.
Expand All @@ -10,4 +10,4 @@ The following samples demonstrate how to provision Wi-Fi® credentials to a Wi-F
:caption: Subpages
:glob:

../../../samples/wifi/*/*/README
../../../samples/wifi/provisioning/*/README
13 changes: 13 additions & 0 deletions doc/nrf/samples/wifi_radiotest.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
.. _wifi_radiotest_samples:

Wi-Fi: Radio test samples
###########################

The following samples demonstrate how to use the Wi-Fi® radio test commands.

.. toctree::
:maxdepth: 1
:caption: Subpages
:glob:

../../../samples/wifi/radio_test/*/README
File renamed without changes.
File renamed without changes.
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
.. _wifi_radio_test:

Wi-Fi: Radio test
#################
Wi-Fi: Radio test (Multi Domain)
################################

The Radio test sample supports the Radio test subcommands and subcommands to program the Factory Information Configuration Registers (FICR) fields defined in the nRF7002 one-time programmable (OTP) memory.
The sample can be run on multiple domains, for example Wi-Fi only on the Application core or Wi-Fi and Bluetooth combo mode where Wi-Fi runs on the Application core and Bluetooth runs on the Network core.

See the subpages for detailed documentation on the sample and its features.

Expand Down
File renamed without changes.
File renamed without changes.
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,7 @@ tests:
sample.nrf7002_eb.thingy53.radio_test:
sysbuild: true
build_only: true
extra_args: radio_test_SHIELD=nrf7002eb
extra_args: multi_domain_SHIELD=nrf7002eb
integration_platforms:
- thingy53/nrf5340/cpuapp
platform_allow: thingy53/nrf5340/cpuapp
Expand All @@ -78,7 +78,7 @@ tests:
build_only: true
extra_args:
- FILE_SUFFIX=wifi_combo
- radio_test_SHIELD="nrf7002eb_interposer_p1;nrf7002eb"
- multi_domain_SHIELD="nrf7002eb_interposer_p1;nrf7002eb"
- SNIPPET=nrf70-wifi
integration_platforms:
- nrf54h20dk/nrf54h20/cpuapp
Expand Down
File renamed without changes.
File renamed without changes.
File renamed without changes.
23 changes: 23 additions & 0 deletions samples/wifi/radio_test/single_domain/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -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
27 changes: 27 additions & 0 deletions samples/wifi/radio_test/single_domain/Kconfig
Original file line number Diff line number Diff line change
@@ -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_SD_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_SD_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"
20 changes: 20 additions & 0 deletions samples/wifi/radio_test/single_domain/README.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
.. _wifi_radio_test_sd:

Wi-Fi: Wi-Fi BLE Radio Test Sample (Single Domain)
##################################################

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 (Application 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
Original file line number Diff line number Diff line change
@@ -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
Original file line number Diff line number Diff line change
@@ -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
104 changes: 104 additions & 0 deletions samples/wifi/radio_test/single_domain/ficr.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,104 @@
.. _wifi_ficr_prog_sd:

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_sd:

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.
Original file line number Diff line number Diff line change
@@ -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 <zephyr/kernel.h>
#include <stdio.h>
#include <stdlib.h>
#include <zephyr/shell/shell.h>
#include <zephyr/init.h>
#include <ctype.h>
#include <host_rpu_sys_if.h>
#include <fmac_structs.h>
#include <zephyr/drivers/wifi/nrf_wifi/bus/rpu_hw_if.h>

struct nrf_wifi_ctx_zep_rt {
struct nrf_wifi_fmac_priv *fmac_priv;
struct rpu_conf_params conf_params;
};
Loading

0 comments on commit 377e240

Please sign in to comment.