boards: qorvo: add DWM3001CDK support
Add support for the decawave DWM3001C board from qorvo Signed-off-by: Mara Furland <mara@fur.land>
This commit is contained in:
parent
6d6d4565d3
commit
30fa48558e
12 changed files with 411 additions and 0 deletions
12
boards/qorvo/decawave_dwm3001cdk/Kconfig
Normal file
12
boards/qorvo/decawave_dwm3001cdk/Kconfig
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
# DecaWave DWM3001CDK board configuration
|
||||||
|
|
||||||
|
# Copyright (c) 2024 The Zephyr Project Contributors
|
||||||
|
# # SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
|
if BOARD_DECAWAVE_DWM3001CDK
|
||||||
|
|
||||||
|
config BOARD_SERIAL_BACKEND_CDC_ACM
|
||||||
|
bool "Use USB CDC as serial console backend"
|
||||||
|
default y
|
||||||
|
|
||||||
|
endif # BOARD_DECAWAVE_DWM3001CDK
|
|
@ -0,0 +1,7 @@
|
||||||
|
# DecaWave DWM3001CDK board configuration
|
||||||
|
|
||||||
|
# Copyright (c) 2019 Stéphane D'Alu
|
||||||
|
# SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
|
config BOARD_DECAWAVE_DWM3001CDK
|
||||||
|
select SOC_NRF52833_QDAA
|
70
boards/qorvo/decawave_dwm3001cdk/Kconfig.defconfig
Normal file
70
boards/qorvo/decawave_dwm3001cdk/Kconfig.defconfig
Normal file
|
@ -0,0 +1,70 @@
|
||||||
|
# DecaWave DWM3001CDK board configuration
|
||||||
|
|
||||||
|
# Copyright (c) 2019 Stéphane D'Alu
|
||||||
|
# SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
|
if BOARD_DECAWAVE_DWM3001CDK
|
||||||
|
|
||||||
|
config BT_CTLR
|
||||||
|
default BT
|
||||||
|
|
||||||
|
config I2C
|
||||||
|
default SENSOR
|
||||||
|
|
||||||
|
if BOARD_SERIAL_BACKEND_CDC_ACM
|
||||||
|
|
||||||
|
config USB_DEVICE_STACK
|
||||||
|
default y
|
||||||
|
|
||||||
|
config USB_CDC_ACM
|
||||||
|
default SERIAL
|
||||||
|
|
||||||
|
config CONSOLE
|
||||||
|
default y
|
||||||
|
|
||||||
|
config UART_CONSOLE
|
||||||
|
default CONSOLE
|
||||||
|
|
||||||
|
config USB_DEVICE_INITIALIZE_AT_BOOT
|
||||||
|
default y if !MCUBOOT && CONSOLE
|
||||||
|
|
||||||
|
config SHELL_BACKEND_SERIAL_CHECK_DTR
|
||||||
|
default SHELL
|
||||||
|
depends on UART_LINE_CTRL
|
||||||
|
|
||||||
|
config UART_LINE_CTRL
|
||||||
|
default y
|
||||||
|
|
||||||
|
config USB_DEVICE_REMOTE_WAKEUP
|
||||||
|
default n
|
||||||
|
|
||||||
|
if LOG
|
||||||
|
|
||||||
|
# Logger cannot use itself to log
|
||||||
|
choice USB_CDC_ACM_LOG_LEVEL_CHOICE
|
||||||
|
default USB_CDC_ACM_LOG_LEVEL_OFF
|
||||||
|
endchoice
|
||||||
|
|
||||||
|
# Set USB log level to error only
|
||||||
|
choice USB_DEVICE_LOG_LEVEL_CHOICE
|
||||||
|
default USB_DEVICE_LOG_LEVEL_ERR
|
||||||
|
endchoice
|
||||||
|
|
||||||
|
endif # LOG
|
||||||
|
|
||||||
|
if USB_DEVICE_STACK
|
||||||
|
|
||||||
|
# Enable UART driver, needed for CDC ACM
|
||||||
|
config SERIAL
|
||||||
|
default y
|
||||||
|
|
||||||
|
endif # USB_DEVICE_STACK
|
||||||
|
|
||||||
|
endif # BOARD_SERIAL_BACKEND_CDC_ACM
|
||||||
|
|
||||||
|
DT_CHOSEN_ZEPHYR_CONSOLE := zephyr,console
|
||||||
|
|
||||||
|
config UART_CONSOLE
|
||||||
|
default y if $(dt_chosen_enabled,$(DT_CHOSEN_ZEPHYR_CONSOLE)) && CONSOLE
|
||||||
|
|
||||||
|
endif # BOARD_DECAWAVE_DWM3001CDK
|
9
boards/qorvo/decawave_dwm3001cdk/board.cmake
Normal file
9
boards/qorvo/decawave_dwm3001cdk/board.cmake
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
# SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
|
board_runner_args(jlink "--device=nRF52833_xxAA" "--speed=4000")
|
||||||
|
board_runner_args(pyocd "--target=nrf52833" "--frequency=4000000")
|
||||||
|
include(${ZEPHYR_BASE}/boards/common/nrfjprog.board.cmake)
|
||||||
|
include(${ZEPHYR_BASE}/boards/common/nrfutil.board.cmake)
|
||||||
|
include(${ZEPHYR_BASE}/boards/common/jlink.board.cmake)
|
||||||
|
include(${ZEPHYR_BASE}/boards/common/pyocd.board.cmake)
|
||||||
|
include(${ZEPHYR_BASE}/boards/common/openocd-nrf5.board.cmake)
|
5
boards/qorvo/decawave_dwm3001cdk/board.yml
Normal file
5
boards/qorvo/decawave_dwm3001cdk/board.yml
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
board:
|
||||||
|
name: decawave_dwm3001cdk
|
||||||
|
vendor: qorvo
|
||||||
|
socs:
|
||||||
|
- name: nrf52833
|
|
@ -0,0 +1,39 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2022 Nordic Semiconductor
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
&pinctrl {
|
||||||
|
i2c0_default: i2c0_default {
|
||||||
|
group1 {
|
||||||
|
psels = <NRF_PSEL(TWIM_SDA, 0, 24)>,
|
||||||
|
<NRF_PSEL(TWIM_SCL, 1, 04)>;
|
||||||
|
bias-pull-up;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
i2c0_sleep: i2c0_sleep {
|
||||||
|
group1 {
|
||||||
|
psels = <NRF_PSEL(TWIM_SDA, 0, 24)>,
|
||||||
|
<NRF_PSEL(TWIM_SCL, 1, 04)>;
|
||||||
|
low-power-enable;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
spi3_default: spi3_default {
|
||||||
|
group1 {
|
||||||
|
psels = <NRF_PSEL(SPIM_SCK, 0, 3)>,
|
||||||
|
<NRF_PSEL(SPIM_MOSI, 0, 8)>,
|
||||||
|
<NRF_PSEL(SPIM_MISO, 0, 29)>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
spi3_sleep: spi3_sleep {
|
||||||
|
group1 {
|
||||||
|
psels = <NRF_PSEL(SPIM_SCK, 0, 3)>,
|
||||||
|
<NRF_PSEL(SPIM_MOSI, 0, 8)>,
|
||||||
|
<NRF_PSEL(SPIM_MISO, 0, 29)>;
|
||||||
|
low-power-enable;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
160
boards/qorvo/decawave_dwm3001cdk/decawave_dwm3001cdk.dts
Normal file
160
boards/qorvo/decawave_dwm3001cdk/decawave_dwm3001cdk.dts
Normal file
|
@ -0,0 +1,160 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2019 Stéphane D'Alu
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
/dts-v1/;
|
||||||
|
#include <nordic/nrf52833_qdaa.dtsi>
|
||||||
|
#include "decawave_dwm3001cdk-pinctrl.dtsi"
|
||||||
|
#include <zephyr/dt-bindings/input/input-event-codes.h>
|
||||||
|
|
||||||
|
/ {
|
||||||
|
model = "Decawave DWM3001CDK";
|
||||||
|
compatible = "decawave,dwm3001";
|
||||||
|
|
||||||
|
chosen {
|
||||||
|
zephyr,console = &cdc_acm_uart0;
|
||||||
|
zephyr,shell-uart = &cdc_acm_uart0;
|
||||||
|
zephyr,uart-mcumgr = &cdc_acm_uart0;
|
||||||
|
zephyr,bt-mon-uart = &cdc_acm_uart0;
|
||||||
|
zephyr,bt-c2h-uart = &cdc_acm_uart0;
|
||||||
|
zephyr,sram = &sram0;
|
||||||
|
zephyr,flash = &flash0;
|
||||||
|
zephyr,code-partition = &slot0_partition;
|
||||||
|
zephyr,ieee802154 = &ieee802154;
|
||||||
|
};
|
||||||
|
|
||||||
|
leds {
|
||||||
|
compatible = "gpio-leds";
|
||||||
|
// led from top of board down
|
||||||
|
// D20: something related to jlink, red
|
||||||
|
// D13: DW3000 tx(red)/rx(green)
|
||||||
|
led0: led_0 {
|
||||||
|
gpios = <&gpio0 04 GPIO_ACTIVE_LOW>;
|
||||||
|
label = "D9 green LED";
|
||||||
|
};
|
||||||
|
led1: led_1 {
|
||||||
|
gpios = <&gpio0 14 GPIO_ACTIVE_LOW>;
|
||||||
|
label = "D12 red LED";
|
||||||
|
};
|
||||||
|
led2: led_2 {
|
||||||
|
gpios = <&gpio0 22 GPIO_ACTIVE_LOW>;
|
||||||
|
label = "D11 red LED";
|
||||||
|
};
|
||||||
|
led3: led_3 {
|
||||||
|
gpios = <&gpio0 05 GPIO_ACTIVE_LOW>;
|
||||||
|
label = "D10 blue LED";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
buttons {
|
||||||
|
compatible = "gpio-keys";
|
||||||
|
// SW1 is connected to P0.18, which by default is nRESET and
|
||||||
|
// will reset the board
|
||||||
|
button2: button_2 {
|
||||||
|
gpios = <&gpio0 2 (GPIO_PULL_UP | GPIO_ACTIVE_LOW)>;
|
||||||
|
label = "Push button switch 2";
|
||||||
|
zephyr,code = <INPUT_KEY_1>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
/* These aliases are provided for compatibility with samples */
|
||||||
|
aliases {
|
||||||
|
sw0 = &button2;
|
||||||
|
led0 = &led0;
|
||||||
|
led1 = &led1;
|
||||||
|
led2 = &led2;
|
||||||
|
led3 = &led3;
|
||||||
|
watchdog0 = &wdt0;
|
||||||
|
accel0 = &lis2dh12;
|
||||||
|
};
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
&uicr {
|
||||||
|
gpio-as-nreset;
|
||||||
|
};
|
||||||
|
|
||||||
|
&gpiote {
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&gpio0 {
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&gpio1 {
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&i2c0 {
|
||||||
|
compatible = "nordic,nrf-twim";
|
||||||
|
status = "okay";
|
||||||
|
clock-frequency = <I2C_BITRATE_FAST>;
|
||||||
|
|
||||||
|
pinctrl-0 = <&i2c0_default>;
|
||||||
|
pinctrl-1 = <&i2c0_sleep>;
|
||||||
|
pinctrl-names = "default", "sleep";
|
||||||
|
lis2dh12: lis2dh12@19 {
|
||||||
|
compatible = "st,lis2dh12", "st,lis2dh";
|
||||||
|
reg = <0x19>;
|
||||||
|
irq-gpios = <&gpio0 16 GPIO_ACTIVE_HIGH>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
&spi3 {
|
||||||
|
compatible = "nordic,nrf-spim";
|
||||||
|
status = "okay";
|
||||||
|
cs-gpios = <&gpio1 6 GPIO_ACTIVE_LOW>;
|
||||||
|
|
||||||
|
pinctrl-0 = <&spi3_default>;
|
||||||
|
pinctrl-1 = <&spi3_sleep>;
|
||||||
|
pinctrl-names = "default", "sleep";
|
||||||
|
};
|
||||||
|
|
||||||
|
&ieee802154 {
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
|
&flash0 {
|
||||||
|
partitions {
|
||||||
|
compatible = "fixed-partitions";
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <1>;
|
||||||
|
|
||||||
|
boot_partition: partition@0 {
|
||||||
|
label = "mcuboot";
|
||||||
|
reg = <0x00000000 0xC000>;
|
||||||
|
};
|
||||||
|
slot0_partition: partition@c000 {
|
||||||
|
label = "image-0";
|
||||||
|
reg = <0x0000C000 0x38000>;
|
||||||
|
};
|
||||||
|
slot1_partition: partition@44000 {
|
||||||
|
label = "image-1";
|
||||||
|
reg = <0x00044000 0x36000>;
|
||||||
|
};
|
||||||
|
storage_partition: partition@7a000 {
|
||||||
|
label = "storage";
|
||||||
|
reg = <0x0007A000 0x00006000>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
zephyr_udc0: &usbd {
|
||||||
|
compatible = "nordic,nrf-usbd";
|
||||||
|
status = "okay";
|
||||||
|
|
||||||
|
cdc_acm_uart0: cdc_acm_uart0 {
|
||||||
|
compatible = "zephyr,cdc-acm-uart";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
®1 {
|
||||||
|
regulator-initial-mode = <NRF5X_REG_MODE_DCDC>;
|
||||||
|
};
|
||||||
|
|
||||||
|
&adc {
|
||||||
|
status = "okay";
|
||||||
|
};
|
20
boards/qorvo/decawave_dwm3001cdk/decawave_dwm3001cdk.yaml
Normal file
20
boards/qorvo/decawave_dwm3001cdk/decawave_dwm3001cdk.yaml
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
identifier: decawave_dwm3001cdk
|
||||||
|
name: Decawave-DWM3001CDK
|
||||||
|
type: mcu
|
||||||
|
arch: arm
|
||||||
|
ram: 128
|
||||||
|
flash: 512
|
||||||
|
vendor: decawave
|
||||||
|
toolchain:
|
||||||
|
- zephyr
|
||||||
|
- gnuarmemb
|
||||||
|
- xtools
|
||||||
|
supported:
|
||||||
|
- adc
|
||||||
|
- usb_device
|
||||||
|
- ble
|
||||||
|
- gpio
|
||||||
|
- pwm
|
||||||
|
- watchdog
|
||||||
|
- counter
|
||||||
|
- netif:openthread
|
|
@ -0,0 +1,10 @@
|
||||||
|
# SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
|
# Enable MPU
|
||||||
|
CONFIG_ARM_MPU=y
|
||||||
|
|
||||||
|
# Enable hardware stack protection
|
||||||
|
CONFIG_HW_STACK_PROTECTION=y
|
||||||
|
|
||||||
|
# Enable GPIO
|
||||||
|
CONFIG_GPIO=y
|
65
boards/qorvo/decawave_dwm3001cdk/doc/index.rst
Normal file
65
boards/qorvo/decawave_dwm3001cdk/doc/index.rst
Normal file
|
@ -0,0 +1,65 @@
|
||||||
|
.. _decawave_dwm3001cdk:
|
||||||
|
|
||||||
|
Decawave DWM3001CDK
|
||||||
|
###################
|
||||||
|
|
||||||
|
Overview
|
||||||
|
********
|
||||||
|
|
||||||
|
The DWM3001CDK development board includes the DWM3001C module, battery connector
|
||||||
|
and charging circuit, LEDs, buttons, Raspberry Pi connector, and USB connector.
|
||||||
|
In addition, the board comes with J-Link OB adding debugging and Virtual COM
|
||||||
|
Port capabilities.
|
||||||
|
|
||||||
|
See `Qorvo (Decawave) DWM3001CDK website`_ for more information about the
|
||||||
|
development board, `Qorvo (Decawave) DWM3001C website`_ about the module
|
||||||
|
itself, and `nRF52833 website`_ for the official reference on the IC itself.
|
||||||
|
|
||||||
|
Programming and Debugging
|
||||||
|
*************************
|
||||||
|
|
||||||
|
Applications for the ``decawave_dwm3001cdk`` board target can be built, flashed,
|
||||||
|
and debugged in the usual way. See :ref:`build_an_application` and
|
||||||
|
:ref:`application_run` for more details on building and running.
|
||||||
|
|
||||||
|
Flashing
|
||||||
|
========
|
||||||
|
|
||||||
|
Follow the instructions in the :ref:`nordic_segger` page to install
|
||||||
|
and configure all the necessary software. Further information can be
|
||||||
|
found in :ref:`nordic_segger_flashing`. Then build and flash
|
||||||
|
applications as usual (see :ref:`build_an_application` and
|
||||||
|
:ref:`application_run` for more details).
|
||||||
|
|
||||||
|
There are two USB ports, the one farthest from the DWM3001C is connected to the
|
||||||
|
J-Link debugger and the closer one is connected to the nRF52833, though you need
|
||||||
|
to use CDC ACM USB to get output over it
|
||||||
|
|
||||||
|
Here is an example for the :zephyr:code-sample:`usb-cdc-acm` application.
|
||||||
|
|
||||||
|
Connect to the bottom USB port, and flash the sample
|
||||||
|
|
||||||
|
.. zephyr-app-commands::
|
||||||
|
:zephyr-app: samples/subsys/usb/console
|
||||||
|
:board: decawave_dwm3001cdk
|
||||||
|
:goals: build flash
|
||||||
|
|
||||||
|
|
||||||
|
Then, connect the top USB port and open run your favorite terminal program to
|
||||||
|
listen for output.
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
$ minicom -D <tty_device> -b 115200
|
||||||
|
|
||||||
|
Replace :code:`<tty_device>` with the port where the board nRF52 DK
|
||||||
|
can be found. For example, under Linux, :code:`/dev/ttyACM0`.
|
||||||
|
|
||||||
|
|
||||||
|
References
|
||||||
|
**********
|
||||||
|
.. target-notes::
|
||||||
|
|
||||||
|
.. _nRF52833 website: https://www.nordicsemi.com/products/nrf52833
|
||||||
|
.. _Qorvo (Decawave) DWM3001C website: https://www.qorvo.com/products/p/DWM3001C
|
||||||
|
.. _Qorvo (Decawave) DWM3001CDK website: https://www.qorvo.com/products/p/DWM3001CDK
|
7
boards/qorvo/decawave_dwm3001cdk/pre_dt_board.cmake
Normal file
7
boards/qorvo/decawave_dwm3001cdk/pre_dt_board.cmake
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
# Copyright (c) 2022 Nordic Semiconductor
|
||||||
|
# SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
|
# Suppress "unique_unit_address_if_enabled" to handle the following overlaps:
|
||||||
|
# - power@40000000 & clock@40000000 & bprot@40000000
|
||||||
|
# - acl@4001e000 & flash-controller@4001e000
|
||||||
|
list(APPEND EXTRA_DTC_FLAGS "-Wno-unique_unit_address_if_enabled")
|
|
@ -0,0 +1,7 @@
|
||||||
|
/*
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*
|
||||||
|
* Copyright (c) 2024 The Zephyr Project Contributors
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "nordic,nrf-saadc-common.dtsi"
|
Loading…
Add table
Add a link
Reference in a new issue