diff --git a/README.md b/README.md
index ce844069..8ed2d581 100644
--- a/README.md
+++ b/README.md
@@ -1,6 +1,6 @@
# Third Party Hardware Drivers #
-[![Version Badge](https://img.shields.io/badge/-v2.0.1-green)](https://github.com/SiliconLabs/third_party_hw_drivers_extension/releases)
+[![Version Badge](https://img.shields.io/badge/-v2.0.2-green)](https://github.com/SiliconLabs/third_party_hw_drivers_extension/releases)
[![GSDK Badge](https://img.shields.io/badge/GSDK-v4.4.0-green)](https://github.com/SiliconLabs/gecko_sdk/releases)
![License badge](https://img.shields.io/badge/License-Zlib-green)
@@ -98,8 +98,9 @@ A full list of all drivers in this repository is defined below:
| particulate_matter_sensor_sps30 | [Click Here](./driver/public/silabs/particulate_matter_sensor_sps30) | [Click Here](./app/example/sparkfun_particulate_matter_sensor_sps30) | [Click Here](./app/documentation/example/sparkfun_particulate_matter_sensor_sps30) |
| adafruit_neotrellis_keypad_atsamd09 | [Click Here](./driver/public/silabs/adafruit_neotrellis_keypad_atsamd09) | [Click Here](./app/example/adafruit_neotrellis_keypad_atsamd09) | [Click Here](./app/documentation/example/adafruit_neotrellis_keypad_atsamd09) |
| hvac_bundle_scd41_sps30 | [Click Here](./driver/public/mikroe/hvac_scd41)
[Click Here](./driver/public/silabs/particulate_matter_sensor_sps30)| [Click Here](./app/example/mikroe_hvac_bundle_scd41_sps30) | [Click Here](./app/documentation/example/mikroe_hvac_bundle_scd41_sps30) |
-| mikroe_uwb_dwm1000 | [Click Here](./driver/public/mikroe/uwb_dwm1000) | [Click Here](./app/example/mikroe_uwb_dwm1000) | [Click Here](./app/documentation/example/mikroe_uwb_dwm1000) |
| mikroe_pir_pl_n823_01 | [Click Here](./driver/public/mikroe/pir_pl_n823_01) | [Click Here](./app/example/mikroe_pir_pl_n823_01) | [Click Here](./app/documentation/example/mikroe_pir_pl_n823_01) |
+| mikroe_uwb_dwm1000 | [Click Here](./driver/public/mikroe/uwb_dwm1000) | [Click Here](./app/example/mikroe_uwb_dwm1000) | [Click Here](./app/documentation/example/mikroe_uwb_dwm1000) |
+| mikroe_uwb2_dwm3000 | [Click Here](./driver/public/silabs/uwb2_dwm3000) | [Click Here](./app/example/mikroe_uwb2_dwm3000) | [Click Here](./app/documentation/example/mikroe_uwb2_dwm3000) |
## Requirements ##
- Desired Silicon Labs Starter Kit
diff --git a/app/documentation/example/mikroe_uwb2_dwm3000/README.md b/app/documentation/example/mikroe_uwb2_dwm3000/README.md
new file mode 100644
index 00000000..ab7cc9d9
--- /dev/null
+++ b/app/documentation/example/mikroe_uwb2_dwm3000/README.md
@@ -0,0 +1,104 @@
+# DWM3000 - UWB 2 Click (Mikroe) #
+
+## Summary ##
+
+This example project showcases the driver integration of the Mikroe DWM3000 - UWB 2 Click board™.
+
+UWB 2 Click board™ is an Ultra-Wideband transceiver. It features the DWM3000, an IEEE 802.15-z UWB transceiver module from Qorvo. This module fully aligns with FiRaTM PHY, MAC, and certification development. It uses an integrated UWB antenna to establish wireless communication in UWB channels 5 (6.5GHz) and 9 (8GHz). This Click board™ is optimized for developing precision real-time positioning system (RTLS) applications using two-way ranging diagrams or Time Difference of Arrival (TDoA). It can also be applied in many other fields such as agriculture, automation & building controls, factory automation, healthcare, safety & security and warehousing & logistics.
+
+## Required Hardware ##
+
+- [EFR32xG24 Explorer Kit](https://www.silabs.com/development-tools/wireless/efr32xg24-explorer-kit?tab=overview)
+
+- [UWB 2 Click board™](https://www.mikroe.com/uwb-2-click)
+
+**NOTE:**
+Tested boards for working with this example:
+
+| Board ID | Description |
+| ---------------------- | ------ |
+| BRD2703A | [xG24-EK2703A - EFR32xG24 Explorer Kit](https://www.silabs.com/development-tools/wireless/efr32xg24-explorer-kit?tab=overview) |
+| BRD4314A | [BGM220-EK4314A - BGM220P Bluetooth Module Explorer Kit](https://www.silabs.com/development-tools/wireless/bluetooth/bgm220-explorer-kit?tab=overview) |
+| BRD4108A | [BG22-EK4108A - EFR32BG22 Explorer Kit Board](https://www.silabs.com/development-tools/wireless/bluetooth/bg22-explorer-kit?tab=overview) |
+
+## Hardware Connection ##
+
+The DWM3000 - UWB 2 Click board™ supports MikroBus. Therefore, it can connect easily to the MikroBus header of the EFR32xG24 Explorer Kit. Be sure that the 45-degree corner of the board matches the 45-degree white line of the Explorer Kit. The hardware connection is shown in the image below:
+
+![board](image/hardware_connection.png)
+
+## Setup ##
+
+You can either create a project based on an example project or start with an empty example project.
+
+### Create a project based on an example project ###
+
+1. From the Launcher Home, add the BRD2703A to My Products, click on it, and click on the **EXAMPLE PROJECTS & DEMOS** tab. Find the example project filtering by "uwb 2".
+
+2. Click **Create** button on the **Third Party Hardware Drivers - DWM3000 - UWB 2 Click (Mikroe)** example. Example project creation dialog pops up -> click Create and Finish and Project should be generated.
+
+![create_example](image/create_example.png)
+
+3. Build and flash this example to the board.
+
+### Start with an empty example project ###
+
+1. Create an "Empty C Project" for the "EFR32xG24 Explorer Kit" using Simplicity Studio v5. Use the default project settings.
+
+2. Copy all of the files in the "app/example/mikroe_uwb2_dwm3000/app_files" folder into the project root folder (overwriting the existing file).
+
+3. Install the software components:
+
+ - Open the *.slcp file in the project.
+
+ - Select the SOFTWARE COMPONENTS tab.
+
+ - Install the following components:
+
+ - **[Services] → [IO Stream] → [IO Stream: EUSART]** → default instance name: vcom
+ - **[Application] → [Utility] → [Log]**
+ - **[Application] → [Utility] → [Assert]**
+ - **[Services] → [Timers] → [Sleep Timer]**
+ - **[Third Party Hardware Drivers] → [Wireless Connectivity] → [DWM3000 - UWB 2 Click (Mikroe)]** → use default configuration
+
+4. Editing the Linker File:
+ - From the project root folder, open "autogen/linkerfile.ld" file and copy the following section to the autogenerated linker:
+ ```
+ .dw_drivers ALIGN(4):
+ {
+ __dw_drivers_start = . ;
+ KEEP(*(.dw_drivers*))
+ __dw_drivers_end = . ;
+ } > FLASH
+ ```
+ The final "linkerfile.ld" file after editing is shown in the image below:
+
+ ![linker](image/custom_linker.png)
+
+5. Build and flash this example to the board.
+
+**Note:**
+
+- Make sure that the SDK extension has already been installed. If not, please follow [this documentation](https://github.com/SiliconLabs/third_party_hw_drivers_extension/blob/master/README.md#how-to-add-to-simplicity-studio-ide).
+
+- SDK Extension must be enabled for the project to install "DWM3000 - UWB 2 Click (Mikroe)" component.
+
+## How It Works #
+
+After you flash the code to the Explorer Kit and power the connected boards, the application starts running automatically. Use Putty/Tera Term (or another program) to read the values of the serial output. Note that the EFR32xG24 Explorer Kit board uses the default baud rate of 115200.
+
+First, the user must have two boards to run this demo example, one for the Transmitter, and one for Receiver. The user can decide whether to use the device in Transmitter (Tx) or Receiver (Rx) mode by macro "DEMO_APP_TRANSMITTER" in the "app.c" file.
+
+In Tx mode, the main program initializes the driver, reads some information and checks communication with the dwm3000 device. After that, it transmits a packet message periodically. There is a periodic timer in the code, which determines the transmitting intervals; the default transmitting intervals rate is 2000 ms. If you need more frequent transmitting, it is possible to change the value of the macro "TRANSMITTING_INTERVAL_MSEC" in the "app.c" file. The screenshot of the console is shown in the image below:
+
+![transmit](image/tx_log.png)
+
+In Rx mode, the main program initializes the driver, reads some information and checks communication with the dwm3000 device. After that, the device enters receiver mode, and it prints each received packet. The screenshot of the console is shown in the image below:
+
+![receive](image/rx_log.png)
+
+## Report Bugs & Get Support ##
+
+To report bugs in the Application Examples projects, please create a new "Issue" in the "Issues" section of [third_party_hw_drivers_extension](https://github.com/SiliconLabs/third_party_hw_drivers_extension) repo. Please reference the board, project, and source files associated with the bug, and reference line numbers. If you are proposing a fix, also include information on the proposed fix. Since these examples are provided as-is, there is no guarantee that these examples will be updated to fix these issues.
+
+Questions and comments related to these examples should be made by creating a new "Issue" in the "Issues" section of [third_party_hw_drivers_extension](https://github.com/SiliconLabs/third_party_hw_drivers_extension) repo.
\ No newline at end of file
diff --git a/app/documentation/example/mikroe_uwb2_dwm3000/image/create_example.png b/app/documentation/example/mikroe_uwb2_dwm3000/image/create_example.png
new file mode 100644
index 00000000..03e0c076
Binary files /dev/null and b/app/documentation/example/mikroe_uwb2_dwm3000/image/create_example.png differ
diff --git a/app/documentation/example/mikroe_uwb2_dwm3000/image/custom_linker.png b/app/documentation/example/mikroe_uwb2_dwm3000/image/custom_linker.png
new file mode 100644
index 00000000..609feec6
Binary files /dev/null and b/app/documentation/example/mikroe_uwb2_dwm3000/image/custom_linker.png differ
diff --git a/app/documentation/example/mikroe_uwb2_dwm3000/image/hardware_connection.png b/app/documentation/example/mikroe_uwb2_dwm3000/image/hardware_connection.png
new file mode 100644
index 00000000..d4afecf4
Binary files /dev/null and b/app/documentation/example/mikroe_uwb2_dwm3000/image/hardware_connection.png differ
diff --git a/app/documentation/example/mikroe_uwb2_dwm3000/image/rx_log.png b/app/documentation/example/mikroe_uwb2_dwm3000/image/rx_log.png
new file mode 100644
index 00000000..4038372d
Binary files /dev/null and b/app/documentation/example/mikroe_uwb2_dwm3000/image/rx_log.png differ
diff --git a/app/documentation/example/mikroe_uwb2_dwm3000/image/tx_log.png b/app/documentation/example/mikroe_uwb2_dwm3000/image/tx_log.png
new file mode 100644
index 00000000..6789b338
Binary files /dev/null and b/app/documentation/example/mikroe_uwb2_dwm3000/image/tx_log.png differ
diff --git a/app/example/adafruit_neotrellis_keypad_atsamd09/adafruit_neotrellis_keypad_atsamd09.slcp b/app/example/adafruit_neotrellis_keypad_atsamd09/adafruit_neotrellis_keypad_atsamd09.slcp
index 5bcfef62..62fb38e3 100644
--- a/app/example/adafruit_neotrellis_keypad_atsamd09/adafruit_neotrellis_keypad_atsamd09.slcp
+++ b/app/example/adafruit_neotrellis_keypad_atsamd09/adafruit_neotrellis_keypad_atsamd09.slcp
@@ -39,7 +39,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/adafruit_neotrellis_keypad_atsamd09/image/connection.png
diff --git a/app/example/adafruit_rgb_led_is31fl3741/adafruit_rgb_led_is31fl3741.slcp b/app/example/adafruit_rgb_led_is31fl3741/adafruit_rgb_led_is31fl3741.slcp
index f33f1fef..8203ae7c 100644
--- a/app/example/adafruit_rgb_led_is31fl3741/adafruit_rgb_led_is31fl3741.slcp
+++ b/app/example/adafruit_rgb_led_is31fl3741/adafruit_rgb_led_is31fl3741.slcp
@@ -46,7 +46,7 @@ define:
- name: DEBUG_EFM
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/adafruit_rgb_led_is31fl3741/image/connection.png
directory: "image"
diff --git a/app/example/adafruit_tft_lcd_hxd8357d/adafruit_tft_lcd_hxd8357d.slcp b/app/example/adafruit_tft_lcd_hxd8357d/adafruit_tft_lcd_hxd8357d.slcp
index 9e6552f5..0984025f 100644
--- a/app/example/adafruit_tft_lcd_hxd8357d/adafruit_tft_lcd_hxd8357d.slcp
+++ b/app/example/adafruit_tft_lcd_hxd8357d/adafruit_tft_lcd_hxd8357d.slcp
@@ -46,7 +46,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/adafruit_tft_lcd_hxd8357d/image/create_example_with_dma_mode.png
diff --git a/app/example/adafruit_tft_lcd_hxd8357d/adafruit_tft_lcd_hxd8357d_dma.slcp b/app/example/adafruit_tft_lcd_hxd8357d/adafruit_tft_lcd_hxd8357d_dma.slcp
index fd240dc1..58e0f4e6 100644
--- a/app/example/adafruit_tft_lcd_hxd8357d/adafruit_tft_lcd_hxd8357d_dma.slcp
+++ b/app/example/adafruit_tft_lcd_hxd8357d/adafruit_tft_lcd_hxd8357d_dma.slcp
@@ -46,7 +46,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/adafruit_tft_lcd_hxd8357d/image/create_example_with_dma_mode.png
diff --git a/app/example/adafruit_tft_lcd_hxd8357d_lvgl/adafruit_tft_lcd_hxd8357d_lvgl.slcp b/app/example/adafruit_tft_lcd_hxd8357d_lvgl/adafruit_tft_lcd_hxd8357d_lvgl.slcp
index f9e66262..45e43a7c 100644
--- a/app/example/adafruit_tft_lcd_hxd8357d_lvgl/adafruit_tft_lcd_hxd8357d_lvgl.slcp
+++ b/app/example/adafruit_tft_lcd_hxd8357d_lvgl/adafruit_tft_lcd_hxd8357d_lvgl.slcp
@@ -66,7 +66,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/adafruit_tft_lcd_hxd8357d_lvgl/image/create_example.png
diff --git a/app/example/adafruit_tft_lcd_hxd8357d_lvgl/adafruit_tft_lcd_hxd8357d_lvgl_dma.slcp b/app/example/adafruit_tft_lcd_hxd8357d_lvgl/adafruit_tft_lcd_hxd8357d_lvgl_dma.slcp
index c5b83ffd..f31263aa 100644
--- a/app/example/adafruit_tft_lcd_hxd8357d_lvgl/adafruit_tft_lcd_hxd8357d_lvgl_dma.slcp
+++ b/app/example/adafruit_tft_lcd_hxd8357d_lvgl/adafruit_tft_lcd_hxd8357d_lvgl_dma.slcp
@@ -68,7 +68,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/adafruit_tft_lcd_hxd8357d_lvgl/image/create_example.png
diff --git a/app/example/adafruit_tft_lcd_ili9341/adafruit_tft_lcd_ili9341.slcp b/app/example/adafruit_tft_lcd_ili9341/adafruit_tft_lcd_ili9341.slcp
index 32de5b8c..8163dc2a 100644
--- a/app/example/adafruit_tft_lcd_ili9341/adafruit_tft_lcd_ili9341.slcp
+++ b/app/example/adafruit_tft_lcd_ili9341/adafruit_tft_lcd_ili9341.slcp
@@ -46,7 +46,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/adafruit_tft_lcd_ili9341/image/create_example.png
diff --git a/app/example/adafruit_tft_lcd_ili9341/adafruit_tft_lcd_ili9341_dma.slcp b/app/example/adafruit_tft_lcd_ili9341/adafruit_tft_lcd_ili9341_dma.slcp
index 49d22595..2c652278 100644
--- a/app/example/adafruit_tft_lcd_ili9341/adafruit_tft_lcd_ili9341_dma.slcp
+++ b/app/example/adafruit_tft_lcd_ili9341/adafruit_tft_lcd_ili9341_dma.slcp
@@ -46,7 +46,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/adafruit_tft_lcd_ili9341/image/create_example.png
diff --git a/app/example/adafruit_tft_lcd_ili9341_lvgl/adafruit_tft_lcd_ili9341_lvgl.slcp b/app/example/adafruit_tft_lcd_ili9341_lvgl/adafruit_tft_lcd_ili9341_lvgl.slcp
index 8050882a..2043f617 100644
--- a/app/example/adafruit_tft_lcd_ili9341_lvgl/adafruit_tft_lcd_ili9341_lvgl.slcp
+++ b/app/example/adafruit_tft_lcd_ili9341_lvgl/adafruit_tft_lcd_ili9341_lvgl.slcp
@@ -88,7 +88,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
configuration:
- name: LV_BUFFER_MODE
diff --git a/app/example/adafruit_tft_lcd_ili9341_lvgl/adafruit_tft_lcd_ili9341_lvgl_dma.slcp b/app/example/adafruit_tft_lcd_ili9341_lvgl/adafruit_tft_lcd_ili9341_lvgl_dma.slcp
index 8dca8837..2522d7c7 100644
--- a/app/example/adafruit_tft_lcd_ili9341_lvgl/adafruit_tft_lcd_ili9341_lvgl_dma.slcp
+++ b/app/example/adafruit_tft_lcd_ili9341_lvgl/adafruit_tft_lcd_ili9341_lvgl_dma.slcp
@@ -60,7 +60,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
configuration:
- name: LV_BUFFER_MODE
diff --git a/app/example/adafruit_tft_lcd_st7789/adafruit_tft_lcd_st7789.slcp b/app/example/adafruit_tft_lcd_st7789/adafruit_tft_lcd_st7789.slcp
index decf0a13..3987d8e4 100644
--- a/app/example/adafruit_tft_lcd_st7789/adafruit_tft_lcd_st7789.slcp
+++ b/app/example/adafruit_tft_lcd_st7789/adafruit_tft_lcd_st7789.slcp
@@ -49,7 +49,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/adafruit_tft_lcd_st7789/image/create_example.png
diff --git a/app/example/adafruit_tft_lcd_st7789/adafruit_tft_lcd_st7789_dma.slcp b/app/example/adafruit_tft_lcd_st7789/adafruit_tft_lcd_st7789_dma.slcp
index bf9ff247..763718df 100644
--- a/app/example/adafruit_tft_lcd_st7789/adafruit_tft_lcd_st7789_dma.slcp
+++ b/app/example/adafruit_tft_lcd_st7789/adafruit_tft_lcd_st7789_dma.slcp
@@ -50,7 +50,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/adafruit_tft_lcd_st7789/image/create_example.png
diff --git a/app/example/adafruit_tft_lcd_st7789_lvgl_dma/adafruit_tft_lcd_st7789_lvgl_dma.slcp b/app/example/adafruit_tft_lcd_st7789_lvgl_dma/adafruit_tft_lcd_st7789_lvgl_dma.slcp
index 5e2290f3..783e71f2 100644
--- a/app/example/adafruit_tft_lcd_st7789_lvgl_dma/adafruit_tft_lcd_st7789_lvgl_dma.slcp
+++ b/app/example/adafruit_tft_lcd_st7789_lvgl_dma/adafruit_tft_lcd_st7789_lvgl_dma.slcp
@@ -59,7 +59,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/adafruit_tft_lcd_st7789_lvgl_dma/image/create_example.png
diff --git a/app/example/adafruit_touchscreen_tsc2007/adafruit_touchscreen_tsc2007.slcp b/app/example/adafruit_touchscreen_tsc2007/adafruit_touchscreen_tsc2007.slcp
index a885e472..7eff814a 100644
--- a/app/example/adafruit_touchscreen_tsc2007/adafruit_touchscreen_tsc2007.slcp
+++ b/app/example/adafruit_touchscreen_tsc2007/adafruit_touchscreen_tsc2007.slcp
@@ -45,7 +45,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/adafruit_touchscreen_tsc2007/image/calib.png
diff --git a/app/example/bthome_v2_server/app.c b/app/example/bthome_v2_server/app.c
index 6bbca5ba..3be6904b 100644
--- a/app/example/bthome_v2_server/app.c
+++ b/app/example/bthome_v2_server/app.c
@@ -84,7 +84,7 @@ void sl_bt_on_event(sl_bt_msg_t *evt)
== SIGNAL_LOG_DATA) {
uint8_t mac[6];
uint8_t device_count;
- bthome_v2_server_sensor_data_t object[5];
+ bthome_v2_server_sensor_data_t object[10];
uint8_t object_count;
bool encrypted;
bool key_available;
@@ -113,7 +113,7 @@ void sl_bt_on_event(sl_bt_msg_t *evt)
object_count = 0;
bthome_v2_server_sensor_data_read(mac,
object,
- 5,
+ 10,
&object_count,
NULL);
diff --git a/app/example/bthome_v2_server/bthome_v2_server.slcp b/app/example/bthome_v2_server/bthome_v2_server.slcp
index d7ae6990..98cec0ba 100644
--- a/app/example/bthome_v2_server/bthome_v2_server.slcp
+++ b/app/example/bthome_v2_server/bthome_v2_server.slcp
@@ -50,6 +50,10 @@ component:
- id: gatt_service_device_information
- id: app_log
+toolchain_settings:
+ - option: gcc_linker_option
+ value: "-u _printf_float"
+
config_file:
- override:
component: gatt_configuration
@@ -62,7 +66,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/bthome_v2_server/image/connection.png
diff --git a/app/example/maxim_fuel_gauge_max17048/maxim_fuel_gauge_max17048.slcp b/app/example/maxim_fuel_gauge_max17048/maxim_fuel_gauge_max17048.slcp
index 4df49ced..e8dcd58b 100644
--- a/app/example/maxim_fuel_gauge_max17048/maxim_fuel_gauge_max17048.slcp
+++ b/app/example/maxim_fuel_gauge_max17048/maxim_fuel_gauge_max17048.slcp
@@ -47,7 +47,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/maxim_fuel_gauge_max17048/image/overview.png
diff --git a/app/example/mikroe_accel5_bma400/mikroe_accel5_bma400_i2c.slcp b/app/example/mikroe_accel5_bma400/mikroe_accel5_bma400_i2c.slcp
index dd432d03..e3680251 100644
--- a/app/example/mikroe_accel5_bma400/mikroe_accel5_bma400_i2c.slcp
+++ b/app/example/mikroe_accel5_bma400/mikroe_accel5_bma400_i2c.slcp
@@ -44,7 +44,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_accel5_bma400/image/hardware_connection.png
diff --git a/app/example/mikroe_accel5_bma400/mikroe_accel5_bma400_spi.slcp b/app/example/mikroe_accel5_bma400/mikroe_accel5_bma400_spi.slcp
index 622a9a22..ab469ab7 100644
--- a/app/example/mikroe_accel5_bma400/mikroe_accel5_bma400_spi.slcp
+++ b/app/example/mikroe_accel5_bma400/mikroe_accel5_bma400_spi.slcp
@@ -44,7 +44,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_accel5_bma400/image/hardware_connection.png
diff --git a/app/example/mikroe_alcohol_mq3/mikroe_alcohol_mq3.slcp b/app/example/mikroe_alcohol_mq3/mikroe_alcohol_mq3.slcp
index 45c0a406..8477a387 100644
--- a/app/example/mikroe_alcohol_mq3/mikroe_alcohol_mq3.slcp
+++ b/app/example/mikroe_alcohol_mq3/mikroe_alcohol_mq3.slcp
@@ -45,7 +45,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_alcohol_mq3/image/create_project.png
diff --git a/app/example/mikroe_barcode2_em3080w/mikroe_barcode2_em3080w.slcp b/app/example/mikroe_barcode2_em3080w/mikroe_barcode2_em3080w.slcp
index c03d1845..92b7b966 100644
--- a/app/example/mikroe_barcode2_em3080w/mikroe_barcode2_em3080w.slcp
+++ b/app/example/mikroe_barcode2_em3080w/mikroe_barcode2_em3080w.slcp
@@ -53,7 +53,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_barcode2_em3080w/image/hardware_connection.png
diff --git a/app/example/mikroe_brushless16_lb11685av/mikroe_brushless16_lb11685av.slcp b/app/example/mikroe_brushless16_lb11685av/mikroe_brushless16_lb11685av.slcp
index be372117..4dc270c7 100644
--- a/app/example/mikroe_brushless16_lb11685av/mikroe_brushless16_lb11685av.slcp
+++ b/app/example/mikroe_brushless16_lb11685av/mikroe_brushless16_lb11685av.slcp
@@ -42,7 +42,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_brushless16_lb11685av/image/create_example.png
diff --git a/app/example/mikroe_buzz2_cmt_8540s_smt/mikroe_buzz2_cmt_8540s_smt.slcp b/app/example/mikroe_buzz2_cmt_8540s_smt/mikroe_buzz2_cmt_8540s_smt.slcp
index e0d62e9c..c2997ab5 100644
--- a/app/example/mikroe_buzz2_cmt_8540s_smt/mikroe_buzz2_cmt_8540s_smt.slcp
+++ b/app/example/mikroe_buzz2_cmt_8540s_smt/mikroe_buzz2_cmt_8540s_smt.slcp
@@ -44,7 +44,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_buzz2_cmt_8540s_smt/image/create_example.png
diff --git a/app/example/mikroe_captouch2_cap1166/mikroe_captouch2_cap1166.slcp b/app/example/mikroe_captouch2_cap1166/mikroe_captouch2_cap1166.slcp
index 8c947e05..534fcb85 100644
--- a/app/example/mikroe_captouch2_cap1166/mikroe_captouch2_cap1166.slcp
+++ b/app/example/mikroe_captouch2_cap1166/mikroe_captouch2_cap1166.slcp
@@ -44,7 +44,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_captouch2_cap1166/image/hardware_connection.png
diff --git a/app/example/mikroe_co_mq7/mikroe_co_mq7.slcp b/app/example/mikroe_co_mq7/mikroe_co_mq7.slcp
index da9aaa10..8b1a328c 100644
--- a/app/example/mikroe_co_mq7/mikroe_co_mq7.slcp
+++ b/app/example/mikroe_co_mq7/mikroe_co_mq7.slcp
@@ -58,7 +58,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
ui_hints:
highlight:
diff --git a/app/example/mikroe_dcmotor24_l9958/mikroe_dcmotor24_l9958.slcp b/app/example/mikroe_dcmotor24_l9958/mikroe_dcmotor24_l9958.slcp
index 93b17c24..8c82e245 100644
--- a/app/example/mikroe_dcmotor24_l9958/mikroe_dcmotor24_l9958.slcp
+++ b/app/example/mikroe_dcmotor24_l9958/mikroe_dcmotor24_l9958.slcp
@@ -47,7 +47,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_dcmotor24_l9958/image/create_example.png
diff --git a/app/example/mikroe_dcmotor26_tb9053ftg/mikroe_dcmotor26_tb9053ftg.slcp b/app/example/mikroe_dcmotor26_tb9053ftg/mikroe_dcmotor26_tb9053ftg.slcp
index d0718b5d..18543776 100644
--- a/app/example/mikroe_dcmotor26_tb9053ftg/mikroe_dcmotor26_tb9053ftg.slcp
+++ b/app/example/mikroe_dcmotor26_tb9053ftg/mikroe_dcmotor26_tb9053ftg.slcp
@@ -47,7 +47,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_dcmotor26_tb9053ftg/image/create_project.png
diff --git a/app/example/mikroe_dcmotor3_tb6549fg/mikroe_dcmotor3_tb6549fg.slcp b/app/example/mikroe_dcmotor3_tb6549fg/mikroe_dcmotor3_tb6549fg.slcp
index 273a2fd9..b65df54e 100644
--- a/app/example/mikroe_dcmotor3_tb6549fg/mikroe_dcmotor3_tb6549fg.slcp
+++ b/app/example/mikroe_dcmotor3_tb6549fg/mikroe_dcmotor3_tb6549fg.slcp
@@ -44,7 +44,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_dcmotor3_tb6549fg/image/create_example.png
diff --git a/app/example/mikroe_e_paper_154_inch/mikroe_e_paper_154_inch.slcp b/app/example/mikroe_e_paper_154_inch/mikroe_e_paper_154_inch.slcp
index e690cf8c..ccf14950 100644
--- a/app/example/mikroe_e_paper_154_inch/mikroe_e_paper_154_inch.slcp
+++ b/app/example/mikroe_e_paper_154_inch/mikroe_e_paper_154_inch.slcp
@@ -34,7 +34,7 @@ define:
- name: DEBUG_EFM
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_e_paper_154_inch/image/hardware_connection.png
directory: image
diff --git a/app/example/mikroe_emg/mikroe_emg.slcp b/app/example/mikroe_emg/mikroe_emg.slcp
index e86721f7..8ca4ad33 100644
--- a/app/example/mikroe_emg/mikroe_emg.slcp
+++ b/app/example/mikroe_emg/mikroe_emg.slcp
@@ -41,7 +41,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_emg/image/create_example.png
diff --git a/app/example/mikroe_environment2_sht40_sgp40/mikroe_environment2_sht40_sgp40.slcp b/app/example/mikroe_environment2_sht40_sgp40/mikroe_environment2_sht40_sgp40.slcp
index 6dea0d8e..75ed1a9d 100644
--- a/app/example/mikroe_environment2_sht40_sgp40/mikroe_environment2_sht40_sgp40.slcp
+++ b/app/example/mikroe_environment2_sht40_sgp40/mikroe_environment2_sht40_sgp40.slcp
@@ -47,7 +47,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_environment2_sht40_sgp40/image/create_example.png
diff --git a/app/example/mikroe_environment3_bme688/mikroe_environment3_bme688_i2c.slcp b/app/example/mikroe_environment3_bme688/mikroe_environment3_bme688_i2c.slcp
index 8e34ee2c..c25b78fa 100644
--- a/app/example/mikroe_environment3_bme688/mikroe_environment3_bme688_i2c.slcp
+++ b/app/example/mikroe_environment3_bme688/mikroe_environment3_bme688_i2c.slcp
@@ -48,7 +48,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_environment3_bme688/image/create_example.png
diff --git a/app/example/mikroe_environment3_bme688/mikroe_environment3_bme688_spi.slcp b/app/example/mikroe_environment3_bme688/mikroe_environment3_bme688_spi.slcp
index 8e03e153..a216f335 100644
--- a/app/example/mikroe_environment3_bme688/mikroe_environment3_bme688_spi.slcp
+++ b/app/example/mikroe_environment3_bme688/mikroe_environment3_bme688_spi.slcp
@@ -48,7 +48,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_environment3_bme688/image/create_example.png
diff --git a/app/example/mikroe_eth_wiz_w5500/mikroe_eth_wiz_w5500.slcp b/app/example/mikroe_eth_wiz_w5500/mikroe_eth_wiz_w5500.slcp
index 8f7c361f..d28c62ef 100644
--- a/app/example/mikroe_eth_wiz_w5500/mikroe_eth_wiz_w5500.slcp
+++ b/app/example/mikroe_eth_wiz_w5500/mikroe_eth_wiz_w5500.slcp
@@ -44,7 +44,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_eth_wiz_w5500/image/board.png
diff --git a/app/example/mikroe_fingerprint2_a172mrq/mikroe_fingerprint2_a172mrq.slcp b/app/example/mikroe_fingerprint2_a172mrq/mikroe_fingerprint2_a172mrq.slcp
index 099353f6..68c4b8e2 100644
--- a/app/example/mikroe_fingerprint2_a172mrq/mikroe_fingerprint2_a172mrq.slcp
+++ b/app/example/mikroe_fingerprint2_a172mrq/mikroe_fingerprint2_a172mrq.slcp
@@ -44,7 +44,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_fingerprint2_a172mrq/image/hardware_connection.png
diff --git a/app/example/mikroe_force3_fsr400/mikroe_force3_fsr400.slcp b/app/example/mikroe_force3_fsr400/mikroe_force3_fsr400.slcp
index 2dbd8542..b6ce3244 100644
--- a/app/example/mikroe_force3_fsr400/mikroe_force3_fsr400.slcp
+++ b/app/example/mikroe_force3_fsr400/mikroe_force3_fsr400.slcp
@@ -47,7 +47,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_force3_fsr400/image/create_example.png
diff --git a/app/example/mikroe_gps_lea6s/mikroe_gps_lea6s.slcp b/app/example/mikroe_gps_lea6s/mikroe_gps_lea6s.slcp
index 0f194691..5d853317 100644
--- a/app/example/mikroe_gps_lea6s/mikroe_gps_lea6s.slcp
+++ b/app/example/mikroe_gps_lea6s/mikroe_gps_lea6s.slcp
@@ -49,7 +49,7 @@ toolchain_settings:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_gps_lea6s/image/create_example.png
diff --git a/app/example/mikroe_heartrate2_maxm86161/mikroe_heartrate2_maxm86161.slcp b/app/example/mikroe_heartrate2_maxm86161/mikroe_heartrate2_maxm86161.slcp
index 25491b2d..16564d6d 100644
--- a/app/example/mikroe_heartrate2_maxm86161/mikroe_heartrate2_maxm86161.slcp
+++ b/app/example/mikroe_heartrate2_maxm86161/mikroe_heartrate2_maxm86161.slcp
@@ -43,7 +43,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_heartrate2_maxm86161/image/create_example.png
diff --git a/app/example/mikroe_heartrate4_max30101/mikroe_heartrate4_max30101.slcp b/app/example/mikroe_heartrate4_max30101/mikroe_heartrate4_max30101.slcp
index c7aabc1c..140cffa9 100644
--- a/app/example/mikroe_heartrate4_max30101/mikroe_heartrate4_max30101.slcp
+++ b/app/example/mikroe_heartrate4_max30101/mikroe_heartrate4_max30101.slcp
@@ -54,7 +54,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
ui_hints:
highlight:
diff --git a/app/example/mikroe_hvac_bundle_scd41_sps30/mikroe_hvac_bundle_scd41_sps30.slcp b/app/example/mikroe_hvac_bundle_scd41_sps30/mikroe_hvac_bundle_scd41_sps30.slcp
index 023a7031..6e16a616 100644
--- a/app/example/mikroe_hvac_bundle_scd41_sps30/mikroe_hvac_bundle_scd41_sps30.slcp
+++ b/app/example/mikroe_hvac_bundle_scd41_sps30/mikroe_hvac_bundle_scd41_sps30.slcp
@@ -58,7 +58,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
ui_hints:
highlight:
diff --git a/app/example/mikroe_hvac_scd41/mikroe_hvac_scd41.slcp b/app/example/mikroe_hvac_scd41/mikroe_hvac_scd41.slcp
index 8f8282a5..9c2f40b8 100644
--- a/app/example/mikroe_hvac_scd41/mikroe_hvac_scd41.slcp
+++ b/app/example/mikroe_hvac_scd41/mikroe_hvac_scd41.slcp
@@ -46,7 +46,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_hvac_scd41/image/create_example.png
diff --git a/app/example/mikroe_irthermo3_mlx90632/mikroe_irthermo3_mlx90632.slcp b/app/example/mikroe_irthermo3_mlx90632/mikroe_irthermo3_mlx90632.slcp
index 327989ba..fd95b55e 100644
--- a/app/example/mikroe_irthermo3_mlx90632/mikroe_irthermo3_mlx90632.slcp
+++ b/app/example/mikroe_irthermo3_mlx90632/mikroe_irthermo3_mlx90632.slcp
@@ -59,7 +59,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
ui_hints:
highlight:
diff --git a/app/example/mikroe_lte_iot2_bg96/mikroe_lte_iot2_bg96.slcp b/app/example/mikroe_lte_iot2_bg96/mikroe_lte_iot2_bg96.slcp
index 9a39bd89..a0eaf84d 100644
--- a/app/example/mikroe_lte_iot2_bg96/mikroe_lte_iot2_bg96.slcp
+++ b/app/example/mikroe_lte_iot2_bg96/mikroe_lte_iot2_bg96.slcp
@@ -45,7 +45,7 @@ toolchain_settings:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_lte_iot2_bg96/image/create_example.png
diff --git a/app/example/mikroe_mic2/mikroe_mic2.slcp b/app/example/mikroe_mic2/mikroe_mic2.slcp
index 5600aae2..6f46fbde 100644
--- a/app/example/mikroe_mic2/mikroe_mic2.slcp
+++ b/app/example/mikroe_mic2/mikroe_mic2.slcp
@@ -45,7 +45,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_mic2/image/create_example.png
diff --git a/app/example/mikroe_microsd/mikroe_microsd.slcp b/app/example/mikroe_microsd/mikroe_microsd.slcp
index ff4f9f19..b0b2f853 100644
--- a/app/example/mikroe_microsd/mikroe_microsd.slcp
+++ b/app/example/mikroe_microsd/mikroe_microsd.slcp
@@ -38,7 +38,7 @@ define:
- name: DEBUG_EFM
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_microsd/image/create_example.png
directory: image
diff --git a/app/example/mikroe_nfc2_pn7150/mikroe_nfc2_pn7150.slcp b/app/example/mikroe_nfc2_pn7150/mikroe_nfc2_pn7150.slcp
index fcdc1c21..743442ab 100644
--- a/app/example/mikroe_nfc2_pn7150/mikroe_nfc2_pn7150.slcp
+++ b/app/example/mikroe_nfc2_pn7150/mikroe_nfc2_pn7150.slcp
@@ -36,7 +36,7 @@ define:
- name: DEBUG_EFM
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_nfc2_pn7150/image/hardware_connection.png
directory: image
diff --git a/app/example/mikroe_nfc2_pn7150_nci_t2t_read/pn7150_nci_t2t_read.slcp b/app/example/mikroe_nfc2_pn7150_nci_t2t_read/pn7150_nci_t2t_read.slcp
index 6893d9b7..54d11e5c 100644
--- a/app/example/mikroe_nfc2_pn7150_nci_t2t_read/pn7150_nci_t2t_read.slcp
+++ b/app/example/mikroe_nfc2_pn7150_nci_t2t_read/pn7150_nci_t2t_read.slcp
@@ -48,7 +48,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_nfc2_pn7150_nci_t2t_read/image/hardware_connection.png
diff --git a/app/example/mikroe_nfc2_pn7150_nci_t2t_write/pn7150_nci_t2t_write.slcp b/app/example/mikroe_nfc2_pn7150_nci_t2t_write/pn7150_nci_t2t_write.slcp
index 52fdb902..3684da90 100644
--- a/app/example/mikroe_nfc2_pn7150_nci_t2t_write/pn7150_nci_t2t_write.slcp
+++ b/app/example/mikroe_nfc2_pn7150_nci_t2t_write/pn7150_nci_t2t_write.slcp
@@ -50,7 +50,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_nfc2_pn7150_nci_t2t_write/image/hardware_connection.png
diff --git a/app/example/mikroe_nfctag2_nt3h2111/mikroe_nfctag2_nt3h2111.slcp b/app/example/mikroe_nfctag2_nt3h2111/mikroe_nfctag2_nt3h2111.slcp
index f442a189..6fc753f2 100644
--- a/app/example/mikroe_nfctag2_nt3h2111/mikroe_nfctag2_nt3h2111.slcp
+++ b/app/example/mikroe_nfctag2_nt3h2111/mikroe_nfctag2_nt3h2111.slcp
@@ -35,7 +35,7 @@ define:
- name: DEBUG_EFM
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_nfctag2_nt3h2111/image/hardware_connection.png
directory: image
diff --git a/app/example/mikroe_obdii_stn1110/mikroe_obdii_stn1110.slcp b/app/example/mikroe_obdii_stn1110/mikroe_obdii_stn1110.slcp
index f76a758b..64c3e84d 100644
--- a/app/example/mikroe_obdii_stn1110/mikroe_obdii_stn1110.slcp
+++ b/app/example/mikroe_obdii_stn1110/mikroe_obdii_stn1110.slcp
@@ -44,7 +44,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_obdii_stn1110/image/hardware_connection.png
diff --git a/app/example/mikroe_oledc_ssd1351/mikroe_oledc_ssd1351.slcp b/app/example/mikroe_oledc_ssd1351/mikroe_oledc_ssd1351.slcp
index 13f25f94..c30b999c 100644
--- a/app/example/mikroe_oledc_ssd1351/mikroe_oledc_ssd1351.slcp
+++ b/app/example/mikroe_oledc_ssd1351/mikroe_oledc_ssd1351.slcp
@@ -39,7 +39,7 @@ define:
- name: DEBUG_EFM
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_oledc_ssd1351/image/hardware_connection.png
directory: "image"
diff --git a/app/example/mikroe_oledw_ssd1306/mikroe_oledw_ssd1306.slcp b/app/example/mikroe_oledw_ssd1306/mikroe_oledw_ssd1306.slcp
index ccef27fb..733c65dd 100644
--- a/app/example/mikroe_oledw_ssd1306/mikroe_oledw_ssd1306.slcp
+++ b/app/example/mikroe_oledw_ssd1306/mikroe_oledw_ssd1306.slcp
@@ -43,7 +43,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_oledw_ssd1306/image/hardware_connection.png
diff --git a/app/example/mikroe_oledw_ssd1306_glib/mikroe_oledw_ssd1306_glib.slcp b/app/example/mikroe_oledw_ssd1306_glib/mikroe_oledw_ssd1306_glib.slcp
index 04132878..2b6ff5ef 100644
--- a/app/example/mikroe_oledw_ssd1306_glib/mikroe_oledw_ssd1306_glib.slcp
+++ b/app/example/mikroe_oledw_ssd1306_glib/mikroe_oledw_ssd1306_glib.slcp
@@ -46,7 +46,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_oledw_ssd1306_glib/image/hardware_connection.png
diff --git a/app/example/mikroe_ozone2_mq131/mikroe_ozone2_mq131.slcp b/app/example/mikroe_ozone2_mq131/mikroe_ozone2_mq131.slcp
index 986e21b8..709ad12d 100644
--- a/app/example/mikroe_ozone2_mq131/mikroe_ozone2_mq131.slcp
+++ b/app/example/mikroe_ozone2_mq131/mikroe_ozone2_mq131.slcp
@@ -43,7 +43,7 @@ configuration:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_ozone2_mq131/images/create_example.png
diff --git a/app/example/mikroe_pir_pl_n823_01/mikroe_pir_pl_n823_01.slcp b/app/example/mikroe_pir_pl_n823_01/mikroe_pir_pl_n823_01.slcp
index 856259c6..62c009ba 100644
--- a/app/example/mikroe_pir_pl_n823_01/mikroe_pir_pl_n823_01.slcp
+++ b/app/example/mikroe_pir_pl_n823_01/mikroe_pir_pl_n823_01.slcp
@@ -45,7 +45,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_pir_pl_n823_01/image/create_project.png
diff --git a/app/example/mikroe_pressure3_dps310/mikroe_pressure3_dps310_i2c.slcp b/app/example/mikroe_pressure3_dps310/mikroe_pressure3_dps310_i2c.slcp
index 5bbd0749..c5973536 100644
--- a/app/example/mikroe_pressure3_dps310/mikroe_pressure3_dps310_i2c.slcp
+++ b/app/example/mikroe_pressure3_dps310/mikroe_pressure3_dps310_i2c.slcp
@@ -41,7 +41,7 @@ define:
- name: DEBUG_EFM
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_pressure3_dps310/image/create_example.png
directory: "image"
diff --git a/app/example/mikroe_pressure3_dps310/mikroe_pressure3_dps310_spi.slcp b/app/example/mikroe_pressure3_dps310/mikroe_pressure3_dps310_spi.slcp
index aa499e81..fc27b03e 100644
--- a/app/example/mikroe_pressure3_dps310/mikroe_pressure3_dps310_spi.slcp
+++ b/app/example/mikroe_pressure3_dps310/mikroe_pressure3_dps310_spi.slcp
@@ -41,7 +41,7 @@ define:
- name: DEBUG_EFM
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
configuration:
- name: SL_SPIDRV_MIKROE_CS_CONTROL
value: "spidrvCsControlApplication"
diff --git a/app/example/mikroe_pwm_driver_si8711cc/mikroe_pwm_driver_si8711cc.slcp b/app/example/mikroe_pwm_driver_si8711cc/mikroe_pwm_driver_si8711cc.slcp
index 76488dca..c1377399 100644
--- a/app/example/mikroe_pwm_driver_si8711cc/mikroe_pwm_driver_si8711cc.slcp
+++ b/app/example/mikroe_pwm_driver_si8711cc/mikroe_pwm_driver_si8711cc.slcp
@@ -34,7 +34,7 @@ component:
from: third_party_hw_drivers
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_pwm_driver_si8711cc/image/create_example.png
directory: "image"
diff --git a/app/example/mikroe_radar_mm5d91_00/mikroe_radar_mm5d91_00.slcp b/app/example/mikroe_radar_mm5d91_00/mikroe_radar_mm5d91_00.slcp
index e6bc11a7..b0d27397 100644
--- a/app/example/mikroe_radar_mm5d91_00/mikroe_radar_mm5d91_00.slcp
+++ b/app/example/mikroe_radar_mm5d91_00/mikroe_radar_mm5d91_00.slcp
@@ -48,7 +48,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_radar_mm5d91_00/image/hardware_connection.png
diff --git a/app/example/mikroe_relay2_lca717/mikroe_relay2_lca717.slcp b/app/example/mikroe_relay2_lca717/mikroe_relay2_lca717.slcp
index 74d8df97..ba0de9cd 100644
--- a/app/example/mikroe_relay2_lca717/mikroe_relay2_lca717.slcp
+++ b/app/example/mikroe_relay2_lca717/mikroe_relay2_lca717.slcp
@@ -38,7 +38,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_relay2_lca717/image/hardware_connection.png
diff --git a/app/example/mikroe_rf_meter_ad8318/mikroe_rf_meter_ad8318.slcp b/app/example/mikroe_rf_meter_ad8318/mikroe_rf_meter_ad8318.slcp
index 44e35b98..96caf4f8 100644
--- a/app/example/mikroe_rf_meter_ad8318/mikroe_rf_meter_ad8318.slcp
+++ b/app/example/mikroe_rf_meter_ad8318/mikroe_rf_meter_ad8318.slcp
@@ -47,7 +47,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_rf_meter_ad8318/image/create_example.png
diff --git a/app/example/mikroe_rng/mikroe_rng.slcp b/app/example/mikroe_rng/mikroe_rng.slcp
index ed77bc58..cb3515e3 100644
--- a/app/example/mikroe_rng/mikroe_rng.slcp
+++ b/app/example/mikroe_rng/mikroe_rng.slcp
@@ -47,7 +47,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_rng/image/create_example.png
diff --git a/app/example/mikroe_rtc10_ds3231m/mikroe_rtc10_ds3231m.slcp b/app/example/mikroe_rtc10_ds3231m/mikroe_rtc10_ds3231m.slcp
index be7cdf3e..0c0f2b28 100644
--- a/app/example/mikroe_rtc10_ds3231m/mikroe_rtc10_ds3231m.slcp
+++ b/app/example/mikroe_rtc10_ds3231m/mikroe_rtc10_ds3231m.slcp
@@ -47,7 +47,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_rtc10_ds3231m/image/create_project.png
diff --git a/app/example/mikroe_servo_pca9685/mikroe_servo_pca9685.slcp b/app/example/mikroe_servo_pca9685/mikroe_servo_pca9685.slcp
index 559b7b5f..58413851 100644
--- a/app/example/mikroe_servo_pca9685/mikroe_servo_pca9685.slcp
+++ b/app/example/mikroe_servo_pca9685/mikroe_servo_pca9685.slcp
@@ -43,7 +43,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_servo_pca9685/image/create_project.png
diff --git a/app/example/mikroe_smoke2_adpd188bi/mikroe_smoke2_adpd188bi_i2c.slcp b/app/example/mikroe_smoke2_adpd188bi/mikroe_smoke2_adpd188bi_i2c.slcp
index 11ae4b44..787e8f9f 100644
--- a/app/example/mikroe_smoke2_adpd188bi/mikroe_smoke2_adpd188bi_i2c.slcp
+++ b/app/example/mikroe_smoke2_adpd188bi/mikroe_smoke2_adpd188bi_i2c.slcp
@@ -44,7 +44,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_smoke2_adpd188bi/image/create_example.png
diff --git a/app/example/mikroe_smoke2_adpd188bi/mikroe_smoke2_adpd188bi_spi.slcp b/app/example/mikroe_smoke2_adpd188bi/mikroe_smoke2_adpd188bi_spi.slcp
index 908cc885..faecdb7c 100644
--- a/app/example/mikroe_smoke2_adpd188bi/mikroe_smoke2_adpd188bi_spi.slcp
+++ b/app/example/mikroe_smoke2_adpd188bi/mikroe_smoke2_adpd188bi_spi.slcp
@@ -44,7 +44,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_smoke2_adpd188bi/image/create_example.png
diff --git a/app/example/mikroe_stepper2_a4988/mikroe_stepper2_a4988.slcp b/app/example/mikroe_stepper2_a4988/mikroe_stepper2_a4988.slcp
index 8d2fcb8e..c7014355 100644
--- a/app/example/mikroe_stepper2_a4988/mikroe_stepper2_a4988.slcp
+++ b/app/example/mikroe_stepper2_a4988/mikroe_stepper2_a4988.slcp
@@ -42,7 +42,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_stepper2_a4988/image/create_example.png
diff --git a/app/example/mikroe_stepper_a3967/mikroe_stepper_a3967.slcp b/app/example/mikroe_stepper_a3967/mikroe_stepper_a3967.slcp
index 7aad6836..d543526a 100644
--- a/app/example/mikroe_stepper_a3967/mikroe_stepper_a3967.slcp
+++ b/app/example/mikroe_stepper_a3967/mikroe_stepper_a3967.slcp
@@ -40,7 +40,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_stepper_a3967/image/create_example.png
diff --git a/app/example/mikroe_stretch/mikroe_stretch.slcp b/app/example/mikroe_stretch/mikroe_stretch.slcp
index 77b62143..398f60bf 100644
--- a/app/example/mikroe_stretch/mikroe_stretch.slcp
+++ b/app/example/mikroe_stretch/mikroe_stretch.slcp
@@ -41,7 +41,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_stretch/image/console_log.png
diff --git a/app/example/mikroe_temphum15_sht40/mikroe_temphum15_sht40.slcp b/app/example/mikroe_temphum15_sht40/mikroe_temphum15_sht40.slcp
index 84b5737e..f298a5d9 100644
--- a/app/example/mikroe_temphum15_sht40/mikroe_temphum15_sht40.slcp
+++ b/app/example/mikroe_temphum15_sht40/mikroe_temphum15_sht40.slcp
@@ -47,7 +47,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_temphum15_sht40/image/create_example.png
diff --git a/app/example/mikroe_temphum9_shtc3/mikroe_temphum9_shtc3.slcp b/app/example/mikroe_temphum9_shtc3/mikroe_temphum9_shtc3.slcp
index 130a55b8..02c1f421 100644
--- a/app/example/mikroe_temphum9_shtc3/mikroe_temphum9_shtc3.slcp
+++ b/app/example/mikroe_temphum9_shtc3/mikroe_temphum9_shtc3.slcp
@@ -47,7 +47,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_temphum9_shtc3/image/create_example.png
diff --git a/app/example/mikroe_thunder_as3935/mikroe_thunder_as3935.slcp b/app/example/mikroe_thunder_as3935/mikroe_thunder_as3935.slcp
index ec3c61a4..bed75201 100644
--- a/app/example/mikroe_thunder_as3935/mikroe_thunder_as3935.slcp
+++ b/app/example/mikroe_thunder_as3935/mikroe_thunder_as3935.slcp
@@ -43,7 +43,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_thunder_as3935/image/create_example.png
diff --git a/app/example/mikroe_turbidity_tsd10/mikroe_turbidity_tsd10.slcp b/app/example/mikroe_turbidity_tsd10/mikroe_turbidity_tsd10.slcp
index 22263e42..2652fa57 100644
--- a/app/example/mikroe_turbidity_tsd10/mikroe_turbidity_tsd10.slcp
+++ b/app/example/mikroe_turbidity_tsd10/mikroe_turbidity_tsd10.slcp
@@ -47,7 +47,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_turbidity_tsd10/image/create_example.png
diff --git a/app/example/mikroe_utm7segr_max6969/mikroe_utm7segr_max6969.slcp b/app/example/mikroe_utm7segr_max6969/mikroe_utm7segr_max6969.slcp
index 70ce4c3a..45b55f6d 100644
--- a/app/example/mikroe_utm7segr_max6969/mikroe_utm7segr_max6969.slcp
+++ b/app/example/mikroe_utm7segr_max6969/mikroe_utm7segr_max6969.slcp
@@ -42,7 +42,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_utm7segr_max6969/image/create_example.png
diff --git a/app/example/mikroe_uv_ml8511a/mikroe_uv_ml8511a.slcp b/app/example/mikroe_uv_ml8511a/mikroe_uv_ml8511a.slcp
index 19a337ee..dae19a69 100644
--- a/app/example/mikroe_uv_ml8511a/mikroe_uv_ml8511a.slcp
+++ b/app/example/mikroe_uv_ml8511a/mikroe_uv_ml8511a.slcp
@@ -39,7 +39,7 @@ define:
- name: DEBUG_EFM
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_uv_ml8511a/image/hardware_connection.png
directory: image
diff --git a/app/example/mikroe_uwb2_dwm3000/SimplicityStudio/mikroe_uwb2_dwm3000.slcp b/app/example/mikroe_uwb2_dwm3000/SimplicityStudio/mikroe_uwb2_dwm3000.slcp
new file mode 100644
index 00000000..fbafb3ba
--- /dev/null
+++ b/app/example/mikroe_uwb2_dwm3000/SimplicityStudio/mikroe_uwb2_dwm3000.slcp
@@ -0,0 +1,80 @@
+project_name: mikroe_uwb2_dwm3000
+package: platform
+label: Third Party Hardware Drivers - DWM3000 - UWB2 Click (Mikroe)
+description: This example project shows an example for DWM3000 - UWB2 Click (Mikroe).
+category: Example|Platform
+quality: evaluation
+
+filter:
+- name: Device Type
+ value: [SoC]
+- name: MCU
+ value: [32-bit MCU]
+- name: Project Difficulty
+ value: [Beginner]
+
+readme:
+- path: ../../../documentation/example/mikroe_uwb2_dwm3000/README.md
+
+source:
+- path: ../app_files/app.c
+ directory: app_files
+- path: ../app_files/config_options.c
+ directory: app_files
+- path: ../app_files/shared_functions.c
+ directory: app_files
+- path: ../main.c
+
+include:
+- path: ../app_files
+ file_list:
+ - path: app.h
+ - path: config_options.h
+ - path: shared_defines.h
+ - path: shared_functions.h
+ directory: app_files
+
+component:
+- id: device_init
+- id: sl_system
+- id: component_catalog
+- id: app_assert
+- id: app_log
+- instance: [vcom]
+ id: iostream_eusart
+- id: mikroe_uwb2_dwm3000
+ from: third_party_hw_drivers
+
+toolchain_settings:
+ - option: linkerfile
+ value: linkerfile.ld
+
+define:
+- name: DEBUG_EFM
+
+sdk_extension:
+- id: third_party_hw_drivers
+ version: 2.0.2
+
+other_file:
+ - path: ../linker_files/brd2703a/linkerfile.ld
+ condition: [brd2703a]
+ - path: ../linker_files/brd4108a/linkerfile.ld
+ condition: [brd4108a]
+ - path: ../linker_files/brd4314a/linkerfile.ld
+ condition: [brd4314a]
+ - path: ../../../documentation/example/mikroe_uwb2_dwm3000/image/create_example.png
+ directory: image
+ - path: ../../../documentation/example/mikroe_uwb2_dwm3000/image/hardware_connection.png
+ directory: image
+ - path: ../../../documentation/example/mikroe_uwb2_dwm3000/image/custom_linker.png
+ directory: image
+ - path: ../../../documentation/example/mikroe_uwb2_dwm3000/image/tx_log.png
+ directory: image
+ - path: ../../../documentation/example/mikroe_uwb2_dwm3000/image/rx_log.png
+ directory: image
+
+ui_hints:
+ highlight:
+ - path: README.md
+ focus: true
diff --git a/app/example/mikroe_uwb2_dwm3000/app_files/app.c b/app/example/mikroe_uwb2_dwm3000/app_files/app.c
new file mode 100644
index 00000000..91f9871d
--- /dev/null
+++ b/app/example/mikroe_uwb2_dwm3000/app_files/app.c
@@ -0,0 +1,273 @@
+/***************************************************************************//**
+ * @file
+ * @brief Top level application functions
+ *******************************************************************************
+ * # License
+ * Copyright 2020 Silicon Laboratories Inc. www.silabs.com
+ *******************************************************************************
+ *
+ * The licensor of this software is Silicon Laboratories Inc. Your use of this
+ * software is governed by the terms of Silicon Labs Master Software License
+ * Agreement (MSLA) available at
+ * www.silabs.com/about-us/legal/master-software-license-agreement. This
+ * software is distributed to you in Source Code format and is governed by the
+ * sections of the MSLA applicable to Source Code.
+ *
+ ******************************************************************************/
+
+/***************************************************************************//**
+ * Initialize application.
+ ******************************************************************************/
+#include "app.h"
+#include "em_gpio.h"
+#include "sl_system_init.h"
+#include "sl_event_handler.h"
+#include "port.h"
+#include "deca_probe_interface.h"
+#include "app_log.h"
+#include "shared_functions.h"
+#include "shared_defines.h"
+#include "string.h"
+#include "config_options.h"
+#include "sl_sleeptimer.h"
+
+// Comment out the line below in order to switch the application mode to
+// receiver
+#define DEMO_APP_TRANSMITTER
+
+/* Default communication configuration. We use default non-STS DW mode. */
+static dwt_config_t config = {
+ 5, /* Channel number. */
+ DWT_PLEN_128, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 9, /* TX preamble code. Used in TX only. */
+ 9, /* RX preamble code. Used in RX only. */
+ 1, /* 0 to use standard 8 symbol SFD, 1 to use non-standard 8
+ * symbol, 2 for non-standard 16 symbol SFD and 3 for 4z
+ * 8 symbol SDF type */
+ DWT_BR_6M8, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (129 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_OFF, /* No STS mode enabled (STS Mode 0). */
+ DWT_STS_LEN_64, /* STS length, see allowed values in Enum
+ * dwt_sts_lengths_e */
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+
+/* Index to access to sequence number of the blink frame in the tx_msg/rx_msg
+ * array. */
+#define BLINK_FRAME_SN_IDX 1
+
+#ifdef DEMO_APP_TRANSMITTER /* TX Side define*/
+
+/* The frame sent in this example is an 802.15.4e standard blink. It is a
+ * 12-byte frame composed of the following fields:
+ * - byte 0: frame type (0xC5 for a blink).
+ * - byte 1: sequence number, incremented for each new frame.
+ * - byte 2 -> end: message data
+ */
+static uint8_t tx_msg[] =
+{ 0xC5, 0, 'S', 'I', 'L', 'I', 'C', 'O', 'N', 'L', 'A', 'B', 'S', '\0' };
+
+/* The real length that is going to be transmitted */
+#define FRAME_LENGTH (sizeof(tx_msg) + FCS_LEN)
+
+/* Inter-frame delay period, in milliseconds. */
+#define TRANSMITTING_INTERVAL_MSEC 2000
+
+static sl_sleeptimer_timer_handle_t app_timer_handle;
+static volatile bool tx_trigger_process = false;
+void app_tx_timer_callback(sl_sleeptimer_timer_handle_t *handle, void *data);
+
+#endif
+
+#ifndef DEMO_APP_TRANSMITTER /* RX Side define*/
+
+#define RX_MSG_DATA_IDX 2
+
+/* Buffer to store received frame. See NOTE 1 below. */
+static uint8_t rx_buffer[FRAME_LEN_MAX];
+static uint8_t rx_msg[FRAME_LEN_MAX];
+static uint8_t frame_id;
+
+/* Hold copy of status register state here for reference so that it can be
+ * examined at a debug breakpoint. */
+static uint32_t status_reg;
+
+/* Hold copy of frame length of frame received (if good) so that it can be
+ * examined at a debug breakpoint. */
+static uint16_t frame_len;
+
+#endif
+
+void app_init(void)
+{
+ app_log("DWM3000 - UWB 2 Click Driver\r\n");
+
+#ifdef DEMO_APP_TRANSMITTER
+ app_log("Application Mode: Transmitter\r\n");
+#else
+ app_log("Application Mode: Receiver\r\n");
+#endif
+
+ port_init_dw_chip();
+ reset_DW3000();
+
+ if (dwt_probe((struct dwt_probe_s *)&dw3000_probe_interf)) {
+ app_log("DWM 3000 probe fail\r\n");
+ while (1) {}
+ }
+
+ /* This initialization is added to avoid crashing the board when calling APIs
+ * that writes inside local data
+ * like setxtaltrim */
+ if (dwt_initialise(DWT_DW_INIT) != DWT_SUCCESS) {
+ app_log("DWM 3000 init fail\r\n");
+ while (1) {}
+ }
+
+ uint32_t dev_id = dwt_readdevid();
+
+ /* Reads and validate device ID returns DWT_ERROR if it does not match
+ * expected else DWT_SUCCESS */
+ if (dwt_check_dev_id() == DWT_SUCCESS) {
+ app_log("DWM3000 dev id = 0x%lx\r\n", dev_id);
+ } else {
+ app_log("DWM3000 read dev id failed\r\n");
+ }
+
+ uint32_t part_id = dwt_getpartid();
+ app_log("DWM3000 part id = 0x%lx\r\n", part_id);
+
+ uint32_t lot_id = dwt_getlotid();
+ app_log("DWM3000 lot id = 0x%lx\r\n", lot_id);
+
+ uint8_t otprevision = dwt_otprevision();
+ app_log("DWM3000 otp revision = 0x%x\r\n", otprevision);
+
+ /* Enabling LEDs here for debug so that for each TX the D1 LED will flash on
+ * DW3000 red eval-shield boards. */
+ dwt_setleds(DWT_LEDS_ENABLE | DWT_LEDS_INIT_BLINK);
+
+ /* Configure DW IC. See NOTE 5 below. */
+
+ /* if the dwt_configure returns DWT_ERROR either the PLL or RX calibration has
+ * failed the host should reset the device */
+ if (dwt_configure(&config)) {
+ app_log("DWM3000 config failed\r\n");
+ while (1) {}
+ }
+
+#ifdef DEMO_APP_TRANSMITTER
+
+ /* Configure the TX spectrum parameters (power PG delay and PG Count) */
+ dwt_configuretxrf(&txconfig_options);
+
+ app_log("Start TX timer periodic = 0x%lx\r\n",
+ sl_sleeptimer_start_periodic_timer_ms(&app_timer_handle,
+ TRANSMITTING_INTERVAL_MSEC,
+ app_tx_timer_callback,
+ NULL,
+ 0,
+ 0));
+#endif
+}
+
+/***************************************************************************//**
+ * App ticking function.
+ ******************************************************************************/
+void app_process_action(void)
+{
+#ifdef DEMO_APP_TRANSMITTER /* TX Side */
+ if (tx_trigger_process) {
+ /* Write frame data to DW IC and prepare transmission. See NOTE 3 below.*/
+ dwt_writetxdata(FRAME_LENGTH - FCS_LEN, tx_msg, 0); /* Zero offset
+ * in TX
+ * buffer. */
+
+ /* In this example since the length of the transmitted frame does not
+ * change,
+ * nor the other parameters of the dwt_writetxfctrl function, the
+ * dwt_writetxfctrl call could be outside the main while(1) loop.
+ */
+ dwt_writetxfctrl(FRAME_LENGTH, 0, 0); /* Zero offset in TX buffer,
+ * no ranging. */
+
+ /* Start transmission. */
+ dwt_starttx(DWT_START_TX_IMMEDIATE);
+
+ /* Poll DW IC until TX frame sent event set. See NOTE 4 below.
+ * STATUS register is 4 bytes long but, as the event we are looking
+ * at is in the first byte of the register, we can use this simplest
+ * API function to access it.*/
+ waitforsysstatus(NULL, NULL, DWT_INT_TXFRS_BIT_MASK, 0);
+
+ /* Clear TX frame sent event. */
+ dwt_writesysstatuslo(DWT_INT_TXFRS_BIT_MASK);
+
+ app_log("TX Frame Sent #%d\r\n", tx_msg[BLINK_FRAME_SN_IDX]);
+
+ /* Increment the blink frame sequence number (modulo 256). */
+ tx_msg[BLINK_FRAME_SN_IDX]++;
+
+ tx_trigger_process = false;
+ }
+
+#else /* RX Side */
+
+ /* Clear local RX buffer to avoid having leftovers from previous receptions
+ * This is not necessary but is included here to aid reading
+ * the RX buffer.
+ * This is a good place to put a breakpoint. Here (after first time through
+ * the loop) the local status register will be set for last event
+ * and if a good receive has happened the data buffer will have the data in
+ * it, and frame_len will be set to the length of the RX frame. */
+ memset(rx_buffer, 0, sizeof(rx_buffer));
+ memset(rx_msg, 0, sizeof(rx_msg));
+
+ /* Activate reception immediately. See NOTE 2 below. */
+ dwt_rxenable(DWT_START_RX_IMMEDIATE);
+
+ /* Poll until a frame is properly received or an error/timeout occurs. See
+ * NOTE 3 below.
+ * STATUS register is 5 bytes long but, as the event we are looking at is in
+ * the first byte of the register, we can use this simplest API
+ * function to access it. */
+ waitforsysstatus(&status_reg, NULL,
+ (DWT_INT_RXFCG_BIT_MASK | SYS_STATUS_ALL_RX_ERR), 0);
+
+ if (status_reg & DWT_INT_RXFCG_BIT_MASK) {
+ /* A frame has been received, copy it to our local buffer. */
+ frame_len = dwt_getframelength();
+ if (frame_len <= FRAME_LEN_MAX) {
+ /* No need to read the FCS/CRC. */
+ dwt_readrxdata(rx_buffer, (frame_len - FCS_LEN), 0);
+ frame_id = *(rx_buffer + BLINK_FRAME_SN_IDX);
+ memcpy(rx_msg, (rx_buffer + RX_MSG_DATA_IDX),
+ (frame_len - FCS_LEN - RX_MSG_DATA_IDX));
+
+ app_log("Message received #%u: %s\r\n",
+ ( uint16_t ) frame_id, rx_msg);
+
+ /* Clear good RX frame event in the DW IC status register. */
+ dwt_writesysstatuslo(DWT_INT_RXFCG_BIT_MASK);
+ }
+ } else {
+ /* Clear RX error events in the DW IC status register. */
+ dwt_writesysstatuslo(SYS_STATUS_ALL_RX_ERR);
+ }
+#endif
+}
+
+#ifdef DEMO_APP_TRANSMITTER
+void app_tx_timer_callback(sl_sleeptimer_timer_handle_t *handle, void *data)
+{
+ (void) data;
+ (void) handle;
+
+ tx_trigger_process = true;
+}
+
+#endif
diff --git a/app/example/mikroe_uwb2_dwm3000/app_files/app.h b/app/example/mikroe_uwb2_dwm3000/app_files/app.h
new file mode 100644
index 00000000..efa2fd7a
--- /dev/null
+++ b/app/example/mikroe_uwb2_dwm3000/app_files/app.h
@@ -0,0 +1,31 @@
+/***************************************************************************//**
+ * @file
+ * @brief Top level application functions
+ *******************************************************************************
+ * # License
+ * Copyright 2024 Silicon Laboratories Inc. www.silabs.com
+ *******************************************************************************
+ *
+ * The licensor of this software is Silicon Laboratories Inc. Your use of this
+ * software is governed by the terms of Silicon Labs Master Software License
+ * Agreement (MSLA) available at
+ * www.silabs.com/about-us/legal/master-software-license-agreement. This
+ * software is distributed to you in Source Code format and is governed by the
+ * sections of the MSLA applicable to Source Code.
+ *
+ ******************************************************************************/
+
+#ifndef APP_H
+#define APP_H
+
+/***************************************************************************//**
+ * Initialize application.
+ ******************************************************************************/
+void app_init(void);
+
+/***************************************************************************//**
+ * App ticking function.
+ ******************************************************************************/
+void app_process_action(void);
+
+#endif // APP_H
diff --git a/app/example/mikroe_uwb2_dwm3000/app_files/config_options.c b/app/example/mikroe_uwb2_dwm3000/app_files/config_options.c
new file mode 100644
index 00000000..6bf6d327
--- /dev/null
+++ b/app/example/mikroe_uwb2_dwm3000/app_files/config_options.c
@@ -0,0 +1,951 @@
+/*! ----------------------------------------------------------------------------
+ * @file config_options.c
+ * @brief Configuration options are defined here.
+ *
+ * @attention
+ *
+ * Copyright 2019 - 2021 (c) Decawave Ltd, Dublin, Ireland.
+ *
+ * All rights reserved.
+ *
+ */
+
+#include "config_options.h"
+
+/* String used to display measured distance on LCD screen (16 characters
+ * maximum). */
+char dist_str[16] = { 0 };
+
+/*
+ * TX Power Configuration Settings
+ */
+/* Values for the PG_DELAY and TX_POWER registers reflect the bandwidth and
+ * power of the spectrum at the current
+ * temperature. These values can be calibrated prior to taking reference
+ * measurements. */
+dwt_txconfig_t txconfig_options = {
+ 0x34, /* PG delay. */
+ 0xfdfdfdfd, /* TX power. */
+ 0x0 /*PG count*/
+};
+
+dwt_txconfig_t txconfig_options_ch9 = {
+ 0x34, /* PG delay. */
+ 0xfefefefe, /* TX power. */
+ 0x0 /*PG count*/
+};
+
+/*
+ * Configuration options for the following parameters:
+ * Channel: 5, 9
+ * PRF: 64
+ * Preamble Length: 64, 128, 512, 1024
+ * Preamble Code: 3/4 for 16MHz PRf, 9/10/11/12 for 64MHz PRF
+ * Data Rate: 0.85, 6.8
+ * STS: Length 64
+ */
+
+#ifdef CONFIG_OPTION_01
+
+/* Configuration option 01.
+ * Channel 5, PRF 64M, Preamble Length 64, PAC 8, Preamble code 9, Data Rate
+ * 850k, STS Length 64
+ */
+dwt_config_t config_options = {
+ 5, /* Channel number. */
+ DWT_PLEN_64, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 9, /* TX preamble code. Used in TX only. */
+ 9, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard 8
+ * symbol, 2 for non-standard 16 symbol SFD and 3 for 4z
+ * 8 symbol SDF type */
+ DWT_BR_850K, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (64 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_02
+
+/* Configuration option 02.
+ * Channel 9, PRF 64M, Preamble Length 64, PAC 8, Preamble code 9, Data Rate
+ * 850k, STS Length 64
+ */
+dwt_config_t config_options = {
+ 9, /* Channel number. */
+ DWT_PLEN_64, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 9, /* TX preamble code. Used in TX only. */
+ 9, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard 8
+ * symbol, 2 for non-standard 16 symbol SFD and 3 for 4z
+ * 8 symbol SDF type */
+ DWT_BR_850K, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (64 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_03
+
+/* Configuration option 03.
+ * Channel 5, PRF 64M, Preamble Length 128, PAC 8, Preamble code 9, Data Rate
+ * 850k, STS Length 64
+ */
+dwt_config_t config_options = {
+ 5, /* Channel number. */
+ DWT_PLEN_128, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 9, /* TX preamble code. Used in TX only. */
+ 9, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3 for
+ * 4z 8 symbol SDF type */
+ DWT_BR_850K, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (128 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_04
+
+/* Configuration option 04.
+ * Channel 9, PRF 64M, Preamble Length 128, PAC 8, Preamble code 9, Data Rate
+ * 850k, STS Length 64
+ */
+dwt_config_t config_options = {
+ 9, /* Channel number. */
+ DWT_PLEN_128, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 9, /* TX preamble code. Used in TX only. */
+ 9, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3 for
+ * 4z 8 symbol SDF type */
+ DWT_BR_850K, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (128 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_05
+
+/* Configuration option 05.
+ * Channel 5, PRF 64M, Preamble Length 512, PAC 8, Preamble code 9, Data Rate
+ * 850k, STS Length 64
+ */
+dwt_config_t config_options = {
+ 5, /* Channel number. */
+ DWT_PLEN_512, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 9, /* TX preamble code. Used in TX only. */
+ 9, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3 for
+ * 4z 8 symbol SDF type */
+ DWT_BR_850K, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (512 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_06
+
+/* Configuration option 06.
+ * Channel 9, PRF 64M, Preamble Length 512, PAC 8, Preamble code 9, Data Rate
+ * 850k, STS Length 64
+ */
+dwt_config_t config_options = {
+ 9, /* Channel number. */
+ DWT_PLEN_512, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 9, /* TX preamble code. Used in TX only. */
+ 9, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3 for
+ * 4z 8 symbol SDF type */
+ DWT_BR_850K, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (512 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_07
+
+/* Configuration option 07.
+ * Channel 5, PRF 64M, Preamble Length 1024, PAC 8, Preamble code 9, Data Rate
+ * 850k, STS Length 64
+ */
+dwt_config_t config_options = {
+ 5, /* Channel number. */
+ DWT_PLEN_1024, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 9, /* TX preamble code. Used in TX only. */
+ 9, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3
+ * for 4z 8 symbol SDF type */
+ DWT_BR_850K, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (1024 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_08
+
+/* Configuration option 08.
+ * Channel 9, PRF 64M, Preamble Length 1024, PAC 8, Preamble code 9, Data Rate
+ * 850k, STS Length 64
+ */
+dwt_config_t config_options = {
+ 9, /* Channel number. */
+ DWT_PLEN_1024, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 9, /* TX preamble code. Used in TX only. */
+ 9, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3
+ * for 4z 8 symbol SDF type */
+ DWT_BR_850K, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (1024 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_09
+
+/* Configuration option 09.
+ * Channel 5, PRF 64M, Preamble Length 64, PAC 8, Preamble code 10, Data Rate
+ * 850k, STS Length 64
+ */
+dwt_config_t config_options = {
+ 5, /* Channel number. */
+ DWT_PLEN_64, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 10, /* TX preamble code. Used in TX only. */
+ 10, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard 8
+ * symbol, 2 for non-standard 16 symbol SFD and 3 for 4z
+ * 8 symbol SDF type */
+ DWT_BR_850K, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (64 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_10
+
+/* Configuration option 10.
+ * Channel 9, PRF 64M, Preamble Length 64, PAC 8, Preamble code 10, Data Rate
+ * 850k, STS Length 64
+ */
+dwt_config_t config_options = {
+ 9, /* Channel number. */
+ DWT_PLEN_64, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 10, /* TX preamble code. Used in TX only. */
+ 10, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard 8
+ * symbol, 2 for non-standard 16 symbol SFD and 3 for 4z
+ * 8 symbol SDF type */
+ DWT_BR_850K, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (64 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_11
+
+/* Configuration option 11.
+ * Channel 5, PRF 64M, Preamble Length 128, PAC 8, Preamble code 10, Data Rate
+ * 850k, STS Length 64
+ */
+dwt_config_t config_options = {
+ 5, /* Channel number. */
+ DWT_PLEN_128, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 10, /* TX preamble code. Used in TX only. */
+ 10, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3 for
+ * 4z 8 symbol SDF type */
+ DWT_BR_850K, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (128 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_12
+
+/* Configuration option 12.
+ * Channel 9, PRF 64M, Preamble Length 128, PAC 8, Preamble code 10, Data Rate
+ * 850k, STS Length 64
+ */
+dwt_config_t config_options = {
+ 9, /* Channel number. */
+ DWT_PLEN_128, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 10, /* TX preamble code. Used in TX only. */
+ 10, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3 for
+ * 4z 8 symbol SDF type */
+ DWT_BR_850K, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (128 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_13
+
+/* Configuration option 13.
+ * Channel 5, PRF 64M, Preamble Length 512, PAC 8, Preamble code 10, Data Rate
+ * 850k, STS Length 64
+ */
+dwt_config_t config_options = {
+ 5, /* Channel number. */
+ DWT_PLEN_512, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 10, /* TX preamble code. Used in TX only. */
+ 10, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3 for
+ * 4z 8 symbol SDF type */
+ DWT_BR_850K, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (512 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_14
+
+/* Configuration option 14.
+ * Channel 9, PRF 64M, Preamble Length 512, PAC 8, Preamble code 10, Data Rate
+ * 850k, STS Length 64
+ */
+dwt_config_t config_options = {
+ 9, /* Channel number. */
+ DWT_PLEN_512, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 10, /* TX preamble code. Used in TX only. */
+ 10, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3 for
+ * 4z 8 symbol SDF type */
+ DWT_BR_850K, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (512 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_15
+
+/* Configuration option 15.
+ * Channel 5, PRF 64M, Preamble Length 1024, PAC 8, Preamble code 10, Data Rate
+ * 850k, STS Length 64
+ */
+dwt_config_t config_options = {
+ 5, /* Channel number. */
+ DWT_PLEN_1024, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 10, /* TX preamble code. Used in TX only. */
+ 10, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3
+ * for 4z 8 symbol SDF type */
+ DWT_BR_850K, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (1024 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_16
+
+/* Configuration option 16.
+ * Channel 9, PRF 64M, Preamble Length 1024, PAC 8, Preamble code 10, Data Rate
+ * 850k, STS Length 64
+ */
+dwt_config_t config_options = {
+ 9, /* Channel number. */
+ DWT_PLEN_1024, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 10, /* TX preamble code. Used in TX only. */
+ 10, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3
+ * for 4z 8 symbol SDF type */
+ DWT_BR_850K, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (1024 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_17
+
+/* Configuration option 17.
+ * Channel 5, PRF 64M, Preamble Length 64, PAC 8, Preamble code 9, Data Rate
+ * 6.8M, STS Length 64
+ */
+dwt_config_t config_options = {
+ 5, /* Channel number. */
+ DWT_PLEN_64, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 9, /* TX preamble code. Used in TX only. */
+ 9, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard 8
+ * symbol, 2 for non-standard 16 symbol SFD and 3 for 4z
+ * 8 symbol SDF type */
+ DWT_BR_6M8, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (64 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_18
+
+/* Configuration option 18.
+ * Channel 9, PRF 64M, Preamble Length 64, PAC 8, Preamble code 9, Data Rate
+ * 6.8M, STS Length 64
+ */
+dwt_config_t config_options = {
+ 9, /* Channel number. */
+ DWT_PLEN_64, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 9, /* TX preamble code. Used in TX only. */
+ 9, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard 8
+ * symbol, 2 for non-standard 16 symbol SFD and 3 for 4z
+ * 8 symbol SDF type */
+ DWT_BR_6M8, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (64 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_19
+
+/* Configuration option 19.
+ * Channel 5, PRF 64M, Preamble Length 128, PAC 8, Preamble code 9, Data Rate
+ * 6.8M, STS Length 64
+ */
+dwt_config_t config_options = {
+ 5, /* Channel number. */
+ DWT_PLEN_128, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 9, /* TX preamble code. Used in TX only. */
+ 9, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3 for
+ * 4z 8 symbol SDF type */
+ DWT_BR_6M8, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (128 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_20
+
+/* Configuration option 20.
+ * Channel 9, PRF 64M, Preamble Length 128, PAC 8, Preamble code 9, Data Rate
+ * 6.8M, STS Length 64
+ */
+dwt_config_t config_options = {
+ 9, /* Channel number. */
+ DWT_PLEN_128, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 9, /* TX preamble code. Used in TX only. */
+ 9, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3 for
+ * 4z 8 symbol SDF type */
+ DWT_BR_6M8, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (128 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_21
+
+/* Configuration option 21.
+ * Channel 5, PRF 64M, Preamble Length 512, PAC 8, Preamble code 9, Data Rate
+ * 850k, STS Length 64
+ */
+dwt_config_t config_options = {
+ 5, /* Channel number. */
+ DWT_PLEN_512, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 9, /* TX preamble code. Used in TX only. */
+ 9, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3 for
+ * 4z 8 symbol SDF type */
+ DWT_BR_6M8, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (512 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_22
+
+/* Configuration option 22.
+ * Channel 9, PRF 64M, Preamble Length 512, PAC 8, Preamble code 9, Data Rate
+ * 6.8M, STS Length 64
+ */
+dwt_config_t config_options = {
+ 9, /* Channel number. */
+ DWT_PLEN_512, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 9, /* TX preamble code. Used in TX only. */
+ 9, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3 for
+ * 4z 8 symbol SDF type */
+ DWT_BR_6M8, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (512 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_23
+
+/* Configuration option 23.
+ * Channel 5, PRF 64M, Preamble Length 1024, PAC 8, Preamble code 9, Data Rate
+ * 6.8M, STS Length 64
+ */
+dwt_config_t config_options = {
+ 5, /* Channel number. */
+ DWT_PLEN_1024, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 9, /* TX preamble code. Used in TX only. */
+ 9, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3
+ * for 4z 8 symbol SDF type */
+ DWT_BR_6M8, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (1024 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_24
+
+/* Configuration option 24.
+ * Channel 9, PRF 64M, Preamble Length 1024, PAC 8, Preamble code 9, Data Rate
+ * 6.8M, STS Length 64
+ */
+dwt_config_t config_options = {
+ 9, /* Channel number. */
+ DWT_PLEN_1024, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 9, /* TX preamble code. Used in TX only. */
+ 9, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3
+ * for 4z 8 symbol SDF type */
+ DWT_BR_6M8, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (1024 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_25
+
+/* Configuration option 25.
+ * Channel 5, PRF 64M, Preamble Length 64, PAC 8, Preamble code 10, Data Rate
+ * 6.8M, STS Length 64
+ */
+dwt_config_t config_options = {
+ 5, /* Channel number. */
+ DWT_PLEN_64, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 10, /* TX preamble code. Used in TX only. */
+ 10, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard 8
+ * symbol, 2 for non-standard 16 symbol SFD and 3 for 4z
+ * 8 symbol SDF type */
+ DWT_BR_6M8, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (64 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_26
+
+/* Configuration option 26.
+ * Channel 9, PRF 64M, Preamble Length 64, PAC 8, Preamble code 10, Data Rate
+ * 6.8M, STS Length 64
+ */
+dwt_config_t config_options = {
+ 9, /* Channel number. */
+ DWT_PLEN_64, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 10, /* TX preamble code. Used in TX only. */
+ 10, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard 8
+ * symbol, 2 for non-standard 16 symbol SFD and 3 for 4z
+ * 8 symbol SDF type */
+ DWT_BR_6M8, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (64 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_27
+
+/* Configuration option 27.
+ * Channel 5, PRF 64M, Preamble Length 128, PAC 8, Preamble code 10, Data Rate
+ * 6.8M, STS Length 64
+ */
+dwt_config_t config_options = {
+ 5, /* Channel number. */
+ DWT_PLEN_128, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 10, /* TX preamble code. Used in TX only. */
+ 10, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3 for
+ * 4z 8 symbol SDF type */
+ DWT_BR_6M8, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (128 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_28
+
+/* Configuration option 28.
+ * Channel 9, PRF 64M, Preamble Length 128, PAC 8, Preamble code 10, Data Rate
+ * 6.8M, STS Length 64
+ */
+dwt_config_t config_options = {
+ 9, /* Channel number. */
+ DWT_PLEN_128, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 10, /* TX preamble code. Used in TX only. */
+ 10, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3 for
+ * 4z 8 symbol SDF type */
+ DWT_BR_6M8, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (128 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_29
+
+/* Configuration option 29.
+ * Channel 5, PRF 64M, Preamble Length 512, PAC 8, Preamble code 10, Data Rate
+ * 6.8M, STS Length 64
+ */
+dwt_config_t config_options = {
+ 5, /* Channel number. */
+ DWT_PLEN_512, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 10, /* TX preamble code. Used in TX only. */
+ 10, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3 for
+ * 4z 8 symbol SDF type */
+ DWT_BR_6M8, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (512 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_30
+
+/* Configuration option 30.
+ * Channel 9, PRF 64M, Preamble Length 512, PAC 8, Preamble code 10, Data Rate
+ * 6.8M, STS Length 64
+ */
+dwt_config_t config_options = {
+ 9, /* Channel number. */
+ DWT_PLEN_512, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 10, /* TX preamble code. Used in TX only. */
+ 10, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3 for
+ * 4z 8 symbol SDF type */
+ DWT_BR_6M8, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (512 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_31
+
+/* Configuration option 31.
+ * Channel 5, PRF 64M, Preamble Length 1024, PAC 8, Preamble code 10, Data Rate
+ * 6.8M, STS Length 64
+ */
+dwt_config_t config_options = {
+ 5, /* Channel number. */
+ DWT_PLEN_1024, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 10, /* TX preamble code. Used in TX only. */
+ 10, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3
+ * for 4z 8 symbol SDF type */
+ DWT_BR_6M8, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (1024 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_32
+
+/* Configuration option 32.
+ * Channel 9, PRF 64M, Preamble Length 1024, PAC 8, Preamble code 10, Data Rate
+ * 6.8M, STS Length 64
+ */
+dwt_config_t config_options = {
+ 9, /* Channel number. */
+ DWT_PLEN_1024, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 10, /* TX preamble code. Used in TX only. */
+ 10, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3
+ * for 4z 8 symbol SDF type */
+ DWT_BR_6M8, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (1024 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_64, /* STS length*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+#endif
+
+#ifdef CONFIG_OPTION_33
+
+/* Configuration option 33.
+ * Channel 5, PRF 64M, Preamble Length 128, PAC 8, Preamble code 9, Data Rate
+ * 6.8M, STS Length 128
+ */
+dwt_config_t config_options = {
+ 5, /* Channel number. */
+ DWT_PLEN_128, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 9, /* TX preamble code. Used in TX only. */
+ 9, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3 for
+ * 4z 8 symbol SDF type */
+ DWT_BR_6M8, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (128 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_1, /* Mode 1 STS enabled */
+ DWT_STS_LEN_128, /* (STS length in blocks of 8) - 1*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+
+/* Configuration option SP3.
+ * Channel 5, PRF 64M, Preamble Length 128, PAC 8, Preamble code 9, Data Rate
+ * 6.8M, STS Length 128, STS Mode 3
+ */
+dwt_config_t config_option_sp3 = {
+ 5, /* Channel number. */
+ DWT_PLEN_128, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 9, /* TX preamble code. Used in TX only. */
+ 9, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3 for
+ * 4z 8 symbol SDF type */
+ DWT_BR_6M8, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (128 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_ND, /* Mode 3 STS (no data) enabled */
+ DWT_STS_LEN_128, /* (STS length in blocks of 8) - 1*/
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+
+/* Configuration option SP0.
+ * Channel 5, PRF 64M, Preamble Length 128, PAC 8, Preamble code 9, Data Rate
+ * 6.8M, No STS
+ */
+dwt_config_t config_option_sp0 = {
+ 5, /* Channel number. */
+ DWT_PLEN_128, /* Preamble length. Used in TX only. */
+ DWT_PAC8, /* Preamble acquisition chunk size. Used in RX only. */
+ 9, /* TX preamble code. Used in TX only. */
+ 9, /* RX preamble code. Used in RX only. */
+ 3, /* 0 to use standard 8 symbol SFD, 1 to use non-standard
+ * 8 symbol, 2 for non-standard 16 symbol SFD and 3 for
+ * 4z 8 symbol SDF type */
+ DWT_BR_6M8, /* Data rate. */
+ DWT_PHRMODE_STD, /* PHY header mode. */
+ DWT_PHRRATE_STD, /* PHY header rate. */
+ (128 + 1 + 8 - 8), /* SFD timeout (preamble length + 1 + SFD length - PAC
+ * size). Used in RX only. */
+ DWT_STS_MODE_OFF, /* STS Off */
+ DWT_STS_LEN_128, /* Ignore value when STS is disabled */
+ DWT_PDOA_M0 /* PDOA mode off */
+};
+
+#endif
diff --git a/app/example/mikroe_uwb2_dwm3000/app_files/config_options.h b/app/example/mikroe_uwb2_dwm3000/app_files/config_options.h
new file mode 100644
index 00000000..c1dfd069
--- /dev/null
+++ b/app/example/mikroe_uwb2_dwm3000/app_files/config_options.h
@@ -0,0 +1,281 @@
+/*! ----------------------------------------------------------------------------
+ * @file config_options.h
+ * @brief Configuration options are selected here.
+ *
+ * @attention
+ *
+ * Copyright 2019(c) Decawave Ltd, Dublin, Ireland.
+ *
+ * All rights reserved.
+ *
+ */
+
+#include
+
+#ifndef EXAMPLES_CONFIG_OPTIONS_H_
+#define EXAMPLES_CONFIG_OPTIONS_H_
+
+/* Index values for errors in array */
+#define CRC_ERR_IDX 0
+#define RSE_ERR_IDX 1
+#define PHE_ERR_IDX 2
+#define SFDTO_ERR_IDX 3
+#define PTO_ERR_IDX 4
+#define RTO_ERR_IDX 5
+#define SPICRC_ERR_IDX 6
+#define TXTO_ERR_IDX 7
+#define ARFE_ERR_IDX 8
+#define TS_MISMATCH_ERR_IDX 9
+#define BAD_FRAME_ERR_IDX 10
+#define PREAMBLE_COUNT_ERR_IDX 11
+#define CP_QUAL_ERR_IDX 12
+#define STS_PREAMBLE_ERR 13
+#define STS_PEAK_GROWTH_RATE_ERR 14
+#define STS_ADC_COUNT_ERR 15
+#define STS_SFD_COUNT_ERR 16
+#define STS_LATE_FIRST_PATH_ERR 17
+#define STS_LATE_COARSE_EST_ERR 18
+#define STS_COARSE_EST_EMPTY_ERR 19
+#define STS_HIGH_NOISE_THREASH_ERR 20
+#define STS_NON_TRIANGLE_ERR 21
+#define STS_LOG_REG_FAILED_ERR 22
+
+/*
+ * Number of ranges to attempt in test
+ */
+#define RANGE_COUNT 200
+
+/* Compensation value for CPU
+ * The time taken to receive the poll frame, check for errors,
+ * calculate length, read content, get poll timestamp,
+ * calculate response timestamp and send delayed response with timestamp will
+ * be different for each device.
+ * Adjusting this value lower and lower until dwt_starttx() starts returning
+ * DWT_ERROR status allows the user to tweak their system to calculate the
+ * shortest turn-around time for messages.
+ */
+#define CPU_PROCESSING_TIME 400
+
+/*
+ * SPI Rate Configuration Settings
+ */
+#define CONFIG_SPI_FAST_RATE
+// #define CONFIG_SPI_SLOW_RATE
+
+/*
+ * Changing threshold to 5ns for DW3000 B0 red board devices.
+ * ~10% of ranging attempts have a larger than usual difference between Ipatov
+ * and STS.
+ * A larger threshold allows for better coverage with this coverage.
+ * This should be fixed for DW3000 C0 devices.
+ */
+#define TS_MISMATCH_THRESHOLD 5 * 64 /* 64 = 1 ns --> 5 ns */
+
+/*
+ * Please note that a PRF of 16 MHz and a STS PRF of 64 MHz will not be
+ * supported for the DW3000.
+ */
+
+/* Configuration option 01.
+ * Channel 5, PRF 64M, Preamble Length 64, PAC 8, Preamble code 9, Data Rate
+ * 850k, STS Length 64
+ */
+// #define CONFIG_OPTION_01
+
+/* Configuration option 02.
+ * Channel 9, PRF 64M, Preamble Length 64, PAC 8, Preamble code 9, Data Rate
+ * 850k, STS Length 64
+ */
+// #define CONFIG_OPTION_02
+
+/* Configuration option 03.
+ * Channel 5, PRF 64M, Preamble Length 128, PAC 8, Preamble code 9, Data Rate
+ * 850k, STS Length 64
+ */
+// #define CONFIG_OPTION_03
+
+/* Configuration option 04.
+ * Channel 9, PRF 64M, Preamble Length 128, PAC 8, Preamble code 9, Data Rate
+ * 850k, STS Length 64
+ */
+// #define CONFIG_OPTION_04
+
+/* Configuration option 05.
+ * Channel 5, PRF 64M, Preamble Length 512, PAC 8, Preamble code 9, Data Rate
+ * 850k, STS Length 64
+ */
+// #define CONFIG_OPTION_05
+
+/* Configuration option 06.
+ * Channel 9, PRF 64M, Preamble Length 512, PAC 8, Preamble code 9, Data Rate
+ * 850k, STS Length 64
+ */
+// #define CONFIG_OPTION_06
+
+/* Configuration option 07.
+ * Channel 5, PRF 64M, Preamble Length 1024, PAC 8, Preamble code 9, Data Rate
+ * 850k, STS Length 64
+ */
+// #define CONFIG_OPTION_07
+
+/* Configuration option 08.
+ * Channel 9, PRF 64M, Preamble Length 1024, PAC 8, Preamble code 9, Data Rate
+ * 850k, STS Length 64
+ */
+// #define CONFIG_OPTION_08
+
+/* Configuration option 09.
+ * Channel 5, PRF 64M, Preamble Length 64, PAC 8, Preamble code 10, Data Rate
+ * 850k, STS Length 64
+ */
+// #define CONFIG_OPTION_09
+
+/* Configuration option 10.
+ * Channel 9, PRF 64M, Preamble Length 64, PAC 8, Preamble code 10, Data Rate
+ * 850k, STS Length 64
+ */
+// #define CONFIG_OPTION_10
+
+/* Configuration option 11.
+ * Channel 5, PRF 64M, Preamble Length 128, PAC 8, Preamble code 10, Data Rate
+ * 850k, STS Length 64
+ */
+// #define CONFIG_OPTION_11
+
+/* Configuration option 12.
+ * Channel 9, PRF 64M, Preamble Length 128, PAC 8, Preamble code 10, Data Rate
+ * 850k, STS Length 64
+ */
+// #define CONFIG_OPTION_12
+
+/* Configuration option 13.
+ * Channel 5, PRF 64M, Preamble Length 512, PAC 8, Preamble code 10, Data Rate
+ * 850k, STS Length 64
+ */
+// #define CONFIG_OPTION_13
+
+/* Configuration option 14.
+ * Channel 9, PRF 64M, Preamble Length 512, PAC 8, Preamble code 10, Data Rate
+ * 850k, STS Length 64
+ */
+// #define CONFIG_OPTION_14
+
+/* Configuration option 15.
+ * Channel 5, PRF 64M, Preamble Length 1024, PAC 8, Preamble code 10, Data Rate
+ * 850k, STS Length 64
+ */
+// #define CONFIG_OPTION_15
+
+/* Configuration option 16.
+ * Channel 9, PRF 64M, Preamble Length 1024, PAC 8, Preamble code 10, Data Rate
+ * 850k, STS Length 64
+ */
+// #define CONFIG_OPTION_16
+
+/* Configuration option 17.
+ * Channel 5, PRF 64M, Preamble Length 64, PAC 8, Preamble code 9, Data Rate
+ * 6.8M, STS Length 64
+ */
+// #define CONFIG_OPTION_17
+
+/* Configuration option 18.
+ * Channel 9, PRF 64M, Preamble Length 64, PAC 8, Preamble code 9, Data Rate
+ * 6.8M, STS Length 64
+ */
+// #define CONFIG_OPTION_18
+
+/* Configuration option 19.
+ * Channel 5, PRF 64M, Preamble Length 128, PAC 8, Preamble code 9, Data Rate
+ * 6.8M, STS Length 64
+ */
+// #define CONFIG_OPTION_19
+
+/* Configuration option 20.
+ * Channel 9, PRF 64M, Preamble Length 128, PAC 8, Preamble code 9, Data Rate
+ * 6.8M, STS Length 64
+ */
+// #define CONFIG_OPTION_20
+
+/* Configuration option 21.
+ * Channel 5, PRF 64M, Preamble Length 512, PAC 8, Preamble code 9, Data Rate
+ * 850k, STS Length 64
+ */
+// #define CONFIG_OPTION_21
+
+/* Configuration option 22.
+ * Channel 9, PRF 64M, Preamble Length 512, PAC 8, Preamble code 9, Data Rate
+ * 6.8M, STS Length 64
+ */
+// #define CONFIG_OPTION_22
+
+/* Configuration option 23.
+ * Channel 5, PRF 64M, Preamble Length 1024, PAC 8, Preamble code 9, Data Rate
+ * 6.8M, STS Length 64
+ */
+// #define CONFIG_OPTION_23
+
+/* Configuration option 24.
+ * Channel 9, PRF 64M, Preamble Length 1024, PAC 8, Preamble code 9, Data Rate
+ * 6.8M, STS Length 64
+ */
+// #define CONFIG_OPTION_24
+
+/* Configuration option 25.
+ * Channel 5, PRF 64M, Preamble Length 64, PAC 8, Preamble code 10, Data Rate
+ * 6.8M, STS Length 64
+ */
+// #define CONFIG_OPTION_25
+
+/* Configuration option 26.
+ * Channel 9, PRF 64M, Preamble Length 64, PAC 8, Preamble code 10, Data Rate
+ * 6.8M, STS Length 64
+ */
+// #define CONFIG_OPTION_26
+
+/* Configuration option 27.
+ * Channel 5, PRF 64M, Preamble Length 128, PAC 8, Preamble code 10, Data Rate
+ * 6.8M, STS Length 64
+ */
+// #define CONFIG_OPTION_27
+
+/* Configuration option 28.
+ * Channel 9, PRF 64M, Preamble Length 128, PAC 8, Preamble code 10, Data Rate
+ * 6.8M, STS Length 64
+ */
+// #define CONFIG_OPTION_28
+
+/* Configuration option 29.
+ * Channel 5, PRF 64M, Preamble Length 512, PAC 8, Preamble code 10, Data Rate
+ * 6.8M, STS Length 64
+ */
+// #define CONFIG_OPTION_29
+
+/* Configuration option 30.
+ * Channel 9, PRF 64M, Preamble Length 512, PAC 8, Preamble code 10, Data Rate
+ * 6.8M, STS Length 64
+ */
+// #define CONFIG_OPTION_30
+
+/* Configuration option 31.
+ * Channel 5, PRF 64M, Preamble Length 1024, PAC 8, Preamble code 10, Data Rate
+ * 6.8M, STS Length 64
+ */
+// #define CONFIG_OPTION_31
+
+/* Configuration option 32.
+ * Channel 9, PRF 64M, Preamble Length 1024, PAC 8, Preamble code 10, Data Rate
+ * 6.8M, STS Length 64
+ */
+// #define CONFIG_OPTION_32
+
+/* Configuration option 33.
+ * Channel 5, PRF 64M, Preamble Length 128, PAC 8, Preamble code 9, Data Rate
+ * 6.8M, STS Length 128
+ */
+#define CONFIG_OPTION_33
+
+extern char dist_str[16];
+extern dwt_txconfig_t txconfig_options;
+extern dwt_txconfig_t txconfig_options_ch9;
+
+#endif /* EXAMPLES_CONFIG_OPTIONS_H_ */
diff --git a/app/example/mikroe_uwb2_dwm3000/app_files/shared_defines.h b/app/example/mikroe_uwb2_dwm3000/app_files/shared_defines.h
new file mode 100644
index 00000000..6643f51f
--- /dev/null
+++ b/app/example/mikroe_uwb2_dwm3000/app_files/shared_defines.h
@@ -0,0 +1,71 @@
+/*! ----------------------------------------------------------------------------
+ * @file shared_defines.h
+ * @brief Global definitions are found here
+ *
+ * @attention
+ *
+ * Copyright 2013 - 2021 (c) Decawave Ltd, Dublin, Ireland.
+ *
+ * All rights reserved.
+ *
+ */
+
+#ifndef _SHARE_DEF_
+#define _SHARE_DEF_
+
+#ifdef __cplusplus
+extern "C"
+{
+#endif
+
+#ifdef STM32F429xx
+#include
+#endif // STM32F429xx
+
+#define SPEED_OF_LIGHT (299702547)
+#define FRAME_LEN_MAX (127)
+#define FRAME_LEN_MAX_EX (1023)
+
+#define RXFLEN_MASK 0x0000007FUL /* Receive Frame Length (0 to 127) */
+#define RXFL_MASK_1023 0x000003FFUL /* Receive Frame Length Extension (0 to
+ * 1023) */
+
+#define RESP_MSG_TS_LEN 4
+#define FINAL_MSG_TS_LEN 4
+
+/* UWB microsecond (uus) to device time unit (dtu, around 15.65 ps) conversion
+ * factor.
+ * 1 uus = 512 / 499.2 µs and 1 µs = 499.2 * 128 dtu. */
+#define UUS_TO_DWT_TIME 63898
+
+#define TX_CHANGEABLE_DATA (10) /*Can change the length of TX data by this
+ * size*/
+#define MINIMAL_DATA_LENGTH (11) /*The TX length will be at least the buffer
+ * below*/
+#define SIMPLE_TX_DATA_SIZE (MINIMAL_DATA_LENGTH + TX_CHANGEABLE_DATA)
+#define TX_LENGTH_BYTE_POS (2) /*This byte index represent the total length of
+ * the TX data*/
+
+typedef enum
+{
+ DBL_BUFF_ERR_TYPE_UNKNOWN = -1, /*Unknown yet*/
+ DBL_BUFF_ERR_TYPE_OK, /*No error*/
+ DBL_BUFF_ERR_TYPE_TIMEOUT, /*Timeout*/
+ DBL_BUFF_ERR_TYPE_ERROR, /*Error*/
+ DBL_BUFF_ERR_TYPE_GOT_UNNEEDED_DATA,
+} dbl_buff_error_type_e;
+
+typedef enum
+{
+ AES_RES_OK = 0,
+ AES_RES_ERROR_LENGTH = -1,
+ AES_RES_ERROR = -2,
+ AES_RES_ERROR_FRAME = -3,
+ AES_RES_ERROR_IGNORE_FRAME = -4
+} aes_results_e;
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
diff --git a/app/example/mikroe_uwb2_dwm3000/app_files/shared_functions.c b/app/example/mikroe_uwb2_dwm3000/app_files/shared_functions.c
new file mode 100644
index 00000000..fbb69e99
--- /dev/null
+++ b/app/example/mikroe_uwb2_dwm3000/app_files/shared_functions.c
@@ -0,0 +1,696 @@
+/*! ----------------------------------------------------------------------------
+ * @file shared_functions.h
+ * @brief Global functions are found here
+ *
+ * @attention
+ *
+ * Copyright 2013 - 2021 (c) Decawave Ltd, Dublin, Ireland.
+ *
+ * All rights reserved.
+ *
+ */
+
+#include "config_options.h"
+#include
+#include
+#include
+#include "shared_defines.h"
+#include "shared_functions.h"
+#include
+
+extern dwt_config_t config_options;
+
+/*Reference look-up table to calculate TxPower boost depending on frame duration
+ * Using two different tables as per logarithmic calculation:
+ * - 1000us to 200us range - index unit of 25us
+ * - 200us to 70us -- index unit of 10us
+ * The table values are in steps 0f 0.1dB
+ * This allow to have a maximum granularity of 0.5dB between two frame
+ * durations, which is
+ * in the magnitude of the DW3XXX TxOutput setting.
+ */
+
+const uint8_t txpower_boost_per_frame_duration_1000_200_us[LUT_1000_200_US_NUM]
+ = {
+ 0, // 1000us
+ 1, // 975us -> 1*0.1dB boost between 975us and 1000us frames
+ 2, // 950us -> 2*0.1dB boost between 950us and 1000us frames
+ 3, // 925us
+ 4, // 900us
+ 5, // 875us
+ 6, // 850us
+ 7, // 825us
+ 8, // 800us
+ 9, // 775us
+ 10, // 750us
+ 11, // 725us
+ 13, // 700us
+ 15, // 675us
+ 17, // 650us
+ 19, // 625us
+ 21, // 600us
+ 23, // 575us
+ 25, // 550us
+ 27, // 525us
+ 29, // 500us
+ 31, // 475us
+ 33, // 450us
+ 35, // 425us
+ 38, // 400us
+ 41, // 375us
+ 44, // 350us
+ 47, // 325us
+ 50, // 300us
+ 54, // 275us
+ 58, // 250us
+ 63, // 225us
+ 68 // 200us
+ };
+
+const uint8_t txpower_boost_per_frame_duration_200_70_us[LUT_200_70_US_NUM] = {
+ 68, // 200us -> 68*0.1dB boost between 200us frame and 1000us frame.
+ 70, // 190us -> 70*0.1dB boost between 190us and 1000us frame
+ 72, // 180us
+ 74, // 170us
+ 77, // 160us
+ 80, // 150us
+ 83, // 140us
+ 86, // 130us
+ 89, // 120us
+ 93, // 110us
+ 97, // 100us
+ 102, // 90us
+ 107, // 80us
+ 113 // 70us
+};
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @fn calculate_power_boost()
+ *
+ * @brief Calculation the allowed power boost for a frame_duration_us frame
+ * relatively to a 1ms frame.
+ *
+ * @param reg: uint16_t duration of frame..
+ *
+ * @return boost: the amount of boost in 0.1dB steps which is allowed when
+ * transmitting the frame_dur_us frame
+ * relatively to a 1ms frame. For example, if the frame duration
+ * is 500us, then relatively to 1ms,
+ * a 3dB boost is allowed, and the function will return 30.
+ */
+uint8_t calculate_power_boost(uint16_t frame_duration_us)
+{
+ const uint8_t *lut = NULL;
+ uint16_t lut_i;
+ uint16_t lut_num;
+ uint16_t lut_min;
+ uint16_t lut_step;
+ uint16_t limit;
+
+ // If the frame is longer than the reference duration, then no boost to apply
+ if (frame_duration_us >= FRAME_DURATION_REF) {
+ return LUT_1000_200_US_MIN_BST;
+ } else if (frame_duration_us < LUT_200_70_US_MIN) { // If frame shorter than
+ // 70us apply the
+ // maximum boost
+ return LUT_200_70_US_MAX_BST;
+ } else if (frame_duration_us > LUT_1000_200_US_MIN) { // Select LUT table for
+ // frame 1000us >
+ // duration > 200us
+ lut_num = LUT_1000_200_US_NUM;
+ lut_min = LUT_1000_200_US_MIN;
+ lut_step = LUT_1000_200_US_STEP;
+ lut = txpower_boost_per_frame_duration_1000_200_us;
+ } else { // Select LUT table for frame 200us > duration > 70us
+ lut_num = LUT_200_70_US_NUM;
+ lut_min = LUT_200_70_US_MIN;
+ lut_step = LUT_200_70_US_STEP;
+ lut = txpower_boost_per_frame_duration_200_70_us;
+ }
+
+ // Calculating the LUT index corresponding to the frame duration
+ lut_i = (lut_num - (frame_duration_us - lut_min) / lut_step);
+ limit = (lut_num - lut_i) * lut_step + lut_min;
+
+ // Selecting the index that gives the closest LUT duration to the one passed
+ // as argument.
+ if (abs(frame_duration_us - limit) > lut_step / 2) {
+ lut_i--;
+ }
+
+ // Boost is stored in the LUT at the calculated index - 1.
+ // -1 to account for index 0
+ // lut_i cannot be == 0 or > lut_num here
+ return lut[lut_i - 1];
+}
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @fn check_for_status_errors()
+ *
+ * @brief This function is used to get a value to increase the delay timer by
+ * dependent on the current TX preamble length set.
+ *
+ * @param reg: uint32_t value representing the current status register value.
+ * @param errors: pointer to a uint32_t buffer that contains the sum of
+ * different errors logged during program operation.
+ *
+ * @return none
+ */
+void check_for_status_errors(uint32_t reg, uint32_t *errors)
+{
+ uint16_t stsStatus = 0;
+
+ if (!(reg & DWT_INT_RXFCG_BIT_MASK)) {
+ errors[BAD_FRAME_ERR_IDX] += 1;
+ }
+
+ if (reg & DWT_INT_RXFSL_BIT_MASK) {
+ errors[RSE_ERR_IDX] += 1;
+ }
+
+ if (reg & DWT_INT_RXPHE_BIT_MASK) {
+ errors[PHE_ERR_IDX] += 1;
+ }
+
+ if (reg & DWT_INT_RXPTO_BIT_MASK) {
+ errors[PTO_ERR_IDX] += 1;
+ }
+
+ if (reg & DWT_INT_ARFE_BIT_MASK) {
+ errors[ARFE_ERR_IDX] += 1;
+ }
+
+ if ((reg & DWT_INT_RXFR_BIT_MASK) && !(reg & DWT_INT_RXFCG_BIT_MASK)) {
+ errors[CRC_ERR_IDX] += 1;
+ }
+
+ if ((reg & DWT_INT_RXFTO_BIT_MASK) || (reg & SYS_STATUS_ALL_RX_TO)) {
+ errors[RTO_ERR_IDX] += 1;
+ }
+
+ if (reg & DWT_INT_RXSTO_BIT_MASK) {
+ errors[SFDTO_ERR_IDX] += 1;
+ }
+
+ if (reg & DWT_INT_CPERR_BIT_MASK) {
+ // There is a general STS error
+ errors[STS_PREAMBLE_ERR] += 1;
+
+ // Get the status for a more detailed error reading of what went wrong with
+ // the STS
+ dwt_readstsstatus(&stsStatus, 0);
+ if (stsStatus & 0x100) {
+ // Peak growth rate warning
+ errors[STS_PEAK_GROWTH_RATE_ERR] += 1;
+ }
+ if (stsStatus & 0x080) {
+ // ADC count warning
+ errors[STS_ADC_COUNT_ERR] += 1;
+ }
+ if (stsStatus & 0x040) {
+ // SFD count warning
+ errors[STS_SFD_COUNT_ERR] += 1;
+ }
+ if (stsStatus & 0x020) {
+ // Late first path estimation
+ errors[STS_LATE_FIRST_PATH_ERR] += 1;
+ }
+ if (stsStatus & 0x010) {
+ // Late coarse estimation
+ errors[STS_LATE_COARSE_EST_ERR] += 1;
+ }
+ if (stsStatus & 0x008) {
+ // Coarse estimation empty
+ errors[STS_COARSE_EST_EMPTY_ERR] += 1;
+ }
+ if (stsStatus & 0x004) {
+ // High noise threshold
+ errors[STS_HIGH_NOISE_THREASH_ERR] += 1;
+ }
+ if (stsStatus & 0x002) {
+ // Non-triangle
+ errors[STS_NON_TRIANGLE_ERR] += 1;
+ }
+ if (stsStatus & 0x001) {
+ // Logistic regression failed
+ errors[STS_LOG_REG_FAILED_ERR] += 1;
+ }
+ }
+}
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @fn get_rx_delay_time_txpreamble()
+ *
+ * @brief This function is used to get a value to increase the delay timer by
+ * dependent on the current TX preamble length set.
+ *
+ * @param None
+ *
+ * @return delay_time - a uint32_t value indicating the required increase needed
+ * to delay the time by.
+ */
+uint32_t get_rx_delay_time_txpreamble(void)
+{
+ uint32_t delay_time = 0;
+
+ /* Standard delay values for preamble lengths of 32, 64, 72 & 128 should be
+ * adequate.
+ * Additional time delay will be needed for larger preamble lengths.
+ * Delay required is dependent on the preamble length as it increases the
+ * frame length. */
+ switch (config_options.txPreambLength)
+ {
+ case DWT_PLEN_256:
+ delay_time += 128; /* 256 - 128 */
+ break;
+ case DWT_PLEN_512:
+ delay_time += 384; /* 512 - 128 */
+ break;
+ case DWT_PLEN_1024:
+ delay_time += 896; /* 1024 - 128 */
+ break;
+ case DWT_PLEN_1536:
+ delay_time += 1408; /* 1536 - 128 */
+ break;
+ case DWT_PLEN_2048:
+ delay_time += 1920; /* 2048 - 128 */
+ break;
+ case DWT_PLEN_4096:
+ delay_time += 3968; /* 4096 - 128 */
+ break;
+ case DWT_PLEN_32:
+ case DWT_PLEN_64:
+ case DWT_PLEN_72:
+ case DWT_PLEN_128:
+ default:
+ break;
+ }
+
+ return delay_time;
+}
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @fn get_rx_delay_time_data_rate()
+ *
+ * @brief This function is used to get a value to increase the delay timer by
+ * dependent on the current data rate set.
+ *
+ * @param None
+ *
+ * @return delay_time - a uint32_t value indicating the required increase needed
+ * to delay the time by.
+ */
+uint32_t get_rx_delay_time_data_rate(void)
+{
+ uint32_t delay_time = 0;
+
+ /*
+ * If data rate is set to 850k (slower rate),
+ * increase the delay time
+ */
+ switch (config_options.dataRate)
+ {
+ case DWT_BR_850K:
+ delay_time += 200;
+ break;
+ case DWT_BR_6M8:
+ default:
+ break;
+ }
+
+ return delay_time;
+}
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @fn set_delayed_rx_time()
+ *
+ * @brief This function is used to set the delayed RX time before running
+ * dwt_rxenable()
+ *
+ * @param delay - This is a defined delay value (usually
+ * POLL_TX_TO_RESP_RX_DLY_UUS)
+ * @param config_options - pointer to dwt_config_t configuration structure that
+ * is in use at the time this function
+ * is called.
+ *
+ * @return None
+ */
+void set_delayed_rx_time(uint32_t delay, dwt_config_t *config_options)
+{
+ uint32_t delay_time = delay;
+
+ switch (config_options->txPreambLength)
+ {
+ case DWT_PLEN_32:
+ delay_time -= 32;
+ break;
+ case DWT_PLEN_64:
+ delay_time -= 64;
+ break;
+ case DWT_PLEN_72:
+ delay_time -= 72;
+ break;
+ case DWT_PLEN_128:
+ delay_time -= 128;
+ break;
+ case DWT_PLEN_256:
+ delay_time -= 256;
+ break;
+ case DWT_PLEN_512:
+ delay_time -= 512;
+ break;
+ case DWT_PLEN_1024:
+ delay_time -= 1024;
+ break;
+ case DWT_PLEN_1536:
+ delay_time -= 1536;
+ break;
+ case DWT_PLEN_2048:
+ case DWT_PLEN_4096:
+ delay_time -= 2048;
+ break;
+ default:
+ break;
+ }
+
+ /* Length of the STS effects the size of the frame also.
+ * This means the delay required is greater for larger STS lengths. */
+ delay_time += ((1 << (config_options->stsLength + 2)) * 8);
+
+ dwt_setdelayedtrxtime((uint32_t)((delay_time * UUS_TO_DWT_TIME) >> 8));
+}
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @fn set_resp_rx_timeout()
+ *
+ * @brief This function is used to set the RX timeout value
+ *
+ * @param delay - This is a defined delay value (usually RESP_RX_TIMEOUT_UUS)
+ * @param config_options - pointer to dwt_config_t configuration structure that
+ * is in use at the time this function
+ * is called.
+ *
+ * @return None
+ */
+void set_resp_rx_timeout(uint32_t delay, dwt_config_t *config_options)
+{
+ /*
+ * The program will need to adjust the timeout value depending on the size of
+ * the frame
+ * Different sized frames require different time delays.
+ */
+ uint32_t delay_time = delay + get_rx_delay_time_data_rate()
+ + get_rx_delay_time_txpreamble() + 500;
+
+ /* Length of the STS effects the size of the frame also.
+ * This means the delay required is greater for larger STS lengths. */
+ switch (config_options->stsLength)
+ {
+ case DWT_STS_LEN_256:
+ case DWT_STS_LEN_512:
+ case DWT_STS_LEN_1024:
+ case DWT_STS_LEN_2048:
+ delay_time += ((1 << (config_options->stsLength + 2)) * 8);
+ break;
+ case DWT_STS_LEN_32:
+ case DWT_STS_LEN_64:
+ case DWT_STS_LEN_128:
+ default:
+ break;
+ }
+
+ dwt_setrxtimeout(delay_time);
+}
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @fn resp_msg_get_ts()
+ *
+ * @brief Read a given timestamp value from the response message. In the
+ * timestamp fields of the response message, the
+ * least significant byte is at the lower address.
+ *
+ * @param ts_field pointer on the first byte of the timestamp field to get
+ * ts timestamp value
+ *
+ * @return none
+ */
+void resp_msg_get_ts(uint8_t *ts_field, uint32_t *ts)
+{
+ int i;
+ *ts = 0;
+ for (i = 0; i < RESP_MSG_TS_LEN; i++)
+ {
+ *ts += (uint32_t)ts_field[i] << (i * 8);
+ }
+}
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @fn get_tx_timestamp_u64()
+ *
+ * @brief Get the TX time-stamp in a 64-bit variable.
+ * /!\ This function assumes that length of time-stamps is 40 bits, for
+ * both TX and RX!
+ *
+ * @param none
+ *
+ * @return 64-bit value of the read time-stamp.
+ */
+uint64_t get_tx_timestamp_u64(void)
+{
+ uint8_t ts_tab[5];
+ uint64_t ts = 0;
+ int8_t i;
+ dwt_readtxtimestamp(ts_tab);
+ for (i = 4; i >= 0; i--)
+ {
+ ts <<= 8;
+ ts |= ts_tab[i];
+ }
+ return ts;
+}
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @fn get_rx_timestamp_u64()
+ *
+ * @brief Get the RX time-stamp in a 64-bit variable.
+ * /!\ This function assumes that length of time-stamps is 40 bits, for
+ * both TX and RX!
+ *
+ * @param none
+ *
+ * @return 64-bit value of the read time-stamp.
+ */
+uint64_t get_rx_timestamp_u64(void)
+{
+ uint8_t ts_tab[5];
+ uint64_t ts = 0;
+ int8_t i;
+ dwt_readrxtimestamp(ts_tab);
+ for (i = 4; i >= 0; i--)
+ {
+ ts <<= 8;
+ ts |= ts_tab[i];
+ }
+ return ts;
+}
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @fn final_msg_get_ts()
+ *
+ * @brief Read a given timestamp value from the final message. In the timestamp
+ * fields of the final message, the least
+ * significant byte is at the lower address.
+ *
+ * @param ts_field pointer on the first byte of the timestamp field to read
+ * ts timestamp value
+ *
+ * @return none
+ */
+void final_msg_get_ts(const uint8_t *ts_field, uint32_t *ts)
+{
+ uint8_t i;
+ *ts = 0;
+ for (i = 0; i < FINAL_MSG_TS_LEN; i++)
+ {
+ *ts += ((uint32_t)ts_field[i] << (i * 8));
+ }
+}
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @fn final_msg_set_ts()
+ *
+ * @brief Fill a given timestamp field in the final message with the given
+ * value. In the timestamp fields of the final
+ * message, the least significant byte is at the lower address.
+ *
+ * @param ts_field pointer on the first byte of the timestamp field to fill
+ * ts timestamp value
+ *
+ * @return none
+ */
+void final_msg_set_ts(uint8_t *ts_field, uint64_t ts)
+{
+ uint8_t i;
+ for (i = 0; i < FINAL_MSG_TS_LEN; i++)
+ {
+ ts_field[i] = (uint8_t)ts;
+ ts >>= 8;
+ }
+}
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @fn resp_msg_set_ts()
+ *
+ * @brief Fill a given timestamp field in the response message with the given
+ * value. In the timestamp fields of the
+ * response message, the least significant byte is at the lower address.
+ *
+ * @param ts_field pointer on the first byte of the timestamp field to fill
+ * ts timestamp value
+ *
+ * @return none
+ */
+void resp_msg_set_ts(uint8_t *ts_field, const uint64_t ts)
+{
+ uint8_t i;
+ for (i = 0; i < RESP_MSG_TS_LEN; i++)
+ {
+ ts_field[i] = (uint8_t)(ts >> (i * 8));
+ }
+}
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function will continuously read the system status register until
+ * it matches the bits set in the mask
+ * input parameter. It will then exit the function.
+ * This is useful to use when waiting on particular events to occurs. For
+ * example, the user could wait for a
+ * good UWB frame to be received and/or no receive errors have occurred.
+ * The lower 32-bits of the system status register will be read in a
+ * while loop. Each iteration of the loop will check if a matching
+ * mask value for the higher 32-bits of the system status register is
+ * set. If the mask value is set in the higher 32-bits of the system
+ * status register, the function will return that value along with the
+ * last recorded value of the lower 32-bits of the system status
+ * register. Thus, the user should be aware that this function will not
+ * wait for high and low mask values to be set in both the low and high
+ * system status registers. Alternatively, the user can call this
+ * function to *only* check the higher or lower system status registers.
+ *
+ * input parameters
+ * @param lo_result - A pointer to a uint32_t that will contain the final value
+ * of the system status register (lower 32 bits).
+ * Pass in a NULL pointer to ignore returning this value.
+ * @param hi_result - A pointer to a uint32_t that will contain the final value
+ * of the system status register (higher 32 bits).
+ * Pass in a NULL pointer to ignore returning this value.
+ * @param lo_mask - a uint32 mask value that is used to check for certain bits
+ * to be set in the system status register (lower 32 bits).
+ * Example values to use are as follows:
+ * DWT_INT_TXFRS_BIT_MASK - Wait for a TX frame to be sent.
+ * SYS_STATUS_RXFCG_BIT_MASK | SYS_STATUS_ALL_RX_ERR - Wait for
+ * frame to be received and no reception errors.
+ * SYS_STATUS_RXFCG_BIT_MASK | SYS_STATUS_ALL_RX_TO |
+ * SYS_STATUS_ALL_RX_ERR - Wait for frame to be received and no receive
+ * timeout errors
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ * and
+ * no reception errors.
+ * SYS_STATUS_RXFR_BIT_MASK | SYS_STATUS_ALL_RX_TO |
+ * SYS_STATUS_ALL_ND_RX_ERR - Wait for packet to be received and no receive
+ * timeout errors
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ * and
+ * no reception errors.
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ * These
+ * flags are useful when polling for STS Mode 4 (no data)
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ *
+ * packets.
+ * 0 - The function will not wait for any bits in the system
+ * status register (lower 32 bits).
+ * @param hi_mask - a uint32 mask value that is used to check for certain bits
+ * to be set in the system status register (higher 32 bits).
+ * Example values to use are as follows:
+ * SYS_STATUS_HI_CCA_FAIL_BIT_MASK - Check for CCA fail status.
+ * 0 - The function will not wait for any bits in the system
+ * status register (lower 32 bits).
+ *
+ * return None
+ */
+void waitforsysstatus(uint32_t *lo_result,
+ uint32_t *hi_result,
+ uint32_t lo_mask,
+ uint32_t hi_mask)
+{
+ uint32_t lo_result_tmp = 0;
+ uint32_t hi_result_tmp = 0;
+
+ // If a mask has been passed into the function for the system status register
+ // (lower 32-bits)
+ if (lo_mask) {
+ while (!((lo_result_tmp = dwt_readsysstatuslo()) & (lo_mask)))
+ {
+ // If a mask value is set for the system status register (higher 32-bits)
+ if (hi_mask) {
+ // If mask value for the system status register (higher 32-bits) is
+ // found
+ if ((hi_result_tmp = dwt_readsysstatushi()) & hi_mask) {
+ break;
+ }
+ }
+ }
+ }
+ // if only a mask value for the system status register (higher 32-bits) is set
+ else if (hi_mask) {
+ while (!((hi_result_tmp = dwt_readsysstatushi()) & (hi_mask))) {}
+ }
+
+ if (lo_result != NULL) {
+ *lo_result = lo_result_tmp;
+ }
+
+ if (hi_result != NULL) {
+ *hi_result = hi_result_tmp;
+ }
+}
diff --git a/app/example/mikroe_uwb2_dwm3000/app_files/shared_functions.h b/app/example/mikroe_uwb2_dwm3000/app_files/shared_functions.h
new file mode 100644
index 00000000..4bedf6e4
--- /dev/null
+++ b/app/example/mikroe_uwb2_dwm3000/app_files/shared_functions.h
@@ -0,0 +1,294 @@
+#ifndef _SHARE_FUNC_
+#define _SHARE_FUNC_
+
+#ifdef __cplusplus
+extern "C"
+{
+#endif
+
+/* Power boost calculation service function defines*/
+
+/* Number of frames duration values for which look up table has corresponding
+ * dial back in units of 0.1dB */
+#define LUT_1000_200_US_NUM 33
+
+/* Frame duration step in us between each ndex in LUT */
+#define LUT_1000_200_US_STEP 25
+
+/* Minimum frame duration characterised by LUT */
+#define LUT_1000_200_US_MIN 200
+
+/* Boost to apply when a frame is longer or equal to the maximum duration */
+#define LUT_1000_200_US_MIN_BST 0
+
+/* Number of frames duration values for which look up table has corresponding
+ * dial back in units of 0.1dB */
+#define LUT_200_70_US_NUM 14
+
+/* Frame duration step in us between each index in LUT */
+#define LUT_200_70_US_STEP 10
+
+/* Minimum frame duration characterised by LUT */
+#define LUT_200_70_US_MIN 70
+
+/* Total boost to apply when a frame is equal or shorter to the minimum
+ * duration */
+#define LUT_200_70_US_MAX_BST 113
+
+/* The reference duration for a frame is 1000us. Longer frame will have 0dB
+ * boost. */
+#define FRAME_DURATION_REF 1000
+
+/*!
+ *
+ * -----------------------------------------------------------------------------
+ * @fn calculate_power_boost()
+ *
+ * @brief Calculation the allowed power boost for a frame_duration_us frame
+ * relatively to a 1ms frame.
+ *
+ * @param reg: uint16_t duration of frame..
+ *
+ * @return boost: the amount of boost in 0.1dB steps which is allowed when
+ * transmitting the frame_dur_us frame
+ * relatively to a 1ms frame. For example, if the frame duration
+ * is 500us, then relatively to 1ms,
+ * a 3dB boost is allowed, and the function will return 30.
+ */
+uint8_t calculate_power_boost(uint16_t frame_duration_us);
+
+/*!
+ *
+ * -----------------------------------------------------------------------------
+ * @fn check_for_status_errors()
+ *
+ * @brief This function is used to get a value to increase the delay timer by
+ * dependent on the current TX preamble length set.
+ *
+ * @param reg: uint32_t value representing the current status register value.
+ * @param errors: pointer to a uint32_t buffer that contains the sum of
+ * different errors logged during program operation.
+ *
+ * @return none
+ */
+void check_for_status_errors(uint32_t reg, uint32_t *errors);
+
+/*!
+ *
+ * -----------------------------------------------------------------------------
+ * @fn get_rx_delay_time_txpreamble()
+ *
+ * @brief This function is used to get a value to increase the delay timer by
+ * dependent on the current TX preamble length set.
+ *
+ * @param None
+ *
+ * @return delay_time - a uint32_t value indicating the required increase needed
+ * to delay the time by.
+ */
+uint32_t get_rx_delay_time_txpreamble(void);
+
+/*!
+ *
+ * -----------------------------------------------------------------------------
+ * @fn get_rx_delay_time_data_rate()
+ *
+ * @brief This function is used to get a value to increase the delay timer by
+ * dependent on the current data rate set.
+ *
+ * @param None
+ *
+ * @return delay_time - a uint32_t value indicating the required increase needed
+ * to delay the time by.
+ */
+uint32_t get_rx_delay_time_data_rate(void);
+
+/*!
+ *
+ * -----------------------------------------------------------------------------
+ * @fn set_delayed_rx_time()
+ *
+ * @brief This function is used to set the delayed RX time before running
+ * dwt_rxenable()
+ *
+ * @param delay - This is a defined delay value (usually
+ * POLL_TX_TO_RESP_RX_DLY_UUS)
+ * @param config_options - pointer to dwt_config_t configuration structure that
+ * is in use at the time this function
+ * is called.
+ *
+ * @return None
+ */
+void set_delayed_rx_time(uint32_t delay, dwt_config_t *config_options);
+
+/*!
+ *
+ * -----------------------------------------------------------------------------
+ * @fn set_resp_rx_timeout()
+ *
+ * @brief This function is used to set the RX timeout value
+ *
+ * @param delay - This is a defined delay value (usually RESP_RX_TIMEOUT_UUS)
+ * @param config_options - pointer to dwt_config_t configuration structure that
+ * is in use at the time this function
+ * is called.
+ *
+ * @return None
+ */
+void set_resp_rx_timeout(uint32_t delay, dwt_config_t *config_options);
+
+/*!
+ *
+ * -----------------------------------------------------------------------------
+ * @fn resp_msg_get_ts()
+ *
+ * @brief Read a given timestamp value from the response message. In the
+ * timestamp fields of the response message, the
+ * least significant byte is at the lower address.
+ *
+ * @param ts_field pointer on the first byte of the timestamp field to get
+ * ts timestamp value
+ *
+ * @return none
+ */
+void resp_msg_get_ts(uint8_t *ts_field, uint32_t *ts);
+
+/*!
+ *
+ * -----------------------------------------------------------------------------
+ * @fn get_tx_timestamp_u64()
+ *
+ * @brief Get the TX time-stamp in a 64-bit variable.
+ * /!\ This function assumes that length of time-stamps is 40 bits, for
+ * both TX and RX!
+ *
+ * @param none
+ *
+ * @return 64-bit value of the read time-stamp.
+ */
+uint64_t get_tx_timestamp_u64(void);
+
+/*!
+ *
+ * -----------------------------------------------------------------------------
+ * @fn get_rx_timestamp_u64()
+ *
+ * @brief Get the RX time-stamp in a 64-bit variable.
+ * /!\ This function assumes that length of time-stamps is 40 bits, for
+ * both TX and RX!
+ *
+ * @param none
+ *
+ * @return 64-bit value of the read time-stamp.
+ */
+uint64_t get_rx_timestamp_u64(void);
+
+/*!
+ *
+ * -----------------------------------------------------------------------------
+ * @fn final_msg_get_ts()
+ *
+ * @brief Read a given timestamp value from the final message. In the timestamp
+ * fields of the final message, the least
+ * significant byte is at the lower address.
+ *
+ * @param ts_field pointer on the first byte of the timestamp field to read
+ * ts timestamp value
+ *
+ * @return none
+ */
+void final_msg_get_ts(const uint8_t *ts_field, uint32_t *ts);
+
+/*!
+ *
+ * -----------------------------------------------------------------------------
+ * @fn final_msg_set_ts()
+ *
+ * @brief Fill a given timestamp field in the final message with the given
+ * value. In the timestamp fields of the final
+ * message, the least significant byte is at the lower address.
+ *
+ * @param ts_field pointer on the first byte of the timestamp field to fill
+ * ts timestamp value
+ *
+ * @return none
+ */
+void final_msg_set_ts(uint8_t *ts_field, uint64_t ts);
+
+/*!
+ *
+ * -----------------------------------------------------------------------------
+ * @fn resp_msg_set_ts()
+ *
+ * @brief Fill a given timestamp field in the response message with the given
+ * value. In the timestamp fields of the
+ * response message, the least significant byte is at the lower address.
+ *
+ * @param ts_field pointer on the first byte of the timestamp field to fill
+ * ts timestamp value
+ *
+ * @return none
+ */
+void resp_msg_set_ts(uint8_t *ts_field, const uint64_t ts);
+
+/*!
+ *
+ * -----------------------------------------------------------------------------
+ * @brief This function will continuously read the system status register until
+ * it matches the bits set in the mask
+ * input parameter. It will then exit the function.
+ * This is useful to use when waiting on particular events to occurs. For
+ * example, the user could wait for a
+ * good UWB frame to be received and/or no receive errors have occurred.
+ * The lower 32-bits of the system status register will be read in a
+ * while loop. Each iteration of the loop will check if a matching
+ * mask value for the higher 32-bits of the system status register is
+ * set. If the mask value is set in the higher 32-bits of the system
+ * status register, the function will return that value along with the
+ * last recorded value of the lower 32-bits of the system status
+ * register. Thus, the user should be aware that this function will not
+ * wait for high and low mask values to be set in both the low and high
+ * system status registers. Alternatively, the user can call this
+ * function to *only* check the higher or lower system status registers.
+ *
+ * input parameters
+ * @param lo_result - A pointer to a uint32_t that will contain the final value
+ * of the system status register (lower 32 bits).
+ * Pass in a NULL pointer to ignore returning this value.
+ * @param hi_result - A pointer to a uint32_t that will contain the final value
+ * of the system status register (higher 32 bits).
+ * Pass in a NULL pointer to ignore returning this value.
+ * @param lo_mask - a uint32 mask value that is used to check for certain bits
+ * to be set in the system status register (lower 32 bits).
+ * Example values to use are as follows:
+ * DWT_INT_TXFRS_BIT_MASK - Wait for a TX frame to be sent.
+ * SYS_STATUS_RXFCG_BIT_MASK | SYS_STATUS_ALL_RX_ERR - Wait for
+ * frame to be received and no reception errors.
+ * SYS_STATUS_RXFCG_BIT_MASK | SYS_STATUS_ALL_RX_TO |
+ * SYS_STATUS_ALL_RX_ERR - Wait for frame to be received and no receive
+ * timeout errors and no reception errors.
+ * SYS_STATUS_RXFR_BIT_MASK | SYS_STATUS_ALL_RX_TO |
+ * SYS_STATUS_ALL_ND_RX_ERR - Wait for packet to be received and no receive
+ * timeout errors no reception errors. These flags are useful when polling for
+ * STS Mode 4 (no data) packets.
+ * 0 - The function will not wait for any bits in the system
+ * status register (lower 32 bits).
+ * @param hi_mask - a uint32 mask value that is used to check for certain bits
+ * to be set in the system status register (higher 32 bits).
+ * Example values to use are as follows:
+ * SYS_STATUS_HI_CCA_FAIL_BIT_MASK - Check for CCA fail status.
+ * 0 - The function will not wait for any bits in the system
+ * status register (lower 32 bits).
+ *
+ * return None
+ */
+void waitforsysstatus(uint32_t *lo_result,
+ uint32_t *hi_result,
+ uint32_t lo_mask,
+ uint32_t hi_mask);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
diff --git a/app/example/mikroe_uwb2_dwm3000/linker_files/brd2703a/linkerfile.ld b/app/example/mikroe_uwb2_dwm3000/linker_files/brd2703a/linkerfile.ld
new file mode 100644
index 00000000..dc1723aa
--- /dev/null
+++ b/app/example/mikroe_uwb2_dwm3000/linker_files/brd2703a/linkerfile.ld
@@ -0,0 +1,257 @@
+/***************************************************************************//**
+ * GCC Linker script for Silicon Labs devices
+ *******************************************************************************
+ * # License
+ * Copyright 2020 Silicon Laboratories Inc. www.silabs.com
+ *******************************************************************************
+ *
+ * SPDX-License-Identifier: Zlib
+ *
+ * The licensor of this software is Silicon Laboratories Inc.
+ *
+ * This software is provided 'as-is', without any express or implied
+ * warranty. In no event will the authors be held liable for any damages
+ * arising from the use of this software.
+ *
+ * Permission is granted to anyone to use this software for any purpose,
+ * including commercial applications, and to alter it and redistribute it
+ * freely, subject to the following restrictions:
+ *
+ * 1. The origin of this software must not be misrepresented; you must not
+ * claim that you wrote the original software. If you use this software
+ * in a product, an acknowledgment in the product documentation would be
+ * appreciated but is not required.
+ * 2. Altered source versions must be plainly marked as such, and must not be
+ * misrepresented as being the original software.
+ * 3. This notice may not be removed or altered from any source distribution.
+ *
+ ******************************************************************************/
+ MEMORY
+ {
+ FLASH (rx) : ORIGIN = 0x8000000, LENGTH = 0x17e000
+ RAM (rwx) : ORIGIN = 0x20000000, LENGTH = 0x40000
+ }
+
+ENTRY(Reset_Handler)
+
+SECTIONS
+{
+
+ .text :
+ {
+ linker_vectors_begin = .;
+ KEEP(*(.vectors))
+ linker_vectors_end = .;
+
+ __Vectors_End = .;
+ __Vectors_Size = __Vectors_End - __Vectors;
+
+ linker_code_begin = .;
+ *(SORT_BY_ALIGNMENT(.text*))
+ . = ALIGN(32);
+ linker_code_end = .;
+
+ KEEP(*(.init))
+ KEEP(*(.fini))
+
+ /* .ctors */
+ *crtbegin.o(.ctors)
+ *crtbegin?.o(.ctors)
+ *(EXCLUDE_FILE(*crtend?.o *crtend.o) .ctors)
+ *(SORT(.ctors.*))
+ *(.ctors)
+
+ /* .dtors */
+ *crtbegin.o(.dtors)
+ *crtbegin?.o(.dtors)
+ *(EXCLUDE_FILE(*crtend?.o *crtend.o) .dtors)
+ *(SORT(.dtors.*))
+ *(.dtors)
+
+ __code_classification_validator_start__ = .;
+ . = . + 0x20;
+ *(code_classification_validator)
+ . = ALIGN(32);
+ __code_classification_validator_end__ = .;
+
+ *(.rodata*)
+ *(.eh_frame*)
+ } > FLASH
+
+ .ARM.extab :
+ {
+ *(.ARM.extab* .gnu.linkonce.armextab.*)
+ } > FLASH
+
+ __exidx_start = .;
+ .ARM.exidx :
+ {
+ *(.ARM.exidx* .gnu.linkonce.armexidx.*)
+ } > FLASH
+ __exidx_end = .;
+
+ .copy.table :
+ {
+ . = ALIGN(4);
+ __copy_table_start__ = .;
+
+ LONG (__etext)
+ LONG (__data_start__)
+ LONG ((__data_end__ - __data_start__) / 4)
+
+ /* Add each additional data section here */
+/*
+ LONG (__etext2)
+ LONG (__data2_start__)
+ LONG ((__data2_end__ - __data2_start__) / 4)
+*/
+ __copy_table_end__ = .;
+ } > FLASH
+
+ .zero.table :
+ {
+ . = ALIGN(4);
+ __zero_table_start__ = .;
+ /* Add each additional bss section here */
+/*
+ LONG (__bss2_start__)
+ LONG ((__bss2_end__ - __bss2_start__) / 4)
+*/
+ __zero_table_end__ = .;
+ } > FLASH
+
+.dw_drivers ALIGN(4):
+ {
+ __dw_drivers_start = . ;
+ KEEP(*(.dw_drivers*))
+ __dw_drivers_end = . ;
+ } > FLASH
+
+ __etext = .;
+
+ /* Start placing output sections which are loaded into RAM */
+ . = ORIGIN(RAM);
+
+ .stack ALIGN(8) (NOLOAD):
+ {
+ __StackLimit = .;
+ KEEP(*(.stack*))
+ . = ALIGN(4);
+ __StackTop = .;
+ PROVIDE(__stack = __StackTop);
+ } > RAM
+
+
+ .noinit . (NOLOAD):
+ {
+ *(.noinit*);
+ } > RAM
+
+ .data . : AT (__etext)
+ {
+ . = ALIGN(4);
+ __data_start__ = .;
+ *(vtable)
+ *(SORT_BY_ALIGNMENT(.data*))
+ . = ALIGN(4);
+
+ PROVIDE(__ram_func_section_start = .);
+ *(.ram)
+ PROVIDE(__ram_func_section_end = .);
+
+ . = ALIGN(4);
+ /* preinit data */
+ PROVIDE_HIDDEN (__preinit_array_start = .);
+ KEEP(*(.preinit_array))
+ PROVIDE_HIDDEN (__preinit_array_end = .);
+
+ . = ALIGN(4);
+ /* init data */
+ PROVIDE_HIDDEN (__init_array_start = .);
+ KEEP(*(SORT(.init_array.*)))
+ KEEP(*(.init_array))
+ PROVIDE_HIDDEN (__init_array_end = .);
+
+ . = ALIGN(4);
+ /* finit data */
+ PROVIDE_HIDDEN (__fini_array_start = .);
+ KEEP(*(SORT(.fini_array.*)))
+ KEEP(*(.fini_array))
+ PROVIDE_HIDDEN (__fini_array_end = .);
+
+ . = ALIGN(4);
+ /* All data end */
+ __data_end__ = .;
+
+ } > RAM
+
+ .bss . :
+ {
+ . = ALIGN(4);
+ __bss_start__ = .;
+ *(SORT_BY_ALIGNMENT(.bss*))
+ *(COMMON)
+ . = ALIGN(4);
+ __bss_end__ = .;
+ } > RAM
+
+ __ramfuncs_start__ = .;
+
+ __vma_ramfuncs_start__ = .;
+ __lma_ramfuncs_start__ = __etext + SIZEOF(.data);
+
+ __text_application_ram_offset__ = . - __vma_ramfuncs_start__;
+ text_application_ram . : AT(__lma_ramfuncs_start__ + __text_application_ram_offset__)
+ {
+ . = ALIGN(4);
+ __text_application_ram_start__ = .;
+ *(text_application_ram)
+ . = ALIGN(4);
+ __text_application_ram_end__ = .;
+ } > RAM
+
+ . = ALIGN(4);
+ __vma_ramfuncs_end__ = .;
+ __lma_ramfuncs_end__ = __lma_ramfuncs_start__ + __text_application_ram_offset__ + SIZEOF(text_application_ram);
+
+ __ramfuncs_end__ = .;
+
+ .heap (COPY):
+ {
+ __HeapBase = .;
+ __end__ = .;
+ end = __end__;
+ _end = __end__;
+ KEEP(*(.heap*))
+ __HeapLimit = ORIGIN(RAM) + LENGTH(RAM);
+ } > RAM
+
+ __heap_size = __HeapLimit - __HeapBase;
+ __ram_end__ = 0x20000000 + 0x40000;
+ __main_flash_end__ = 0x8000000 + 0x17e000;
+
+ /* This is where we handle flash storage blocks. We use dummy sections for finding the configured
+ * block sizes and then "place" them at the end of flash when the size is known. */
+ .internal_storage (DSECT) : {
+ KEEP(*(.internal_storage*))
+ } > FLASH
+
+
+ .nvm (DSECT) : {
+ KEEP(*(.simee*))
+ } > FLASH
+
+ linker_nvm_end = __main_flash_end__;
+ linker_nvm_begin = linker_nvm_end - SIZEOF(.nvm);
+ linker_nvm_size = SIZEOF(.nvm);
+ linker_storage_end = linker_nvm_begin;
+ __nvm3Base = linker_nvm_begin;
+
+ linker_storage_begin = linker_storage_end - SIZEOF(.internal_storage);
+ linker_storage_size = SIZEOF(.internal_storage);
+ ASSERT((linker_storage_begin >= (__etext + SIZEOF(.data))), "FLASH memory overflowed !")
+
+
+ app_flash_end = 0x8000000 + 0x17e000;
+ ASSERT( (linker_nvm_begin + SIZEOF(.nvm)) <= app_flash_end, "NVM3 is excessing the flash size !")
+}
diff --git a/app/example/mikroe_uwb2_dwm3000/linker_files/brd4108a/linkerfile.ld b/app/example/mikroe_uwb2_dwm3000/linker_files/brd4108a/linkerfile.ld
new file mode 100644
index 00000000..257408b8
--- /dev/null
+++ b/app/example/mikroe_uwb2_dwm3000/linker_files/brd4108a/linkerfile.ld
@@ -0,0 +1,255 @@
+/***************************************************************************//**
+ * GCC Linker script for Silicon Labs devices
+ *******************************************************************************
+ * # License
+ * Copyright 2020 Silicon Laboratories Inc. www.silabs.com
+ *******************************************************************************
+ *
+ * SPDX-License-Identifier: Zlib
+ *
+ * The licensor of this software is Silicon Laboratories Inc.
+ *
+ * This software is provided 'as-is', without any express or implied
+ * warranty. In no event will the authors be held liable for any damages
+ * arising from the use of this software.
+ *
+ * Permission is granted to anyone to use this software for any purpose,
+ * including commercial applications, and to alter it and redistribute it
+ * freely, subject to the following restrictions:
+ *
+ * 1. The origin of this software must not be misrepresented; you must not
+ * claim that you wrote the original software. If you use this software
+ * in a product, an acknowledgment in the product documentation would be
+ * appreciated but is not required.
+ * 2. Altered source versions must be plainly marked as such, and must not be
+ * misrepresented as being the original software.
+ * 3. This notice may not be removed or altered from any source distribution.
+ *
+ ******************************************************************************/
+ MEMORY
+ {
+ FLASH (rx) : ORIGIN = 0x0, LENGTH = 0x7e000
+ RAM (rwx) : ORIGIN = 0x20000000, LENGTH = 0x8000
+ }
+
+ENTRY(Reset_Handler)
+
+SECTIONS
+{
+
+ .text :
+ {
+ linker_vectors_begin = .;
+ KEEP(*(.vectors))
+ linker_vectors_end = .;
+
+ __Vectors_End = .;
+ __Vectors_Size = __Vectors_End - __Vectors;
+
+ linker_code_begin = .;
+ *(SORT_BY_ALIGNMENT(.text*))
+ . = ALIGN(32);
+ linker_code_end = .;
+
+ KEEP(*(.init))
+ KEEP(*(.fini))
+
+ /* .ctors */
+ *crtbegin.o(.ctors)
+ *crtbegin?.o(.ctors)
+ *(EXCLUDE_FILE(*crtend?.o *crtend.o) .ctors)
+ *(SORT(.ctors.*))
+ *(.ctors)
+
+ /* .dtors */
+ *crtbegin.o(.dtors)
+ *crtbegin?.o(.dtors)
+ *(EXCLUDE_FILE(*crtend?.o *crtend.o) .dtors)
+ *(SORT(.dtors.*))
+ *(.dtors)
+
+ __code_classification_validator_start__ = .;
+ . = . + 0x20;
+ *(code_classification_validator)
+ . = ALIGN(32);
+ __code_classification_validator_end__ = .;
+
+ *(.rodata*)
+ *(.eh_frame*)
+ } > FLASH
+
+ .ARM.extab :
+ {
+ *(.ARM.extab* .gnu.linkonce.armextab.*)
+ } > FLASH
+
+ __exidx_start = .;
+ .ARM.exidx :
+ {
+ *(.ARM.exidx* .gnu.linkonce.armexidx.*)
+ } > FLASH
+ __exidx_end = .;
+
+ .copy.table :
+ {
+ . = ALIGN(4);
+ __copy_table_start__ = .;
+
+ LONG (__etext)
+ LONG (__data_start__)
+ LONG ((__data_end__ - __data_start__) / 4)
+
+ /* Add each additional data section here */
+/*
+ LONG (__etext2)
+ LONG (__data2_start__)
+ LONG ((__data2_end__ - __data2_start__) / 4)
+*/
+ __copy_table_end__ = .;
+ } > FLASH
+
+ .zero.table :
+ {
+ . = ALIGN(4);
+ __zero_table_start__ = .;
+ /* Add each additional bss section here */
+/*
+ LONG (__bss2_start__)
+ LONG ((__bss2_end__ - __bss2_start__) / 4)
+*/
+ __zero_table_end__ = .;
+ } > FLASH
+
+.dw_drivers ALIGN(4):
+ {
+ __dw_drivers_start = . ;
+ KEEP(*(.dw_drivers*))
+ __dw_drivers_end = . ;
+ } > FLASH
+
+ __etext = .;
+
+ /* Start placing output sections which are loaded into RAM */
+ . = ORIGIN(RAM);
+
+ .stack ALIGN(8) (NOLOAD):
+ {
+ __StackLimit = .;
+ KEEP(*(.stack*))
+ . = ALIGN(4);
+ __StackTop = .;
+ PROVIDE(__stack = __StackTop);
+ } > RAM
+
+
+ .noinit . (NOLOAD):
+ {
+ *(.noinit*);
+ } > RAM
+
+ .data . : AT (__etext)
+ {
+ . = ALIGN(4);
+ __data_start__ = .;
+ *(vtable)
+ *(SORT_BY_ALIGNMENT(.data*))
+ . = ALIGN(4);
+
+ PROVIDE(__ram_func_section_start = .);
+ *(.ram)
+ PROVIDE(__ram_func_section_end = .);
+
+ . = ALIGN(4);
+ /* preinit data */
+ PROVIDE_HIDDEN (__preinit_array_start = .);
+ KEEP(*(.preinit_array))
+ PROVIDE_HIDDEN (__preinit_array_end = .);
+
+ . = ALIGN(4);
+ /* init data */
+ PROVIDE_HIDDEN (__init_array_start = .);
+ KEEP(*(SORT(.init_array.*)))
+ KEEP(*(.init_array))
+ PROVIDE_HIDDEN (__init_array_end = .);
+
+ . = ALIGN(4);
+ /* finit data */
+ PROVIDE_HIDDEN (__fini_array_start = .);
+ KEEP(*(SORT(.fini_array.*)))
+ KEEP(*(.fini_array))
+ PROVIDE_HIDDEN (__fini_array_end = .);
+
+ . = ALIGN(4);
+ /* All data end */
+ __data_end__ = .;
+
+ } > RAM
+
+ .bss . :
+ {
+ . = ALIGN(4);
+ __bss_start__ = .;
+ *(SORT_BY_ALIGNMENT(.bss*))
+ *(COMMON)
+ . = ALIGN(4);
+ __bss_end__ = .;
+ } > RAM
+
+ __ramfuncs_start__ = .;
+
+ __vma_ramfuncs_start__ = .;
+ __lma_ramfuncs_start__ = __etext + SIZEOF(.data);
+
+ __text_application_ram_offset__ = . - __vma_ramfuncs_start__;
+ text_application_ram . : AT(__lma_ramfuncs_start__ + __text_application_ram_offset__)
+ {
+ . = ALIGN(4);
+ __text_application_ram_start__ = .;
+ *(text_application_ram)
+ . = ALIGN(4);
+ __text_application_ram_end__ = .;
+ } > RAM
+
+ . = ALIGN(4);
+ __vma_ramfuncs_end__ = .;
+ __lma_ramfuncs_end__ = __lma_ramfuncs_start__ + __text_application_ram_offset__ + SIZEOF(text_application_ram);
+
+ __ramfuncs_end__ = .;
+
+ .heap (COPY):
+ {
+ __HeapBase = .;
+ __end__ = .;
+ end = __end__;
+ _end = __end__;
+ KEEP(*(.heap*))
+ __HeapLimit = ORIGIN(RAM) + LENGTH(RAM);
+ } > RAM
+
+ __heap_size = __HeapLimit - __HeapBase;
+ __ram_end__ = 0x20000000 + 0x8000;
+ __main_flash_end__ = 0x0 + 0x7e000;
+
+ /* This is where we handle flash storage blocks. We use dummy sections for finding the configured
+ * block sizes and then "place" them at the end of flash when the size is known. */
+ .internal_storage (DSECT) : {
+ KEEP(*(.internal_storage*))
+ } > FLASH
+
+
+ .nvm (DSECT) : {
+ KEEP(*(.simee*))
+ } > FLASH
+
+ linker_nvm_end = __main_flash_end__;
+ linker_nvm_begin = linker_nvm_end - SIZEOF(.nvm);
+ linker_nvm_size = SIZEOF(.nvm);
+ linker_storage_end = linker_nvm_begin;
+ __nvm3Base = linker_nvm_begin;
+
+ linker_storage_begin = linker_storage_end - SIZEOF(.internal_storage);
+ linker_storage_size = SIZEOF(.internal_storage);
+ ASSERT((linker_storage_begin >= (__etext + SIZEOF(.data))), "FLASH memory overflowed !")
+
+
+}
diff --git a/app/example/mikroe_uwb2_dwm3000/linker_files/brd4314a/linkerfile.ld b/app/example/mikroe_uwb2_dwm3000/linker_files/brd4314a/linkerfile.ld
new file mode 100644
index 00000000..257408b8
--- /dev/null
+++ b/app/example/mikroe_uwb2_dwm3000/linker_files/brd4314a/linkerfile.ld
@@ -0,0 +1,255 @@
+/***************************************************************************//**
+ * GCC Linker script for Silicon Labs devices
+ *******************************************************************************
+ * # License
+ * Copyright 2020 Silicon Laboratories Inc. www.silabs.com
+ *******************************************************************************
+ *
+ * SPDX-License-Identifier: Zlib
+ *
+ * The licensor of this software is Silicon Laboratories Inc.
+ *
+ * This software is provided 'as-is', without any express or implied
+ * warranty. In no event will the authors be held liable for any damages
+ * arising from the use of this software.
+ *
+ * Permission is granted to anyone to use this software for any purpose,
+ * including commercial applications, and to alter it and redistribute it
+ * freely, subject to the following restrictions:
+ *
+ * 1. The origin of this software must not be misrepresented; you must not
+ * claim that you wrote the original software. If you use this software
+ * in a product, an acknowledgment in the product documentation would be
+ * appreciated but is not required.
+ * 2. Altered source versions must be plainly marked as such, and must not be
+ * misrepresented as being the original software.
+ * 3. This notice may not be removed or altered from any source distribution.
+ *
+ ******************************************************************************/
+ MEMORY
+ {
+ FLASH (rx) : ORIGIN = 0x0, LENGTH = 0x7e000
+ RAM (rwx) : ORIGIN = 0x20000000, LENGTH = 0x8000
+ }
+
+ENTRY(Reset_Handler)
+
+SECTIONS
+{
+
+ .text :
+ {
+ linker_vectors_begin = .;
+ KEEP(*(.vectors))
+ linker_vectors_end = .;
+
+ __Vectors_End = .;
+ __Vectors_Size = __Vectors_End - __Vectors;
+
+ linker_code_begin = .;
+ *(SORT_BY_ALIGNMENT(.text*))
+ . = ALIGN(32);
+ linker_code_end = .;
+
+ KEEP(*(.init))
+ KEEP(*(.fini))
+
+ /* .ctors */
+ *crtbegin.o(.ctors)
+ *crtbegin?.o(.ctors)
+ *(EXCLUDE_FILE(*crtend?.o *crtend.o) .ctors)
+ *(SORT(.ctors.*))
+ *(.ctors)
+
+ /* .dtors */
+ *crtbegin.o(.dtors)
+ *crtbegin?.o(.dtors)
+ *(EXCLUDE_FILE(*crtend?.o *crtend.o) .dtors)
+ *(SORT(.dtors.*))
+ *(.dtors)
+
+ __code_classification_validator_start__ = .;
+ . = . + 0x20;
+ *(code_classification_validator)
+ . = ALIGN(32);
+ __code_classification_validator_end__ = .;
+
+ *(.rodata*)
+ *(.eh_frame*)
+ } > FLASH
+
+ .ARM.extab :
+ {
+ *(.ARM.extab* .gnu.linkonce.armextab.*)
+ } > FLASH
+
+ __exidx_start = .;
+ .ARM.exidx :
+ {
+ *(.ARM.exidx* .gnu.linkonce.armexidx.*)
+ } > FLASH
+ __exidx_end = .;
+
+ .copy.table :
+ {
+ . = ALIGN(4);
+ __copy_table_start__ = .;
+
+ LONG (__etext)
+ LONG (__data_start__)
+ LONG ((__data_end__ - __data_start__) / 4)
+
+ /* Add each additional data section here */
+/*
+ LONG (__etext2)
+ LONG (__data2_start__)
+ LONG ((__data2_end__ - __data2_start__) / 4)
+*/
+ __copy_table_end__ = .;
+ } > FLASH
+
+ .zero.table :
+ {
+ . = ALIGN(4);
+ __zero_table_start__ = .;
+ /* Add each additional bss section here */
+/*
+ LONG (__bss2_start__)
+ LONG ((__bss2_end__ - __bss2_start__) / 4)
+*/
+ __zero_table_end__ = .;
+ } > FLASH
+
+.dw_drivers ALIGN(4):
+ {
+ __dw_drivers_start = . ;
+ KEEP(*(.dw_drivers*))
+ __dw_drivers_end = . ;
+ } > FLASH
+
+ __etext = .;
+
+ /* Start placing output sections which are loaded into RAM */
+ . = ORIGIN(RAM);
+
+ .stack ALIGN(8) (NOLOAD):
+ {
+ __StackLimit = .;
+ KEEP(*(.stack*))
+ . = ALIGN(4);
+ __StackTop = .;
+ PROVIDE(__stack = __StackTop);
+ } > RAM
+
+
+ .noinit . (NOLOAD):
+ {
+ *(.noinit*);
+ } > RAM
+
+ .data . : AT (__etext)
+ {
+ . = ALIGN(4);
+ __data_start__ = .;
+ *(vtable)
+ *(SORT_BY_ALIGNMENT(.data*))
+ . = ALIGN(4);
+
+ PROVIDE(__ram_func_section_start = .);
+ *(.ram)
+ PROVIDE(__ram_func_section_end = .);
+
+ . = ALIGN(4);
+ /* preinit data */
+ PROVIDE_HIDDEN (__preinit_array_start = .);
+ KEEP(*(.preinit_array))
+ PROVIDE_HIDDEN (__preinit_array_end = .);
+
+ . = ALIGN(4);
+ /* init data */
+ PROVIDE_HIDDEN (__init_array_start = .);
+ KEEP(*(SORT(.init_array.*)))
+ KEEP(*(.init_array))
+ PROVIDE_HIDDEN (__init_array_end = .);
+
+ . = ALIGN(4);
+ /* finit data */
+ PROVIDE_HIDDEN (__fini_array_start = .);
+ KEEP(*(SORT(.fini_array.*)))
+ KEEP(*(.fini_array))
+ PROVIDE_HIDDEN (__fini_array_end = .);
+
+ . = ALIGN(4);
+ /* All data end */
+ __data_end__ = .;
+
+ } > RAM
+
+ .bss . :
+ {
+ . = ALIGN(4);
+ __bss_start__ = .;
+ *(SORT_BY_ALIGNMENT(.bss*))
+ *(COMMON)
+ . = ALIGN(4);
+ __bss_end__ = .;
+ } > RAM
+
+ __ramfuncs_start__ = .;
+
+ __vma_ramfuncs_start__ = .;
+ __lma_ramfuncs_start__ = __etext + SIZEOF(.data);
+
+ __text_application_ram_offset__ = . - __vma_ramfuncs_start__;
+ text_application_ram . : AT(__lma_ramfuncs_start__ + __text_application_ram_offset__)
+ {
+ . = ALIGN(4);
+ __text_application_ram_start__ = .;
+ *(text_application_ram)
+ . = ALIGN(4);
+ __text_application_ram_end__ = .;
+ } > RAM
+
+ . = ALIGN(4);
+ __vma_ramfuncs_end__ = .;
+ __lma_ramfuncs_end__ = __lma_ramfuncs_start__ + __text_application_ram_offset__ + SIZEOF(text_application_ram);
+
+ __ramfuncs_end__ = .;
+
+ .heap (COPY):
+ {
+ __HeapBase = .;
+ __end__ = .;
+ end = __end__;
+ _end = __end__;
+ KEEP(*(.heap*))
+ __HeapLimit = ORIGIN(RAM) + LENGTH(RAM);
+ } > RAM
+
+ __heap_size = __HeapLimit - __HeapBase;
+ __ram_end__ = 0x20000000 + 0x8000;
+ __main_flash_end__ = 0x0 + 0x7e000;
+
+ /* This is where we handle flash storage blocks. We use dummy sections for finding the configured
+ * block sizes and then "place" them at the end of flash when the size is known. */
+ .internal_storage (DSECT) : {
+ KEEP(*(.internal_storage*))
+ } > FLASH
+
+
+ .nvm (DSECT) : {
+ KEEP(*(.simee*))
+ } > FLASH
+
+ linker_nvm_end = __main_flash_end__;
+ linker_nvm_begin = linker_nvm_end - SIZEOF(.nvm);
+ linker_nvm_size = SIZEOF(.nvm);
+ linker_storage_end = linker_nvm_begin;
+ __nvm3Base = linker_nvm_begin;
+
+ linker_storage_begin = linker_storage_end - SIZEOF(.internal_storage);
+ linker_storage_size = SIZEOF(.internal_storage);
+ ASSERT((linker_storage_begin >= (__etext + SIZEOF(.data))), "FLASH memory overflowed !")
+
+
+}
diff --git a/app/example/mikroe_uwb2_dwm3000/main.c b/app/example/mikroe_uwb2_dwm3000/main.c
new file mode 100644
index 00000000..b6aa4e33
--- /dev/null
+++ b/app/example/mikroe_uwb2_dwm3000/main.c
@@ -0,0 +1,80 @@
+/***************************************************************************//**
+ * @file main.c
+ * @brief main() function.
+ *******************************************************************************
+ *******************************************************************************
+ * # License
+ * Copyright 2022 Silicon Laboratories Inc. www.silabs.com
+ *******************************************************************************
+ *
+ * SPDX-License-Identifier: Zlib
+ *
+ * The licensor of this software is Silicon Laboratories Inc.
+ *
+ * This software is provided \'as-is\', without any express or implied
+ * warranty. In no event will the authors be held liable for any damages
+ * arising from the use of this software.
+ *
+ * Permission is granted to anyone to use this software for any purpose,
+ * including commercial applications, and to alter it and redistribute it
+ * freely, subject to the following restrictions:
+ *
+ * 1. The origin of this software must not be misrepresented; you must not
+ * claim that you wrote the original software. If you use this software
+ * in a product, an acknowledgment in the product documentation would be
+ * appreciated but is not required.
+ * 2. Altered source versions must be plainly marked as such, and must not be
+ * misrepresented as being the original software.
+ * 3. This notice may not be removed or altered from any source distribution.
+ *
+ *******************************************************************************
+ *
+ * EVALUATION QUALITY
+ * This code has been minimally tested to ensure that it builds with the
+ * specified dependency versions and is suitable as a demonstration for
+ * evaluation purposes only.
+ * This code will be maintained at the sole discretion of Silicon Labs.
+ *
+ ******************************************************************************/
+#include "sl_component_catalog.h"
+#include "sl_system_init.h"
+#include "app.h"
+#if defined(SL_CATALOG_POWER_MANAGER_PRESENT)
+#include "sl_power_manager.h"
+#endif
+#if defined(SL_CATALOG_KERNEL_PRESENT)
+#include "sl_system_kernel.h"
+#else // SL_CATALOG_KERNEL_PRESENT
+#include "sl_system_process_action.h"
+#endif // SL_CATALOG_KERNEL_PRESENT
+
+int main(void)
+{
+ // Initialize Silicon Labs device, system, service(s) and protocol stack(s).
+ // Note that if the kernel is present, processing task(s) will be created by
+ // this call.
+ sl_system_init();
+
+ // Initialize the application. For example, create periodic timer(s) or
+ // task(s) if the kernel is present.
+ app_init();
+
+#if defined(SL_CATALOG_KERNEL_PRESENT)
+ // Start the kernel. Task(s) created in app_init() will start running.
+ sl_system_kernel_start();
+#else // SL_CATALOG_KERNEL_PRESENT
+ while (1) {
+ // Do not remove this call: Silicon Labs components process action routine
+ // must be called from the super loop.
+ sl_system_process_action();
+
+ // Application process.
+ app_process_action();
+
+#if defined(SL_CATALOG_POWER_MANAGER_PRESENT)
+ // Let the CPU go to sleep if the system allows it.
+ sl_power_manager_sleep();
+#endif
+ }
+#endif // SL_CATALOG_KERNEL_PRESENT
+}
diff --git a/app/example/mikroe_water_detect/mikroe_water_detect.slcp b/app/example/mikroe_water_detect/mikroe_water_detect.slcp
index 2d94b023..e34ca039 100644
--- a/app/example/mikroe_water_detect/mikroe_water_detect.slcp
+++ b/app/example/mikroe_water_detect/mikroe_water_detect.slcp
@@ -42,7 +42,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/mikroe_water_detect/image/create_example.png
diff --git a/app/example/silabs_ir_generate/silabs_ir_generate.slcp b/app/example/silabs_ir_generate/silabs_ir_generate.slcp
index 4a176e20..0dd5a62b 100644
--- a/app/example/silabs_ir_generate/silabs_ir_generate.slcp
+++ b/app/example/silabs_ir_generate/silabs_ir_generate.slcp
@@ -33,7 +33,7 @@ define:
- name: DEBUG_EFM
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/silabs_ir_generate/image/create_example.png
directory: "image"
diff --git a/app/example/silabs_lin_bus/slave/silabs_lin_slave1.slcp b/app/example/silabs_lin_bus/slave/silabs_lin_slave1.slcp
index 008ffc0f..bc5bc501 100644
--- a/app/example/silabs_lin_bus/slave/silabs_lin_slave1.slcp
+++ b/app/example/silabs_lin_bus/slave/silabs_lin_slave1.slcp
@@ -86,7 +86,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../../documentation/example/silabs_lin_bus/images/hardware_connection.jpg
diff --git a/app/example/silabs_lin_bus/slave/silabs_lin_slave2.slcp b/app/example/silabs_lin_bus/slave/silabs_lin_slave2.slcp
index 5d1943eb..34a5ef31 100644
--- a/app/example/silabs_lin_bus/slave/silabs_lin_slave2.slcp
+++ b/app/example/silabs_lin_bus/slave/silabs_lin_slave2.slcp
@@ -85,7 +85,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../../documentation/example/silabs_lin_bus/images/hardware_connection.jpg
diff --git a/app/example/silabs_pir_ira_s210st01/silabs_pir_ira_s210st01.slcp b/app/example/silabs_pir_ira_s210st01/silabs_pir_ira_s210st01.slcp
index 3d250438..57bfdf25 100644
--- a/app/example/silabs_pir_ira_s210st01/silabs_pir_ira_s210st01.slcp
+++ b/app/example/silabs_pir_ira_s210st01/silabs_pir_ira_s210st01.slcp
@@ -43,7 +43,7 @@ define:
- name: DEBUG_EFM
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
ui_hints:
highlight:
- path: README.md
diff --git a/app/example/silabs_triac/silabs_triac.slcp b/app/example/silabs_triac/silabs_triac.slcp
index a2cc7a50..5ef0b569 100644
--- a/app/example/silabs_triac/silabs_triac.slcp
+++ b/app/example/silabs_triac/silabs_triac.slcp
@@ -33,7 +33,7 @@ define:
- name: DEBUG_EFM
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/silabs_triac/image/create_example.png
directory: "image"
diff --git a/app/example/sparkfun_accelerometer_mma8452q/sparkfun_accelerometer_mma8452q.slcp b/app/example/sparkfun_accelerometer_mma8452q/sparkfun_accelerometer_mma8452q.slcp
index 72b42ee0..97e6b91d 100644
--- a/app/example/sparkfun_accelerometer_mma8452q/sparkfun_accelerometer_mma8452q.slcp
+++ b/app/example/sparkfun_accelerometer_mma8452q/sparkfun_accelerometer_mma8452q.slcp
@@ -52,7 +52,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/sparkfun_accelerometer_mma8452q/image/api_overview.png
diff --git a/app/example/sparkfun_air_quality_sgp40/sparkfun_air_quality_sgp40.slcp b/app/example/sparkfun_air_quality_sgp40/sparkfun_air_quality_sgp40.slcp
index f319dbf9..7b6ee651 100644
--- a/app/example/sparkfun_air_quality_sgp40/sparkfun_air_quality_sgp40.slcp
+++ b/app/example/sparkfun_air_quality_sgp40/sparkfun_air_quality_sgp40.slcp
@@ -51,7 +51,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/sparkfun_air_quality_sgp40/image/create_example.png
diff --git a/app/example/sparkfun_distance_vl53l1x/sparkfun_distance_vl53l1x.slcp b/app/example/sparkfun_distance_vl53l1x/sparkfun_distance_vl53l1x.slcp
index 1192bd18..b593ff45 100644
--- a/app/example/sparkfun_distance_vl53l1x/sparkfun_distance_vl53l1x.slcp
+++ b/app/example/sparkfun_distance_vl53l1x/sparkfun_distance_vl53l1x.slcp
@@ -52,7 +52,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/sparkfun_distance_vl53l1x/image/create_example.png
diff --git a/app/example/sparkfun_dosimeter_type5/sparkfun_dosimeter_type5.slcp b/app/example/sparkfun_dosimeter_type5/sparkfun_dosimeter_type5.slcp
index 299b6c32..6c68d12a 100644
--- a/app/example/sparkfun_dosimeter_type5/sparkfun_dosimeter_type5.slcp
+++ b/app/example/sparkfun_dosimeter_type5/sparkfun_dosimeter_type5.slcp
@@ -44,7 +44,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/sparkfun_dosimeter_type5/image/connection.png
diff --git a/app/example/sparkfun_environmental_bme280_ccs811/sparkfun_environmental_bme280_ccs811.slcp b/app/example/sparkfun_environmental_bme280_ccs811/sparkfun_environmental_bme280_ccs811.slcp
index 570c14b8..77b2ac4a 100644
--- a/app/example/sparkfun_environmental_bme280_ccs811/sparkfun_environmental_bme280_ccs811.slcp
+++ b/app/example/sparkfun_environmental_bme280_ccs811/sparkfun_environmental_bme280_ccs811.slcp
@@ -53,7 +53,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/sparkfun_environmental_bme280_ccs811/image/console_log.png
diff --git a/app/example/sparkfun_hr_po_max30101_max32664/sparkfun_hr_po_max30101_max32664.slcp b/app/example/sparkfun_hr_po_max30101_max32664/sparkfun_hr_po_max30101_max32664.slcp
index 8e47749c..352626d1 100644
--- a/app/example/sparkfun_hr_po_max30101_max32664/sparkfun_hr_po_max30101_max32664.slcp
+++ b/app/example/sparkfun_hr_po_max30101_max32664/sparkfun_hr_po_max30101_max32664.slcp
@@ -51,7 +51,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/sparkfun_hr_po_max30101_max32664/image/create_example.png
diff --git a/app/example/sparkfun_human_presence_ak9753/sparkfun_human_presence_ak9753.slcp b/app/example/sparkfun_human_presence_ak9753/sparkfun_human_presence_ak9753.slcp
index 9552043d..35a8f894 100644
--- a/app/example/sparkfun_human_presence_ak9753/sparkfun_human_presence_ak9753.slcp
+++ b/app/example/sparkfun_human_presence_ak9753/sparkfun_human_presence_ak9753.slcp
@@ -54,7 +54,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/sparkfun_human_presence_ak9753/image/create_example.png
diff --git a/app/example/sparkfun_ir_array_amg88xx/sparkfun_ir_array_amg88xx.slcp b/app/example/sparkfun_ir_array_amg88xx/sparkfun_ir_array_amg88xx.slcp
index a3bd1158..86190c8b 100644
--- a/app/example/sparkfun_ir_array_amg88xx/sparkfun_ir_array_amg88xx.slcp
+++ b/app/example/sparkfun_ir_array_amg88xx/sparkfun_ir_array_amg88xx.slcp
@@ -53,7 +53,7 @@ configuration:
value: "6144"
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/sparkfun_ir_array_amg88xx/image/create_example.png
directory: image
diff --git a/app/example/sparkfun_ir_array_mlx90640/sparkfun_ir_array_mlx90640.slcp b/app/example/sparkfun_ir_array_mlx90640/sparkfun_ir_array_mlx90640.slcp
index 96a86cbf..bca1e540 100644
--- a/app/example/sparkfun_ir_array_mlx90640/sparkfun_ir_array_mlx90640.slcp
+++ b/app/example/sparkfun_ir_array_mlx90640/sparkfun_ir_array_mlx90640.slcp
@@ -62,7 +62,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/sparkfun_ir_array_mlx90640/image/connection.png
diff --git a/app/example/sparkfun_micro_oled_ssd1306/sparkfun_micro_oled_ssd1306.slcp b/app/example/sparkfun_micro_oled_ssd1306/sparkfun_micro_oled_ssd1306.slcp
index 5b67a21b..0fff6649 100644
--- a/app/example/sparkfun_micro_oled_ssd1306/sparkfun_micro_oled_ssd1306.slcp
+++ b/app/example/sparkfun_micro_oled_ssd1306/sparkfun_micro_oled_ssd1306.slcp
@@ -57,7 +57,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/sparkfun_micro_oled_ssd1306/image/bgm220_kit_sparkfun_oled.png
diff --git a/app/example/sparkfun_particulate_matter_sensor_sps30/sparkfun_particulate_matter_sensor_sps30_i2c.slcp b/app/example/sparkfun_particulate_matter_sensor_sps30/sparkfun_particulate_matter_sensor_sps30_i2c.slcp
index bccc6e97..290a237d 100644
--- a/app/example/sparkfun_particulate_matter_sensor_sps30/sparkfun_particulate_matter_sensor_sps30_i2c.slcp
+++ b/app/example/sparkfun_particulate_matter_sensor_sps30/sparkfun_particulate_matter_sensor_sps30_i2c.slcp
@@ -46,7 +46,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/sparkfun_particulate_matter_sensor_sps30/image/hw_connection_1.png
diff --git a/app/example/sparkfun_particulate_matter_sensor_sps30/sparkfun_particulate_matter_sensor_sps30_uart.slcp b/app/example/sparkfun_particulate_matter_sensor_sps30/sparkfun_particulate_matter_sensor_sps30_uart.slcp
index 633ba810..da33554d 100644
--- a/app/example/sparkfun_particulate_matter_sensor_sps30/sparkfun_particulate_matter_sensor_sps30_uart.slcp
+++ b/app/example/sparkfun_particulate_matter_sensor_sps30/sparkfun_particulate_matter_sensor_sps30_uart.slcp
@@ -46,7 +46,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/sparkfun_particulate_matter_sensor_sps30/image/hw_connection_1.png
diff --git a/app/example/sparkfun_proximity_vcnl4040/sparkfun_proximity_vcnl4040.slcp b/app/example/sparkfun_proximity_vcnl4040/sparkfun_proximity_vcnl4040.slcp
index 51ad7dee..c7681276 100644
--- a/app/example/sparkfun_proximity_vcnl4040/sparkfun_proximity_vcnl4040.slcp
+++ b/app/example/sparkfun_proximity_vcnl4040/sparkfun_proximity_vcnl4040.slcp
@@ -52,7 +52,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/sparkfun_proximity_vcnl4040/image/connection.png
diff --git a/app/example/sparkfun_qwiic_joystick/sparkfun_qwiic_joystick.slcp b/app/example/sparkfun_qwiic_joystick/sparkfun_qwiic_joystick.slcp
index 452f243a..e27e02fe 100644
--- a/app/example/sparkfun_qwiic_joystick/sparkfun_qwiic_joystick.slcp
+++ b/app/example/sparkfun_qwiic_joystick/sparkfun_qwiic_joystick.slcp
@@ -51,7 +51,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/sparkfun_qwiic_joystick/image/logs.png
diff --git a/app/example/sparkfun_qwiic_keypad/sparkfun_qwiic_keypad.slcp b/app/example/sparkfun_qwiic_keypad/sparkfun_qwiic_keypad.slcp
index 454c3b7a..c9292bcc 100644
--- a/app/example/sparkfun_qwiic_keypad/sparkfun_qwiic_keypad.slcp
+++ b/app/example/sparkfun_qwiic_keypad/sparkfun_qwiic_keypad.slcp
@@ -52,7 +52,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/sparkfun_qwiic_keypad/image/logs.png
diff --git a/app/example/sparkfun_rfid_id12la/sparkfun_rfid_id12la.slcp b/app/example/sparkfun_rfid_id12la/sparkfun_rfid_id12la.slcp
index 61452e69..16cbdd90 100644
--- a/app/example/sparkfun_rfid_id12la/sparkfun_rfid_id12la.slcp
+++ b/app/example/sparkfun_rfid_id12la/sparkfun_rfid_id12la.slcp
@@ -43,7 +43,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/sparkfun_rfid_id12la/image/api_overview.png
diff --git a/app/example/sparkfun_soil_moisture/sparkfun_soil_moisture.slcp b/app/example/sparkfun_soil_moisture/sparkfun_soil_moisture.slcp
index 55196616..932d4a28 100644
--- a/app/example/sparkfun_soil_moisture/sparkfun_soil_moisture.slcp
+++ b/app/example/sparkfun_soil_moisture/sparkfun_soil_moisture.slcp
@@ -49,7 +49,7 @@ config_file:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
define:
- name: DEBUG_EFM
diff --git a/app/example/sparkfun_spectroscopy_as7265x/sparkfun_spectroscopy_as7265x.slcp b/app/example/sparkfun_spectroscopy_as7265x/sparkfun_spectroscopy_as7265x.slcp
index dfbf8dbc..33a0719d 100644
--- a/app/example/sparkfun_spectroscopy_as7265x/sparkfun_spectroscopy_as7265x.slcp
+++ b/app/example/sparkfun_spectroscopy_as7265x/sparkfun_spectroscopy_as7265x.slcp
@@ -56,7 +56,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/sparkfun_spectroscopy_as7265x/image/basic_reading.png
diff --git a/app/example/sparkfun_weatherstation/sparkfun_weatherstation.slcp b/app/example/sparkfun_weatherstation/sparkfun_weatherstation.slcp
index 50263d15..bd301f41 100644
--- a/app/example/sparkfun_weatherstation/sparkfun_weatherstation.slcp
+++ b/app/example/sparkfun_weatherstation/sparkfun_weatherstation.slcp
@@ -45,7 +45,7 @@ define:
sdk_extension:
- id: third_party_hw_drivers
- version: 2.0.1
+ version: 2.0.2
other_file:
- path: ../../documentation/example/sparkfun_weatherstation/image/create_example.png
diff --git a/driver/component/drivers/silabs/silabs_uwb2_dwm3000.slcc b/driver/component/drivers/silabs/silabs_uwb2_dwm3000.slcc
new file mode 100644
index 00000000..d797c410
--- /dev/null
+++ b/driver/component/drivers/silabs/silabs_uwb2_dwm3000.slcc
@@ -0,0 +1,94 @@
+id: mikroe_uwb2_dwm3000
+package: third_party_hw_drivers
+label: DWM3000 - UWB 2 Click (Mikroe)
+description: Driver for the Mikroe DWM3000 UWB 2 Click.
+category: Wireless Connectivity
+quality: evaluation
+ui_hints:
+ visibility: basic
+root_path: driver
+
+requires:
+ - name: status
+ - name: udelay
+ - name: spidrv_core
+ - name: sleeptimer
+ - name: gpiointerrupt
+
+provides:
+ - name: mikroe_uwb2_dwm3000
+
+template_contribution:
+ - name: component_catalog
+ value: mikroe_uwb2_dwm3000
+
+config_file:
+ - path: public/silabs/uwb2_dwm3000/config/brd2703a/uwb2_dwm3000_config.h
+ file_id: driver_config_dwm3000
+ condition: [brd2703a]
+ - path: public/silabs/uwb2_dwm3000/config/brd4108a/uwb2_dwm3000_config.h
+ file_id: driver_config_dwm3000
+ condition: [brd4108a]
+ - path: public/silabs/uwb2_dwm3000/config/brd4314a/uwb2_dwm3000_config.h
+ file_id: driver_config_dwm3000
+ condition: [brd4314a]
+ - path: public/silabs/uwb2_dwm3000/config/other/uwb2_dwm3000_config.h
+ file_id: driver_config_dwm3000
+ unless: [brd4314a, brd4108a, brd2703a]
+
+include:
+ - path: inc
+ file_list:
+ - path: third_party_hw_drivers_helpers.h
+ - path: thirdparty/decawave/uwb2_dwm3000/inc
+ file_list:
+ - path: deca_device_api.h
+ - path: deca_interface.h
+ - path: deca_types.h
+ - path: deca_version.h
+ - path: common.h
+ - path: deca_dbg.h
+ - path: error.h
+ - path: rtls_interface.h
+ - path: uwb_frames.h
+ - path: version.h
+ - path: public/silabs/uwb2_dwm3000/platform/deca_probe
+ file_list:
+ - path: deca_probe_interface.h
+ - path: public/silabs/uwb2_dwm3000/platform/deca_spi
+ file_list:
+ - path: deca_spi.h
+ - path: public/silabs/uwb2_dwm3000/platform/port
+ file_list:
+ - path: port_hal.h
+ - path: port.h
+source:
+ - path: public/silabs/uwb2_dwm3000/platform/deca_probe/deca_probe_interface.c
+ - path: public/silabs/uwb2_dwm3000/platform/deca_sleep/deca_sleep.c
+ - path: public/silabs/uwb2_dwm3000/platform/deca_spi/deca_spi.c
+ - path: public/silabs/uwb2_dwm3000/platform/port/port_dw3000.c
+
+toolchain_settings:
+ - option: gcc_linker_option
+ value: "-Wl,--whole-archive ../libdwt_uwb_driver-m33-hfp-6.0.7.a -Wl,--no-whole-archive"
+ condition:
+ - "toolchain_gcc"
+ - "cortexm33"
+ - option: gcc_linker_option
+ value: "-Wl,--whole-archive ../libdwt_uwb_driver-m4-hfp-6.0.7.a -Wl,--no-whole-archive"
+ condition:
+ - "toolchain_gcc"
+ - "cortexm4"
+other_file:
+ - path: "thirdparty/decawave/uwb2_dwm3000/lib/libdwt_uwb_driver-m33-hfp-6.0.7.a"
+ condition:
+ - "toolchain_gcc"
+ - "cortexm33"
+ project:
+ transfer_ownership: true
+ - path: "thirdparty/decawave/uwb2_dwm3000/lib/libdwt_uwb_driver-m4-hfp-6.0.7.a"
+ condition:
+ - "toolchain_gcc"
+ - "cortexm4"
+ project:
+ transfer_ownership: true
\ No newline at end of file
diff --git a/driver/public/silabs/bthome_v2/src/bthome_v2.c b/driver/public/silabs/bthome_v2/src/bthome_v2.c
index c3a8cabd..859f7590 100644
--- a/driver/public/silabs/bthome_v2/src/bthome_v2.c
+++ b/driver/public/silabs/bthome_v2/src/bthome_v2.c
@@ -45,7 +45,7 @@
// -----------------------------------------------------------------------------
// Static Variables Declarations
// -----------------------------------------------------------------------------
-static uint8_t sensor_data_index;
+static uint8_t sensor_data_index = 0;
static uint8_t sensor_data[MEASUREMENT_MAX_LEN] = { 0 };
static uint8_t *dev_name;
static bool b_encrypt_enable;
@@ -74,6 +74,8 @@ static uint16_t get_factor(uint8_t sens);
static void sort_sensor_data(void);
+static void remove_oldest_sensor_data(void);
+
// -----------------------------------------------------------------------------
// Public Function Definitions
// -----------------------------------------------------------------------------
@@ -151,6 +153,7 @@ void bthome_v2_build_packet(void)
uint8_t address_type;
// dev_name length
uint8_t dn_length;
+ uint8_t dn_flag = COMPLETE_NAME;
// build encrypt
uint8_t ciphertext[MEASUREMENT_MAX_LEN];
uint8_t encryption_mic[MIC_LEN];
@@ -175,30 +178,34 @@ void bthome_v2_build_packet(void)
// local name
if (!sl_str_is_empty((const char *)dev_name)) {
- // +1(flag Complete local name)
- dn_length = sl_strlen((char *)dev_name) + 1;
+ // +1(flag name)+1(name length)
+ dn_length = sl_strlen((char *)dev_name) + 2;
if (b_encrypt_enable) {
// deal with the device name to make sure the adv length <= 31
- // 18=3(FLAG)+1(device name length bit)+1(COMPLETE_NAME)+1(SERVICE_DATA)
- // +2(UUID)+1(ENCRYPT)+4(nonce)+4(mic)+1(serviceData length bit)
- if (dn_length > BLE_ADVERT_MAX_LEN - sensor_data_index - 18) {
- dn_length = BLE_ADVERT_MAX_LEN - sensor_data_index - 18;
+ // 16=3(FLAG)+2(UUID)+1(ENCRYPT)
+ // +4(nonce)+4(mic)+1(serviceData length bit)
+ if (dn_length > BLE_ADVERT_MAX_LEN - sensor_data_index - 16) {
+ dn_length = BLE_ADVERT_MAX_LEN - sensor_data_index - 16;
+ dn_flag = SHORT_NAME;
}
} else {
- // 10=3(FLAG)+1(device name length bit)+1(COMPLETE_NAME)
- // +1(SERVICE_DATA)+2(UUID)+1(ENCRYPT)+1(serviceData length bit)
- if (dn_length > BLE_ADVERT_MAX_LEN - sensor_data_index - 10) {
- dn_length = BLE_ADVERT_MAX_LEN - sensor_data_index - 10;
+ // 8=3(FLAG)+1(SERVICE_DATA)+2(UUID)
+ // +1(ENCRYPT)+1(serviceData length bit)
+ if (dn_length > BLE_ADVERT_MAX_LEN - sensor_data_index - 8) {
+ dn_length = BLE_ADVERT_MAX_LEN - sensor_data_index - 8;
+ dn_flag = SHORT_NAME;
}
}
// Add the length of the Name
// Complete_Name: Complete local name -- Short_Name: Shortened Name
- payload_data[payload_count++] = dn_length;
- payload_data[payload_count++] = COMPLETE_NAME;
- for (uint8_t i = 0; i < (dn_length - 1); i++) {
- payload_data[payload_count++] = dev_name[i];
+ if (dn_length > 2) {
+ payload_data[payload_count++] = dn_length - 1;
+ payload_data[payload_count++] = dn_flag;
+ for (uint8_t i = 0; i < (dn_length - 2); i++) {
+ payload_data[payload_count++] = dev_name[i];
+ }
}
}
@@ -327,6 +334,10 @@ void bthome_v2_add_measurement_state(uint8_t sensor_id,
uint8_t state,
uint8_t steps)
{
+ if (sensor_id == EVENT_BUTTON) {
+ steps = 0;
+ }
+
if ((sensor_data_index + 2 + ((steps > 0) ? 1 : 0))
<= (MEASUREMENT_MAX_LEN - (b_encrypt_enable ? 8 : 0))) {
sensor_data[sensor_data_index] = sensor_id & 0xff;
@@ -345,6 +356,7 @@ void bthome_v2_add_measurement_state(uint8_t sensor_id,
last_object_id = sensor_id;
} else {
bthome_v2_send_packet();
+ remove_oldest_sensor_data();
bthome_v2_add_measurement_state(sensor_id, state, steps);
}
}
@@ -360,8 +372,7 @@ void bthome_v2_add_measurement(uint8_t sensor_id, uint64_t value)
<= (MEASUREMENT_MAX_LEN - (b_encrypt_enable ? 8 : 0))) {
sensor_data[sensor_data_index] = sensor_id & 0xff;
sensor_data_index++;
- for (uint8_t i = 0; i < size; i++)
- {
+ for (uint8_t i = 0; i < size; i++) {
sensor_data[sensor_data_index] =
(uint8_t)(((value * factor) >> (8 * i)) & 0xff);
sensor_data_index++;
@@ -374,6 +385,7 @@ void bthome_v2_add_measurement(uint8_t sensor_id, uint64_t value)
last_object_id = sensor_id;
} else {
bthome_v2_send_packet();
+ remove_oldest_sensor_data();
bthome_v2_add_measurement(sensor_id, value);
}
}
@@ -390,8 +402,7 @@ void bthome_v2_add_measurement_float(uint8_t sensor_id, float value)
uint64_t value2 = (uint64_t)(value * factor);
sensor_data[sensor_data_index] = sensor_id & 0xff;
sensor_data_index++;
- for (uint8_t i = 0; i < size; i++)
- {
+ for (uint8_t i = 0; i < size; i++) {
sensor_data[sensor_data_index] = (uint8_t)((value2 >> (8 * i)) & 0xff);
sensor_data_index++;
}
@@ -403,6 +414,7 @@ void bthome_v2_add_measurement_float(uint8_t sensor_id, float value)
last_object_id = sensor_id;
} else {
bthome_v2_send_packet();
+ remove_oldest_sensor_data();
bthome_v2_add_measurement_float(sensor_id, value);
}
}
@@ -648,3 +660,16 @@ static void sort_sensor_data(void)
}
}
}
+
+/***************************************************************************//**
+ * Sort the sensor data.
+ ******************************************************************************/
+static void remove_oldest_sensor_data(void)
+{
+ uint8_t remove_length = get_byte_number(sensor_data[0]) + 1;
+
+ for (uint8_t i = 0; i < sensor_data_index - remove_length; i++) {
+ sensor_data[i] = sensor_data[i + remove_length];
+ }
+ sensor_data_index = sensor_data_index - remove_length;
+}
diff --git a/driver/public/silabs/uwb2_dwm3000/config/brd2703a/uwb2_dwm3000_config.h b/driver/public/silabs/uwb2_dwm3000/config/brd2703a/uwb2_dwm3000_config.h
new file mode 100644
index 00000000..437d743d
--- /dev/null
+++ b/driver/public/silabs/uwb2_dwm3000/config/brd2703a/uwb2_dwm3000_config.h
@@ -0,0 +1,127 @@
+/***************************************************************************//**
+ * @file mikroe_uwb2_dwm3000_config.h
+ * @brief DWM3000 UWB config.
+ * @version 0.0.1
+ *******************************************************************************
+ * # License
+ * Copyright 2024 Silicon Laboratories Inc. www.silabs.com
+ *******************************************************************************
+ *
+ * SPDX-License-Identifier: Zlib
+ *
+ * The licensor of this software is Silicon Laboratories Inc.
+ *
+ * This software is provided \'as-is\', without any express or implied
+ * warranty. In no event will the authors be held liable for any damages
+ * arising from the use of this software.
+ *
+ * Permission is granted to anyone to use this software for any purpose,
+ * including commercial applications, and to alter it and redistribute it
+ * freely, subject to the following restrictions:
+ *
+ * 1. The origin of this software must not be misrepresented; you must not
+ * claim that you wrote the original software. If you use this software
+ * in a product, an acknowledgment in the product documentation would be
+ * appreciated but is not required.
+ * 2. Altered source versions must be plainly marked as such, and must not be
+ * misrepresented as being the original software.
+ * 3. This notice may not be removed or altered from any source distribution.
+ *
+ *******************************************************************************
+ *
+ * EVALUATION QUALITY
+ * This code has been minimally tested to ensure that it builds with the
+ * specified dependency versions and is suitable as a demonstration for
+ * evaluation purposes only.
+ * This code will be maintained at the sole discretion of Silicon Labs.
+ *
+ ******************************************************************************/
+#ifndef DWM3000_CONFIG_H_
+#define DWM3000_CONFIG_H_
+
+#ifdef __cplusplus
+extern "C"
+{
+#endif
+
+// <<< Use Configuration Wizard in Context Menu
+// SPI Driver settings
+
+// HAL SPI TYPE
+// USART
+// EUSART
+#define DWM3000_SPI_TYPE EUSART
+
+// HAL SPI NUMBER
+// <0=> 0
+// <1=> 1
+// <2=> 2
+#define DWM3000_SPI_NUMBER 1
+
+// SPI FREQUENCY MIN (Hz)
+// 2000000
+#define DWM3000_FREQ_MIN 2000000
+
+// SPI FREQUENCY MAX (Hz)
+// 19500000
+#define DWM3000_FREQ_MAX 19500000
+
+//
+// <<< end of configuration section >>>
+
+// <<< sl:start pin_tool >>>
+
+// DWM3000_RESET
+// $[GPIO_DWM3000_RESET]
+#define DWM3000_RESET_PORT gpioPortC
+#define DWM3000_RESET_PIN 8
+// [GPIO_DWM3000_RESET]$
+
+// DWM3000_INT
+// $[GPIO_DWM3000_INT]
+#define DWM3000_INT_PORT gpioPortB
+#define DWM3000_INT_PIN 1
+// [GPIO_DWM3000_INT]$
+
+// DWM3000_WAKE
+// $[GPIO_DWM3000_WAKE]
+// #define DWM3000_WAKE_PORT gpioPortB
+// #define DWM3000_WAKE_PIN 0
+// [GPIO_DWM3000_WAKE]$
+
+// DWM3000_ON
+// $[GPIO_DWM3000_ON]
+#define DWM3000_ON_PORT gpioPortA
+#define DWM3000_ON_PIN 0
+// [GPIO_DWM3000_ON]$
+
+// DWM3000_CS
+// $[GPIO_DWM3000_CS]
+#define DWM3000_CS_PORT gpioPortC
+#define DWM3000_CS_PIN 0
+// [GPIO_DWM3000_CS]$
+
+// DWM3000_CLK
+// $[GPIO_DWM3000_CLK]
+#define DWM3000_CLK_PORT gpioPortC
+#define DWM3000_CLK_PIN 1
+// [GPIO_DWM3000_CLK]$
+
+// DWM3000_MISO
+// $[GPIO_DWM3000_MISO]
+#define DWM3000_MISO_PORT gpioPortC
+#define DWM3000_MISO_PIN 2
+// [GPIO_DWM3000_MISO]$
+
+// DWM3000_MOSI
+// $[GPIO_DWM3000_MOSI]
+#define DWM3000_MOSI_PORT gpioPortC
+#define DWM3000_MOSI_PIN 3
+// [GPIO_DWM3000_MOSI]$
+
+// <<< sl:end pin_tool >>>
+
+#ifdef __cplusplus
+}
+#endif
+#endif /* DWM3000_CONFIG_H_ */
diff --git a/driver/public/silabs/uwb2_dwm3000/config/brd4108a/uwb2_dwm3000_config.h b/driver/public/silabs/uwb2_dwm3000/config/brd4108a/uwb2_dwm3000_config.h
new file mode 100644
index 00000000..2ccd61a5
--- /dev/null
+++ b/driver/public/silabs/uwb2_dwm3000/config/brd4108a/uwb2_dwm3000_config.h
@@ -0,0 +1,159 @@
+/***************************************************************************//**
+ * @file mikroe_uwb2_dwm3000_config.h
+ * @brief DWM3000 UWB config.
+ * @version 0.0.1
+ *******************************************************************************
+ * # License
+ * Copyright 2024 Silicon Laboratories Inc. www.silabs.com
+ *******************************************************************************
+ *
+ * SPDX-License-Identifier: Zlib
+ *
+ * The licensor of this software is Silicon Laboratories Inc.
+ *
+ * This software is provided \'as-is\', without any express or implied
+ * warranty. In no event will the authors be held liable for any damages
+ * arising from the use of this software.
+ *
+ * Permission is granted to anyone to use this software for any purpose,
+ * including commercial applications, and to alter it and redistribute it
+ * freely, subject to the following restrictions:
+ *
+ * 1. The origin of this software must not be misrepresented; you must not
+ * claim that you wrote the original software. If you use this software
+ * in a product, an acknowledgment in the product documentation would be
+ * appreciated but is not required.
+ * 2. Altered source versions must be plainly marked as such, and must not be
+ * misrepresented as being the original software.
+ * 3. This notice may not be removed or altered from any source distribution.
+ *
+ *******************************************************************************
+ *
+ * EVALUATION QUALITY
+ * This code has been minimally tested to ensure that it builds with the
+ * specified dependency versions and is suitable as a demonstration for
+ * evaluation purposes only.
+ * This code will be maintained at the sole discretion of Silicon Labs.
+ *
+ ******************************************************************************/
+#ifndef DWM3000_CONFIG_H_
+#define DWM3000_CONFIG_H_
+
+#ifdef __cplusplus
+extern "C"
+{
+#endif
+
+// <<< Use Configuration Wizard in Context Menu
+// SPI Driver settings
+
+// HAL SPI TYPE
+// USART
+// EUSART
+#define DWM3000_SPI_TYPE USART
+
+// HAL SPI NUMBER
+// <0=> 0
+// <1=> 1
+// <2=> 2
+#define DWM3000_SPI_NUMBER 0
+
+// SPI FREQUENCY MIN (Hz)
+// 2000000
+#define DWM3000_FREQ_MIN 2000000
+
+// SPI FREQUENCY MAX (Hz)
+// 19500000
+#define DWM3000_FREQ_MAX 19500000
+
+//
+// <<< end of configuration section >>>
+
+// <<< sl:start pin_tool >>>
+
+// DWM3000_RESET
+// $[GPIO_DWM3000_RESET]
+#ifndef DWM3000_RESET_PORT
+#define DWM3000_RESET_PORT gpioPortC
+#endif
+#ifndef DWM3000_RESET_PIN
+#define DWM3000_RESET_PIN 6
+#endif
+// [GPIO_DWM3000_RESET]$
+
+// DWM3000_INT
+// $[GPIO_DWM3000_INT]
+#ifndef DWM3000_INT_PORT
+#define DWM3000_INT_PORT gpioPortB
+#endif
+#ifndef DWM3000_INT_PIN
+#define DWM3000_INT_PIN 3
+#endif
+// [GPIO_DWM3000_INT]$
+
+// DWM3000_WAKE
+// $[GPIO_DWM3000_WAKE]
+// #ifndef DWM3000_WAKE_PORT
+// #define DWM3000_WAKE_PORT gpioPortB
+// #endif
+// #ifndef DWM3000_WAKE_PIN
+// #define DWM3000_WAKE_PIN 0
+// #endif
+// [GPIO_DWM3000_WAKE]$
+
+// DWM3000_ON
+// $[GPIO_DWM3000_ON]
+#ifndef DWM3000_ON_PORT
+#define DWM3000_ON_PORT gpioPortB
+#endif
+#ifndef DWM3000_ON_PIN
+#define DWM3000_ON_PIN 4
+#endif
+// [GPIO_DWM3000_ON]$
+
+// DWM3000_CS
+// $[GPIO_DWM3000_CS]
+#ifndef DWM3000_CS_PORT
+#define DWM3000_CS_PORT gpioPortC
+#endif
+#ifndef DWM3000_CS_PIN
+#define DWM3000_CS_PIN 3
+#endif
+// [GPIO_DWM3000_CS]$
+
+// DWM3000_CLK
+// $[GPIO_DWM3000_CLK]
+#ifndef DWM3000_CLK_PORT
+#define DWM3000_CLK_PORT gpioPortC
+#endif
+#ifndef DWM3000_CLK_PIN
+#define DWM3000_CLK_PIN 2
+#endif
+// [GPIO_DWM3000_CLK]$
+
+// DWM3000_MISO
+// $[GPIO_DWM3000_MISO]
+#ifndef DWM3000_MISO_PORT
+#define DWM3000_MISO_PORT gpioPortC
+#endif
+#ifndef DWM3000_MISO_PIN
+#define DWM3000_MISO_PIN 1
+#endif
+// [GPIO_DWM3000_MISO]$
+
+// DWM3000_MOSI
+// $[GPIO_DWM3000_MOSI]
+#ifndef DWM3000_MOSI_PORT
+#define DWM3000_MOSI_PORT gpioPortC
+#endif
+#ifndef DWM3000_MOSI_PIN
+#define DWM3000_MOSI_PIN 0
+#endif
+// [GPIO_DWM3000_MOSI]$
+
+// <<< sl:end pin_tool >>>
+
+#ifdef __cplusplus
+}
+#endif
+#endif /* DWM3000_CONFIG_H_ */
diff --git a/driver/public/silabs/uwb2_dwm3000/config/brd4314a/uwb2_dwm3000_config.h b/driver/public/silabs/uwb2_dwm3000/config/brd4314a/uwb2_dwm3000_config.h
new file mode 100644
index 00000000..2ccd61a5
--- /dev/null
+++ b/driver/public/silabs/uwb2_dwm3000/config/brd4314a/uwb2_dwm3000_config.h
@@ -0,0 +1,159 @@
+/***************************************************************************//**
+ * @file mikroe_uwb2_dwm3000_config.h
+ * @brief DWM3000 UWB config.
+ * @version 0.0.1
+ *******************************************************************************
+ * # License
+ * Copyright 2024 Silicon Laboratories Inc. www.silabs.com
+ *******************************************************************************
+ *
+ * SPDX-License-Identifier: Zlib
+ *
+ * The licensor of this software is Silicon Laboratories Inc.
+ *
+ * This software is provided \'as-is\', without any express or implied
+ * warranty. In no event will the authors be held liable for any damages
+ * arising from the use of this software.
+ *
+ * Permission is granted to anyone to use this software for any purpose,
+ * including commercial applications, and to alter it and redistribute it
+ * freely, subject to the following restrictions:
+ *
+ * 1. The origin of this software must not be misrepresented; you must not
+ * claim that you wrote the original software. If you use this software
+ * in a product, an acknowledgment in the product documentation would be
+ * appreciated but is not required.
+ * 2. Altered source versions must be plainly marked as such, and must not be
+ * misrepresented as being the original software.
+ * 3. This notice may not be removed or altered from any source distribution.
+ *
+ *******************************************************************************
+ *
+ * EVALUATION QUALITY
+ * This code has been minimally tested to ensure that it builds with the
+ * specified dependency versions and is suitable as a demonstration for
+ * evaluation purposes only.
+ * This code will be maintained at the sole discretion of Silicon Labs.
+ *
+ ******************************************************************************/
+#ifndef DWM3000_CONFIG_H_
+#define DWM3000_CONFIG_H_
+
+#ifdef __cplusplus
+extern "C"
+{
+#endif
+
+// <<< Use Configuration Wizard in Context Menu
+// SPI Driver settings
+
+// HAL SPI TYPE
+// USART
+// EUSART
+#define DWM3000_SPI_TYPE USART
+
+// HAL SPI NUMBER
+// <0=> 0
+// <1=> 1
+// <2=> 2
+#define DWM3000_SPI_NUMBER 0
+
+// SPI FREQUENCY MIN (Hz)
+// 2000000
+#define DWM3000_FREQ_MIN 2000000
+
+// SPI FREQUENCY MAX (Hz)
+// 19500000
+#define DWM3000_FREQ_MAX 19500000
+
+//
+// <<< end of configuration section >>>
+
+// <<< sl:start pin_tool >>>
+
+// DWM3000_RESET
+// $[GPIO_DWM3000_RESET]
+#ifndef DWM3000_RESET_PORT
+#define DWM3000_RESET_PORT gpioPortC
+#endif
+#ifndef DWM3000_RESET_PIN
+#define DWM3000_RESET_PIN 6
+#endif
+// [GPIO_DWM3000_RESET]$
+
+// DWM3000_INT
+// $[GPIO_DWM3000_INT]
+#ifndef DWM3000_INT_PORT
+#define DWM3000_INT_PORT gpioPortB
+#endif
+#ifndef DWM3000_INT_PIN
+#define DWM3000_INT_PIN 3
+#endif
+// [GPIO_DWM3000_INT]$
+
+// DWM3000_WAKE
+// $[GPIO_DWM3000_WAKE]
+// #ifndef DWM3000_WAKE_PORT
+// #define DWM3000_WAKE_PORT gpioPortB
+// #endif
+// #ifndef DWM3000_WAKE_PIN
+// #define DWM3000_WAKE_PIN 0
+// #endif
+// [GPIO_DWM3000_WAKE]$
+
+// DWM3000_ON
+// $[GPIO_DWM3000_ON]
+#ifndef DWM3000_ON_PORT
+#define DWM3000_ON_PORT gpioPortB
+#endif
+#ifndef DWM3000_ON_PIN
+#define DWM3000_ON_PIN 4
+#endif
+// [GPIO_DWM3000_ON]$
+
+// DWM3000_CS
+// $[GPIO_DWM3000_CS]
+#ifndef DWM3000_CS_PORT
+#define DWM3000_CS_PORT gpioPortC
+#endif
+#ifndef DWM3000_CS_PIN
+#define DWM3000_CS_PIN 3
+#endif
+// [GPIO_DWM3000_CS]$
+
+// DWM3000_CLK
+// $[GPIO_DWM3000_CLK]
+#ifndef DWM3000_CLK_PORT
+#define DWM3000_CLK_PORT gpioPortC
+#endif
+#ifndef DWM3000_CLK_PIN
+#define DWM3000_CLK_PIN 2
+#endif
+// [GPIO_DWM3000_CLK]$
+
+// DWM3000_MISO
+// $[GPIO_DWM3000_MISO]
+#ifndef DWM3000_MISO_PORT
+#define DWM3000_MISO_PORT gpioPortC
+#endif
+#ifndef DWM3000_MISO_PIN
+#define DWM3000_MISO_PIN 1
+#endif
+// [GPIO_DWM3000_MISO]$
+
+// DWM3000_MOSI
+// $[GPIO_DWM3000_MOSI]
+#ifndef DWM3000_MOSI_PORT
+#define DWM3000_MOSI_PORT gpioPortC
+#endif
+#ifndef DWM3000_MOSI_PIN
+#define DWM3000_MOSI_PIN 0
+#endif
+// [GPIO_DWM3000_MOSI]$
+
+// <<< sl:end pin_tool >>>
+
+#ifdef __cplusplus
+}
+#endif
+#endif /* DWM3000_CONFIG_H_ */
diff --git a/driver/public/silabs/uwb2_dwm3000/config/other/uwb2_dwm3000_config.h b/driver/public/silabs/uwb2_dwm3000/config/other/uwb2_dwm3000_config.h
new file mode 100644
index 00000000..734a3eed
--- /dev/null
+++ b/driver/public/silabs/uwb2_dwm3000/config/other/uwb2_dwm3000_config.h
@@ -0,0 +1,167 @@
+/***************************************************************************//**
+ * @file mikroe_uwb2_dwm3000_config.h
+ * @brief DWM3000 UWB config.
+ * @version 0.0.1
+ *******************************************************************************
+ * # License
+ * Copyright 2024 Silicon Laboratories Inc. www.silabs.com
+ *******************************************************************************
+ *
+ * SPDX-License-Identifier: Zlib
+ *
+ * The licensor of this software is Silicon Laboratories Inc.
+ *
+ * This software is provided \'as-is\', without any express or implied
+ * warranty. In no event will the authors be held liable for any damages
+ * arising from the use of this software.
+ *
+ * Permission is granted to anyone to use this software for any purpose,
+ * including commercial applications, and to alter it and redistribute it
+ * freely, subject to the following restrictions:
+ *
+ * 1. The origin of this software must not be misrepresented; you must not
+ * claim that you wrote the original software. If you use this software
+ * in a product, an acknowledgment in the product documentation would be
+ * appreciated but is not required.
+ * 2. Altered source versions must be plainly marked as such, and must not be
+ * misrepresented as being the original software.
+ * 3. This notice may not be removed or altered from any source distribution.
+ *
+ *******************************************************************************
+ *
+ * EVALUATION QUALITY
+ * This code has been minimally tested to ensure that it builds with the
+ * specified dependency versions and is suitable as a demonstration for
+ * evaluation purposes only.
+ * This code will be maintained at the sole discretion of Silicon Labs.
+ *
+ ******************************************************************************/
+#ifndef DWM3000_CONFIG_H_
+#define DWM3000_CONFIG_H_
+
+#ifdef __cplusplus
+extern "C"
+{
+#endif
+
+// <<< Use Configuration Wizard in Context Menu
+// SPI Driver settings
+
+// HAL SPI TYPE
+// USART
+// EUSART
+#define DWM3000_SPI_TYPE EUSART
+
+// HAL SPI NUMBER
+// <0=> 0
+// <1=> 1
+// <2=> 2
+#define DWM3000_SPI_NUMBER 1
+
+// SPI FREQUENCY MIN (Hz)
+// 2000000
+#define DWM3000_FREQ_MIN 2000000
+
+// SPI FREQUENCY MAX (Hz)
+// 19500000
+#define DWM3000_FREQ_MAX 19500000
+
+//
+// <<< end of configuration section >>>
+
+// <<< sl:start pin_tool >>>
+
+// DWM3000_RESET
+// $[GPIO_DWM3000_RESET]
+#warning "DWM3000_RESET is not configured"
+// #ifndef DWM3000_RESET_PORT
+// #define DWM3000_RESET_PORT gpioPortC
+// #endif
+// #ifndef DWM3000_RESET_PIN
+// #define DWM3000_RESET_PIN 8
+// #endif
+// [GPIO_DWM3000_RESET]$
+
+// DWM3000_INT
+// $[GPIO_DWM3000_INT]
+#warning "DWM3000_INT is not configured"
+// #ifndef DWM3000_INT_PORT
+// #define DWM3000_INT_PORT gpioPortB
+// #endif
+// #ifndef DWM3000_INT_PIN
+// #define DWM3000_INT_PIN 1
+// #endif
+// [GPIO_DWM3000_INT]$
+
+// DWM3000_WAKE
+// $[GPIO_DWM3000_WAKE]
+//#warning "DWM3000_WAKE is not configured"
+// #ifndef DWM3000_WAKE_PORT
+// #define DWM3000_WAKE_PORT gpioPortB
+// #endif
+// #ifndef DWM3000_WAKE_PIN
+// #define DWM3000_WAKE_PIN 0
+// #endif
+// [GPIO_DWM3000_WAKE]$
+
+// DWM3000_ON
+// $[GPIO_DWM3000_ON]
+#warning "DWM3000_ON is not configured"
+// #ifndef DWM3000_ON_PORT
+// #define DWM3000_ON_PORT gpioPortA
+// #endif
+// #ifndef DWM3000_ON_PIN
+// #define DWM3000_ON_PIN 0
+// #endif
+// [GPIO_DWM3000_ON]$
+
+// DWM3000_CS
+// $[GPIO_DWM3000_CS]
+#warning "DWM3000_CS is not configured"
+// #ifndef DWM3000_CS_PORT
+// #define DWM3000_CS_PORT gpioPortC
+// #endif
+// #ifndef DWM3000_CS_PIN
+// #define DWM3000_CS_PIN 0
+// #endif
+// [GPIO_DWM3000_CS]$
+
+// DWM3000_CLK
+// $[GPIO_DWM3000_CLK]
+#warning "DWM3000_CLK is not configured"
+// #ifndef DWM3000_CLK_PORT
+// #define DWM3000_CLK_PORT gpioPortC
+// #endif
+// #ifndef DWM3000_CLK_PIN
+// #define DWM3000_CLK_PIN 1
+// #endif
+// [GPIO_DWM3000_CLK]$
+
+// DWM3000_MISO
+// $[GPIO_DWM3000_MISO]
+#warning "DWM3000_MISO is not configured"
+// #ifndef DWM3000_MISO_PORT
+// #define DWM3000_MISO_PORT gpioPortC
+// #endif
+// #ifndef DWM3000_MISO_PIN
+// #define DWM3000_MISO_PIN 2
+// #endif
+// [GPIO_DWM3000_MISO]$
+
+// DWM3000_MOSI
+// $[GPIO_DWM3000_MOSI]
+#warning "DWM3000_MOSI is not configured"
+// #ifndef DWM3000_MOSI_PORT
+// #define DWM3000_MOSI_PORT gpioPortC
+// #endif
+// #ifndef DWM3000_MOSI_PIN
+// #define DWM3000_MOSI_PIN 3
+// #endif
+// [GPIO_DWM3000_MOSI]$
+
+// <<< sl:end pin_tool >>>
+
+#ifdef __cplusplus
+}
+#endif
+#endif /* DWM3000_CONFIG_H_ */
diff --git a/driver/public/silabs/uwb2_dwm3000/platform/deca_probe/deca_probe_interface.c b/driver/public/silabs/uwb2_dwm3000/platform/deca_probe/deca_probe_interface.c
new file mode 100644
index 00000000..69b88157
--- /dev/null
+++ b/driver/public/silabs/uwb2_dwm3000/platform/deca_probe/deca_probe_interface.c
@@ -0,0 +1,31 @@
+/*! ----------------------------------------------------------------------------
+ * @file deca_probe_interface.c
+ * @brief Interface structure. Provides external dependencies required by the
+ * driver
+ *
+ * @attention
+ *
+ * Copyright 2015 - 2021 (c) DecaWave Ltd, Dublin, Ireland.
+ *
+ * All rights reserved.
+ *
+ */
+#include "deca_probe_interface.h"
+#include "deca_interface.h"
+#include "deca_spi.h"
+#include "port.h"
+
+static const struct dwt_spi_s dw3000_spi_fct = {
+ .readfromspi = readfromspi,
+ .writetospi = writetospi,
+ .writetospiwithcrc = writetospiwithcrc,
+ .setslowrate = set_dw_spi_slow_rate,
+ .setfastrate = set_dw_spi_fast_rate
+};
+
+const struct dwt_probe_s dw3000_probe_interf =
+{
+ .dw = NULL,
+ .spi = (void *)&dw3000_spi_fct,
+ .wakeup_device_with_io = wakeup_device_with_io
+};
diff --git a/driver/public/silabs/uwb2_dwm3000/platform/deca_probe/deca_probe_interface.h b/driver/public/silabs/uwb2_dwm3000/platform/deca_probe/deca_probe_interface.h
new file mode 100644
index 00000000..95cceca0
--- /dev/null
+++ b/driver/public/silabs/uwb2_dwm3000/platform/deca_probe/deca_probe_interface.h
@@ -0,0 +1,19 @@
+/*! ----------------------------------------------------------------------------
+ * @file deca_probe_interface.h
+ * @brief Interface structure. Provides external dependencies required by the
+ * driver
+ *
+ * @attention
+ *
+ * Copyright 2015 - 2021 (c) DecaWave Ltd, Dublin, Ireland.
+ *
+ * All rights reserved.
+ *
+ */
+#ifndef DECA_PROBE_INTERFACE_H
+#define DECA_PROBE_INTERFACE_H
+#include "deca_device_api.h"
+
+extern const struct dwt_probe_s dw3000_probe_interf;
+
+#endif
diff --git a/driver/public/silabs/uwb2_dwm3000/platform/deca_sleep/deca_sleep.c b/driver/public/silabs/uwb2_dwm3000/platform/deca_sleep/deca_sleep.c
new file mode 100644
index 00000000..a1a72262
--- /dev/null
+++ b/driver/public/silabs/uwb2_dwm3000/platform/deca_sleep/deca_sleep.c
@@ -0,0 +1,28 @@
+/**-
+ * @file deca_sleep.c
+ *
+ * @brief platform dependent sleep implementation
+ *
+ * @attention
+ *
+ * Copyright 2015 (c) Decawave Ltd, Dublin, Ireland.
+ *
+ * All rights reserved.
+ *
+ * @author Decawave
+ */
+
+#include "port.h"
+#include "sl_udelay.h"
+
+/* Wrapper function to be used by decadriver. Declared in deca_device_api.h */
+void deca_sleep(unsigned int time_ms)
+{
+ sl_udelay_wait(time_ms * 1000);
+}
+
+/* Wrapper function to be used by decadriver. Declared in deca_device_api.h */
+void deca_usleep(unsigned long time_us)
+{
+ sl_udelay_wait(time_us);
+}
diff --git a/driver/public/silabs/uwb2_dwm3000/platform/deca_spi/deca_spi.c b/driver/public/silabs/uwb2_dwm3000/platform/deca_spi/deca_spi.c
new file mode 100644
index 00000000..eaf1176d
--- /dev/null
+++ b/driver/public/silabs/uwb2_dwm3000/platform/deca_spi/deca_spi.c
@@ -0,0 +1,227 @@
+/**
+ * @file deca_spi.c
+ *
+ * @brief SPI functions to interface to DW3000 chip's from EFR32.
+ *
+ * @author Decawave
+ *
+ * @attention Copyright 2017-2019 (c) Decawave Ltd, Dublin, Ireland.
+ * All rights reserved.
+ *
+ */
+
+#include "port.h"
+#include "em_cmu.h"
+#include "em_gpio.h"
+#include "em_eusart.h"
+#include "em_usart.h"
+#include "spidrv.h"
+#if defined (SL_CATALOG_POWER_MANAGER_PRESENT)
+#include "sl_power_manager.h"
+#endif
+#include "deca_spi.h"
+#include
+
+#ifndef SPI_USE_SPIDRV_API
+#define SPI_USE_SPIDRV_API 0
+#endif
+#define SPI_GPIO_SLOW_SLEWRATE 5
+#define SPI_GPIO_FAST_SLEWRATE 7
+#define SPI_DUMMY_TX_VALUE 0xFF
+
+#define EUSART_SpiTransfer EUSART_Spi_TxRx
+#define spi_tx_rx(data) HAL_CAT2(HAL_SPI_TYPE, _SpiTransfer)(HAL_SPI_PERIPHERAL, \
+ data)
+
+static SPIDRV_HandleData_t spi_driver_handle;
+static volatile bool spi_lock;
+
+/*!
+ *
+ * -----------------------------------------------------------------------------
+ * Function: openspi()
+ *
+ * Low level abstract function to open and initialise access to the SPI device.
+ * returns 0 for success, or -1 for error
+ */
+int openspi(void)
+{
+ SPIDRV_Init_t spi_init = {
+ .port = HAL_SPI_PERIPHERAL,
+ .portTx = HAL_SPI_MOSI_PORT,
+ .portRx = HAL_SPI_MISO_PORT,
+ .portClk = HAL_SPI_CLK_PORT,
+ .portCs = HAL_SPI_CS_PORT,
+ .pinTx = HAL_SPI_MOSI_PIN,
+ .pinRx = HAL_SPI_MISO_PIN,
+ .pinClk = HAL_SPI_CLK_PIN,
+ .pinCs = HAL_SPI_CS_PIN,
+ .bitRate = HAL_SPI_FREQ_MIN,
+ .frameLength = 8,
+ .dummyTxValue = SPI_DUMMY_TX_VALUE,
+ .type = spidrvMaster,
+ .bitOrder = spidrvBitOrderMsbFirst,
+ .clockMode = spidrvClockMode0,
+ .csControl = spidrvCsControlApplication,
+ };
+
+ CMU_ClockEnable(cmuClock_GPIO, true);
+ GPIO_SlewrateSet(spi_init.portClk,
+ SPI_GPIO_SLOW_SLEWRATE,
+ SPI_GPIO_SLOW_SLEWRATE);
+ GPIO_SlewrateSet(spi_init.portTx,
+ SPI_GPIO_SLOW_SLEWRATE,
+ SPI_GPIO_SLOW_SLEWRATE);
+ GPIO_PinModeSet(spi_init.portCs, spi_init.pinCs, gpioModePushPull, 1);
+ return SPIDRV_Init(&spi_driver_handle, &spi_init);
+}
+
+/*!
+ *
+ * -----------------------------------------------------------------------------
+ * Function: closespi()
+ *
+ * Low level abstract function to close the the SPI device.
+ * returns 0 for success, or -1 for error
+ */
+int closespi(void)
+{
+ return SPIDRV_DeInit(&spi_driver_handle);
+}
+
+static void port_spi_set_bitrate(uint32_t goal_bitrate)
+{
+ uint32_t required_slewrate =
+ (goal_bitrate
+ >= 10000000) ? SPI_GPIO_FAST_SLEWRATE : SPI_GPIO_SLOW_SLEWRATE;
+ GPIO_SlewrateSet(spi_driver_handle.initData.portClk,
+ required_slewrate,
+ required_slewrate);
+ GPIO_SlewrateSet(spi_driver_handle.initData.portTx,
+ required_slewrate,
+ required_slewrate);
+ SPIDRV_SetBitrate(&spi_driver_handle, goal_bitrate);
+}
+
+/* @fn set_dw_spi_slow_rate
+ * @brief sets slow SPI clock speed for the DW chip
+ * left for compatibility.
+ * */
+void set_dw_spi_slow_rate(void)
+{
+ port_spi_set_bitrate(HAL_SPI_FREQ_MIN);
+}
+
+/* @fn set_dw_spi_fast_rate
+ * @brief sets High SPI clock speed for the DW chip
+ * */
+void set_dw_spi_fast_rate(void)
+{
+ port_spi_set_bitrate(HAL_SPI_FREQ_MAX);
+}
+
+static inline void spi_transfer_open(void)
+{
+ // TODO: not thread safe at all... (but same as other Vendors' implementation)
+ while (spi_lock) {}
+ spi_lock = true;
+
+#if (!SPI_USE_SPIDRV_API) && defined (SL_CATALOG_POWER_MANAGER_PRESENT)
+ sl_power_manager_add_em_requirement(SL_POWER_MANAGER_EM1);
+#endif
+ GPIO_PinOutClear(spi_driver_handle.initData.portCs,
+ spi_driver_handle.initData.pinCs);
+}
+
+static inline void spi_transfer_close(void)
+{
+ GPIO_PinOutSet(spi_driver_handle.initData.portCs,
+ spi_driver_handle.initData.pinCs);
+#if (!SPI_USE_SPIDRV_API) && defined (SL_CATALOG_POWER_MANAGER_PRESENT)
+ sl_power_manager_remove_em_requirement(SL_POWER_MANAGER_EM1);
+#endif
+ spi_lock = false;
+}
+
+static inline Ecode_t spi_blocking_transmit(const uint8_t *buffer, int count)
+{
+#if SPI_USE_SPIDRV_API
+ return SPIDRV_MTransmitB(&spi_driver_handle, buffer, count);
+#else
+ for (int i = 0; i < count; i++) {
+ spi_tx_rx(buffer[i]);
+ }
+ return ECODE_OK;
+#endif
+}
+
+static inline Ecode_t spi_blocking_receive(uint8_t *buffer, int count)
+{
+#if SPI_USE_SPIDRV_API
+ return SPIDRV_MReceiveB(&spi_driver_handle, buffer, count);
+#else
+ for (int i = 0; i < count; i++) {
+ buffer[i] = spi_tx_rx(SPI_DUMMY_TX_VALUE);
+ }
+ return ECODE_OK;
+#endif
+}
+
+int readfromspi(uint16_t headerLength,
+ uint8_t *headerBuffer,
+ uint16_t readLength,
+ uint8_t *readBuffer)
+{
+ Ecode_t sc = 0;
+
+ spi_transfer_open();
+ if (headerBuffer && headerLength) {
+ sc |= spi_blocking_transmit(headerBuffer, headerLength);
+ }
+ if (!sc && readBuffer && readLength) {
+ sc |= spi_blocking_receive(readBuffer, readLength);
+ }
+ spi_transfer_close();
+
+ return sc;
+}
+
+static int spi_write(uint16_t headerLength,
+ const uint8_t *headerBuffer,
+ uint16_t bodyLength,
+ const uint8_t *bodyBuffer,
+ uint8_t *crc8)
+{
+ Ecode_t sc = 0;
+
+ spi_transfer_open();
+ if (headerBuffer && headerLength) {
+ sc |= spi_blocking_transmit(headerBuffer, headerLength);
+ }
+ if (!sc && bodyBuffer && bodyLength) {
+ sc |= spi_blocking_transmit(bodyBuffer, bodyLength);
+ }
+ if (crc8) {
+ sc |= spi_blocking_transmit(crc8, sizeof(*crc8));
+ }
+ spi_transfer_close();
+
+ return sc;
+}
+
+int writetospi(uint16_t headerLength,
+ const uint8_t *headerBuffer,
+ uint16_t bodyLength,
+ const uint8_t *bodyBuffer)
+{
+ return spi_write(headerLength, headerBuffer, bodyLength, bodyBuffer, NULL);
+}
+
+int writetospiwithcrc(uint16_t headerLength,
+ const uint8_t *headerBuffer,
+ uint16_t bodyLength,
+ const uint8_t *bodyBuffer,
+ uint8_t crc8)
+{
+ return spi_write(headerLength, headerBuffer, bodyLength, bodyBuffer, &crc8);
+}
diff --git a/driver/public/silabs/uwb2_dwm3000/platform/deca_spi/deca_spi.h b/driver/public/silabs/uwb2_dwm3000/platform/deca_spi/deca_spi.h
new file mode 100644
index 00000000..412afe24
--- /dev/null
+++ b/driver/public/silabs/uwb2_dwm3000/platform/deca_spi/deca_spi.h
@@ -0,0 +1,55 @@
+/**
+ * @file deca_spi.h
+ *
+ * @brief SPI interface access function protypes
+ *
+ * @author Decawave
+ *
+ * @attention Copyright 2017-2019 (c) Decawave Ltd, Dublin, Ireland.
+ * All rights reserved.
+ */
+
+#ifndef _DECA_SPI_H_
+#define _DECA_SPI_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/**---------------------------------------
+ * Function: openspi()
+ *
+ * Low level abstract function to open and initialise access to the SPI device.
+ * returns 0 for success, or -1 for error
+ */
+int openspi(void);
+
+/**---------------------------------------
+ * Function: closespi()
+ *
+ * Low level abstract function to close the the SPI device.
+ * returns 0 for success, or -1 for error
+ */
+int closespi(void);
+
+int writetospi(uint16_t headerLength,
+ const uint8_t *headerBuffer,
+ uint16_t bodyLength,
+ const uint8_t *bodyBuffer);
+int writetospiwithcrc(uint16_t headerLength,
+ const uint8_t *headerBuffer,
+ uint16_t bodyLength,
+ const uint8_t *bodyBuffer,
+ uint8_t crc8);
+int readfromspi(uint16_t headerLength,
+ uint8_t *headerBuffer,
+ uint16_t readlength,
+ uint8_t *readBuffer);
+void set_dw_spi_fast_rate(void);
+void set_dw_spi_slow_rate(void);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _DECA_SPI_H_ */
diff --git a/driver/public/silabs/uwb2_dwm3000/platform/port/port.h b/driver/public/silabs/uwb2_dwm3000/platform/port/port.h
new file mode 100644
index 00000000..e31e2ab7
--- /dev/null
+++ b/driver/public/silabs/uwb2_dwm3000/platform/port/port.h
@@ -0,0 +1,47 @@
+/**
+ * @file port.h
+ *
+ * @brief port headers file to EFR32BG22
+ *
+ * @author Decawave
+ *
+ * @attention Copyright 2017-2019 (c) Decawave Ltd, Dublin, Ireland.
+ * All rights reserved.
+ *
+ */
+
+#ifndef PORT__H_
+#define PORT__H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#include
+#include
+#include "error.h"
+#include "port_hal.h"
+#include "deca_spi.h"
+#include "deca_device_api.h"
+
+/* port functions prototypes */
+error_e port_init_dw_chip(void);
+error_e port_wakeup_dw3000_fast(void);
+error_e port_wakeup_dw3000(void);
+void wakeup_device_with_io(void);
+
+void dw_irq_init(void);
+void init_dw3000_irq(void);
+void enable_dw3000_irq(void);
+void disable_dw3000_irq(void);
+void reset_DW3000(void);
+
+void port_stop_all_UWB(void);
+
+error_e port_disable_dw_irq_and_reset(int reset);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* PORT__H__ */
diff --git a/driver/public/silabs/uwb2_dwm3000/platform/port/port_dw3000.c b/driver/public/silabs/uwb2_dwm3000/platform/port/port_dw3000.c
new file mode 100644
index 00000000..c63cdc81
--- /dev/null
+++ b/driver/public/silabs/uwb2_dwm3000/platform/port/port_dw3000.c
@@ -0,0 +1,263 @@
+/*! ----------------------------------------------------------------------------
+ * @file port_dw3000.c
+ * @brief HW specific definitions and functions for DW3000 Interface
+ *
+ * @attention
+ *
+ * Copyright 2016 (c) DecaWave Ltd, Dublin, Ireland.
+ *
+ * All rights reserved.
+ *
+ * @author
+ */
+
+#include "port.h"
+#include "em_gpio.h"
+#include "sl_udelay.h"
+#include "gpiointerrupt.h"
+
+#if defined(HAL_UWB_WAKEUP_PORT) && defined(HAL_UWB_WAKEUP_PIN)
+#define port_wakeup_start() GPIO_PinModeSet(HAL_UWB_WAKEUP_PORT, \
+ HAL_UWB_WAKEUP_PIN, \
+ gpioModePushPull, \
+ 1);
+#define port_wakeup_end() GPIO_PinModeSet(HAL_UWB_WAKEUP_PORT, \
+ HAL_UWB_WAKEUP_PIN, \
+ gpioModePushPull, \
+ 0);
+#else
+#define port_wakeup_start() GPIO_PinModeSet(HAL_SPI_CS_PORT, \
+ HAL_SPI_CS_PIN, \
+ gpioModePushPull, \
+ 0);
+#define port_wakeup_end() GPIO_PinModeSet(HAL_SPI_CS_PORT, \
+ HAL_SPI_CS_PIN, \
+ gpioModePushPull, \
+ 1);
+#endif
+
+/* @brief manually configuring of EXTI priority
+ * */
+void init_dw3000_irq(void)
+{
+}
+
+void disable_dw3000_irq(void)
+{
+ GPIO_IntDisable(1 << HAL_UWB_IRQ_IT_NBR);
+}
+
+void enable_dw3000_irq(void)
+{
+ GPIO_IntEnable(1 << HAL_UWB_IRQ_IT_NBR);
+}
+
+/* @fn reset_DW1000
+ * @brief DW_RESET pin on DW1000 has 2 functions
+ * In general it is output, but it also can be used to reset the
+ * digital part of DW1000 by driving this pin low.
+ * Note, the DW_RESET pin should not be driven high externally.
+ * */
+void reset_DW3000(void)
+{
+ GPIO_PinModeSet(HAL_UWB_RST_PORT, HAL_UWB_RST_PIN, gpioModePushPull, 0);
+ sl_udelay_wait(2000);
+ GPIO_PinModeSet(HAL_UWB_RST_PORT, HAL_UWB_RST_PIN, gpioModeInputPull, 1);
+ sl_udelay_wait(2000);
+}
+
+__attribute__((weak)) void wakeup_device_with_io(void)
+{
+ port_wakeup_dw3000_fast();
+}
+
+/* @fn port_wakeup_dw3000_fast
+ * @brief waking up of DW3000 using DW_CS pin
+ *
+ * the fast wakeup takes ~1ms:
+ * 500us to hold the CS - TODO: this time can be reduced
+ * 500us to the crystal to startup
+ * + ~various time 100us...10ms
+ * */
+error_e port_wakeup_dw3000_fast(void)
+{
+ port_wakeup_start();
+ sl_udelay_wait(500);
+ port_wakeup_end();
+
+ return _NO_ERR;
+}
+
+/* @fn port_wakeup_dw3000
+ * @brief waking up of DW3000 using DW_CS pin
+ *
+ * the fast wakeup takes ~1ms:
+ * 500us to hold the CS - TODO: this time can be reduced
+ * 500us to the crystal to startup
+ * + ~various time 100us...10ms
+ * */
+error_e port_wakeup_dw3000(void)
+{
+ // device wake-up
+ port_wakeup_dw3000_fast();
+
+ // it takes ~500us for crystal startup total for the DW3000 to switch to
+ // RC_IDLE 120MHz
+ sl_udelay_wait(500);
+
+ // we are here on 120MHz RC
+
+ /* Need to make sure DW IC is in IDLE_RC before proceeding */
+ uint32_t cnt = 0;
+ for (; (!dwt_checkidlerc()) && (cnt < 10); cnt++)
+ {
+ // FIXME: DW3000 B0 silicon bugfix
+ if (cnt == 5) {
+ port_wakeup_dw3000_fast();
+ }
+ sl_udelay_wait(20);
+ }
+ return (cnt >= 10) ? _ERR_INIT : _NO_ERR;
+}
+
+/**
+ * @brief Bare-metal level
+ * initialise master/slave DW1000 (check if can talk to device and wake
+ * up and reset)
+ */
+static int port_init_device(void)
+{
+ set_dw_spi_slow_rate();
+
+ if (dwt_check_dev_id() != DWT_SUCCESS) {
+ return DWT_ERROR;
+ }
+
+ // clear the sleep bit in case it is set - so that after the hard reset below
+ // the DW does not go into sleep
+ dwt_softreset(0);
+
+ return 0;
+}
+
+error_e port_disable_wake_init_dw(void)
+{
+ disable_dw3000_irq(); /**< disable NVIC IRQ until we configure
+ * the device */
+
+ reset_DW3000();
+
+ // this is called here to wake up the device (i.e. if it was in sleep mode
+ // before the restart)
+ port_wakeup_dw3000();
+
+ if (port_init_device() != 0x00) {
+ return _ERR_INIT;
+ }
+ return _NO_ERR;
+}
+
+error_e port_init_dw_chip(void)
+{
+ dwt_setlocaldataptr(0);
+
+ int sc = openspi();
+ if (0 != sc) {
+ return _ERR_SPI;
+ }
+ return _NO_ERR;
+}
+
+void port_stop_all_UWB(void)
+{
+ port_disable_dw_irq_and_reset(1);
+ dwt_setcallbacks(NULL, NULL, NULL, NULL, NULL, NULL, NULL);
+}
+
+/******************************************************************************
+*
+* IRQ section
+*
+******************************************************************************/
+/*! ----------------------------------------------------------------------------
+ * Function: decamutexon()
+ *
+ * Description: This function should disable interrupts.
+ *
+ *
+ * input parameters: void
+ *
+ * output parameters: uint16
+ * returns the state of the DW1000 interrupt
+ */
+decaIrqStatus_t decamutexon(void)
+{
+ uint32_t s = GPIO_EnabledIntGet();
+ if (s & (1 << HAL_UWB_IRQ_IT_NBR)) {
+ GPIO_IntDisable(1 << HAL_UWB_IRQ_IT_NBR);
+ }
+ return s;
+}
+
+/*! ----------------------------------------------------------------------------
+ * Function: decamutexoff()
+ *
+ * Description: This function should re-enable interrupts, or at least restore
+ * their state as returned(&saved) by decamutexon
+ * This is called at the end of a critical section
+ *
+ * input parameters:
+ * @param s - the state of the DW1000 interrupt as returned by decamutexon
+ *
+ * output parameters
+ *
+ * returns the state of the DW1000 interrupt
+ */
+void decamutexoff(decaIrqStatus_t s)
+{
+ if (s & (1 << HAL_UWB_IRQ_IT_NBR)) {
+ GPIO_IntEnable(1 << HAL_UWB_IRQ_IT_NBR);
+ }
+}
+
+/* @fn process_deca_irq
+ * @brief main call-back for processing of DW3000 IRQ
+ * it re-enters the IRQ routing and processes all events.
+ * After processing of all events, DW3000 will clear the IRQ line.
+ * */
+static void process_deca_irq(uint8_t interrupt_number)
+{
+ (void)interrupt_number;
+
+ while (GPIO_PinInGet(HAL_UWB_IRQ_PORT, HAL_UWB_IRQ_PIN) != 0)
+ {
+ dwt_isr();
+ } // while DW3000 IRQ line active
+}
+
+void dw_irq_init(void)
+{
+ GPIO_PinModeSet(HAL_UWB_IRQ_PORT, HAL_UWB_IRQ_PIN, gpioModeInputPull, 0);
+
+ GPIOINT_CallbackRegister(HAL_UWB_IRQ_IT_NBR, process_deca_irq);
+ GPIO_ExtIntConfig(HAL_UWB_IRQ_PORT, HAL_UWB_IRQ_PIN,
+ HAL_UWB_IRQ_IT_NBR, true, false, false);
+}
+
+/*
+ * @brief disable DW_IRQ, reset DW3000
+ * and set
+ * app.DwCanSleep = DW_CANNOT_SLEEP;
+ * app.DwEnterSleep = DW_NOT_SLEEPING;
+ * */
+error_e port_disable_dw_irq_and_reset(int reset)
+{
+ disable_dw3000_irq(); /**< disable NVIC IRQ until we configure the device */
+
+ // this is called to reset the DW device
+ if (reset) {
+ reset_DW3000();
+ }
+
+ return _NO_ERR;
+}
diff --git a/driver/public/silabs/uwb2_dwm3000/platform/port/port_hal.h b/driver/public/silabs/uwb2_dwm3000/platform/port/port_hal.h
new file mode 100644
index 00000000..ef27a131
--- /dev/null
+++ b/driver/public/silabs/uwb2_dwm3000/platform/port/port_hal.h
@@ -0,0 +1,57 @@
+/**
+ * @file port_hal.h
+ *
+ * @brief port Hardware Abstraction Layer headers file
+ *
+ * @author Decawave
+ *
+ * @attention Copyright 2017-2019 (c) Decawave Ltd, Dublin, Ireland.
+ * All rights reserved.
+ *
+ */
+
+#include "uwb2_dwm3000_config.h"
+
+#define _HAL_CAT2EXP(a, b) a ## b
+#define HAL_CAT2(a, b) _HAL_CAT2EXP(a, b)
+#define _HAL_CAT3EXP(a, b, c) a ## b ## c
+#define HAL_CAT3(a, b, c) _HAL_CAT3EXP(a, b, c)
+
+// UWB/DW3000
+#define HAL_UWB_IRQ_PORT DWM3000_INT_PORT
+#define HAL_UWB_IRQ_PIN DWM3000_INT_PIN
+#define HAL_UWB_IRQ_IT_NBR DWM3000_INT_PIN
+
+#define HAL_UWB_RST_PORT DWM3000_RESET_PORT
+#define HAL_UWB_RST_PIN DWM3000_RESET_PIN
+#define HAL_UWB_RST_IT_NBR DWM3000_RESET_PIN
+
+#if defined(DWM3000_WAKE_PORT) && defined(DWM3000_WAKE_PIN)
+#define HAL_UWB_WAKEUP_PORT DWM3000_WAKE_PORT
+#define HAL_UWB_WAKEUP_PIN DWM3000_WAKE_PIN
+#define HAL_UWB_WAKEUP_IT_NBR DWM3000_WAKE_PIN
+#endif
+
+#define HAL_UWB_EXTON_PORT DWM3000_ON_PORT
+#define HAL_UWB_EXTON_PIN DWM3000_ON_PIN
+#define HAL_UWB_EXTON_IT_NBR DWM3000_ON_PIN
+
+// SPI
+#define HAL_SPI_TYPE DWM3000_SPI_TYPE
+#define HAL_SPI_NUMBER DWM3000_SPI_NUMBER
+#define HAL_SPI_PERIPHERAL HAL_CAT2(HAL_SPI_TYPE, HAL_SPI_NUMBER)
+
+#define HAL_SPI_CS_PORT DWM3000_CS_PORT
+#define HAL_SPI_CS_PIN DWM3000_CS_PIN
+
+#define HAL_SPI_CLK_PORT DWM3000_CLK_PORT
+#define HAL_SPI_CLK_PIN DWM3000_CLK_PIN
+
+#define HAL_SPI_MISO_PORT DWM3000_MISO_PORT
+#define HAL_SPI_MISO_PIN DWM3000_MISO_PIN
+
+#define HAL_SPI_MOSI_PORT DWM3000_MOSI_PORT
+#define HAL_SPI_MOSI_PIN DWM3000_MOSI_PIN
+
+#define HAL_SPI_FREQ_MIN DWM3000_FREQ_MIN
+#define HAL_SPI_FREQ_MAX DWM3000_FREQ_MAX
diff --git a/driver/thirdparty/decawave/uwb2_dwm3000/inc/common.h b/driver/thirdparty/decawave/uwb2_dwm3000/inc/common.h
new file mode 100644
index 00000000..be53e76a
--- /dev/null
+++ b/driver/thirdparty/decawave/uwb2_dwm3000/inc/common.h
@@ -0,0 +1,147 @@
+/**
+ * @file common.h
+ *
+ * @brief Only common macros and enumerations
+ *
+ * @author Decawave Software
+ *
+ * @attention Copyright 2017-2020 (c) DecaWave Ltd, Dublin, Ireland.
+ * All rights reserved.
+ *
+ */
+
+#ifndef COMMON_H_
+#define COMMON_H_ 1
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#define TS_40B_SIZE (5)
+
+#define PHY_READ_DIG_ENABLE (0x1)
+#define PHY_READ_ACC_ENABLE (0x2)
+
+#define SPEED_OF_LIGHT (299702547.0) // in m/s in air
+
+#define CCP_FIXED_REPLY_DELAY_US 150000 /* us */
+
+#ifndef EVENT_BUFSIZE
+#define EVENT_BUFSIZE 0x20
+#endif
+
+#ifdef UWB_BH_ENABLE
+
+/* With UWB_BH option the max throughput would be smaller, because each instance
+ * has the ETH_REPORT_BUFSIZE buffer */
+# define NUM_BH_BUFFERS (8) /* the maximum number of supported
+ * downstream anchors: should be 1<rx[tail].msg.blinkMsg. \
+ frameCtrl[0] == HEAD_MSG_BLINK)
+#define APP_EV_CLOCK_SYNC_RX ((phyevent->rx[tail].msg.ccpMsg. \
+ messageData[0] \
+ == RTLS_MSG_ANCH_CLK_SYNC) && \
+ (phyevent->rx[tail].rxDataLen \
+ == sizeof(ccp_msg_t)))
+#define APP_EV_DATA_RX (phyevent->rx[tail].msg.bcastMsg. \
+ messageData[0] == APP_MSG_DATA)
+#define APP_EV_UWB_BH_DWNSTREAM_RX ((phyevent->rx[tail].msg.bcastMsg. \
+ messageData[0] \
+ == APP_MSG_UWB_BH_DWNSTREAM) && \
+ (phyevent->rx[tail].rxDataLen \
+ == sizeof(uwb_bh_dwnstream_msg_t)))
+#define APP_EV_UWB_BH_UPSTREAM_RX ((phyevent->rx[tail].msg.bcastMsg. \
+ messageData[0] \
+ == APP_MSG_UWB_BH_UPSTREAM) && \
+ (phyevent->rx[tail].rxDataLen \
+ == sizeof(uwb_bh_upstream_msg_t)))
+
+// -----------------------------------------------------------------------------
+// common macros
+
+#ifndef SWAP
+#define SWAP(a, b) { a ^= b; b ^= a; a ^= b; }
+#endif /* SWAP */
+
+#ifndef MIN
+#define MIN(a, b) (((a) < (b)) ? (a) : (b))
+#endif /* MIN */
+
+#ifndef MAX
+#define MAX(a, b) (((a) > (b)) ? (a) : (b))
+#endif /* MAX */
+
+#ifndef TRUE
+#define TRUE 1
+#endif /* TRUE */
+
+#ifndef FALSE
+#define FALSE 0
+#endif /* FALSE */
+
+#define MASK_40BIT (0x00FFFFFFFFFFULL) // DW1000 counter is 40 bits
+#define MASK_TXDTS (0x00FFFFFFFE00ULL) // The TX timestamp will snap
+ // to 8 ns resolution -
+ // mask lower 9 bits.
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* COMMON_H_ */
diff --git a/driver/thirdparty/decawave/uwb2_dwm3000/inc/deca_dbg.h b/driver/thirdparty/decawave/uwb2_dwm3000/inc/deca_dbg.h
new file mode 100644
index 00000000..73838ea0
--- /dev/null
+++ b/driver/thirdparty/decawave/uwb2_dwm3000/inc/deca_dbg.h
@@ -0,0 +1,126 @@
+/**
+ * @file deca_dbg.h
+ *
+ * @brief Debug macros for debug prints
+ *
+ * @author Decawave
+ *
+ * @attention Copyright 2017-2019 (c) Decawave Ltd, Dublin, Ireland.
+ * All rights reserved.
+ *
+ */
+#ifndef DECA_DBG_H_
+#define DECA_DBG_H_ 1
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#include "usb_uart_tx.h"
+#include
+#include
+
+#if 0
+#define DBG_PRINTF diag_printf
+
+#define DBG_TRACE_EVENTS if (!TX_EVENT_RECEIVED) printf( \
+ "MsgPtrs [ %d - %d %d %d - %3d - 0x%X] \n", \
+ rxData[ \
+ phyEvent[app.eventIdx].rxDataPtr].rxDataLen, \
+ phyCfg.eventIdx, \
+ app.eventIdx, \
+ phyEvent[app.eventIdx].type, \
+ rxData[ \
+ phyEvent[app.eventIdx].rxDataPtr].msg.stdMsg.seqNum, \
+ rxData[ \
+ phyEvent[app.eventIdx].rxDataPtr].msg.stdMsg.messageData[0]);
+
+#define DBG_TRACE_CLOCK_SYNC_TX printf( \
+ "CS Sent at .. @ .. 0x%02x%02x%02x%02x%02x \n", \
+ phyEvent[app.eventIdx].timeStamp[4], \
+ phyEvent[app.eventIdx].timeStamp[3], \
+ phyEvent[app.eventIdx].timeStamp[2], \
+ phyEvent[app.eventIdx].timeStamp[1], \
+ phyEvent[app.eventIdx].timeStamp[0]); \
+ printf("C:%d\n", app.rtls_info.ccpSeqNum);
+
+#define DBG_TRACE_CLOCK_SYNC_RX printf( \
+ "CS Received .. @ .. 0x%02x%02x%02x%02x%02x \n", \
+ phyEvent[app.eventIdx].timeStamp[4], \
+ phyEvent[app.eventIdx].timeStamp[3], \
+ phyEvent[app.eventIdx].timeStamp[2], \
+ phyEvent[app.eventIdx].timeStamp[1], \
+ phyEvent[app.eventIdx].timeStamp[0]); \
+ printf("C:%d\n", rxMsg.msg.bcastMsg.seqNum);
+
+#define DBG_TRACE_TAG_BLINK printf( \
+ "Tag Blink : Seq : %d : Time : %lld \n", \
+ rxMsg.msg.blinkMsg.seqNum, \
+ phyEvent[app.eventIdx].timeStamp); \
+ // printf("S:%d\n", rxMsg.msg.blinkMsg.seqNum);
+
+#define DBG_TRACE_NETWORK_MSG printf( \
+ "Received Network Configuration : %s %d \n", \
+ (app.rtls_info.master?"MASTER":"SLAVE"), \
+ app.rtls_info.id);
+
+#define DBG_TRACE_CONFIGURATION printf( \
+ "Configuration Message %x %x : Time : %lld \n", \
+ rxData[phyEvent[app.eventIdx]. \
+ rxDataPtr].msg.stdMsg.messageData[0], \
+ rxData[phyEvent[app.eventIdx]. \
+ rxDataPtr].msg.stdMsg.messageData[1], \
+ phyEvent[app.eventIdx].timeStamp);
+
+#else
+
+#define DIAG_BUF_LEN 0x8
+#define DIAG_STR_LEN 64
+// note, (DIAG_BUF_LEN*(DIAG_STR_LEN+4)) shall be < HTTP_PAGE_MALLOC_SIZE-16
+//
=4
+typedef struct
+{
+ uint8_t buf[DIAG_BUF_LEN][DIAG_STR_LEN];
+ int head;
+}gDiagPrintFStr_t;
+
+extern gDiagPrintFStr_t gDiagPrintFStr;
+
+#define diag_printf(...) do{ \
+ snprintf((char *)(&gDiagPrintFStr.buf[gDiagPrintFStr.head][0]), \
+ DIAG_STR_LEN, \
+ __VA_ARGS__); \
+ port_tx_msg(&gDiagPrintFStr.buf[gDiagPrintFStr.head][0], \
+ strlen((char *)(&gDiagPrintFStr.buf[gDiagPrintFStr.head][0]))); \
+ gDiagPrintFStr.head = (gDiagPrintFStr.head + 1) & (DIAG_BUF_LEN - 1); \
+}while (0)
+
+#define DBG_PRINTF diag_printf
+#define DBG_TRACE_EVENTS
+#define DBG_TRACE_CLOCK_SYNC_TX
+#define DBG_TRACE_CLOCK_SYNC_RX
+#define DBG_TRACE_TAG_BLINK
+#define DBG_TRACE_NETWORK_MSG
+#define DBG_TRACE_CONFIGURATION
+#endif
+
+#define DBG_TRACE(x) { uint8_t buf; buf = x; dwt_writetodevice(0xb, \
+ 0, \
+ 1, \
+ &buf); }
+
+/* TRACE_DEBUG and TRACE_INFO used in drivers when -DDEBUG in Makefile defined
+ */
+#ifdef DEBUG
+#define TRACE_DEBUG diag_printf
+#define TRACE_INFO diag_printf
+#else
+#define TRACE_DEBUG
+#define TRACE_INFO diag_printf
+#endif
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* DECA_DBG_H_ */
diff --git a/driver/thirdparty/decawave/uwb2_dwm3000/inc/deca_device_api.h b/driver/thirdparty/decawave/uwb2_dwm3000/inc/deca_device_api.h
new file mode 100644
index 00000000..9d857bc2
--- /dev/null
+++ b/driver/thirdparty/decawave/uwb2_dwm3000/inc/deca_device_api.h
@@ -0,0 +1,4321 @@
+/*! ----------------------------------------------------------------------------
+ * @file deca_device_api.h
+ * @brief DW3000 API Functions
+ *
+ * @attention
+ *
+ * Copyright 2013 - 2021(c) Decawave Ltd, Dublin, Ireland.
+ *
+ * All rights reserved.
+ *
+ */
+
+#ifndef _DECA_DEVICE_API_H_
+#define _DECA_DEVICE_API_H_
+
+#ifdef __cplusplus
+extern "C"
+{
+#endif
+
+#include "deca_types.h"
+
+#ifndef DWT_NUM_DW_DEV
+#define DWT_NUM_DW_DEV (1)
+#endif
+
+#define DWT_BIT_MASK(bit_num) (((uint32_t)1) << (bit_num))
+#define FCS_LEN (2)
+
+#define GPIO_MFIO_MODE_MASK 0x7U
+#define STS_CONFIG_HI_B0_MASK 0xFF // STS_CONFIG_HI Byte 0 mask.
+#define RX_SFD_HLDOFF 0x20000000UL // Number of symbols of
+ // accumulation to wait before
+ // checking for an SFD pattern,
+ // when Ipatov len > 64.
+#define RX_SFD_HLDOFF_DEF 0x14000000UL // Default number of symbols of
+ // accumulation to wait before
+ // checking for an SFD pattern.
+#define RX_BUFFER_MAX_LEN (1023)
+
+/* Default interface implementation functions */
+
+#define DW3000_CHIP_FREQ 499200000
+#define DW3000_CHIP_PER_DTU 2
+#define DW3000_CHIP_PER_DLY 512
+#define DW3000_DTU_FREQ (DW3000_CHIP_FREQ / DW3000_CHIP_PER_DTU)
+#define DTU_TO_US(x) (int)((uint64_t)(x) * 1000000 / DW3000_DTU_FREQ)
+#define US_TO_DTU(x) (int)((uint64_t)(x) * DW3000_DTU_FREQ / 1000000)
+#define COEX_TIME_US 1000
+#define COEX_TIME_DTU US_TO_DTU(COEX_TIME_US)
+#define COEX_MARGIN_US 20
+#define COEX_MARGIN_DTU US_TO_DTU(COEX_MARGIN_US)
+
+#define DWT_DW3720_PDOA_DEV_ID DWT_QM33120_PDOA_DEV_ID /* Backward
+ * compatibility
+ * definition of
+ * the P/N */
+
+// Enable CRC functionality. Disable to save space when CRC not required.
+#define DWT_ENABLE_CRC
+
+/* */
+typedef enum
+{
+ DWT_SUCCESS = 0,
+ DWT_ERROR = -1,
+ DWT_ERR_PLL_LOCK = -2,
+ DWT_ERR_RX_CAL_PGF = -3,
+ DWT_ERR_RX_CAL_RESI = -4,
+ DWT_ERR_RX_CAL_RESQ = -5,
+ DWT_ERR_RX_ADC_CAL = -6,
+} dwt_error_e;
+
+#define DWT_TIME_UNITS (1.0 / 499.2e6 / 128.0) //!< = 15.65e-12 s
+
+typedef enum
+{
+ DWT_DW3000_DEV_ID = (int)(0xDECA0302), //!< DW3000 (non PDOA)
+ //!< silicon device ID
+ DWT_DW3000_PDOA_DEV_ID = (int)(0xDECA0312), //!< DW3000 (with PDOA)
+ //!< silicon device ID
+ DWT_DW3700_PDOA_DEV_ID = (int)(0xDECA0313), //!< DW3700 (with PDOA)
+ //!< silicon device ID
+ DWT_QM33120_PDOA_DEV_ID = (int)(0xDECA0314) //!< QM33120 (with PDOA)
+ //!< silicon device ID
+} dw_chip_id_e;
+
+#define DELAY_20uUSec (20) /*Delay of 20uSec(measured 24uSec)*/
+#define MAX_RETRIES_FOR_PLL (50) /*The PLL calibration should take less than
+ * 400us, typically it is < 100us (however on
+ * some corners with ch9 it can take
+ * ~900us)*/
+#define MAX_RETRIES_FOR_PGF (3)
+
+typedef enum
+{
+ AOA,
+ NON_AOA
+} dw3000type_e;
+
+typedef enum
+{
+ DW3000_SPI_RD_BIT = 0x0000U,
+ DW3000_SPI_RD_FAST_CMD = 0x0001U,
+ DW3000_SPI_WR_FAST_CMD = 0x0002U,
+ DW3000_SPI_WR_BIT = 0x8000U,
+ DW3000_SPI_AND_OR_8 = 0x8001U,
+ DW3000_SPI_AND_OR_16 = 0x8002U,
+ DW3000_SPI_AND_OR_32 = 0x8003U,
+} spi_modes_e;
+
+//! enums for selecting the bit rate for data TX (and RX)
+//! These are defined for write (with just a shift) the TX_FCTRL register
+typedef enum
+{
+ DWT_BR_850K = 0, //!< UWB bit rate 850 kbits/s
+ DWT_BR_6M8 = 1, //!< UWB bit rate 6.8 Mbits/s
+ DWT_BR_NODATA = 2, //!< No data (SP3 packet format)
+} dwt_uwb_bit_rate_e;
+
+//! enums for specifying the (Nominal) mean Pulse Repetition Frequency
+//! These are defined for direct write (with a shift if necessary) to CHAN_CTRL
+//! and TX_FCTRL regs
+typedef enum
+{
+ DWT_PRF_16M = 1, //!< UWB PRF 16 MHz
+ DWT_PRF_64M = 2, //!< UWB PRF 64 MHz
+ DWT_PRF_SCP = 3, //!< SCP UWB PRF ~100 MHz
+} dwt_prf_e;
+
+//! enums for specifying Preamble Acquisition Chunk (PAC) Size in symbols
+typedef enum
+{
+ DWT_PAC8 = 0, //!< PAC 8 (recommended for RX of preamble length 128
+ //!< and below
+ DWT_PAC16 = 1, //!< PAC 16 (recommended for RX of preamble length 256
+ DWT_PAC32 = 2, //!< PAC 32 (recommended for RX of preamble length 512
+ DWT_PAC4 = 3, //!< PAC 4 (recommended for RX of preamble length < 127
+} dwt_pac_size_e;
+
+//! enums for specifying SFD Types and size
+typedef enum
+{
+ DWT_SFD_IEEE_4A = 0, //!< IEEE 8-bit ternary
+ DWT_SFD_DW_8 = 1, //!< DW 8-bit
+ DWT_SFD_DW_16 = 2, //!< DW 16-bit
+ DWT_SFD_IEEE_4Z = 3, //!< IEEE 8-bit binary (4z)
+ DWT_SFD_LEN8 = 8, //!< IEEE, and DW 8-bit are length 8
+ DWT_SFD_LEN16 = 16, //!< DW 16-bit is length 16
+} dwt_sfd_type_e;
+
+//! enums for specifying TX Preamble length in symbols
+//! These are defined to allow them be directly written into byte 2 of the
+//! TX_FCTRL register
+//! (i.e. a four bit value destined for bits 20..18 but shifted left by 2 for
+//! byte alignment)
+typedef enum
+{
+ DWT_PLEN_4096 = 0x03, //! Standard preamble length 4096 symbols
+ DWT_PLEN_2048 = 0x0A, //! Non-standard preamble length 2048 symbols
+ DWT_PLEN_1536 = 0x06, //! Non-standard preamble length 1536 symbols
+ DWT_PLEN_1024 = 0x02, //! Standard preamble length 1024 symbols
+ DWT_PLEN_512 = 0x0d, //! Non-standard preamble length 512 symbols
+ DWT_PLEN_256 = 0x09, //! Non-standard preamble length 256 symbols
+ DWT_PLEN_128 = 0x05, //! Non-standard preamble length 128 symbols
+ DWT_PLEN_64 = 0x01, //! Standard preamble length 64 symbols
+ DWT_PLEN_32 = 0x04, //! Non-standard length 32
+ DWT_PLEN_72 = 0x07, //! Non-standard length 72
+} dwt_tx_plen_e;
+
+#define DWT_SFDTOC_DEF 129 // default SFD timeout value
+
+//! enums for selecting PHR modes
+typedef enum
+{
+ DWT_PHRMODE_STD = 0x0, // standard PHR mode
+ DWT_PHRMODE_EXT = 0x1, // DW proprietary extended frames PHR mode
+} dwt_phr_mode_e;
+
+//! enums for selecting PHR rate
+typedef enum
+{
+ DWT_PHRRATE_STD = 0x0, // standard PHR rate
+ DWT_PHRRATE_DTA = 0x1, // PHR at data rate (6M81)
+} dwt_phr_rate_e;
+
+// Define DW3000 PDOA modes
+typedef enum
+{
+ DWT_PDOA_M0 = 0x0, // DW PDOA mode is off
+ DWT_PDOA_M1 = 0x1, // DW PDOA mode 1
+ DWT_PDOA_M3 = 0x3, // DW PDOA mode 3
+} dwt_pdoa_mode_e;
+
+// Define DW3000 STS modes
+typedef enum
+{
+ DWT_STS_MODE_OFF = 0x0, // STS is off
+ DWT_STS_MODE_1 = 0x1, // STS mode 1
+ DWT_STS_MODE_2 = 0x2, // STS mode 2
+ DWT_STS_MODE_ND = 0x3, // STS with no data
+ DWT_STS_MODE_SDC = 0x8, // Enable Super Deterministic Codes
+ DWT_STS_CONFIG_MASK = 0xB,
+ DWT_STS_CONFIG_MASK_NO_SDC = 0x3,
+} dwt_sts_mode_e;
+
+#define DWT_SFD_COUNT_WARN (0x2000 >> 7) // SFD count warning bit (STS quality
+ // status bit)
+
+// Defined constants for "mode" bitmask parameter passed into dwt_starttx()
+// function.
+typedef enum
+{
+ DWT_START_TX_IMMEDIATE = 0x00, //! Send the frame immediately
+ DWT_START_TX_DELAYED = 0x01, //! Send the frame at specified time
+ //! (time must be less that half period
+ //! away)
+ DWT_RESPONSE_EXPECTED = 0x02, //! Will enable the receiver after TX has
+ //! completed
+ DWT_START_TX_DLY_REF = 0x04, //! Send the frame at specified time
+ //! (time in DREF_TIME register + any
+ //! time in DX_TIME register)
+ DWT_START_TX_DLY_RS = 0x08, //! Send the frame at specified time
+ //! (time in RX_TIME_0 register + any
+ //! time in DX_TIME register)
+ DWT_START_TX_DLY_TS = 0x10, //! Send the frame at specified time
+ //! (time in TX_TIME_LO register + any
+ //! time in DX_TIME register)
+ DWT_START_TX_CCA = 0x20, //! Send the frame if no preamble
+ //! detected within PTO time
+} dwt_starttx_mode_e;
+
+// Defined constants for "mode" bitmask parameter passed into dwt_rxenable()
+// function.
+typedef enum
+{
+ DWT_START_RX_IMMEDIATE = 0x00, //! Enable the receiver immediately
+ DWT_START_RX_DELAYED = 0x01, //! Set up delayed RX, if "late" error
+ //! triggers, then the RX will be
+ //! enabled immediately
+ //! If delay RX fails due to "late" error then if this flag is set, the RX
+ //! will not be re-enabled immediately, and device will be in IDLE when
+ //! function
+ //! exits.
+ DWT_IDLE_ON_DLY_ERR = 0x02,
+ DWT_START_RX_DLY_REF = 0x04, //! Enable the receiver at specified time
+ //! (time in DREF_TIME register + any
+ //! time in DX_TIME register)
+ DWT_START_RX_DLY_RS = 0x08, //! Enable the receiver at specified time
+ //! (time in RX_TIME_0 register + any
+ //! time in DX_TIME register)
+ DWT_START_RX_DLY_TS = 0x10, //! Enable the receiver at specified time
+ //! (time in TX_TIME_LO register + any
+ //! time in DX_TIME register)
+} dwt_startrx_mode_e;
+
+/******************************************************************************
+ * @brief Bit definition of the SYS_ENABLE register
+ * exported for dwt_setinterrupt() API
+ **/
+typedef enum
+{
+ DWT_INT_TIMER1_BIT_MASK = (int)(0x80000000), // TIMER1 expiry
+ DWT_INT_TIMER0_BIT_MASK = 0x40000000UL, // TIMER0 expiry
+ DWT_INT_ARFE_BIT_MASK = 0x20000000UL, // Frame filtering error
+ DWT_INT_CPERR_BIT_MASK = 0x10000000UL, // STS quality
+ // warning/error
+ DWT_INT_HPDWARN_BIT_MASK = 0x8000000UL, // Half period warning flag
+ // when delayed TX/RX is
+ // used
+ DWT_INT_RXSTO_BIT_MASK = 0x4000000UL, // SFD timeout
+ DWT_INT_PLL_HILO_BIT_MASK = 0x2000000UL, // PLL calibration flag
+ DWT_INT_RCINIT_BIT_MASK = 0x1000000UL, // Device has entered
+ // IDLE_RC
+ DWT_INT_SPIRDY_BIT_MASK = 0x800000UL, // SPI ready flag
+ DWT_INT_RXPTO_BIT_MASK = 0x200000UL, // Preamble timeout
+ DWT_INT_RXOVRR_BIT_MASK = 0x100000UL, // RX overrun event when
+ // double RX buffer is
+ // used
+ DWT_INT_VWARN_BIT_MASK = 0x80000UL, // Brownout event detected
+ DWT_INT_CIAERR_BIT_MASK = 0x40000UL, // CIA error
+ DWT_INT_RXFTO_BIT_MASK = 0x20000UL, // RX frame wait timeout
+ DWT_INT_RXFSL_BIT_MASK = 0x10000UL, // Reed-Solomon error (RX
+ // sync loss)
+ DWT_INT_RXFCE_BIT_MASK = 0x8000U, // RX frame CRC error
+ DWT_INT_RXFCG_BIT_MASK = 0x4000U, // RX frame CRC good
+ DWT_INT_RXFR_BIT_MASK = 0x2000U, // RX ended - frame ready
+ DWT_INT_RXPHE_BIT_MASK = 0x1000U, // PHY header error
+ DWT_INT_RXPHD_BIT_MASK = 0x800U, // PHY header detected
+ DWT_INT_CIADONE_BIT_MASK = 0x400U, // CIA done
+ DWT_INT_RXSFDD_BIT_MASK = 0x200U, // SFD detected
+ DWT_INT_RXPRD_BIT_MASK = 0x100U, // Preamble detected
+ DWT_INT_TXFRS_BIT_MASK = 0x80U, // Frame sent
+ DWT_INT_TXPHS_BIT_MASK = 0x40U, // Frame PHR sent
+ DWT_INT_TXPRS_BIT_MASK = 0x20U, // Frame preamble sent
+ DWT_INT_TXFRB_BIT_MASK = 0x10U, // Frame transmission
+ // begins
+ DWT_INT_AAT_BIT_MASK = 0x8U, // Automatic ACK
+ // transmission pending
+ DWT_INT_SPICRCE_BIT_MASK = 0x4U, // SPI CRC error
+ DWT_INT_CP_LOCK_BIT_MASK = 0x2U, // PLL locked
+ DWT_INT_IRQS_BIT_MASK = 0x1U, // Interrupt set
+} dwt_int_conf_e;
+
+// Bit definition of the double RX buffer status events
+typedef enum
+{
+ DWT_RDB_STATUS_CP_ERR1_BIT_MASK = 0x80U, // STS quality warning/error
+ // in RX buffer 1
+ DWT_RDB_STATUS_CIADONE1_BIT_MASK = 0x40U, // CIA done for frame in RX
+ // buffer 1
+ DWT_RDB_STATUS_RXFR1_BIT_MASK = 0x20U, // Frame ready in RX buffer 1
+ DWT_RDB_STATUS_RXFCG1_BIT_MASK = 0x10U, // Frame CC good in RX buffer
+ // 1
+ DWT_RDB_STATUS_CP_ERR0_BIT_MASK = 0x8U, // STS quality warning/error
+ // in RX buffer 0
+ DWT_RDB_STATUS_CIADONE0_BIT_MASK = 0x4U, // CIA done for frame in RX
+ // buffer 0
+ DWT_RDB_STATUS_RXFR0_BIT_MASK = 0x2U, // Frame ready in RX buffer 0
+ DWT_RDB_STATUS_RXFCG0_BIT_MASK = 0x1U, // Frame CC good in RX buffer
+ // 0
+} dwt_rdb_e;
+
+/* RX events mask relating to reception into RX buffer 0, when double buffer is
+ * used */
+#define DWT_RDB_STATUS_CLEAR_BUFF0_EVENTS (RDB_STATUS_CP_ERR0_BIT_MASK \
+ | RDB_STATUS_CIADONE0_BIT_MASK \
+ | RDB_STATUS_RXFR0_BIT_MASK \
+ | RDB_STATUS_RXFCG0_BIT_MASK)
+
+/* RX events mask relating to reception into RX buffer 1, when double buffer is
+ * used */
+#define DWT_RDB_STATUS_CLEAR_BUFF1_EVENTS (RDB_STATUS_CP_ERR1_BIT_MASK \
+ | RDB_STATUS_CIADONE1_BIT_MASK \
+ | RDB_STATUS_RXFR1_BIT_MASK \
+ | RDB_STATUS_RXFCG1_BIT_MASK)
+
+#define RDB_STATUS_RXOK \
+ (DWT_RDB_STATUS_RXFCG0_BIT_MASK | DWT_RDB_STATUS_RXFR0_BIT_MASK \
+ | DWT_RDB_STATUS_CIADONE0_BIT_MASK | DWT_RDB_STATUS_CP_ERR0_BIT_MASK \
+ | DWT_RDB_STATUS_RXFCG1_BIT_MASK | DWT_RDB_STATUS_RXFR1_BIT_MASK \
+ | DWT_RDB_STATUS_CIADONE1_BIT_MASK | DWT_RDB_STATUS_CP_ERR1_BIT_MASK)
+
+// DW37xx double RX buffer interrupt events
+#define DWT_DB_INT_RX (RDB_STATUS_RXOK)
+
+// DW3000 interrupt events
+#define DWT_INT_RX \
+ (DWT_INT_CIADONE_BIT_MASK | DWT_INT_RXFCG_BIT_MASK | DWT_INT_RXPHE_BIT_MASK \
+ | DWT_INT_RXFR_BIT_MASK | DWT_INT_RXFCE_BIT_MASK | DWT_INT_RXFSL_BIT_MASK \
+ | DWT_INT_RXFTO_BIT_MASK | DWT_INT_CIAERR_BIT_MASK | DWT_INT_RXPTO_BIT_MASK \
+ | DWT_INT_RXSTO_BIT_MASK | DWT_INT_ARFE_BIT_MASK)
+#define DWT_INT_ALL_LO (0xffffffff)
+#define DWT_INT_ALL_HI (0xffffffff)
+
+/* User defined RX timeouts (frame wait timeout and preamble detect timeout)
+ * mask. */
+#define SYS_STATUS_ALL_RX_TO (DWT_INT_RXFTO_BIT_MASK \
+ | DWT_INT_RXPTO_BIT_MASK \
+ | DWT_INT_CPERR_BIT_MASK)
+
+/* All RX errors mask. */
+#define SYS_STATUS_ALL_RX_ERR \
+ (DWT_INT_RXPHE_BIT_MASK | DWT_INT_RXFCE_BIT_MASK | DWT_INT_RXFSL_BIT_MASK \
+ | DWT_INT_RXSTO_BIT_MASK | DWT_INT_ARFE_BIT_MASK | DWT_INT_CIAERR_BIT_MASK \
+ | DWT_INT_CPERR_BIT_MASK)
+
+/* All RX events after a correct packet reception mask. */
+#define SYS_STATUS_ALL_RX_GOOD \
+ (DWT_INT_RXFR_BIT_MASK | DWT_INT_RXFCG_BIT_MASK | DWT_INT_RXPRD_BIT_MASK \
+ | DWT_INT_RXSFDD_BIT_MASK | DWT_INT_RXPHD_BIT_MASK \
+ | DWT_INT_CIADONE_BIT_MASK)
+
+/* All STS Mode 3 RX errors mask. */
+#define SYS_STATUS_ALL_ND_RX_ERR (DWT_INT_CIAERR_BIT_MASK \
+ | DWT_INT_RXSTO_BIT_MASK)
+#define DWT_INT_HI_CCA_FAIL_BIT_MASK 0x1000U
+
+#define DWT_INT_AES_STS_MEM_CONF_BIT_MASK 0x8U
+#define DWT_INT_AES_STS_TRANS_ERR_BIT_MASK 0x4U
+#define DWT_INT_AES_STS_AUTH_ERR_BIT_MASK 0x2U
+
+/* Entry point to AES IV 0 */
+#define DWT_AES_IV_ENTRY (0x10034)
+
+#define DWT_AES_ERRORS (DWT_INT_AES_STS_AUTH_ERR_BIT_MASK \
+ | DWT_INT_AES_STS_TRANS_ERR_BIT_MASK \
+ | DWT_INT_AES_STS_MEM_CONF_BIT_MASK)
+// Defined constants when SPI CRC mode is used:
+typedef enum
+{
+ DWT_SPI_CRC_MODE_NO = 0, /* No CRC */
+ DWT_SPI_CRC_MODE_WR, /* This is used to enable SPI CRC check (the SPI
+ * CRC check will be enabled on DW3000 and CRC-8
+ * added for SPI write transactions) */
+ DWT_SPI_CRC_MODE_WRRD /* This is used to optionally enable additional
+ * CRC check on the SPI read operations, while
+ * the CRC check on the SPI write
+ * operations is also enabled */
+} dwt_spi_crc_mode_e;
+
+// Defined constants for "mode" bit field parameter passed to dwt_setleds()
+// function.
+typedef enum
+{
+ DWT_LEDS_DISABLE = 0x00,
+ DWT_LEDS_ENABLE = 0x01,
+ DWT_LEDS_INIT_BLINK = 0x02,
+ // Default blink time. Blink time is expressed in multiples of 14 ms. The
+ // value defined here is ~225 ms.
+ DWT_LEDS_BLINK_TIME_DEF = 0x10,
+} dwt_setleds_mode_e;
+
+typedef enum
+{
+ // Common for all devices
+ GPIO_PIN0_EXTTXE = 0x2 << 0, /* Deprecated, only works for DW3000.
+ * The pin operates as the EXTTXE
+ * output (output TX state) */
+ GPIO_PIN1_EXTRXE = 0x2 << (1 * 3), /* Deprecated, only works for DW3000.
+ * The pin operates as the EXTRXE
+ * output (output RX state) */
+ GPIO_PIN2_RXLED = 0x1 << (2 * 3), /* The pin operates as the RXLED output
+ */
+ GPIO_PIN3_TXLED = 0x1 << (3 * 3), /* The pin operates as the TXLED output
+ */
+ GPIO_PIN4_EXTDA = 0x1 << (4 * 3), /* Deprecated, only works for DW3000.
+ * The pin operates to support
+ * external DA/PA */
+ GPIO_PIN4_EXTTXE = 0x2 << (4 * 3), /* Deprecated, only works for DW37xx.
+ * The pin operates as the EXTTXE
+ * output (output TX state) */
+ GPIO_PIN5_EXTTX = 0x1 << (5 * 3), /* Deprecated, only works for DW3000.
+ * The pin operates to support
+ * external PA / TX enable */
+ GPIO_PIN5_EXTRXE = 0x2 << (5 * 3), /* Deprecated, only works for DW37xx.
+ * The pin operates as the EXTRXE
+ * output (output RX state) */
+ GPIO_PIN6_EXTRX = 0x1 << (6 * 3), /* Deprecated, only works for DW3000.
+ * The pin operates to support
+ * external LNA */
+ // DW3000
+ DW3000_GPIO_PIN0_GPIO = 0x0,
+ DW3000_GPIO_PIN0_RXOKLED = 0x1,
+ DW3000_GPIO_PIN0_PDOA_SW_TX = 0x2,
+ DW3000_GPIO_PIN1_GPIO = 0x0 << (1 * 3),
+ DW3000_GPIO_PIN1_SFDLED = 0x1 << (1 * 3),
+ DW3000_GPIO_PIN1_PDOA_SW_RX = 0x2 << (1 * 3),
+ DW3000_GPIO_PIN2_GPIO = 0x0 << (2 * 3),
+ DW3000_GPIO_PIN2_RXLED = 0x1 << (2 * 3),
+ DW3000_GPIO_PIN2_PDOA_SW_RF1 = 0x2 << (2 * 3),
+ DW3000_GPIO_PIN3_GPIO = 0x0 << (3 * 3),
+ DW3000_GPIO_PIN3_TXLED = 0x1 << (3 * 3),
+ DW3000_GPIO_PIN3_PDOA_SW_RF2 = 0x2 << (3 * 3),
+ DW3000_GPIO_PIN4_GPIO = 0x0 << (4 * 3),
+ DW3000_GPIO_PIN4_EXTPA = 0x1 << (4 * 3),
+ DW3000_GPIO_PIN4_IRQ = 0x2 << (4 * 3),
+ DW3000_GPIO_PIN5_GPIO = 0x0 << (5 * 3),
+ DW3000_GPIO_PIN5_EXTTXE = 0x1 << (5 * 3),
+ DW3000_GPIO_PIN6_GPIO = 0x0 << (6 * 3),
+ DW3000_GPIO_PIN6_EXTRXE = 0x1 << (6 * 3),
+ DW3000_GPIO_PIN7_SYNC = 0x0 << (7 * 3),
+ DW3000_GPIO_PIN7_GPIO = 0x1 << (7 * 3),
+ DW3000_GPIO_PIN8_IRQ = 0x0 << (8 * 3),
+ DW3000_GPIO_PIN8_GPIO = 0x1 << (8 * 3),
+ // DW3700 and DW3720
+ DW37XX_GPIO_PIN0_SPI2_CLK = 0x0,
+ DW37XX_GPIO_PIN0_RXOKLED = 0x1,
+ DW37XX_GPIO_PIN0_GPIO = 0x2,
+ DW37XX_GPIO_PIN1_SPI2_MISO = 0x0 << (1 * 3),
+ DW37XX_GPIO_PIN1_SFDLED = 0x1 << (1 * 3),
+ DW37XX_GPIO_PIN1_GPIO = 0x2 << (1 * 3),
+ DW37XX_GPIO_PIN2_IRQ2 = 0x0 << (2 * 3),
+ DW37XX_GPIO_PIN2_RXLED = 0x1 << (2 * 3),
+ DW37XX_GPIO_PIN2_GPIO = 0x2 << (2 * 3),
+ DW37XX_GPIO_PIN3_SPI2_MOSI = 0x0 << (3 * 3),
+ DW37XX_GPIO_PIN3_TXLED = 0x1 << (3 * 3),
+ DW37XX_GPIO_PIN3_GPIO = 0x2 << (3 * 3),
+ DW37XX_GPIO_PIN4_GPIO = 0x0 << (4 * 3),
+ DW37XX_GPIO_PIN4_COEX_IN = 0x1 << (4 * 3),
+ DW37XX_GPIO_PIN4_PDOA_SW_TX = 0x2 << (4 * 3),
+ DW37XX_GPIO_PIN5_GPIO = 0x0 << (5 * 3),
+ DW37XX_GPIO_PIN5_COEX_OUT = 0x1 << (5 * 3),
+ DW37XX_GPIO_PIN5_PDOA_SW_RX = 0x2 << (5 * 3),
+ DW37XX_GPIO_PIN6_GPIO = 0x0 << (6 * 3),
+ DW37XX_GPIO_PIN6_EXT_SW_RX = 0x1 << (6 * 3),
+ DW37XX_GPIO_PIN6_PDOA_SW_RF1 = 0x2 << (6 * 3),
+ DW37XX_GPIO_PIN7_SYNC = 0x0 << (7 * 3),
+ DW37XX_GPIO_PIN7_GPIO = 0x1 << (7 * 3),
+ DW37XX_GPIO_PIN7_PDOA_SW_RF2 = 0x2 << (7 * 3),
+ DW37XX_GPIO_PIN8_IRQ = 0x0 << (8 * 3),
+ DW37XX_GPIO_PIN8_GPIO = 0x1 << (8 * 3)
+} dwt_gpio_pin_e;
+
+/* Mask that can be used in e.g ull_setgpiomode to use the GPIO mode of all GPIO
+ * pins on a DW3000 IC */
+#define DW3000_ENABLE_ALL_GPIOS_MASK 0x1200000
+
+/* Mask that can be used in e.g ull_setgpiomode to use the GPIO mode of all GPIO
+ * pins on a DW3700 or DW3720 IC*/
+#define DW37XX_ENABLE_ALL_GPIOS_MASK 0x1200492
+
+typedef enum
+{
+ GPIO0_FUNC_MASK = 0x0000007,
+ GPIO1_FUNC_MASK = 0x0000038,
+ GPIO2_FUNC_MASK = 0x00001c0,
+ GPIO3_FUNC_MASK = 0x0000e00,
+ GPIO4_FUNC_MASK = 0x0007000,
+ GPIO5_FUNC_MASK = 0x0038000,
+ GPIO6_FUNC_MASK = 0x01c0000,
+ GPIO7_FUNC_MASK = 0x0e00000,
+ GPIO8_FUNC_MASK = 0x7000000,
+} dwt_gpio_func_mask_e;
+
+/* Mask values for GPIO pins on DW3xxx */
+typedef enum
+{
+ GPIO0_BIT_MASK = 0x001,
+ GPIO1_BIT_MASK = 0x002,
+ GPIO2_BIT_MASK = 0x004,
+ GPIO3_BIT_MASK = 0x008,
+ GPIO4_BIT_MASK = 0x010,
+ GPIO5_BIT_MASK = 0x020,
+ GPIO6_BIT_MASK = 0x040,
+ GPIO7_BIT_MASK = 0x080,
+ GPIO8_BIT_MASK = 0x100,
+} dwt_gpio_mask_e;
+
+#define GPIO_BIT_MASK_ALL 0x1FF
+
+/* Deprecated. Use dwt_gpio_mask_e instead */
+typedef enum
+{
+ GPIO_0 = GPIO0_BIT_MASK,
+ GPIO_1 = GPIO1_BIT_MASK,
+ GPIO_2 = GPIO2_BIT_MASK,
+ GPIO_3 = GPIO3_BIT_MASK,
+ GPIO_4 = GPIO4_BIT_MASK,
+ GPIO_5 = GPIO5_BIT_MASK,
+ GPIO_6 = GPIO6_BIT_MASK,
+ GPIO_7 = GPIO7_BIT_MASK,
+ GPIO_8 = GPIO8_BIT_MASK,
+ GPIO_ALL = GPIO_BIT_MASK_ALL,
+} gpio_num_e;
+
+#define GPIO_MFIO_MODE_MASK 0x7U
+
+/* Enable/disable WiFi co-existence */
+typedef enum
+{
+ DWT_EN_WIFI_COEX = 0, /* Configure GPIO for WiFi co-ex - GPIO high*/
+ DWT_DIS_WIFI_COEX /* Configure GPIO for WiFi co-ex - GPIO low */
+} dwt_wifi_coex_e;
+
+// Defined constants for "lna_pa" bit field parameter passed to
+// dwt_setlnapamode() function
+typedef enum
+{
+ DWT_LNA_PA_DISABLE = 0x00,
+ DWT_LNA_ENABLE = 0x01,
+ DWT_PA_ENABLE = 0x02,
+ DWT_TXRX_EN = 0x04,
+} dwt_setlnapmodes_e;
+
+typedef enum
+{
+ DWT_TIMER0 = 0,
+ DWT_TIMER1
+} dwt_timers_e;
+
+typedef enum
+{
+ DWT_TIM_SINGLE = 0,
+ DWT_TIM_REPEAT
+} dwt_timer_mode_e;
+
+typedef enum
+{
+ DWT_XTAL = 0, // 38.4 MHz
+ DWT_XTAL_DIV2 = 1, // 19.2 MHz
+ DWT_XTAL_DIV4 = 2, // 9.6 MHz
+ DWT_XTAL_DIV8 = 3, // 4.8 MHz
+ DWT_XTAL_DIV16 = 4, // 2.4 MHz
+ DWT_XTAL_DIV32 = 5, // 1.2 MHz
+ DWT_XTAL_DIV64 = 6, // 0.6 MHz
+ DWT_XTAL_DIV128 = 7 // 0.3 MHz
+} dwt_timer_period_e;
+
+typedef struct
+{
+ dwt_timers_e timer; // Select the timer to use.
+ dwt_timer_period_e timer_div; // Select the timer frequency (divider).
+ dwt_timer_mode_e timer_mode; // Select the timer mode.
+ uint8_t timer_gpio_stop; // Set to '1' to halt GPIO on interrupt.
+ uint8_t timer_coexout; // Configure GPIO for WiFi co-ex.
+} dwt_timer_cfg_t;
+
+// Reset options
+typedef enum
+{
+ DWT_RESET_ALL = 0x00,
+ DWT_RESET_CTRX = 0x0F,
+ DWT_RESET_RX = 0xEF,
+ DWT_RESET_CLEAR = 0xFF,
+} dwt_reset_options_e;
+
+// frame filtering configuration options
+typedef enum
+{
+ DWT_FF_ENABLE_802_15_4 = 0x2, // enable FF for 802.15.4
+ DWT_FF_DISABLE = 0x0, // disable FF
+ DWT_FF_BEACON_EN = 0x001, // beacon frames allowed
+ DWT_FF_DATA_EN = 0x002, // data frames allowed
+ DWT_FF_ACK_EN = 0x004, // ack frames allowed
+ DWT_FF_MAC_EN = 0x008, // mac control frames allowed
+ DWT_FF_RSVD_EN = 0x010, // reserved frame types allowed
+ DWT_FF_MULTI_EN = 0x020, // multipurpose frames allowed
+ DWT_FF_FRAG_EN = 0x040, // fragmented frame types allowed
+ DWT_FF_EXTEND_EN = 0x080, // extended frame types allowed
+ DWT_FF_COORD_EN = 0x100, // behave as coordinator (can receive
+ // frames with no dest address (PAN ID
+ // has to match))
+ DWT_FF_IMPBRCAST_EN = 0x200, // allow MAC implicit broadcast
+ DWT_FF_MAC_LE0_EN = 0x408, // mac frames allowed if address in
+ // LE0_PEND matches source address
+ DWT_FF_MAC_LE1_EN = 0x808, // mac frames allowed if address in
+ // LE1_PEND matches source address
+ DWT_FF_MAC_LE2_EN = 0x1008, // mac frames allowed if address in
+ // LE2_PEND matches source address
+ DWT_FF_MAC_LE3_EN = 0x2008, // mac frames allowed if address in
+ // LE3_PEND matches source address
+} dwt_ff_conf_options_e;
+
+// DW3000 SLEEP and WAKEUP configuration parameters
+typedef enum
+{
+ DWT_PGFCAL = 0x0800,
+ DWT_GOTORX = 0x0200,
+ DWT_GOTOIDLE = 0x0100,
+ DWT_SEL_OPS3 = 0x00C0,
+ DWT_SEL_OPS2 = 0x0080, // Short OPS table
+ DWT_SEL_OPS1 = 0x0040, // SCP
+ DWT_SEL_OPS0 = 0x0000, // Long OPS table
+ DWT_ALT_OPS = 0x0020,
+ DWT_LOADLDO = 0x0010,
+ DWT_LOADDGC = 0x0008,
+ DWT_LOADBIAS = 0x0004,
+ DWT_RUNSAR = 0x0002,
+ DWT_CONFIG = 0x0001, // download the AON array into the HIF
+ // (configuration download)
+} dwt_on_wake_param_e;
+
+typedef enum
+{
+ DWT_PRES_SLEEP = 0x20, // allows for SLEEP_EN bit to be "preserved",
+ // although it will self - clear on wake up
+ DWT_WAKE_WUP = 0x10, // wake up on WAKEUP PIN
+ DWT_WAKE_CSN = 0x8, // wake up on chip select
+ DWT_BROUT_EN = 0x4, // enable brownout detector during sleep/deep
+ // sleep
+ DWT_SLEEP = 0x2, // enable sleep (if this bit is clear the device
+ // will enter deep sleep)
+ DWT_SLP_EN = 0x1, // enable sleep/deep sleep functionality
+} dwt_wkup_param_e;
+
+// Events that can be used to automatically transition to SLEEP or DEEPSLEEP
+typedef enum
+{
+ DWT_TX_COMPLETE = 0x01,
+ DWT_RX_COMPLETE = 0x02
+} dwt_sleep_after_param_e;
+
+// DW3000 IDLE/INIT mode definitions
+typedef enum
+{
+ DWT_DW_INIT = 0x0,
+ DWT_DW_IDLE = 0x1,
+ DWT_DW_IDLE_RC = 0x2,
+} dwt_idle_init_modes_e;
+
+typedef enum
+{
+ DWT_READ_OTP_PID = 0x10, // read part ID from OTP
+ DWT_READ_OTP_LID = 0x20, // read lot ID from OTP
+ DWT_READ_OTP_BAT = 0x40, // read ref voltage from OTP
+ DWT_READ_OTP_TMP = 0x80, // read ref temperature from OTP
+} dwt_read_otp_modes_e;
+
+// DW3xxx RF Port configuration set selection
+typedef enum
+{
+ DWT_RF_PORT_DEF = 0, // Configure RF port to default value 0 (device
+ // will internally switch depending on the PDoA
+ // mode)
+ DWT_RF_PORT_1 = 1, // select RF port 1
+ DWT_RF_PORT_2 = 2, // select RF port 2
+} dwt_rf_port_selection_e;
+
+// DW3xxx enabling manual control of antenna selection
+typedef enum
+{
+ DWT_RF_PORT_MAN_CTRL_EN = 1, // enabling manual control of antenna
+ // selection bits
+ DWT_RF_PORT_MAN_CTRL_DISEN = 0, // disabling manual control of antenna
+ // selection bits
+} dwt_rf_port_ctrl_e;
+
+// Conversion factor to convert clock offset from PPM to ratio
+#define CLOCK_OFFSET_PPM_TO_RATIO (1.0 / (1 << 26))
+
+typedef enum
+{
+ AON_SLPCNT_LO = (0x102), // address of SLEEP counter bits [19:12]
+ // in AON memory
+ AON_SLPCNT_HI = (0x103), // address of SLEEP counter bits [27:20]
+ // in AON memory
+ AON_SLPCNT_CAL_CTRL = (0x104), // address of SLEEP counter cal control
+ AON_LPOSC_TRIM = (0x10B), // address of LP OSC trim code
+ AON_SLPCNT_CAL_LO = (0x10E), // address of SLEEP counter cal value low
+ // byte
+ AON_SLPCNT_CAL_HI = (0x10F), // address of SLEEP counter cal value
+ // high byte
+} dwt_aon_sleep_conf_e;
+
+typedef enum
+{
+ DW_CIA_DIAG_LOG_MAX = 0x8, // CIA to copy to swinging set a maximum set
+ // of diagnostic registers in Double Buffer
+ // mode
+ DW_CIA_DIAG_LOG_MID = 0x4, // CIA to copy to swinging set a medium set
+ // of diagnostic registers in Double Buffer
+ // mode
+ DW_CIA_DIAG_LOG_MIN = 0x2, // CIA to copy to swinging set a minimal set
+ // of diagnostic registers in Double Buffer
+ // mode
+ DW_CIA_DIAG_LOG_ALL = 0x1, // CIA to log all diagnostic registers
+ DW_CIA_DIAG_LOG_OFF = 0x0, // CIA to log reduced set of diagnostic
+ // registers
+} dwt_cia_diag_log_conf_e;
+
+// Call-back data RX frames flags
+typedef enum
+{
+ DWT_CB_DATA_RX_FLAG_RNG = 0x01, // Ranging bit
+ DWT_CB_DATA_RX_FLAG_ND = 0x02, // No data mode
+ DWT_CB_DATA_RX_FLAG_CIA = 0x04, // CIA done
+ DWT_CB_DATA_RX_FLAG_CER = 0x08, // CIA error
+ DWT_CB_DATA_RX_FLAG_CPER = 0x10, // STS error
+} dwt_cb_data_rx_flags_e;
+
+// Multiplication factors to convert carrier integrator value to a frequency
+// offset in Hertz
+#define FREQ_OFFSET_MULTIPLIER (998.4e6 / 2.0 / 1024.0 / 131072.0)
+
+// Multiplication factors to convert frequency offset in Hertz to PPM crystal
+// offset
+// NB: also changes sign so a positive value means the local RX clock is running
+// slower than the remote TX device.
+#define HERTZ_TO_PPM_MULTIPLIER_CHAN_5 (-1.0e6 / 6489.6e6)
+#define HERTZ_TO_PPM_MULTIPLIER_CHAN_9 (-1.0e6 / 7987.2e6)
+
+#define DWT_VALID_TDOA_LIMIT (100) // If the abs(TDoA) value is larger
+ // than this constant, this means
+ // the PDoA will not be valid,
+ // and should not be used.
+
+// Low Energy (LE) device addresses
+typedef enum
+{
+ LE0 = 0, // LE0_PEND address
+ LE1 = 1, // LE1_PEND address
+ LE2 = 2, // LE2_PEND address
+ LE3 = 3, // LE3_PEND address
+} dwt_le_addresses_e;
+
+// TX/RX call-back data
+typedef struct
+{
+ uint32_t status; // initial value of register as ISR is entered
+ uint16_t status_hi; // initial value of register as ISR is entered, if
+ // relevant for that event type
+ uint16_t datalength; // length of frame
+ uint8_t rx_flags; // RX frame flags, see above
+ uint8_t dss_stat; // Dual SPI status reg 11:38, 2 LSbits relevant :
+ // bit0 (DWT_CB_DSS_SPI1_AVAIL) and bit1
+ // (DWT_CB_DSS_SPI2_AVAIL)
+ struct dwchip_s *dw;
+} dwt_cb_data_t;
+
+// Call-back type for SPI read error event (if the DW3000 generated CRC does not
+// match the one calculated by the dwt_generatecrc8 function)
+typedef void (*dwt_spierrcb_t)(void);
+
+// Call-back type for all interrupt events
+typedef void (*dwt_cb_t)(const dwt_cb_data_t *);
+
+#define SQRT_FACTOR 181 /*Factor of sqrt(2) for calculation*/
+#define STS_LEN_SUPPORTED 7 /*The supported STS length options*/
+#define SQRT_SHIFT_VAL 7
+#define SHIFT_VALUE 11
+#define MOD_VALUE 2048
+#define HALF_MOD (MOD_VALUE >> 1)
+
+/*This Enum holds INT working options.*/
+typedef enum
+{
+ DWT_DISABLE_INT = 0, /* Disable these INT */
+ DWT_ENABLE_INT, /* Enable these INT */
+ DWT_ENABLE_INT_ONLY, /* Enable only these INT*/
+ DWT_ENABLE_INT_DUAL_SPI, /* Enable these INT, dual SPI mode */
+ DWT_ENABLE_INT_ONLY_DUAL_SPI, /* Enable only these INT, dual SPI mode */
+} dwt_INT_options_e;
+
+/*This Enum holds the index for factor calculation.*/
+typedef enum
+{
+ DWT_STS_LEN_32 = 0,
+ DWT_STS_LEN_64 = 1,
+ DWT_STS_LEN_128 = 2,
+ DWT_STS_LEN_256 = 3,
+ DWT_STS_LEN_512 = 4,
+ DWT_STS_LEN_1024 = 5,
+ DWT_STS_LEN_2048 = 6
+} dwt_sts_lengths_e;
+
+/* Returns the value to set in CP_CFG0_ID for STS length. The x is the enum
+ * value from dwt_sts_lengths_e */
+#define GET_STS_REG_SET_VALUE(x) ((uint16_t)1 << ((x) + 2))
+
+/* Enum used for selecting channel for DGC on-wake kick. */
+typedef enum
+{
+ DWT_DGC_SEL_CH5 = 0,
+ DWT_DGC_SEL_CH9
+} dwt_dgc_chan_sel;
+
+/* Enum used for selecting location to load DGC data from */
+typedef enum
+{
+ DWT_DGC_LOAD_FROM_SW = 0,
+ DWT_DGC_LOAD_FROM_OTP
+} dwt_dgc_load_location;
+
+/*!
+ * ---------------------------------------------------------------------------
+ * Structure typedef: dwt_config_t
+ *
+ * Structure for setting device configuration via dwt_configure() function
+ *
+ */
+typedef struct
+{
+ uint8_t chan; //!< Channel number (5 or 9)
+ dwt_tx_plen_e txPreambLength; //!< DWT_PLEN_64..DWT_PLEN_4096
+ dwt_pac_size_e rxPAC; //!< Acquisition Chunk Size (Relates to RX
+ //!< preamble length)
+ uint8_t txCode; //!< TX preamble code (the code configures
+ //!< the PRF, e.g. 9 -> PRF of 64 MHz)
+ uint8_t rxCode; //!< RX preamble code (the code configures
+ //!< the PRF, e.g. 9 -> PRF of 64 MHz)
+ dwt_sfd_type_e sfdType; //!< SFD type (0 for short IEEE 8-bit
+ //!< standard, 1 for DW 8-bit, 2 for DW
+ //!< 16-bit, 3 for 4z BPRF)
+ dwt_uwb_bit_rate_e dataRate; //!< Data rate {DWT_BR_850K or DWT_BR_6M8}
+ dwt_phr_mode_e phrMode; //!< PHR mode {0x0 - standard
+ //!< DWT_PHRMODE_STD, 0x3 - extended
+ //!< frames DWT_PHRMODE_EXT}
+ dwt_phr_rate_e phrRate; //!< PHR rate {0x0 - standard
+ //!< DWT_PHRRATE_STD, 0x1 - at datarate
+ //!< DWT_PHRRATE_DTA}
+ uint16_t sfdTO; //!< SFD timeout value (in symbols)
+ dwt_sts_mode_e stsMode; //!< STS mode (no STS, STS before PHR or
+ //!< STS after data)
+ dwt_sts_lengths_e stsLength; //!< STS length (the allowed values are
+ //!< listed in dwt_sts_lengths_e
+ dwt_pdoa_mode_e pdoaMode; //!< PDOA mode
+#ifndef WIN32
+} __attribute__((packed)) dwt_config_t;
+#else
+} dwt_config_t;
+#endif // WIN32
+
+typedef struct
+{
+ uint8_t PGdly;
+ // TX POWER
+ // 31:24 TX_CP_PWR
+ // 23:16 TX_SHR_PWR
+ // 15:8 TX_PHR_PWR
+ // 7:0 TX_DATA_PWR
+ uint32_t power;
+ uint16_t PGcount;
+#ifndef WIN32
+} __attribute__((packed)) dwt_txconfig_t;
+#else
+} dwt_txconfig_t;
+#endif // WIN32
+
+typedef struct
+{
+ uint8_t ipatovRxTime[5]; // RX timestamp from Ipatov sequence
+ uint8_t ipatovRxStatus; // RX status info for Ipatov sequence
+ uint16_t ipatovPOA; // POA of Ipatov
+
+ uint8_t stsRxTime[5]; // RX timestamp from STS
+ uint16_t stsRxStatus; // RX status info for STS
+ uint16_t stsPOA; // POA of STS block 1
+ uint8_t sts2RxTime[5]; // RX timestamp from STS
+ uint16_t sts2RxStatus; // RX status info for STS
+ uint16_t sts2POA; // POA of STS block 2
+
+ uint8_t tdoa[6]; // TDOA from two STS RX timestamps
+ int16_t pdoa; // PDOA from two STS POAs signed int [1:-11] in radians
+
+ int16_t xtalOffset; // estimated xtal offset of remote device
+ uint32_t ciaDiag1; // Diagnostics common to both sequences
+
+ uint32_t ipatovPeak; // index and amplitude of peak sample in
+ // Ipatov sequence CIR
+ uint32_t ipatovPower; // channel area allows estimation of channel
+ // power for the Ipatov sequence
+ uint32_t ipatovF1; // F1 for Ipatov sequence
+ uint32_t ipatovF2; // F2 for Ipatov sequence
+ uint32_t ipatovF3; // F3 for Ipatov sequence
+ uint16_t ipatovFpIndex; // First path index for Ipatov sequence
+ uint16_t ipatovAccumCount; // Number accumulated symbols for Ipatov
+ // sequence
+
+ uint32_t stsPeak; // index and amplitude of peak sample in STS CIR
+ uint32_t stsPower; // channel area allows estimation of channel
+ // power for the STS
+ uint32_t stsF1; // F1 for STS
+ uint32_t stsF2; // F2 for STS
+ uint32_t stsF3; // F3 for STS
+ uint16_t stsFpIndex; // First path index for STS
+ uint16_t stsAccumCount; // Number accumulated symbols for STS
+
+ uint32_t sts2Peak; // index and amplitude of peak sample in STS
+ // CIR
+ uint32_t sts2Power; // channel area allows estimation of channel
+ // power for the STS
+ uint32_t sts2F1; // F1 for STS
+ uint32_t sts2F2; // F2 for STS
+ uint32_t sts2F3; // F3 for STS
+ uint16_t sts2FpIndex; // First path index for STS
+ uint16_t sts2AccumCount; // Number accumulated symbols for STS
+
+#ifndef WIN32
+} __attribute__((packed)) dwt_rxdiag_t;
+#else
+} dwt_rxdiag_t;
+#endif // WIN32
+
+typedef struct
+{
+ // all of the below are mapped to a register in DW3000
+ uint16_t PHE; // 12-bit number of received header error events
+ uint16_t RSL; // 12-bit number of received frame sync loss event
+ // events
+ uint16_t CRCG; // 12-bit number of good CRC received frame events
+ uint16_t CRCB; // 12-bit number of bad CRC (CRC error) received frame
+ // events
+ uint8_t ARFE; // 8-bit number of address filter error events
+ uint8_t OVER; // 8-bit number of receive buffer overrun events (used
+ // in double buffer mode)
+ uint16_t SFDTO; // 12-bit number of SFD timeout events
+ uint16_t PTO; // 12-bit number of Preamble timeout events
+ uint8_t RTO; // 8-bit number of RX frame wait timeout events
+ uint16_t TXF; // 12-bit number of transmitted frame events
+ uint8_t HPW; // 8-bit half period warning events (when delayed RX/TX
+ // enable is used)
+ uint8_t CRCE; // 8-bit SPI CRC error events
+ uint16_t PREJ; // 12-bit number of Preamble rejection events
+ uint16_t SFDD; // 12-bit SFD detection events ... only DW3720
+ uint8_t STSE; // 8-bit STS error/warning events
+#ifndef WIN32
+} __attribute__((packed)) dwt_deviceentcnts_t;
+#else
+} dwt_deviceentcnts_t;
+#endif // WIN32
+
+/* BEGIN: CHIP_SPECIFIC_SECTION DW37xx */
+
+/* Hosts for the SPI bus */
+typedef enum
+{
+ DWT_HOST_SPI1 = 0, /* Host using SPI1 interface */
+ DWT_HOST_SPI2 /* Host using SPI2 interface */
+} dwt_spi_host_e;
+
+#define SPI2MAVAIL_BIT_MASK 0x2 // bit 1 of 1a:01
+#define SPI1MAVAIL_BIT_MASK 0x4 // bit 2 of 1a:01
+
+typedef enum
+{
+ HOST_EN_SLEEP = 0x00, /* Host enable Sleep/Deepsleep */
+ HOST_DIS_SLEEP = 0x60 /* Host disable Sleep/Deepsleep */
+} dwt_host_sleep_en_e;
+
+/* END: CHIP_SPECIFIC_SECTION DW37xx */
+
+/******************************************************************************/
+
+/* AES BLOCK
+ * */
+
+/******************************************************************************/
+
+// enums below are defined in such a way as to allow a simple write to DW3000
+// AES configuration registers
+
+/* For MIC size definition */
+typedef enum
+{
+ MIC_0 = 0,
+ MIC_4,
+ MIC_6,
+ MIC_8,
+ MIC_10,
+ MIC_12,
+ MIC_14,
+ MIC_16
+} dwt_mic_size_e;
+
+/* Key size definition */
+typedef enum
+{
+ AES_KEY_128bit = 0,
+ AES_KEY_192bit = 1,
+ AES_KEY_256bit = 2
+} dwt_aes_key_size_e;
+
+/* Load key from RAM selection */
+typedef enum
+{
+ AES_KEY_No_Load = 0,
+ AES_KEY_Load
+} dwt_aes_key_load_e;
+
+/* Key source - RAM or registers */
+typedef enum
+{
+ AES_KEY_Src_Register = 0, /* Use AES KEY from registers */
+ AES_KEY_Src_RAMorOTP /* Use AES KEY from RAM or OTP (depending if
+ * AES_key_OTP set),
+ * AES_KEY_Load needs to be set as well
+ */
+} dwt_aes_key_src_e;
+
+/* Operation selection */
+typedef enum
+{
+ AES_Encrypt = 0,
+ AES_Decrypt
+} dwt_aes_mode_e;
+
+/* This defines the source port for encrypted/unencrypted data */
+typedef enum
+{
+ AES_Src_Scratch = 0,
+ AES_Src_Rx_buf_0,
+ AES_Src_Rx_buf_1,
+ AES_Src_Tx_buf
+} dwt_aes_src_port_e;
+
+/* This defines the dest port for encrypted/unencrypted data */
+typedef enum
+{
+ AES_Dst_Scratch = 0,
+ AES_Dst_Rx_buf_0,
+ AES_Dst_Rx_buf_1,
+ AES_Dst_Tx_buf,
+ AES_Dst_STS_key
+} dwt_aes_dst_port_e;
+
+/* storage for 128/192/256-bit key */
+typedef struct
+{
+ uint32_t key0;
+ uint32_t key1;
+ uint32_t key2;
+ uint32_t key3;
+ uint32_t key4;
+ uint32_t key5;
+ uint32_t key6;
+ uint32_t key7;
+} dwt_aes_key_t;
+
+typedef enum
+{
+ AES_core_type_GCM = 0, /* Core type GCM */
+ AES_core_type_CCM /* Core type CCM */
+} dwt_aes_core_type_e;
+
+typedef enum
+{
+ AES_key_RAM = 0, /* Use the AES KEY from RAM */
+ AES_key_OTP /* Use the AES KEY from OTP, key_load needs to match ->
+ * needs to be set to AES_KEY_Src_Ram */
+} dwt_aes_key_otp_type_e;
+
+typedef enum
+{
+ AES_key_otp_sel_1st_128 = 0, /* Key first 128bits */
+ AES_key_otp_sel_2nd_128 /* Key second 128bits */
+} dwt_aes_otp_sel_key_block_e;
+
+typedef struct
+{
+ dwt_aes_otp_sel_key_block_e aes_otp_sel_key_block; //!< Select OTP key,
+ //!< first 128 or
+ //!< 2nd 128 bits
+ dwt_aes_key_otp_type_e aes_key_otp_type; //!< Using KEY from
+ //!< OTP or RAM, if
+ //!< this is set to
+ //!< AES_key_OTP,
+ //!< KEY from OTP
+ //!< is used
+ dwt_aes_core_type_e aes_core_type; //!< Core type GCM or
+ //!< CCM*
+ dwt_mic_size_e mic; //!< Message
+ //!< integrity code
+ //!< size
+ dwt_aes_key_src_e key_src; //!< Location of the
+ //!< key: either as
+ //!< programmed in
+ //!< registers(128
+ //!< bit) or in the
+ //!< RAM or in the
+ //!< OTP
+ dwt_aes_key_load_e key_load; //!< Loads key from
+ //!< RAM or uses
+ //!< KEY from the
+ //!< registers
+ uint8_t key_addr; //!< Address offset
+ //!< of AES key
+ //!< when using AES
+ //!< key in RAM
+ dwt_aes_key_size_e key_size; //!< AES key length
+ //!< configuration
+ //!< corresponding
+ //!< to
+ //!< AES_KEY_128/192/256bit
+ dwt_aes_mode_e mode; //!< Operation type
+ //!< encrypt/decrypt
+} dwt_aes_config_t;
+
+typedef struct
+{
+ uint8_t *nonce; //!< Pointer to the nonce
+ uint8_t *header; //!< Pointer to header (this is not
+ //!< encrypted/decrypted)
+ uint8_t *payload; //!< Pointer to payload (this is
+ //!< encrypted/decrypted)
+ uint8_t header_len; //!< Header size
+ uint16_t payload_len; //!< Payload size
+ dwt_aes_src_port_e src_port; //!< Source port
+ dwt_aes_dst_port_e dst_port; //!< Dest port
+ dwt_aes_mode_e mode; //!< Encryption or decryption
+ uint8_t mic_size; //!< tag_size;
+} dwt_aes_job_t;
+
+/* storage for 128-bit STS CP key */
+typedef struct
+{
+ uint32_t key0;
+ uint32_t key1;
+ uint32_t key2;
+ uint32_t key3;
+#ifndef WIN32
+} __attribute__((packed)) dwt_sts_cp_key_t;
+#else
+} dwt_sts_cp_key_t;
+#endif // WIN32
+
+/* storage for 128-bit STS CP IV (nonce) */
+typedef struct
+{
+ uint32_t iv0;
+ uint32_t iv1;
+ uint32_t iv2;
+ uint32_t iv3;
+#ifndef WIN32
+} __attribute__((packed)) dwt_sts_cp_iv_t;
+#else
+} dwt_sts_cp_iv_t;
+#endif // WIN32
+
+#define ERROR_DATA_SIZE (-1)
+#define ERROR_WRONG_MODE (-2)
+#define ERROR_WRONG_MIC_SIZE (-3)
+#define ERROR_PAYLOAD_SIZE (-4)
+#define MIC_ERROR (0xff)
+#define STS_LEN_128BIT (16)
+
+typedef enum
+{
+ DBL_BUF_STATE_EN = 0, /*Double buffer enabled*/
+ DBL_BUF_STATE_DIS /*Double buffer disabled*/
+} dwt_dbl_buff_state_e;
+
+typedef enum
+{
+ DBL_BUF_MODE_AUTO = 0, /*Automatic*/
+ DBL_BUF_MODE_MAN /*Manual*/
+} dwt_dbl_buff_mode_e;
+
+typedef enum
+{
+ DBL_BUFF_OFF = 0x0,
+ DBL_BUFF_ACCESS_BUFFER_0 = 0x1,
+ DBL_BUFF_ACCESS_BUFFER_1 = 0x3,
+} dwt_dbl_buff_conf_e;
+
+// DW3000 NLOS DIAGNOSTIC TYPE
+typedef enum
+{
+ IPATOV = 0x0, // Select Ipatov Diagnostic
+ STS1 = 0x1, // Select STS1 Diagnostic
+ STS2 = 0x2, // Select STS2 Diagnostic
+} dwt_diag_type_e;
+
+// NLOS structs
+typedef struct
+{
+ uint32_t accumCount; // the number of preamble symbols
+ // accumulated, or accumulated STS
+ // length.
+ uint32_t F1; // the First Path Amplitude (point 1)
+ // magnitude value.
+ uint32_t F2; // the First Path Amplitude (point 2)
+ // magnitude value.
+ uint32_t F3; // the First Path Amplitude (point 3)
+ // magnitude value.
+ uint32_t cir_power; // the Channel Impulse Response Power
+ // value.
+ uint8_t D; // the DGC_DECISION, treated as an
+ // unsigned integer in range 0 to 7.
+ dwt_diag_type_e diag_type;
+ uint8_t result;
+} dwt_nlos_alldiag_t;
+
+typedef struct
+{
+ uint32_t index_fp_u32; // the First Path Index.
+ uint32_t index_pp_u32; // the Peak Path Index
+} dwt_nlos_ipdiag_t;
+
+/*
+ * The default XTAL TRIM value for load capacitors of 2pF.
+ * During the initialization the XTAL TRIM value can be read from the OTP and in
+ * case it is not present, the default would be used instead
+ * */
+#define DEFAULT_XTAL_TRIM 0x2E
+
+/*
+ * Max allowed value for XTAL trim
+ * */
+#define XTAL_TRIM_BIT_MASK 0x3F
+
+/*
+ * Antenna configuration
+ */
+#define ANT_GPIO6_POS_MASK 0x1U
+#define ANT_GPIO6_POS_OFFSET (0U)
+#define ANT_GPIO6_VAL_MASK 0x2U
+#define ANT_GPIO6_VAL_OFFSET (1U)
+#define ANT_GPIO7_POS_MASK 0x4U
+#define ANT_GPIO7_POS_OFFSET (2U)
+#define ANT_GPIO7_VAL_MASK 0x8U
+#define ANT_GPIO7_VAL_OFFSET (3U)
+
+/*
+ * DW37xx - enable/disable equaliser in the CIA
+ */
+typedef enum
+{
+ DWT_EQ_DISABLED = 0x0,
+ DWT_EQ_ENABLED = 0x1,
+} dwt_eq_config_e;
+
+/*
+ * Debug register name/value structure
+ */
+typedef struct {
+ char *name;
+ uint32_t address;
+} register_name_add_t;
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief The dwt_probe_s structure is a structure assembling all the external
+ * structures and function
+ * that must be defined externally
+ * NB: In porting this to a particular microprocessor, the implementer needs to
+ * define the low
+ * level abstract functions matching the selected hardware.
+ */
+struct dwt_probe_s
+{
+ /*!
+ * -------------------------------------------------------------------------
+ * @brief dw pointer to an externally defined dwchip_s.
+ * if set to NULL then an internal structure will be used
+ * the typical use case is to support multiple DW chip connection on the same
+ * board
+ * NB: see dwchip_s structure definition for details in deca_interface.h
+ */
+ void *dw;
+
+ /*!
+ * -------------------------------------------------------------------------
+ * @brief dw pointer to an externally defined dwt_spi_s structure
+ * NB: see dwt_spi_s structure definition for details in deca_interface.h
+ */
+ void *spi;
+
+ /*!
+ * -------------------------------------------------------------------------
+ * @brief This function wakeup device by an IO pin. DW3000 SPI_CS or WAKEUP
+ * pins can be used for this.
+ * wakeup_device_with_io() which is external to this file and is
+ * platform dependant and it should be modified to
+ * toggle the correct pin depending on the HW/MCU connections with
+ * DW3000.
+ */
+ void(*wakeup_device_with_io)(void);
+};
+
+/******************************************************************************/
+
+/* API LIST
+ * */
+
+/******************************************************************************/
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function selects the correct DecaDriver from the list
+ *
+ * input parameters
+ * @param probe_interf pointer to a dwt_probe_s structure. See above description
+ *
+ * output parameters
+ *
+ * returns ret - DWT_ERROR if no driver found or DWT_SUCCESS if driver is
+ * found.
+ */
+int dwt_probe(struct dwt_probe_s *probe_interf);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function returns the version of the API
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * returns version (DW3xxx_DRIVER_VERSION)
+ */
+int32_t dwt_apiversion(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function will update dw pointer used by interrupt
+ *
+ * input parameters
+ * @param new_dw - dw instatiated by MCPS layer
+ *
+ * return parameters
+ * old_dw pointer. This pointer can be restored when deleting MCPS instance
+ *
+ */
+struct dwchip_s * dwt_update_dw(struct dwchip_s *new_dw);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function returns the driver version of the API
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * returns version string
+ */
+char *dwt_version_string(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function sets the local data structure pointer to point to the
+ * element in the local array as given by the index.
+ *
+ * input parameters
+ * @param index - selects the array element to point to. Must be within the
+ * array bounds, i.e. < DWT_NUM_DW_DEV
+ *
+ * output parameters
+ *
+ * returns DWT_SUCCESS for success, or DWT_ERROR for error
+ */
+int dwt_setlocaldataptr(unsigned int index);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to return the read V measured @ 3.0 V value recorded in
+ * OTP address 0x8 (VBAT_ADDRESS)
+ *
+ * NOTE: dwt_initialise() must be called prior to this function so that it can
+ * return a relevant value.
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * returns the 8 bit V bat value as programmed in the factory
+ */
+uint8_t dwt_geticrefvolt(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to return the read T measured @ 22 C value recorded in
+ * OTP address 0x9 (VTEMP_ADDRESS)
+ *
+ * NOTE: dwt_initialise() must be called prior to this function so that it can
+ * return a relevant value.
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * returns the 8 bit V temp value as programmed in the factory
+ */
+uint8_t dwt_geticreftemp(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to return the read part ID of the device
+ *
+ * NOTE: dwt_initialise() must be called prior to this function so that it can
+ * return a relevant value.
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * returns the 32 bit part ID value as programmed in the factory
+ */
+uint32_t dwt_getpartid(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to return the read lot ID of the device
+ *
+ * NOTE: dwt_initialise() must be called prior to this function so that it can
+ * return a relevant value.
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * returns the 32 bit lot ID value as programmed in the factory
+ */
+uint32_t dwt_getlotid(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to return the read device type and revision information
+ * of the DW UWB chip
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * returns the silicon DevID
+ */
+uint32_t dwt_readdevid(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to return the read OTP revision
+ *
+ * NOTE: dwt_initialise() must be called prior to this function so that it can
+ * return a relevant value.
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * returns the read OTP revision value
+ */
+uint8_t dwt_otprevision(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function enables/disables the fine grain TX sequencing (enabled
+ * by default).
+ *
+ * input parameters
+ * @param enable - 1 to enable fine grain TX sequencing, 0 to disable it.
+ *
+ * output parameters none
+ *
+ * no return value
+ */
+void dwt_setfinegraintxseq(int enable);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to enable GPIO for external LNA or PA functionality - HW
+ * dependent, consult the DW3000 User Manual.
+ * This can also be used for debug as enabling TX and RX GPIOs is quite
+ * handy to monitor DW3000's activity.
+ *
+ * NOTE: Enabling PA functionality requires that fine grain TX sequencing is
+ * deactivated. This can be done using
+ * dwt_setfinegraintxseq().
+ *
+ * input parameters
+ * @param lna_pa - bit field: bit 0 if set will enable LNA functionality,
+ * : bit 1 if set will enable PA functionality,
+ * : to disable LNA/PA set the bits to 0 (
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_setlnapamode(int lna_pa);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to configure GPIO function
+ *
+ *
+ * input parameters
+ * @param gpio_mask - the mask of the GPIOs to change the mode of. Typically
+ * built from dwt_gpio_mask_e values.
+ * @param gpio_modes - the GPIO modes to set. Typically built from
+ * dwt_gpio_pin_e values.
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_setgpiomode(uint32_t gpio_mask, uint32_t gpio_modes);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to configure the GPIOs as inputs or outputs, default is
+ * input == 1
+ *
+ * input parameters
+ * @param in_out - if corresponding GPIO bit is set to 1 then it is input,
+ * otherwise it is output
+ * - GPIO 0 = bit 0, GPIO 1 = bit 1 etc...
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_setgpiodir(uint16_t in_out);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to set output value on GPIOs that have been configured
+ * for output via dwt_setgpiodir() API
+ *
+ * input parameters
+ * @param gpio - should be one or multiple of dwt_gpio_mask_e values
+ * @param value - Logic value for GPIO or GPIOs if multiple set at same time.
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_setgpiovalue(uint16_t gpio, int value);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the raw value of the GPIO pins.
+ * It is presumed that functions such as dwt_setgpiomode(),
+ * dwt_setgpiovalue() and dwt_setgpiodir() are called before this function.
+ *
+ * input parameters
+ *
+ * returns a uint16_t value that holds the value read on the GPIO pins.
+ */
+uint16_t dwt_readgpiovalue(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function initialises the DW3xxx transceiver:
+ * It performs the initially required device configurations and initializes
+ * a static data belonging to the low-level driver.
+ *
+ * NOTES:
+ * 1.this function needs to be run before dwt_configuresleep, also the SPI
+ * frequency has to be < 7MHz
+ * 2.it also reads and applies LDO and BIAS tune and crystal trim values from
+ * OTP memory
+ * 3.it is assumed this function is called after a reset or on power up of the
+ * DW3xxx transceiver
+ *
+ * input parameters
+ * @param mode - mask which defines which OTP values to read.
+ *
+ * output parameters
+ *
+ * returns DWT_SUCCESS for success, or DWT_ERROR for error
+ */
+int dwt_initialise(int mode);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function can place DW3000 into IDLE/IDLE_PLL or IDLE_RC mode when
+ * it is not actively in TX or RX.
+ *
+ * input parameters
+ * @param state - DWT_DW_IDLE (1) to put DW3000 into IDLE/IDLE_PLL state;
+ * DWT_DW_INIT (0) to put DW3000 into INIT_RC state;
+ * DWT_DE_IDLE_RC (2) to put DW3000 into IDLE_RC state.
+ *
+ * output parameters none
+ *
+ * no return value
+ */
+void dwt_setdwstate(int state);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to enable GPIO clocks. The clocks are needed to ensure
+ * correct GPIO operation
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_enablegpioclocks(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function needs to be called after device is woken up from
+ * DEEPSLEEP/SLEEP state, to restore the
+ * configuration which has not been automatically restored from AON
+ *
+ * input parameters
+ *
+ * return DWT_SUCCESS
+ *
+ */
+void dwt_restoreconfig(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function configures STS mode: e.g. DWT_STS_MODE_OFF,
+ * DWT_STS_MODE_1 etc
+ * The dwt_configure should be called prior to this to configure other
+ * parameters
+ *
+ * input parameters
+ * @param stsMode - e.g. DWT_STS_MODE_OFF, DWT_STS_MODE_1 etc.
+ *
+ * return DWT_SUCCESS
+ *
+ */
+void dwt_configurestsmode(uint8_t stsMode);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function provides the main API for the configuration of the
+ * DW3000 and this low-level driver. The input is a pointer to the data
+ * structure
+ * of type dwt_config_t that holds all the configurable items.
+ * The dwt_config_t structure shows which ones are supported
+ *
+ * input parameters
+ * @param config - pointer to the configuration structure, which contains
+ * the device configuration data.
+ *
+ * output parameters
+ *
+ * return DWT_SUCCESS or DWT_ERROR (e.g. when PLL CAL fails / PLL fails to lock)
+ */
+int dwt_configure(dwt_config_t *config);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function provides the API for the configuration of the TX
+ * spectrum
+ * including the power and pulse generator delay. The input is a pointer to the
+ * data structure
+ * of type dwt_txconfig_t that holds all the configurable items.
+ *
+ * input parameters
+ * @param config - pointer to the txrf configuration structure, which
+ * contains the tx rf config data
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_configuretxrf(dwt_txconfig_t *config);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function re-loads the STS AES initial value
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_configurestsloadiv(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function sets the default values of the lookup tables depending
+ * on the channel selected.
+ *
+ * input parameters
+ * @param[in] channel - Channel that the device will be transmitting/receiving
+ * on.
+ *
+ * no return value
+ */
+void dwt_configmrxlut(int channel);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function configures the STS AES 128 bit key value.
+ * the default value is [31:00]c9a375fa,
+ * [63:32]8df43a20,
+ * [95:64]b5e5a4ed,
+ * [127:96]0738123b
+ *
+ * input parameters
+ * @param pStsKey - the pointer to the structure of dwt_sts_cp_key_t type, which
+ * holds the AES128 key value to generate STS
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_configurestskey(dwt_sts_cp_key_t *pStsKey);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function configures the STS AES 128 bit initial value, the
+ * default value is 1, i.e. DW3000 reset value is 1.
+ *
+ * input parameters
+ * @param pStsIv - the pointer to the structure of dwt_sts_cp_iv_t type, which
+ * holds the IV value to generate STS
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_configurestsiv(dwt_sts_cp_iv_t *pStsIv);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This API function writes the antenna delay (in time units) to RX
+ * registers
+ *
+ * input parameters:
+ * @param rxDelay - this is the total (RX) antenna delay value, which
+ * will be programmed into the RX register
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_setrxantennadelay(uint16_t antennaDly);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This API function reads the antenna delay (in time units) from the RX
+ * antenna delay register
+ *
+ * input parameters:
+ * @param dw - DW3xxx chip descriptor handler.
+ *
+ * output parameters
+ *
+ * returns 16-bit RX antenna delay value which is currently programmed in
+ * CIA_CONF_ID register
+ */
+uint16_t dwt_getrxantennadelay(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This API function writes the antenna delay (in time units) to TX
+ * registers
+ *
+ * input parameters:
+ * @param txDelay - this is the total (TX) antenna delay value, which
+ * will be programmed into the TX delay register
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_settxantennadelay(uint16_t antennaDly);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This API function reads the antenna delay (in time units) from the TX
+ * antenna delay register
+ *
+ * input parameters:
+ * @param dw - DW3xxx chip descriptor handler.
+ *
+ * output parameters
+ *
+ * returns 16-bit TX antenna delay value which is currently programmed in
+ * TX_ANTD_ID register
+ */
+uint16_t dwt_gettxantennadelay(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This API function writes the supplied TX data into the DW3000's
+ * TX buffer. The input parameters are the data length in bytes and a pointer
+ * to those data bytes.
+ *
+ * input parameters
+ * @param txDataLength - This is the total length of data (in bytes) to write
+ * to the tx buffer.
+ * Note: the size of tx buffer is 1024 bytes.
+ * The standard PHR mode allows to transmit frames of up
+ * to 127 bytes (including 2 byte CRC)
+ * The extended PHR mode allows to transmit frames of up
+ * to 1023 bytes (including 2 byte CRC)
+ * if > 127 is programmed, DWT_PHRMODE_EXT needs to be
+ * set in the phrMode configuration
+ * see dwt_configure function
+ * @param txDataBytes - Pointer to the user's buffer containing the data to
+ * send.
+ * @param txBufferOffset - This specifies an offset in the DW IC's TX Buffer at
+ * which to start writing data.
+ *
+ * output parameters
+ *
+ * returns DWT_SUCCESS for success, or DWT_ERROR for error
+ */
+int dwt_writetxdata(uint16_t txDataLength,
+ uint8_t *txDataBytes,
+ uint16_t txBufferOffset);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This API function configures the TX frame control register before the
+ * transmission of a frame
+ *
+ * input parameters:
+ * @param txFrameLength - this is the length of TX message (including the 2 byte
+ * CRC) - max is 1023
+ * NOTE: standard PHR mode allows up to 127 bytes
+ * if > 127 is programmed, DWT_PHRMODE_EXT needs to
+ * be set in the phrMode configuration
+ * see dwt_configure function
+ * @param txBufferOffset - the offset in the tx buffer to start writing the data
+ * @param ranging - 1 if this is a ranging frame, else 0
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_writetxfctrl(uint16_t txFrameLength,
+ uint16_t txBufferOffset,
+ uint8_t ranging);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This API function is used to configure frame preamble length, the
+ * frame premable length can be
+ * configured in steps of 8, from 16 to 2048 symbols. If a non-zero value is
+ * configured, then the TXPSR_PE setting is ignored.
+ *
+ * input parameters:
+ * @param preambleLength - sets the length of the preamble, value of 0 disables
+ * this setting and the length of the
+ * frame will be dependent on the TXPSR_PE setting as
+ * configured by dwt_configure function
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_setplenfine(uint8_t preambleLength);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This call initiates the transmission, input parameter indicates which
+ * TX mode is used see below
+ *
+ * input parameters:
+ * @param mode - if mode = DWT_START_TX_IMMEDIATE - immediate TX (no response
+ * expected)
+ * if mode = DWT_START_TX_DELAYED - delayed TX (no response
+ * expected) at specified time (time in DX_TIME register)
+ * if mode = DWT_START_TX_DLY_REF - delayed TX (no response
+ * expected) at specified time
+ * (time in DREF_TIME register
+ * + any time in DX_TIME register)
+ * if mode = DWT_START_TX_DLY_RS - delayed TX (no response
+ * expected) at specified time
+ * (time in RX_TIME_0 register
+ * + any time in DX_TIME register)
+ * if mode = DWT_START_TX_DLY_TS - delayed TX (no response
+ * expected) at specified time
+ * (time in TX_TIME_LO register
+ * + any time in DX_TIME register)
+ * if mode = DWT_START_TX_IMMEDIATE | DWT_RESPONSE_EXPECTED -
+ * immediate TX (response expected,
+ * so
+ * the receiver will be automatically
+ *
+ *
+ * turned
+ * on after TX is done)
+ * if mode = DWT_START_TX_DELAYED | DWT_RESPONSE_EXPECTED -
+ * delayed TX (response expected,
+ * so the
+ * receiver will be automatically
+ * turned
+ * on after TX is done)
+ * if mode = DWT_START_TX_CCA - Send the frame if no
+ * preamble detected within PTO time
+ * if mode = DWT_START_TX_CCA | DWT_RESPONSE_EXPECTED - Send the
+ * frame if no preamble detected
+ * within
+ * PTO time and then enable RX output parameters
+ *
+ * returns DWT_SUCCESS for success, or DWT_ERROR for error (e.g. a delayed
+ * transmission will be cancelled if the delayed time has passed)
+ */
+int dwt_starttx(uint8_t mode);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This API function configures the reference time used for relative
+ * timing of delayed sending and reception.
+ * The value is at a 8ns resolution.
+ *
+ * input parameters
+ * @param reftime - the reference time (which together with DX_TIME or TX
+ * timestamp or RX timestamp time is used to define a
+ * transmission time or delayed RX on time)
+ *
+ * output parameters none
+ *
+ * no return value
+ */
+void dwt_setreferencetrxtime(uint32_t reftime);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This API function configures the delayed transmit time or the delayed
+ * RX on time
+ *
+ * input parameters
+ * @param starttime - the TX/RX start time (the 32 bits should be the high 32
+ * bits of the system time at which to send the message,
+ * or at which to turn on the receiver)
+ *
+ * output parameters none
+ *
+ * no return value
+ */
+void dwt_setdelayedtrxtime(uint32_t starttime);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the DGC_DECISION index when RX_TUNING is enabled,
+ * this value is used to adjust the
+ * RX level and FP level estimation
+ *
+ * input parameters
+ *
+ * output parameters - the index value to be used in RX level and FP level
+ * formulas
+ *
+ * no return value
+ */
+uint8_t dwt_get_dgcdecision(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the TX timestamp (adjusted with the programmed
+ * antenna delay)
+ *
+ * input parameters
+ * @param timestamp - a pointer to a 5-byte buffer which will store the read TX
+ * timestamp time
+ *
+ * output parameters - the timestamp buffer will contain the value after the
+ * function call
+ *
+ * no return value
+ */
+void dwt_readtxtimestamp(uint8_t *timestamp);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the high 32-bits of the TX timestamp (adjusted
+ * with the programmed antenna delay)
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * returns high 32-bits of TX timestamp
+ */
+uint32_t dwt_readtxtimestamphi32(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the low 32-bits of the TX timestamp (adjusted
+ * with the programmed antenna delay)
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * returns low 32-bits of TX timestamp
+ */
+uint32_t dwt_readtxtimestamplo32(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the PDOA result, it is the phase difference
+ * between either the Ipatov and STS POA, or
+ * the two STS POAs, depending on the PDOA mode of operation. (POA - Phase Of
+ * Arrival)
+ *
+ * NOTE: To convert to degrees: float pdoa_deg = ((float)pdoa / (1 << 11)) * 180
+ * / M_PI
+ *
+ * input parameters
+ *
+ * output parameters - the PDOA result (signed in [1:-11] radian units)
+ *
+ * no return value
+ */
+int16_t dwt_readpdoa(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function is used to read the TDOA (Time Difference On Arrival).
+ * The TDOA value that is read from the
+ * register is 41-bits in length. However, 6 bytes (or 48 bits) are read from
+ * the register. The remaining 7 bits at
+ * the 'top' of the 6 bytes that are not part of the TDOA value should be set to
+ * zero and should not interfere with
+ * rest of the 41-bit value. However, there is no harm in masking the returned
+ * value.
+ *
+ * input parameters
+ *
+ * output parameters
+ * @param tdoa: time difference on arrival - buffer of 6 bytes that will be
+ * filled with TDOA value by calling this function
+ *
+ * no return value
+ */
+void dwt_readtdoa(uint8_t *tdoa);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the RX timestamp (adjusted time of arrival)
+ *
+ * input parameters
+ * @param timestamp - a pointer to a 5-byte buffer which will store the read RX
+ * timestamp time
+ *
+ * output parameters - the timestamp buffer will contain the value after the
+ * function call
+ *
+ * no return value
+ */
+void dwt_readrxtimestamp(uint8_t *timestamp);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the RX timestamp (unadjusted time of arrival)
+ *
+ * input parameters
+ * @param timestamp - a pointer to a 5-byte buffer which will store the read RX
+ * timestamp time
+ *
+ * output parameters - the timestamp buffer will contain the value after the
+ * function call
+ *
+ * no return value
+ */
+void dwt_readrxtimestampunadj(uint8_t *timestamp);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the RX timestamp (adjusted time of arrival)
+ * w.r.t. Ipatov CIR
+ *
+ * input parameters
+ * @param timestamp - a pointer to a 5-byte buffer which will store the read RX
+ * timestamp time
+ *
+ * output parameters - the timestamp buffer will contain the value after the
+ * function call
+ *
+ * no return value
+ */
+void dwt_readrxtimestamp_ipatov(uint8_t *timestamp);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the RX timestamp (adjusted time of arrival)
+ * w.r.t. STS CIR
+ *
+ * input parameters
+ * @param timestamp - a pointer to a 5-byte buffer which will store the read RX
+ * timestamp time
+ *
+ * output parameters - the timestamp buffer will contain the value after the
+ * function call
+ *
+ * no return value
+ */
+void dwt_readrxtimestamp_sts(uint8_t *timestamp);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the high 32-bits of the RX timestamp (adjusted
+ * with the programmed antenna delay)
+ *
+ * NOTE: This should not be used when RX double buffer mode is enabled.
+ * Following APIs to read RX timestamp should be
+ * used: dwt_readrxtimestamp_ipatov or dwt_readrxtimestamp_sts or
+ * dwt_readrxtimestamp
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * returns high 32-bits of RX timestamp
+ */
+uint32_t dwt_readrxtimestamphi32(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the low 32-bits of the RX timestamp (adjusted
+ * with the programmed antenna delay)
+ *
+ * NOTE: This should not be used when RX double buffer mode is enabled.
+ * Following APIs to read RX timestamp should be
+ * used: dwt_readrxtimestamp_ipatov or dwt_readrxtimestamp_sts or
+ * dwt_readrxtimestamp
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * returns low 32-bits of RX timestamp
+ */
+uint32_t dwt_readrxtimestamplo32(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the high 32-bits of the system time
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * returns high 32-bits of system time timestamp
+ */
+uint32_t dwt_readsystimestamphi32(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the system time
+ *
+ * input parameters
+ * @param timestamp - a pointer to a 4-byte buffer which will store the read
+ * system time
+ *
+ * output parameters
+ * @param timestamp - the timestamp buffer will contain the value after the
+ * function call
+ *
+ * no return value
+ */
+void dwt_readsystime(uint8_t *timestamp);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to turn off the transceiver
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_forcetrxoff(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This call turns on the receiver, can be immediate or delayed
+ * (depending on the mode parameter). In the case of a
+ * "late" error the receiver will only be turned on if the DWT_IDLE_ON_DLY_ERR
+ * is not set.
+ * The receiver will stay turned on, listening to any messages until
+ * it either receives a good frame, an error (CRC, PHY header, Reed Solomon) or
+ * it times out (SFD, Preamble or Frame).
+ *
+ * input parameters
+ * @param mode - this can be one of the following allowed values:
+ *
+ * DWT_START_RX_IMMEDIATE 0x00 Enable the receiver immediately
+ * DWT_START_RX_DELAYED 0x01 Set up delayed RX, if "late" error
+ * triggers, then the RX will be enabled immediately
+ * DWT_IDLE_ON_DLY_ERR 0x02 If delayed RX failed due to "late" error
+ * then if this
+ * flag is set the RX will not be re-enabled
+ * immediately, and device will be in IDLE when function exits
+ * DWT_START_RX_DLY_REF 0x04 Enable the receiver at specified time
+ * (time in DREF_TIME register + any time in DX_TIME register)
+ * DWT_START_RX_DLY_RS 0x08 Enable the receiver at specified time
+ * (time in RX_TIME_0 register + any time in DX_TIME register)
+ * DWT_START_RX_DLY_TS 0x10 Enable the receiver at specified time
+ * (time in TX_TIME_LO register + any time in DX_TIME register)
+ *
+ * e.g.
+ * (DWT_START_RX_DELAYED | DWT_IDLE_ON_DLY_ERR) 0x03 used to disable re-enabling
+ * of receiver if delayed RX failed due to "late" error
+ *
+ * returns DWT_SUCCESS for success, or DWT_ERROR for error (e.g. a delayed
+ * receive enable will be too far in the future if delayed time has passed)
+ */
+int dwt_rxenable(int mode);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief enable/disable and configure SNIFF mode.
+ *
+ * SNIFF mode is a low-power reception mode where the receiver is sequenced on
+ * and off instead of being on all the time.
+ * The time spent in each state (on/off) is specified through the parameters
+ * below.
+ * See DW3000 User Manual section 4.5 "Low-Power SNIFF mode" for more details.
+ *
+ * input parameters:
+ * @param enable - 1 to enable SNIFF mode, 0 to disable. When 0, all other
+ * parameters are not taken into account.
+ * @param timeOn - duration of receiver ON phase, expressed in multiples of PAC
+ * size. The counter automatically adds 1 PAC
+ * size to the value set. Min value that can be set is 1 (i.e.
+ * an ON time of 2 PAC size), max value is 15.
+ * @param timeOff - duration of receiver OFF phase, expressed in multiples of
+ * 128/125 us (~1 us). Max value is 255.
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_setsniffmode(int enable, uint8_t timeOn, uint8_t timeOff);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This call enables the double receive buffer mode
+ *
+ * input parameters
+ * @param dbl_buff_state - enum variable for enabling/disabling double buffering
+ * mode
+ * @param dbl_buff_mode - enum variable for Receiver Auto-Re-enable
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_setdblrxbuffmode(dwt_dbl_buff_state_e dbl_buff_state,
+ dwt_dbl_buff_mode_e dbl_buff_mode);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This call signal to the chip that the specific RX buff is free for
+ * fill
+ *
+ * input parameters
+ * @param None
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_signal_rx_buff_free(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This call enables RX timeout (SY_STAT_RFTO event)
+ *
+ * input parameters
+ * @param time - how long the receiver remains on from the RX enable command
+ * The time parameter used here is in 1.0256 us (512/499.2MHz)
+ * units
+ * If set to 0 the timeout is disabled.
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_setrxtimeout(uint32_t time);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This call enables preamble timeout (SY_STAT_RXPTO event)
+ *
+ * input parameters
+ * @param timeout - Preamble detection timeout, expressed in multiples of PAC
+ * size. The counter automatically adds 1 PAC
+ * size to the value set. Min value that can be set is 1 (i.e.
+ * a timeout of 2 PAC size).
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_setpreambledetecttimeout(uint16_t timeout);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief calibrates the local oscillator as its frequency can vary between 15
+ * and 34kHz depending on temp and voltage
+ *
+ * NOTE: this function needs to be run before dwt_configuresleepcnt, so that we
+ * know what the counter units are
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * returns the number of XTAL cycles per low-power oscillator cycle. LP OSC
+ * frequency = 38.4 MHz/return value
+ */
+uint16_t dwt_calibratesleepcnt(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief sets the sleep counter to new value, this function programs the high
+ * 16-bits of the 28-bit counter
+ *
+ * NOTE: this function needs to be run before dwt_configuresleep, also the SPI
+ * frequency has to be < 3MHz
+ *
+ * input parameters
+ * @param sleepcnt - this it value of the sleep counter to program
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_configuresleepcnt(uint16_t sleepcnt);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief configures the device for both DEEP_SLEEP and SLEEP modes, and on-wake
+ * mode
+ * i.e. before entering the sleep, the device should be programmed for TX or RX,
+ * then upon "waking up" the TX/RX settings
+ * will be preserved and the device can immediately perform the desired action
+ * TX/RX
+ *
+ * NOTE: e.g. Tag operation - after deep sleep, the device needs to just load
+ * the TX buffer and send the frame
+ *
+ *
+ * mode:
+ * DWT_PGFCAL 0x0800 - Re-enable receiver on wake-up. !!!! on DW3720
+ * - this should be cleared
+ * DWT_GOTORX 0x0200
+ * DWT_GOTOIDLE 0x0100
+ * DWT_SEL_OPS 0x0040 | 0x0080
+ * DWT_LOADOPS 0x0020
+ * DWT_LOADLDO 0x0010
+ * DWT_LOADDGC 0x0008
+ * DWT_LOADBIAS 0x0004
+ * DWT_RUNSAR 0x0002
+ * DWT_CONFIG 0x0001 - download the AON array into the HIF
+ * (configuration download)
+ *
+ * wake: wake up parameters
+ * DWT_SLP_CNT_RPT 0x40 - sleep counter loop after expiration
+ * DWT_PRESRVE_SLP 0x20 - allows for SLEEP_EN bit to be "preserved",
+ * although it will self-clear on wake up
+ * DWT_WAKE_WK 0x10 - wake up on WAKEUP PIN
+ * DWT_WAKE_CS 0x8 - wake up on chip select
+ * DWT_BR_DET 0x4 - enable brownout detector during sleep/deep sleep
+ * DWT_SLEEP 0x2 - enable sleep
+ * DWT_SLP_EN 0x1 - enable sleep/deep sleep functionality
+ *
+ * input parameters
+ * @param mode - config on-wake parameters
+ * @param wake - config wake up parameters
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_configuresleep(uint16_t mode, uint8_t wake);
+
+/*!
+ * ---------------------------------------------------------------------------
+ *
+ * @brief this function clears the AON configuration in DW3000
+ *
+ * input parameters:
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_clearaonconfig(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function puts the device into deep sleep or sleep.
+ * dwt_configuresleep() should be called first
+ * to configure the sleep and on-wake/wake-up parameters.
+ *
+ * input parameters
+ * @param idle_rc - if this is set to DWT_DW_IDLE_RC, the auto INIT2IDLE bit
+ * will be cleared prior to going to sleep
+ * thus after wakeup device will stay in IDLE_RC state
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_entersleep(int idle_rc);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief sets or clears the auto TX to sleep bit. This means that after a frame
+ * transmission the device will enter sleep or deep sleep mode. The
+ * dwt_configuresleep() function
+ * needs to be called before this to configure the on-wake settings
+ *
+ * NOTE: the IRQ line has to be low/inactive (i.e. no pending events)
+ *
+ * Deprecated, might be removed in a future mayor release. Consider using the
+ * dwt_entersleepafter() function instead.
+ *
+ * input parameters
+ * @param enable - 1 to configure the device to enter sleep or deep sleep after
+ * TX, 0 - disables the configuration
+ *
+ * no return value
+ */
+void dwt_entersleepaftertx(int enable);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief Sets or clears the auto TX and/or RX to sleep bits.
+ *
+ * This makes the device automatically enter deep sleep or sleep mode after a
+ * frame transmission and/or reception.
+ * dwt_configuresleep() needs to be called before this to configure the sleep
+ * and on-wake/wake-up parameters.
+ *
+ * NOTE: the IRQ line has to be low/inactive (i.e. no pending events)
+ *
+ * input parameters
+ * @param event_mask: bitmask to go to sleep after:
+ * - DWT_TX_COMPLETE to configure the device to enter sleep or deep sleep after
+ * TX
+ * - DWT_RX_COMPLETE to configure the device to enter sleep or deep sleep after
+ * RX
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_entersleepafter(int event_mask);
+
+#ifdef WIN32
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @fn dwt_spicswakeup() --------- ********** NOTE: in decatest only
+ * ****************
+ *
+ * @brief wake up the device from sleep mode using the SPI read,
+ * the device will wake up on chip select line going low if the line is held low
+ * for at least 500us.
+ * To define the length depending on the time one wants to hold
+ * the chip select line low, use the following formula:
+ *
+ * length (bytes) = time (s) * byte_rate (Hz)
+ *
+ * where fastest byte_rate is spi_rate (Hz) / 8 if the SPI is sending the bytes
+ * back-to-back.
+ * To save time and power, a system designer could determine byte_rate value
+ * more precisely.
+ *
+ * NOTE: Alternatively the device can be waken up with WAKE_UP pin if configured
+ * for that operation
+ *
+ * input parameters
+ * @param buff - this is a pointer to the dummy buffer which will be used in
+ * the SPI read transaction used for the WAKE UP of the device
+ * @param length - this is the length of the dummy buffer
+ *
+ * output parameters
+ *
+ * returns DWT_SUCCESS for success, or DWT_ERROR for error
+ */
+int dwt_spicswakeup(uint8_t *buff, uint16_t length);
+
+#endif
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function is used to register the different callbacks called when
+ * one of the corresponding event occurs.
+ *
+ * NOTE: Callbacks can be undefined (set to NULL). In this case, dwt_isr() will
+ * process the event as usual but the 'null'
+ * callback will not be called.
+ *
+ * input parameters
+ * @param cbTxDone - the pointer to the TX confirmation event callback function
+ * @param cbRxOk - the pointer to the RX good frame event callback function
+ * @param cbRxTo - the pointer to the RX timeout events callback function
+ * @param cbRxErr - the pointer to the RX error events callback function
+ * @param cbSPIErr - the pointer to the SPI error events callback function
+ * @param cbSPIRdy - the pointer to the SPI ready events callback function
+ * @param cbDualSPIEv - the pointer to the Dual SPI events callback function
+ * (SPI1 Avail, SPI2 Avail)
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_setcallbacks(dwt_cb_t cbTxDone,
+ dwt_cb_t cbRxOk,
+ dwt_cb_t cbRxTo,
+ dwt_cb_t cbRxErr,
+ dwt_cb_t cbSPIErr,
+ dwt_cb_t cbSPIRdy,
+ dwt_cb_t cbDualSPIEv);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function checks if the IRQ line is active - this is used instead
+ * of interrupt handler
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * return value is 1 if the IRQS bit is set and 0 otherwise
+ */
+uint8_t dwt_checkirq(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function checks if the DW3000 is in IDLE_RC state
+ *
+ * The DW3XXX states are described in the User Manual. On power up, or following
+ * a reset the device will progress from INIT_RC to IDLE_RC.
+ * Once the device is in IDLE_RC SPI rate ca be increased to more than 7 MHz.
+ * The device will automatically proceed from INIT_RC to IDLE_RC
+ * and both INIT_RC and SPI_RDY event flags will be set, once device is in
+ * IDLE_RC.
+ *
+ * It is recommended that host waits for SPI_RDY event, which will also generate
+ * interrupt once device is ready after reset/power on.
+ * If the host cannot use interrupt as a way to check device is ready for SPI
+ * comms, then we recommend the host waits for 2 ms and reads this function,
+ * which checks if the device is in IDLE_RC state by reading the SYS_STATUS
+ * register and checking for the IDLE_RC event to be set.
+ * If host initiates SPI transaction with the device prior to it being ready,
+ * the SPI transaction may be incorrectly decoded by the device and
+ * the device may be misconfigured. Reading registers over SPI prior to device
+ * being ready may return garbage on the MISO, which may confuse the host
+ * application.
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * return value is 1 if the IDLE_RC bit is set and 0 otherwise
+ */
+uint8_t dwt_checkidlerc(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is the DW3000's general Interrupt Service Routine. It will
+ * process/report the following events:
+ * - RXFCG (through cbRxOk callback)
+ * - TXFRS (through cbTxDone callback)
+ * - RXRFTO/RXPTO (through cbRxTo callback)
+ * - RXPHE/RXFCE/RXRFSL/RXSFDTO/AFFREJ/LDEERR (through cbRxErr
+ * callback)
+ * For all events, corresponding interrupts are cleared and necessary
+ * resets are performed. In addition, in the RXFCG case,
+ * received frame information and frame control are read before calling
+ * the callback. If double buffering is activated, it
+ * will also toggle between reception buffers once the reception callback
+ * processing has ended.
+ *
+ * /!\ This version of the ISR supports double buffering but does not
+ * support automatic RX re-enabling!
+ *
+ * NOTE: In PC based system using (Cheetah or ARM) USB to SPI converter there
+ * can be no interrupts, however we still need something
+ * to take the place of it and operate in a polled way. In an embedded
+ * system this function should be configured to be triggered
+ * on any of the interrupts described above.
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_isr(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function enables the specified events to trigger an interrupt.
+ * The following events can be found in SYS_ENABLE_LO and SYS_ENABLE_HI
+ * registers.
+ *
+ *
+ * input parameters:
+ * @param bitmask_lo - sets the events in SYS_ENABLE_LO_ID register which will
+ * generate interrupt
+ * @param bitmask_hi - sets the events in SYS_ENABLE_HI_ID register which will
+ * generate interrupt
+ * @param operation - if set to DWT_ENABLE_INT additional interrupts as
+ * selected in the bitmask are enabled
+ * - if set to DWT_ENABLE_INT_ONLY the interrupts in the
+ * bitmask are forced to selected state -
+ * i.e. the mask is written to the register directly.
+ * - otherwise (if set to DWT_DISABLE_INT) clear the
+ * interrupts as selected in the bitmask
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_setinterrupt(uint32_t bitmask_lo,
+ uint32_t bitmask_hi,
+ dwt_INT_options_e INT_options);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to set the PAN ID
+ *
+ * input parameters
+ * @param panID - this is the PAN ID
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_setpanid(uint16_t panID);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to set 16-bit (short) address
+ *
+ * input parameters
+ * @param shortAddress - this sets the 16 bit short address
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_setaddress16(uint16_t shortAddress);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to set the EUI 64-bit (long) address
+ *
+ * input parameters
+ * @param eui64 - this is the pointer to a buffer that contains the 64bit
+ * address
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_seteui(uint8_t *eui64);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to get the EUI 64-bit from the DW3000
+ *
+ * input parameters
+ * @param eui64 - this is the pointer to a buffer that will contain the read
+ * 64-bit EUI value
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_geteui(uint8_t *eui64);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read from AON memory
+ *
+ * input parameters
+ * @param aon_address - this is the address of the memory location to read
+ *
+ * output parameters - None
+ *
+ * returns 8-bits read from given AON memory address
+ */
+uint8_t dwt_aon_read(uint16_t aon_address);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to write to AON memory
+ *
+ * @param aon_address - this is the address of the memory location to write
+ * @param aon_write_data - this is the data to write
+ *
+ * output parameters - None
+ *
+ * no return value
+ *
+ */
+void dwt_aon_write(uint16_t aon_address, uint8_t aon_write_data);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to enable the frame filtering - (the default option is to
+ * accept any data and ACK frames with correct destination address
+ *
+ * input parameters
+ * @param enabletype (bitmask) - enables/disables the frame filtering and
+ * configures 802.15.4 type
+ * DWT_FF_ENABLE_802_15_4 0x2 // use 802.15.4 filtering
+ * rules
+ * DWT_FF_DISABLE 0x0 // disable FF
+ * @param filtermode (bitmask) - configures the frame filtering options
+ * according to
+ * DWT_FF_BEACON_EN 0x001 // beacon frames allowed
+ * DWT_FF_DATA_EN 0x002 // data frames allowed
+ * DWT_FF_ACK_EN 0x004 // ack frames allowed
+ * DWT_FF_MAC_EN 0x008 // mac control frames
+ * allowed
+ * DWT_FF_RSVD_EN 0x010 // reserved frame types
+ * allowed
+ * DWT_FF_MULTI_EN 0x020 // multipurpose frames
+ * allowed
+ * DWT_FF_FRAG_EN 0x040 // fragmented frame types
+ * allowed
+ * DWT_FF_EXTEND_EN 0x080 // extended frame types
+ * allowed
+ * DWT_FF_COORD_EN 0x100 // behave as coordinator
+ * (can receive frames with no dest address (PAN ID has to match))
+ * DWT_FF_IMPBRCAST_EN 0x200 // allow MAC implicit
+ * broadcast
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_configureframefilter(uint16_t enabletype, uint16_t filtermode);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief this function is used to calculate 8-bit CRC, it uses 100000111
+ * polynomial (i.e. P(x) = x^8+ x^2+ x^1+ x^0)
+ *
+ * input parameters:
+ * @param byteArray - data to calculate CRC for
+ * @param flen - length of byteArray
+ * @param crcInit - initialisation value for CRC calculation
+ *
+ * output parameters
+ *
+ * returns 8-bit calculate CRC value
+ */
+uint8_t dwt_generatecrc8(const uint8_t *byteArray, int flen, uint8_t crcInit);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to enable SPI CRC check in DW3000
+ *
+ * input parameters
+ * @param crc_mode - if set to DWT_SPI_CRC_MODE_WR then SPI CRC checking will be
+ * performed in DW3000 on each SPI write
+ * last byte of the SPI write transaction needs to be the
+ * 8-bit CRC, if it does not match
+ * the one calculated by DW3000 SPI CRC ERROR event will be
+ * set in the status register (SYS_STATUS_SPICRC)
+ *
+ * @param spireaderr_cb - this needs to contain the callback function pointer
+ * which will be called when SPI read error
+ * is detected (when the DW3000 generated CRC does not
+ * match the one calculated by dwt_generatecrc8
+ * following the SPI read transaction)
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_enablespicrccheck(dwt_spi_crc_mode_e crc_mode,
+ dwt_spierrcb_t spireaderr_cb);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This call enables the auto-ACK feature. If the responseDelayTime
+ * (parameter) is 0, the ACK will be sent a.s.a.p.
+ * otherwise it will be sent with a programmed delay (in symbols), max is 255.
+ * NOTE: needs to have frame filtering enabled as well
+ *
+ * input parameters
+ * @param responseDelayTime - if non-zero the ACK is sent after this delay, max
+ * is 255.
+ * @param enable - enables or disables the auto-ACK feature
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_enableautoack(uint8_t responseDelayTime, int enable);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This sets the receiver turn on delay time after a transmission of a
+ * frame
+ *
+ * input parameters
+ * @param rxDelayTime - (20 bits) - the delay is in UWB microseconds
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_setrxaftertxdelay(uint32_t rxDelayTime);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief this function resets the DW3000
+ *
+ * NOTE: SPI rate must be <= 7MHz before a call to this function as the device
+ * will use FOSC/4 as part of internal reset
+ *
+ * input parameters:
+ * @param reset_semaphore - if set to 1 the semaphore will be also reset. (only
+ * valid for DW3720 device)
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_softreset(int reset_semaphore);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the data from the RX buffer, from an offset
+ * location give by offset parameter
+ *
+ * input parameters
+ * @param buffer - the buffer into which the data will be read
+ * @param length - the length of data to read (in bytes)
+ * @param rxBufferOffset - the offset in the rx buffer from which to read the
+ * data
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_readrxdata(uint8_t *buffer, uint16_t length, uint16_t rxBufferOffset);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to write the data from the RX scratch buffer, from an
+ * offset location given by offset parameter.
+ *
+ * input parameters
+ * @param buffer - the buffer which to write to the device
+ * @param length - the length of data to read (in bytes)
+ * @param bufferOffset - the offset in the scratch buffer to which to write the
+ * data
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_write_rx_scratch_data(uint8_t *buffer,
+ uint16_t length,
+ uint16_t bufferOffset);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the data from the RX scratch buffer, from an
+ * offset location given by offset parameter.
+ *
+ * input parameters
+ * @param buffer - the buffer into which the data will be read
+ * @param length - the length of data to read (in bytes)
+ * @param bufferOffset - the offset in the scratch buffer from which to read the
+ * data
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_read_rx_scratch_data(uint8_t *buffer,
+ uint16_t length,
+ uint16_t bufferOffset);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the 18 bit data from the Accumulator buffer, from
+ * an offset location give by offset parameter
+ * for 18 bit complex samples, each sample is 6 bytes (3 real and 3
+ * imaginary)
+ *
+ *
+ * NOTE: Because of an internal memory access delay when reading the accumulator
+ * the first octet output is a dummy octet
+ * that should be discarded. This is true no matter what sub-index the
+ * read begins at.
+ *
+ * input parameters
+ * @param buffer - the buffer into which the data will be read
+ * @param length - the length of data to read (in bytes)
+ * @param accOffset - the offset in the acc buffer from which to read the data,
+ * this is a complex sample index
+ * e.g. to read 10 samples starting at sample 100
+ * buffer would need to be >= 10*6 + 1, length is 61 (1 is
+ * for dummy), accOffset is 100
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_readaccdata(uint8_t *buffer, uint16_t len, uint16_t accOffset);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the crystal offset (relating to the frequency
+ * offset of the far DW3000 device compared to this one)
+ * Note: the returned signed 16-bit number shoudl be divided by 16 to get
+ * ppm offset.
+ *
+ * input parameters - NONE
+ *
+ * return value - the (int12) signed offset value. (s[6:-4])
+ * A positive value means the local RX clock is running faster
+ * than the remote TX device.
+ */
+int16_t dwt_readclockoffset(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the RX carrier integrator value (relating to the
+ * frequency offset of the TX node)
+ *
+ * input parameters - NONE
+ *
+ * return value - the (int32_t) signed carrier integrator value.
+ * A positive value means the local RX clock is running faster
+ * than the remote TX device.
+ */
+int32_t dwt_readcarrierintegrator(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief this function enables CIA diagnostic data. When turned on the
+ * following registers will be logged:
+ * IP_TOA_LO, IP_TOA_HI, STS_TOA_LO, STS_TOA_HI, STS1_TOA_LO, STS1_TOA_HI,
+ * CIA_TDOA_0, CIA_TDOA_1_PDOA, CIA_DIAG_0, CIA_DIAG_1
+ *
+ * input parameters
+ * @param enable_mask : DW_CIA_DIAG_LOG_MAX (0x8) //CIA to copy to
+ * swinging set a maximum set of diagnostic registers in Double Buffer mode
+ * DW_CIA_DIAG_LOG_MID (0x4) //CIA to copy to
+ * swinging set a medium set of diagnostic registers in Double Buffer mode
+ * DW_CIA_DIAG_LOG_MIN (0x2) //CIA to copy to
+ * swinging set a minimal set of diagnostic registers in Double Buffer mode
+ * DW_CIA_DIAG_LOG_ALL (0x1) //CIA to log all
+ * diagnostic registers
+ * DW_CIA_DIAG_LOG_OFF (0x0) //CIA to log reduced set
+ * of diagnostic registers
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_configciadiag(uint8_t enable_mask);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief this function reads the STS signal quality index
+ *
+ * input parameters
+ * @param rxStsQualityIndex - the (int16_t) signed STS quality index value.
+ *
+ * output parameters
+ * return value - >=0 for good and < 0 if bad STS quality.
+ *
+ * Note: For the 64 MHz PRF if value is >= 90% of the STS length then we can
+ * assume good STS reception.
+ * Otherwise the STS timestamp may not be accurate.
+ */
+int dwt_readstsquality(int16_t *rxStsQualityIndex);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief this function reads the STS status
+ *
+ * input parameters
+ * @param stsstatus - the (uint8_t) STS status value.
+ * @param sts_num - 0 for 1st STS, 1 for 2nd STS (2nd only valid when PDOA
+ * Mode 3 is used)
+ *
+ * output parameters
+ * return value 0 for good/valid STS < 0 if bad STS quality.
+ */
+int dwt_readstsstatus(uint16_t *stsStatus, int sts_num);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief this function reads the RX signal quality diagnostic data
+ *
+ * input parameters
+ * @param diagnostics - diagnostic structure pointer, this will contain the
+ * diagnostic data read from the DW3000
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_readdiagnostics(dwt_rxdiag_t *diagnostics);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to enable/disable the event counter in the IC
+ *
+ * input parameters
+ * @param - enable - 1 enables (and reset), 0 disables the event counters
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_configeventcounters(int enable);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the event counters in the IC
+ *
+ * input parameters
+ * @param counters - pointer to the dwt_deviceentcnts_t structure which will
+ * hold the read data
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_readeventcounters(dwt_deviceentcnts_t *counters);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the OTP data from given address into provided
+ * array
+ *
+ * input parameters
+ * @param address - this is the OTP address to read from
+ * @param array - this is the pointer to the array into which to read the data
+ * @param length - this is the number of 32 bit words to read (array needs to be
+ * at least this length)
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_otpread(uint16_t address, uint32_t *array, uint8_t length);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to program 32-bit value into the DW3000 OTP memory.
+ *
+ * input parameters
+ * @param value - this is the 32-bit value to be programmed into OTP
+ * @param address - this is the 16-bit OTP address into which the 32-bit value
+ * is programmed
+ *
+ * output parameters
+ *
+ * returns DWT_SUCCESS for success, or DWT_ERROR for error
+ */
+int dwt_otpwriteandverify(uint32_t value, uint16_t address);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to program 32-bit value into the DW3700 OTP memory, it
+ * will not validate the word was written correctly
+ *
+ * input parameters
+ * @param value - this is the 32-bit value to be programmed into OTP
+ * @param address - this is the 16-bit OTP address into which the 32-bit value
+ * is programmed
+ *
+ * output parameters
+ *
+ * returns DWT_SUCCESS
+ */
+int dwt_otpwrite(uint32_t value, uint16_t address);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to set up Tx/Rx GPIOs which could be used to control LEDs
+ * Note: not completely IC dependent, also needs board with LEDS fitted on right
+ * I/O lines
+ * this function enables GPIOs 2 and 3 which are connected to LED3 and
+ * LED4 on EVB1000
+ *
+ * input parameters
+ * @param mode - this is a bit field interpreted as follows:
+ * - bit 0: 1 to enable LEDs, 0 to disable them
+ * - bit 1: 1 to make LEDs blink once on init. Only valid if bit 0 is
+ * set (enable LEDs)
+ * - bit 2 to 7: reserved
+ *
+ * output parameters none
+ *
+ * no return value
+ */
+void dwt_setleds(uint8_t mode);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to adjust the crystal frequency
+ *
+ * input parameters:
+ * @param value - crystal trim value (in range 0x0 to 0x3F) 64 steps (~1.65ppm
+ * per step)
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_setxtaltrim(uint8_t value);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function returns the value of XTAL trim that has been applied
+ * during initialisation (dwt_init). This can
+ * be either the value read in OTP memory or a default value.
+ *
+ * NOTE: The value returned by this function is the initial value only! It is
+ * not updated on dwt_setxtaltrim calls.
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * returns the XTAL trim value set upon initialisation
+ */
+uint8_t dwt_getxtaltrim(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function disables repeated frames from being generated.
+ *
+ * input parameters:
+ * None
+ *
+ * output parameters:
+ * None
+ *
+ * No return value
+ */
+void dwt_stop_repeated_frames(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function enables repeated frames to be generated given a frame
+ * repetition rate.
+ *
+ * input parameters:
+ * @param framerepetitionrate - Value specifying the rate at which frames will
+ * be repeated.
+ * If the value is less than the frame duration, the
+ * frames are sent
+ * back-to-back.
+ *
+ * output parameters:
+ * None
+ *
+ * No return value
+ */
+void dwt_repeated_frames(uint32_t framerepetitionrate);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function will enable a repeated continuous waveform on the device
+ *
+ * input parameters:
+ * @param cw_enable: CW mode enable
+ * @param cw_mode_config: CW configuration mode.
+ *
+ * output parameters:
+ *
+ */
+void dwt_repeated_cw(int cw_enable, int cw_mode_config);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief this function sets the DW3xxx to transmit continuous wave (CW) signal
+ * at specific channel frequency
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_configcwmode(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function sets the DW3xxx to continuous tx frame mode for
+ * regulatory approvals testing.
+ *
+ * input parameters:
+ * @param framerepetitionrate - This is a 32-bit value that is used to set the
+ * interval between transmissions.
+ * The minimum value is 2. The units are approximately 4 ns. (or more precisely
+ * 512/(499.2e6*256) seconds)).
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_configcontinuousframemode(uint32_t framerepetitionrate);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function stops the continuous tx frame mode.
+ *
+ * input parameters:
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_disablecontinuousframemode(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief this function reads the raw battery voltage and temperature values of
+ * the DW IC.
+ * The values read here will be the current values sampled by DW IC AtoD
+ * converters.
+ *
+ *
+ * input parameters:
+ *
+ * output parameters
+ *
+ * returns (temp_raw<<8)|(vbat_raw)
+ */
+uint16_t dwt_readtempvbat(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief this function takes in a raw temperature value and applies the
+ * conversion factor
+ * to give true temperature. The dwt_initialise needs to be called before call
+ * to this to
+ * ensure pdw3000local->tempP contains the SAR_LTEMP value from OTP.
+ *
+ * input parameters:
+ * @param raw_temp - this is the 8-bit raw temperature value as read by
+ * dwt_readtempvbat
+ *
+ * output parameters:
+ *
+ * returns: temperature sensor value
+ */
+float dwt_convertrawtemperature(uint8_t raw_temp);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief this function takes in a raw voltage value and applies the conversion
+ * factor
+ * to give true voltage. The dwt_initialise needs to be called before call to
+ * this to
+ * ensure pdw3000local->vBatP contains the SAR_LVBAT value from OTP
+ *
+ * input parameters:
+ * @param raw_voltage - this is the 8-bit raw voltage value as read by
+ * dwt_readtempvbat
+ *
+ * output parameters:
+ *
+ * returns: voltage sensor value
+ */
+float dwt_convertrawvoltage(uint8_t raw_voltage);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief this function reads the temperature of the DW3000 that was sampled
+ * on waking from Sleep/Deepsleep. They are not current values, but read on last
+ * wakeup if DWT_TANDV bit is set in mode parameter of dwt_configuresleep
+ *
+ * input parameters:
+ *
+ * output parameters:
+ *
+ * returns: 8-bit raw temperature sensor value
+ */
+uint8_t dwt_readwakeuptemp(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief this function reads the battery voltage of the DW3000 that was sampled
+ * on waking from Sleep/Deepsleep. They are not current values, but read on last
+ * wakeup if DWT_TANDV bit is set in mode parameter of dwt_configuresleep
+ *
+ * input parameters:
+ *
+ * output parameters:
+ *
+ * returns: 8-bit raw battery voltage sensor value
+ */
+uint8_t dwt_readwakeupvbat(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief Returns the PG delay value of the TX
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * returns uint8_t
+ */
+uint8_t dwt_readpgdelay(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief this function determines the adjusted bandwidth setting (PG_DELAY
+ * bitfield setting)
+ * of the DW3000. The adjustemnt is a result of DW3000 internal PG cal routine,
+ * given a target count value it will try to
+ * find the PG delay which gives the closest count value.
+ * Manual sequencing of TX blocks and TX clocks need to be enabled for either
+ * channel 5 or 9.
+ * This function presumes that the PLL is already in the IDLE state. Please
+ * configure the PLL to IDLE
+ * state before calling this function, by calling dwt_configure.
+ *
+ * input parameters:
+ * @param target_count - uint16_t - the PG count target to reach in order to
+ * correct the bandwidth
+ *
+ * output parameters:
+ * returns: (uint8_t) The setting that was written to the PG_DELAY register
+ * (when calibration completed)
+ */
+uint8_t dwt_calcbandwidthadj(uint16_t target_count);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief this function calculates the value in the pulse generator counter
+ * register (PGC_STATUS) for a given PG_DELAY
+ * This is used to take a reference measurement, and the value recorded as the
+ * reference is used to adjust the
+ * bandwidth of the device when the temperature changes. This function presumes
+ * that the PLL is already in the IDLE
+ * state.
+ *
+ * input parameters:
+ * @param pgdly - uint8_t - the PG_DELAY (max value 63) to set (to control
+ * bandwidth), and to find the corresponding count value for
+ *
+ * output parameters:
+ * returns (uint16_t) - The count value calculated from the provided PG_DELAY
+ * value (from PGC_STATUS) - used as reference
+ * for later bandwidth adjustments
+ */
+uint16_t dwt_calcpgcount(uint8_t pgdly);
+
+/******************************************************************************/
+
+/* AES BLOCK
+ * */
+
+/******************************************************************************/
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function provides the API for the configuration of the AES key
+ * before first usage.
+ * @param key - pointer to the key which will be programmed to the Key
+ * register
+ * Note, key register supports only 128-bit keys.
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_set_keyreg_128(const dwt_aes_key_t *key);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function provides the API for the configuration of the AES
+ * block before its first usage.
+ *
+ * input parameters
+ * @param pCfg - pointer to the configuration structure, which contains the
+ * AES configuration data.
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_configure_aes(const dwt_aes_config_t *pCfg);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function provides the API for the job of encript/decript the
+ * data block
+ *
+ * 128 bit key shall be pre-loaded with dwt_set_aes_key()
+ * dwt_configure_aes
+ *
+ * supports AES_KEY_Src_Register mode only
+ * packet sizes < 127
+ * note, the "nonce" shall be unique for every transaction
+ * @param job - pointer to AES job, contains data info and encryption info.
+ * @param core_type - Core type
+ *
+ * @return AES_STS_ID status bits
+ *
+ *
+ */
+int8_t dwt_do_aes(dwt_aes_job_t *job, dwt_aes_core_type_e core_type);
+
+/*******************************************************************************
+*
+* Declaration of platform-dependent lower level functions.
+*
+*******************************************************************************/
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function wakeup device by an IO pin
+ *
+ * @param None
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_wakeup_ic(void);
+
+// ---------------------------------------------------------------------------
+//
+// NB: The purpose of the deca_mutex.c file is to provide for microprocessor
+// interrupt enable/disable, this is used for
+// controlling mutual exclusion from critical sections in the code where
+// interrupts and background
+// processing may interact. The code using this is kept to a minimum and
+// the disabling time is also
+// kept to a minimum, so blanket interrupt disable may be the easiest way to
+// provide this. But at a
+// minimum those interrupts coming from the Decawave device should be
+// disabled/re-enabled by this activity.
+//
+// In porting this to a particular microprocessor, the implementer may
+// choose to use #defines here
+// to map these calls transparently to the target system. Alternatively the
+// appropriate code may
+// be embedded in the functions provided in the deca_irq.c file.
+//
+// ---------------------------------------------------------------------------
+
+typedef int decaIrqStatus_t; // Type for remembering IRQ status
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function should disable interrupts. This is called at the start
+ * of a critical section
+ * It returns the IRQ state before disable, this value is used to re-enable in
+ * decamutexoff call
+ *
+ * Note: The body of this function is defined in deca_mutex.c and is platform
+ * specific
+ *
+ * input parameters:
+ *
+ * output parameters
+ *
+ * returns the state of the DW3000 interrupt
+ */
+decaIrqStatus_t decamutexon(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function should re-enable interrupts, or at least restore their
+ * state as returned(&saved) by decamutexon
+ * This is called at the end of a critical section
+ *
+ * Note: The body of this function is defined in deca_mutex.c and is platform
+ * specific
+ *
+ * input parameters:
+ * @param s - the state of the DW3000 interrupt as returned by decamutexon
+ *
+ * output parameters
+ *
+ * returns the state of the DW3000 interrupt
+ */
+void decamutexoff(decaIrqStatus_t s);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief Wait for a given amount of time.
+ * NB: The body of this function is defined in deca_sleep.c and is platform
+ * specific
+ *
+ * input parameters:
+ * @param time_ms - time to wait in milliseconds
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void deca_sleep(unsigned int time_ms);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief Wait for a given amount of time.
+ * NB: The body of this function is defined in deca_sleep.c and is platform
+ * specific
+ *
+ * input parameters:
+ * @param time_us - time to wait in microseconds
+ *
+ * output parameters
+ *
+ * no return value
+ */
+void deca_usleep(unsigned long time_us);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief this reads the device ID and checks if it is the right one
+ *
+ * input parameters
+ * None
+ *
+ * output parameters
+ *
+ * returns DWT_SUCCESS for success, or DWT_ERROR for error
+ */
+int dwt_check_dev_id(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ *
+ * @brief This function runs the PGF calibration. This is needed prior to
+ * reception.
+ * Note: If the RX calibration routine fails the device receiver performance
+ * will be severely affected, the application should reset and try again
+ *
+ * input parameters
+ * @param ldoen - if set to 1 the function will enable LDOs prior to
+ * calibration and disable afterwards.
+ *
+ * return result of PGF calibration (DWT_ERROR/-1 = error)
+ *
+ */
+int dwt_run_pgfcal(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function runs the PGF calibration. This is needed prior to
+ * reception.
+ *
+ * input parameters
+ * @param ldoen - if set to 1 the function will enable LDOs prior to
+ * calibration and disable afterwards.
+ *
+ * return result of PGF calibration (0 = error)
+ *
+ */
+int dwt_pgf_cal(int ldoen);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief
+ * This function will re-calibrate and re-lock the PLL. If the cal/lock is
+ * successful DWT_SUCCESS
+ * will be returned otherwise DWT_ERROR will be returned
+ *
+ * input parameters:None
+ *
+ * output parameters:
+ * returns DWT_SUCCESS for success or DWT_ERROR for error.
+ */
+int dwt_pll_cal(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function is used to control what rf port to use for TX/RX.
+ *
+ * @param rfPort - enum value for selecting desired port
+ * @param enable - enum value for enabling or disabling manual control of
+ * antenna selction
+ *
+ * No return value
+ */
+void dwt_configure_rf_port(dwt_rf_port_selection_e rfPort,
+ dwt_rf_port_ctrl_e enable);
+
+/*!
+ * ---------------------------------------------------------------------------
+ *
+ * @brief This function is used to write a 16 bit address to a desired
+ * Low-Energy device (LE) address. For frame pending to function when
+ * the correct bits are set in the frame filtering configuration via the
+ * dwt_configureframefilter. See dwt_configureframefilter for more details.
+ *
+ * @param addr - the address value to be written to the selected LE register
+ * @param leIndex - Low-Energy device (LE) address to write to
+ *
+ * no return value
+ *
+ */
+void dwt_configure_le_address(uint16_t addr, int leIndex);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function configures SFD type only: e.g. IEEE 4a - 8, DW-8, DW-16,
+ * or IEEE 4z -8 (binary)
+ * The dwt_configure should be called prior to this to configure other
+ * parameters
+ *
+ * input parameters
+ * @param sfdType - e.g. DWT_SFD_IEEE_4A, DWT_SFD_DW_8, DWT_SFD_DW_16,
+ * DWT_SFD_IEEE_4Z
+ *
+ * return none
+ *
+ */
+void dwt_configuresfdtype(uint8_t sfdType);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function writes a value to the system status register (lower).
+ *
+ * input parameters
+ * @param mask - mask value to send to the system status register (lower
+ * 32-bits).
+ * e.g. "SYS_STATUS_TXFRS_BIT_MASK" to clear the TX frame sent
+ * event.
+ *
+ * return none
+ */
+void dwt_writesysstatuslo(uint32_t mask);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function writes a value to the system status register (higher).
+ *
+ * input parameters
+ * @param mask - mask value to send to the system status register (higher bits).
+ * NOTE: Be aware that the size of this register varies per
+ * device.
+ * DW3000 devices only require a 16-bit mask value typecast to
+ * 32-bit.
+ * DW3700 devices only require a 16-bit mask value typecast to
+ * 32-bit.
+ * DW3720 devices require a 32-bit mask value.
+ *
+ * return none
+ */
+void dwt_writesysstatushi(uint32_t mask);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function reads the current value of the system status register
+ * (lower 32 bits)
+ *
+ * input parameters
+ *
+ * return A uint32_t value containing the value of the system status register
+ * (lower 32 bits)
+ */
+uint32_t dwt_readsysstatuslo(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function reads the current value of the system status register
+ * (higher bits)
+ *
+ * input parameters
+ *
+ * return A uint32_t value containing the value of the system status register
+ * (higher bits)
+ * NOTE: Be aware that the size of this register varies per device.
+ * DW3000 devices will return a 16-bit value of the register that is
+ * typecast to a 32-bit value.
+ * DW3700 devices will return a 16-bit value of the register that is
+ * typecast to a 32-bit value.
+ * DW3720 devices will return a 'true' 32-bit value of the register.
+ */
+uint32_t dwt_readsysstatushi(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function writes a value to the Receiver Double Buffer status
+ * register.
+ *
+ * input parameters
+ * @param mask - mask value to send to the register.
+ * e.g. "RDB_STATUS_CLEAR_BUFF0_EVENTS" to clear the clear buffer
+ * 0 events.
+ *
+ * return none
+ */
+void dwt_writerdbstatus(uint8_t mask);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function reads the current value of the Receiver Double Buffer
+ * status register.
+ *
+ * input parameters
+ *
+ * return A uint8_t value containing the value of the Receiver Double Buffer
+ * status register.
+ */
+uint8_t dwt_readrdbstatus(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function will read the frame length of the last received frame.
+ * This function presumes that a good frame or packet has been received.
+ *
+ * input parameters
+ *
+ * return frame_len - A uint16_t with the number of octets in the received
+ * frame.
+ */
+uint16_t dwt_getframelength(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the value stored in CIA_ADJUST_ID register
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * returns value stored in CIA_ADJUST_ID register
+ */
+uint32_t dwt_readpdoaoffset(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function will set the value to the CIA_ADJUST_ID register.
+ *
+ * input parameters
+ * @param offset - the offset value to be written into the CIA_ADJUST_ID
+ * register.
+ *
+ * return None.
+ */
+void dwt_setpdoaoffset(uint16_t offset);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function can set GPIO output to high (1) or low (0) which can
+ * then be used to signal e.g. WiFi chip to
+ * turn off or on. This can be used in devices with multiple radios to minimise
+ * co-existence interference.
+ *
+ * input parameters
+ * @param enable - specifies if to enable or disable WiFi co-ex
+ * functionality on GPIO5 (or GPIO4)
+ * depending if coex_io_swap param is set to 1 or 0
+ * @param coex_io_swap - when set to 0, GPIO5 is used as co-ex out, otherwise
+ * GPIO4 is used
+ *
+ * return event counts from both timers: TIMER0 events in bits [7:0], TIMER1
+ * events in bits [15:8]
+ *
+ */
+void dwt_wifi_coex_set(dwt_wifi_coex_e enable, int coex_io_swap);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function will reset the internal system time counter. The counter
+ * will be momentarily reset to 0,
+ * and then will continue counting as normal. The system time/counter is only
+ * available when device is in
+ * IDLE or TX/RX states.
+ *
+ * input parameters
+ * none
+ *
+ * return
+ * none
+ *
+ */
+void dwt_reset_system_counter(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function is used to configure the device for OSTR mode (One Shot
+ * Timebase Reset mode), this will
+ * prime the device to reset the internal system time counter on SYNC pulse /
+ * SYNC pin toggle.
+ * For more information on this operation please consult the device User Manual.
+ *
+ * input parameters
+ * @param enable - Set to 1 to enable OSTR mode and 0 to disable
+ * @param wait_time - When a counter running on the 38.4 MHz external clock
+ * and initiated on the rising edge
+ * of the SYNC signal equals the WAIT programmed value,
+ * the DW3700 timebase counter will be reset.
+ *
+ * NOTE: At the time the SYNC signal is asserted, the clock PLL dividers
+ * generating the DW3700 125 MHz system clock are reset,
+ * to ensure that a deterministic phase relationship exists between the system
+ * clock and the asynchronous 38.4 MHz external clock.
+ * For this reason, the WAIT value programmed will dictate the phase
+ * relationship and should be chosen to give the
+ * desired phase relationship, as given by WAIT modulo 4. A WAIT value of 33
+ * decimal is recommended,
+ * but if a different value is chosen it should be chosen so that WAIT modulo 4
+ * is equal to 1, i.e. 29, 37, and so on.
+ *
+ * return
+ * none
+ *
+ */
+void dwt_config_ostr_mode(uint8_t enable, uint16_t wait_time);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function drive the antenna configuration GPIO6/7
+ *
+ * input parameters
+ * @param antenna_config - configure GPIO 6 and or 7 to use for Antenna
+ * selection with expected value.
+ * bitfield configuration:
+ * Bit 0: Use GPIO 6
+ * Bit 1: Value to apply (0/1)
+ * Bit 2: Use GPIO 7
+ * Bit 3: Value to apply (0/1)
+ *
+ * return none
+ *
+ */
+void dwt_configure_and_set_antenna_selection_gpio(uint8_t antenna_config);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function will read the Diagnostics Registers - IPATOV, STS1, STS2
+ * from the device, which can help in
+ * determining if packet has been received in LOS (line-of-sight) or NLOS
+ * (non-line-of-sight) condition.
+ * To help determine/estimate NLOS condition either Ipatov, STS1 or STS2
+ * can be used, (or all three).
+ *
+ * NOTE: CIA Diagnostics need to be enabled to "DW_CIA_DIAG_LOG_ALL" else the
+ * diagnostic registers read will be 0.
+ * input parameters:
+ * @param dw - DW3xxx chip descriptor handler.
+ *
+ * @param all_diag - this is the pointer to the Structure into which to read
+ * the data.
+ *
+ * @return a uint8_t value indicating if success or failure.
+ */
+uint8_t dwt_nlos_alldiag(dwt_nlos_alldiag_t *all_diag);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function will read the IPATOV Diagnostic Registers to get the
+ * First Path and Peak Path Index value.
+ * This function is used when signal power is low to determine the signal
+ * type (LOS or NLOS). Hence only
+ * Ipatov diagnostic registers are used to determine the signal type.
+ *
+ * input parameters:
+ * @param dw - DW3xxx chip descriptor handler.
+ *
+ * @param index - this is the pointer to the Structure into which to read the
+ * data.
+ *
+ */
+void dwt_nlos_ipdiag(dwt_nlos_ipdiag_t *index);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the value stored in CTR_DBG_ID register, these
+ * are the low 32-bits of the STS IV counter.
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * returns value stored in CTR_DBG_ID register
+ */
+uint32_t dwt_readctrdbg(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to read the value stored in DGC_DBG_ID register.
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * returns value stored in DGC_DBG_ID register
+ */
+uint32_t dwt_readdgcdbg(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function read CIA version in this device.
+ *
+ * input parameters
+ * @param dw - DW3xxx chip descriptor handler.
+ *
+ * return
+ * none
+ *
+ */
+uint32_t dwt_readCIAversion(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This is used to return base address of ACC_MEM_ID register (CIR base
+ * address)
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * returns address of ACC_MEM_ID register
+ */
+uint32_t dwt_getcirregaddress(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This API enables returns a list of register name/value pairs, to
+ * enable debug output / logging in external applications
+ * e.g. DecaRanging
+ *
+ * input parameters
+ * @param regs - Pointer to registers structure register_name_add_t, will be
+ * returned
+ *
+ * return
+ * none
+ *
+ */
+register_name_add_t * dwt_get_reg_names(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function calculates the adjusted TxPower setting by applying a
+ * boost over a reference TxPower setting.
+ * The reference TxPower setting should correspond to a 1ms frame (or 0dB)
+ * boost.
+ * The boost to be applied should be provided in unit of 0.1dB boost.
+ * For example, for a 125us frame, a theoretical boost of 9dB can be applied. A
+ * boost of 90 should be provided as input
+ * parameter and will be applied over the reference TxPower setting for a 1ms
+ * frame.
+ *
+ * input parameters
+ * @param boost - the boost to apply in 0.1dB units.
+ * DW3XXX maximum boost is 354 in channel 5, 305 in channel 9. If the input
+ * value is greater than the maximum boost,
+ * then it will be discarded and maximum boost will be targeted.
+ * @param ref_tx_power - the tx_power_setting corresponding to a frame of 1ms
+ * (0dB boost)
+ * @param channel - the current RF channel used for transmission of UWB frames
+ * @param adj_tx_power - if successful, the adjusted tx power setting will be
+ * returned through this pointer
+ * @param applied_boost - if successful, the exact amount of boost applied will
+ * be returned through this pointer
+ *
+ * return
+ * int: DWT_SUCCESS: if an adjusted tx power setting could be calculated. In
+ * this case, the actual amount of boost that was
+ * applied and the adjusted tx power setting will be respectively returned
+ * through the parameters adj_tx_power and boost
+ * DWT_ERROR: if the API could not calculate a valid adjusted TxPower
+ * setting
+ *
+ *
+ */
+int dwt_adjust_tx_power(uint16_t boost,
+ uint32_t ref_tx_power,
+ uint8_t channel,
+ uint32_t *adj_tx_power,
+ uint16_t *applied_boost);
+
+/* BEGIN: CHIP_SPECIFIC_SECTION DW37xx */
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function enables the specified double RX buffer to trigger an
+ * interrupt.
+ * The following events can be found in RDB_STAT_EN_ID registers.
+ *
+ *
+ * input parameters:
+ * @param bitmask - sets the events in RDB_STAT_EN_ID register which will
+ * generate interrupt
+ * @param operation - if set to DWT_ENABLE_INT additional interrupts as
+ * selected in the bitmask are enabled
+ * - if set to DWT_ENABLE_INT_ONLY the interrupts in the
+ * bitmask are forced to selected state -
+ * i.e. the mask is written to the register directly.
+ * - otherwise (if set to DWT_DISABLE_INT) clear the
+ * interrupts as selected in the bitmask
+ * output parameters
+ *
+ * no return value
+ */
+void dwt_setinterrupt_db(uint8_t bitmask, dwt_INT_options_e INT_options);
+
+/*!
+ * ---------------------------------------------------------------------------
+ *
+ * @brief This resets the DW3700 device including the semaphore.
+ *
+ * input parameters None
+ *
+ * output parameters None
+ *
+ * return None
+ */
+void dwt_softreset_fcmd(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ *
+ * @brief This resets the DW3700 device without the semaphore.
+ *
+ * input parameters None
+ *
+ * output parameters None
+ *
+ * return None
+ */
+void dwt_softreset_no_sema_fcmd(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ *
+ * @brief Request access to the device registers, using the dual SPI semaphore
+ * request command. If the semaphore is available,
+ * the semaphore will be given, this will be shown by the returned status value.
+ *
+ * input parameters
+ * @param
+ *
+ * @return semaphore value
+ *
+ */
+void dwt_ds_sema_request(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ *
+ * @brief Release the semaphore that was taken by this host
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * return None
+ */
+void dwt_ds_sema_release(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ *
+ * @brief This can be used by host on the SPI2 to force taking of the semaphore.
+ * Take semaphore even if it is not available.
+ * This does not apply to host on SPI1, only host on SPI2 can force
+ * taking of the semaphore.
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * return None
+ */
+void dwt_ds_sema_force(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ *
+ * @brief Reports the semaphore status low byte.
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * @return semaphore value
+ */
+uint8_t dwt_ds_sema_status(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief Reports the semaphore status high byte.
+ *
+ * input parameters
+ *
+ * output parameters
+ *
+ * @return semaphore value
+ */
+uint8_t dwt_ds_sema_status_hi(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ *
+ * @brief With this API each host can prevent the device going into
+ * Sleep/Deepsleep state.
+ * By default it is possible for either host to place the device into
+ * Sleep/Deepsleep. This may not be desirable,
+ * thus a host once it is granted access can set a SLEEP_DISABLE bit in the
+ * register
+ * to prevent the other host from putting the device to sleep once it gives up
+ * its access.
+ *
+ * @param host_sleep_en - HOST_EN_SLEEP: clears the bit - allowing the the
+ * device to go to sleep.
+ * HOST_DIS_SLEEP: sets the bit to prevent the device
+ * from going to sleep
+ *
+ * return None
+ */
+void dwt_ds_en_sleep(dwt_host_sleep_en_e host_sleep_en);
+
+/*!
+ * ---------------------------------------------------------------------------
+ *
+ * @brief With this API the host on either SPI1 or SPI2 can enable/disable
+ * whether the interrupt is raised upon
+ * SPI1MAVAIL or SPI2MAVAIL event.
+ *
+ * @param dwt_spi_host_e spi_num - should be set to either DWT_HOST_SPI1 or
+ * DWT_HOST_SPI2
+ * @param dwt_INT_options_e int_set - should be set to either DWT_ENABLE_INT
+ * or DWT_DISABLE_INT
+ *
+ * return DWT_SUCCESS or DWT_ERROR (if input parameters not consistent)
+ */
+int dwt_ds_setinterrupt_SPIxavailable(dwt_spi_host_e spi_num,
+ dwt_INT_options_e int_set);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function enables or disables the equaliser block within in the
+ * CIA. The equaliser should be used when
+ * receiving from devices which transmit using a Symmetric Root Raised Cosine
+ * pulse shape. The equaliser will adjust
+ * the CIR to give improved receive timestamp results. Normally, this is left
+ * disabled (the default value), which
+ * gives the best receive timestamp performance when interworking with devices
+ * (like this IC) that use the
+ * IEEE 802.15.4z recommended minimum precursor pulse shape.
+ *
+ * @param en - DWT_EQ_ENABLED or DWT_EQ_DISABLED, enables/disables the equaliser
+ * block
+ */
+void dwt_enable_disable_eq(uint8_t en);
+
+/* END: CHIP_SPECIFIC_SECTION DW37xx */
+
+/* BEGIN: CHIP_SPECIFIC_SECTION DW3720 */
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function will reset the timers block. It will reset both timers.
+ * It can be used to stop a timer running
+ * in repeat mode.
+ *
+ * input parameters
+ * none
+ *
+ * return none
+ *
+ */
+void dwt_timers_reset(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function will read the timers' event counts. When reading from
+ * this register the values will be reset/cleared,
+ * thus the host needs to read both timers' event counts the events relating to
+ * TIMER0 are in bits [7:0] and events
+ * relating to TIMER1 in bits [15:8].
+ *
+ * input parameters
+ * none
+ *
+ * return event counts from both timers: TIMER0 events in bits [7:0], TIMER1
+ * events in bits [15:8]
+ *
+ */
+uint16_t dwt_timers_read_and_clear_events(void);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function configures selected timer (TIMER0 or TIMER1) as per
+ * configuration structure
+ *
+ * input parameters
+ * @param tim_cfg - pointer to timer configuration structure
+ *
+ * return none
+ *
+ */
+void dwt_configure_timer(dwt_timer_cfg_t *tim_cfg);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function configures the GPIOs (4 and 5) for COEX_OUT
+ *
+ * input parameters
+ * @param timer_coexout - configure if timer controls the COEX_OUT
+ * @param coex_swap - configures if the COEX_OUT is on GPIO4 or GPIO5, when
+ * set to 1 the GPIO4 will be COEX_OUT
+ *
+ * return none
+ *
+ */
+void dwt_configure_wificoex_gpio(uint8_t timer_coexout, uint8_t coex_swap);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function sets timer expiration period, it is a 22-bit number
+ *
+ * input parameters
+ * @param timer_name - specify which timer period to set: TIMER0 or TIMER1
+ * @param exp - expiry count - e.g. if units are XTAL/64 (1.66 us) then
+ * setting 1024 ~= 1.7 ms period
+ *
+ * return none
+ *
+ */
+void dwt_set_timer_expiration(dwt_timers_e timer_name, uint32_t exp);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This function enables the timer. In order to enable, the timer enable
+ * bit [0] for TIMER0 or [1] for TIMER1
+ * needs to transition from 0->1.
+ *
+ * input parameters
+ * @param enable - specifies which timer to enable
+ *
+ * return none
+ *
+ */
+void dwt_timer_enable(dwt_timers_e timer_name);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This API enables "Fixed STS" function. The fixed STS function means
+ * that the same STS will be sent in each packet.
+ * And also in the receiver, when the receiver is enabled the STS will be reset.
+ * Thus transmitter and the receiver will be in sync.
+ *
+ * input parameters
+ * @param set - Set to 1 to set FIXED STS and 0 to disable
+ *
+ * return
+ * none
+ *
+ */
+void dwt_set_fixedsts(uint8_t set);
+
+/*!
+ * ---------------------------------------------------------------------------
+ * @brief This API sets the Alternative Pulse Shape according to ARIB.
+ *
+ * input parameters
+ * @param set_alternate - Set to 1 to enable the alternate pulse shape and 0 to
+ * restore default shape.
+ *
+ * return
+ * none
+ *
+ */
+void dwt_set_alternative_pulse_shape(uint8_t set_alternate);
+
+/* END: CHIP_SPECIFIC_SECTION DW3720 */
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* _DECA_DEVICE_API_H_ */
diff --git a/driver/thirdparty/decawave/uwb2_dwm3000/inc/deca_interface.h b/driver/thirdparty/decawave/uwb2_dwm3000/inc/deca_interface.h
new file mode 100644
index 00000000..7c679e4f
--- /dev/null
+++ b/driver/thirdparty/decawave/uwb2_dwm3000/inc/deca_interface.h
@@ -0,0 +1,679 @@
+/*
+ * @file: deca_interface.h
+ * @brief Interface to the Decawave driver
+ *
+ * @author Decawave
+ *
+ * @attention Copyright 2020 - 2021 (c) Decawave Ltd, Dublin, Ireland.
+ * All rights reserved.
+ */
+
+#ifndef DECA_INTERFACE_H_
+#define DECA_INTERFACE_H_
+
+#include "deca_device_api.h"
+#include
+
+typedef enum
+{
+ DWT_READ_REG,
+ DWT_WRITE_REG,
+ DWT_WAKEUP,
+ DWT_FORCETRXOFF,
+ DWT_STARTTX,
+ DWT_SETDELAYEDTRXTIME,
+ DWT_CONFIGURESFDTYPE,
+ DWT_CONFIGURELEADDRESS,
+ DWT_SETKEYREG128,
+ DWT_ENABLEGPIOCLOCKS,
+ DWT_OTPREVISION,
+ DWT_GETICREFVOLT,
+ DWT_GETICREFTEMP,
+ DWT_GETPARTID,
+ DWT_GETLOTID,
+ DWT_SIGNALRXBUFFFREE,
+ DWT_SETRXAFTERTXDELAY,
+ DWT_ENABLESPICRCCHECK,
+ DWT_SETFINEGRAINTXSEQ,
+ DWT_SETLNAPAMODE,
+ DWT_READPGDELAY,
+ DWT_CONFIGURESTSKEY,
+ DWT_CONFIGURESTSIV,
+ DWT_CONFIGURESTSLOADIV,
+ DWT_CONFIGMRXLUT,
+ DWT_RESTORECONFIG,
+ DWT_CONFIGURESTSMODE,
+ DWT_SETRXANTENNADELAY,
+ DWT_GETRXANTENNADELAY,
+ DWT_SETTXANTENNADELAY,
+ DWT_GETTXANTENNADELAY,
+ DWT_RXENABLE,
+ DWT_WRITETXDATA,
+ DWT_READRXDATA,
+ DWT_WRITERXSCRATCHDATA,
+ DWT_READRXSCRATCHDATA,
+ DWT_READCARRIERINTEGRATOR,
+ DWT_ENABLEAUTOACK,
+ DWT_CHECKDEVID,
+ DWT_CONFIGCIADIAG,
+ DWT_ENTERSLEEPAFTERTX,
+ DWT_ENTERSLEEPAFTER,
+ DWT_RUNPGFCAL,
+ DWT_PGF_CAL,
+ DWT_READCLOCKOFFSET,
+ DWT_CLEARAONCONFIG,
+ DWT_CALCBANDWIDTHADJ,
+ DWT_READDIAGNOSTICS,
+ DWT_READTXTIMESTAMPHI32,
+ DWT_READTXTIMESTAMPLO32,
+ DWT_READTXTIMESTAMP,
+ DWT_READPDOA,
+ DWT_READTDOA,
+ DWT_READWAKEUPTEMP,
+ DWT_READWAKEUPVBAT,
+ DWT_WRITETXFCTRL,
+ DWT_OTPWRITE,
+ DWT_OTPWRITEANDVERIFY,
+ DWT_ENTERSLEEP,
+ DWT_CONFIGURESLEEPCNT,
+ DWT_CALIBRATESLEEPCNT,
+ DWT_CONFIGURESLEEP,
+ DWT_SOFTRESET,
+ DWT_SETXTALTRIM,
+ DWT_GETXTALTRIM,
+ DWT_REPEATEDCW,
+ DWT_CONFIGCWMODE,
+ DWT_READTEMPVBAT,
+ DWT_CONVERTRAWTEMP,
+ DWT_CONVERTRAWVBAT,
+ DWT_CONFIGCONTINUOUSFRAMEMODE,
+ DWT_DISABLECONTINUOUSFRAMEMODE,
+ DWT_STOPREPEATEDFRAMES,
+ DWT_REPEATEDFRAMES,
+ DWT_DOAES,
+ DWT_READSTSQUALITY,
+ DWT_CONFIGUREAES,
+ DWT_READEVENTCOUNTERS,
+ DWT_CONFIGEVENTCOUNTERS,
+ DWT_SETPREAMBLEDETECTTIMEOUT,
+ DWT_SETSNIFFMODE,
+ DWT_SETRXTIMEOUT,
+ DWT_AONREAD,
+ DWT_AONWRITE,
+ DWT_READSTSSTATUS,
+ DWT_SETLEDS,
+ DWT_SETDWSTATE,
+ DWT_READSYSTIME,
+ DWT_CHECKIDLERC,
+ DWT_CHECKIRQ,
+ DWT_CONFIGUREFRAMEFILTER,
+ DWT_SETEUI,
+ DWT_GETEUI,
+ DWT_SETPANID,
+ DWT_SETADDRESS16,
+ DWT_READRXTIMESTAMP,
+ DWT_READRXTIMESTAMP_IPATOV,
+ DWT_READRXTIMESTAMPUNADJ,
+ DWT_READRXTIMESTAMPHI32,
+ DWT_READRXTIMESTAMPLO32,
+ DWT_READRXTIMESTAMP_STS,
+ DWT_READSYSTIMESTAMPHI32,
+ DWT_OTPREAD,
+ DWT_SETPLENFINE,
+ DWT_CALCPGCOUNT,
+ DWT_SETGPIOMODE,
+ DWT_SETGPIODIR,
+ DWT_SETGPIOVALUE,
+ DWT_GETDGCDECISION,
+ DWT_SETDBLRXBUFFMODE,
+ DWT_SETREFERENCETRXTIME,
+ DWT_MICSIZEFROMBYTES,
+ DWT_PLL_CAL,
+ DWT_CONFIGURE_RF_PORT,
+ DWT_SETPDOAOFFSET,
+ DWT_READPDOAOFFSET,
+#ifdef WIN32
+ DWT_SPICSWAKEUP,
+#endif // WIN32
+ DWT_WRITESYSSTATUSLO,
+ DWT_WRITESYSSTATUSHI,
+ DWT_READSYSSTATUSLO,
+ DWT_READSYSSTATUSHI,
+ DWT_WRITERDBSTATUS,
+ DWT_READRDBSTATUS,
+ DWT_GETFRAMELENGTH,
+ DWT_READGPIOVALUE,
+ DWT_CFGWIFICOEXSET,
+ DWT_CFGANTSEL,
+ DWT_RSTSYSTEMCNT,
+ DWT_CFGOSTRMODE,
+ DWT_NLOS_IPDIAG,
+ DWT_NLOS_ALLDIAG,
+ DWT_ADJ_TXPOWER,
+
+ /* BEGIN: CHIP_SPECIFIC_SECTION DW3700 */
+ DWT_SETINTERUPTDB,
+ DWT_ENTERSLEEPFCMD,
+ DWT_SOFTRESETFCMD,
+ DWT_SOFTRESETNOSEMAFCMD,
+ DWT_DSSEMAREQUEST,
+ DWT_DSSEMARELEASE,
+ DWT_DSSEMAFORCE,
+ DWT_DSSEMASTATUS,
+ DWT_DSENSLEEP,
+ DWT_DSSETINT_SPIAVAIL,
+ DWT_ENABLEDISABLEEQ,
+
+ /* END: CHIP_SPECIFIC_SECTION DW3700 */
+ /* BEGIN: CHIP_SPECIFIC_SECTION DW3720 */
+ DWT_TIMERSRST,
+ DWT_TIMERSRSTCLR,
+ DWT_CONFIGTIMER,
+ DWT_TIMEREXPIRATION,
+ DWT_TIMERENABLE,
+ DWT_CFGWIFICOEXGPIO,
+ DWT_SETFIXEDSTS,
+ DWT_SET_ALT_PULSE_SHAPE,
+
+ /* END: CHIP_SPECIFIC_SECTION DW3720 */
+ /* BEGIN: MCPS SPECIFIC IOCTL */
+ DWT_SET_STS_LEN,
+ DWT_CFG_STS,
+
+ /* END: MCPS SPECIFIC IOCTL */
+ /* BEGIN DEBUG */
+ DWT_DBG_REGS,
+ DWT_READCTRDBG,
+ DWT_READDGCDBG,
+ DWT_CIA_VERSION,
+ DWT_GET_CIR_REGADD,
+
+ /* END DEBUG */
+} dwt_ioctl_e;
+
+struct dwt_rw_data_s
+{
+ uint8_t *buffer;
+ uint16_t length;
+ uint16_t offset;
+};
+
+struct dwt_otp_read_s
+{
+ uint16_t address;
+ uint32_t *array;
+ uint8_t length;
+};
+
+struct dwt_enable_spi_crc_check_s
+{
+ dwt_spi_crc_mode_e crc_mode;
+ dwt_spierrcb_t spireaderr_cb;
+};
+
+struct dwt_set_gpio_mode_s
+{
+ uint32_t mask;
+ uint32_t mode;
+};
+
+struct dwt_set_gpio_value_s
+{
+ uint16_t gpio; // GPIO to set, can be single or multiple:
+ int value; // 0 or 1
+};
+
+struct dwt_configure_ff_s
+{
+ uint16_t enabletype;
+ uint16_t filtermode;
+};
+
+struct dwt_aon_read_s
+{
+ uint8_t ret_val;
+ uint16_t aon_address;
+};
+
+struct dwt_aon_write_s
+{
+ uint16_t aon_address;
+ uint8_t aon_write_data;
+};
+
+struct dwt_opt_write_and_verify_s
+{
+ uint32_t value;
+ uint16_t address;
+};
+
+struct dwt_configure_sleep_s
+{
+ uint16_t mode;
+ uint8_t wake;
+};
+
+#ifdef WIN32
+struct dwt_spi_cs_wakeup_s
+{
+ uint8_t *buff;
+ uint16_t length;
+};
+
+#endif // WIN32
+
+struct dwt_enable_auto_ack_s
+{
+ uint8_t responseDelayTime;
+ int enable;
+};
+
+struct dwt_set_dbl_rx_buff_mode_s
+{
+ dwt_dbl_buff_state_e dbl_buff_state;
+ dwt_dbl_buff_mode_e dbl_buff_mode;
+};
+
+struct dwt_set_sniff_mode_s
+{
+ int enable;
+ uint8_t timeOn;
+ uint8_t timeOff;
+};
+
+struct dwt_repeated_cw_s
+{
+ int cw_enable;
+ int cw_mode_config;
+};
+
+struct dwt_convert_raw_temp_s
+{
+ float result;
+ uint8_t raw_temp;
+};
+
+struct dwt_convert_raw_volt_s
+{
+ float result;
+ uint8_t raw_voltage;
+};
+
+struct dwt_calc_bandwidth_adj_s
+{
+ uint8_t result;
+ uint16_t target_count;
+};
+
+struct dwt_calc_pg_count_s
+{
+ uint16_t result;
+ uint8_t pgdly;
+};
+
+struct dwt_mic_size_from_bytes_s
+{
+ dwt_mic_size_e result;
+ uint8_t mic_size_in_bytes;
+};
+
+struct dwt_do_aes_s
+{
+ int8_t result;
+ dwt_aes_job_t *job;
+ dwt_aes_core_type_e core_type;
+};
+
+struct dwt_configure_le_address_s
+{
+ uint16_t addr;
+ int leIndex;
+};
+
+struct dwt_set_interrupt_db_s
+{
+ uint8_t bitmask;
+ dwt_INT_options_e INT_options;
+};
+
+struct dwt_tx_fctrl_s
+{
+ uint16_t txFrameLength;
+ uint16_t txBufferOffset;
+ uint8_t ranging;
+};
+
+struct dwt_config_rf_port_s
+{
+ dwt_rf_port_selection_e port;
+ dwt_rf_port_ctrl_e enable;
+};
+
+struct dwt_ostr_mode_s
+{
+ uint8_t enable;
+ uint16_t wait_time;
+};
+
+struct dwt_cfg_wifi_coex_set_s
+{
+ dwt_wifi_coex_e enable;
+ int coex_io_swap;
+};
+
+struct dwt_cfg_wifi_coex_s
+{
+ uint8_t timer_coexout;
+ uint8_t coex_swap;
+};
+
+struct dwt_timer_exp_s
+{
+ dwt_timers_e timer_name;
+ uint32_t exp;
+};
+
+struct dwt_adj_tx_power_s
+{
+ int result;
+ uint16_t boost;
+ uint32_t ref_tx_power;
+ uint8_t channel;
+ uint32_t *adj_tx_power;
+ uint16_t *applied_boost;
+};
+
+struct dwchip_s;
+struct dw_rx_s;
+
+struct dwt_callbacks_s
+{
+ dwt_spierrcb_t cbSPIRDErr; // Callback for SPI read error events
+ dwt_cb_t cbTxDone; // Callback for TX confirmation event
+ dwt_cb_t cbRxOk; // Callback for RX good frame event
+ dwt_cb_t cbRxTo; // Callback for RX timeout events
+ dwt_cb_t cbRxErr; // Callback for RX error events
+ dwt_cb_t cbSPIErr; // Callback for SPI error events
+ dwt_cb_t cbSPIRdy; // Callback for SPI ready events
+ dwt_cb_t cbDualSPIEv; // Callback for dual SPI events
+
+ int (*rx_frame)(struct dwchip_s *, struct dw_rx_s *);
+ int (*rx_error)(struct dwchip_s *, int);
+};
+
+/*!
+ *
+ *
+ * -----------------------------------------------------------------------------
+ * functions that must be defined externally
+ * NB: In porting this to a particular microprocessor, the implementer needs to
+ * define the low
+ * level abstract functions matching the selected hardware.
+ */
+struct dwt_spi_s
+{
+/*!
+ *
+ *
+ * -----------------------------------------------------------------------------
+ * @brief readfromspi
+ * Low level abstract function to read from the SPI
+ * Takes two separate byte buffers for write header and read data
+ * input parameters:
+ * @param headerLength - number of bytes header to write
+ * @param headerBuffer - pointer to buffer containing the 'headerLength' bytes
+ * of header to write
+ * @param readlength - number of bytes data being read
+ * @param readBuffer - pointer to buffer containing to return the data (NB:
+ * size required = headerLength + readlength)
+ *
+ * output parameters:
+ * returns DWT_SUCCESS for success, or DWT_ERROR for error
+ */
+ int (*readfromspi)(uint16_t headerLength, /*const*/ uint8_t *headerBuffer,
+ uint16_t readlength, uint8_t *readBuffer);
+
+/*!
+ *
+ *
+ * -----------------------------------------------------------------------------
+ * @brief writetospi
+ * Low level abstract function to write to the SPI
+ * Takes two separate byte buffers for write header and write data
+ * input parameters:
+ * @param headerLength - number of bytes header being written
+ * @param headerBuffer - pointer to buffer containing the 'headerLength' bytes
+ * of header to be written
+ * @param bodylength - number of bytes data being written
+ * @param bodyBuffer - pointer to buffer containing the 'bodylength' bytes od
+ * data to be written
+ *
+ * output parameters:
+ * returns DWT_SUCCESS for success, or DWT_ERROR for error
+ */
+ int (*writetospi)(uint16_t headerLength, const uint8_t *headerBuffer,
+ uint16_t bodyLength, const uint8_t *bodyBuffer);
+
+/*!
+ *
+ *
+ * -----------------------------------------------------------------------------
+ * @brief writetospiwithcrc
+ * Low level abstract function to write to the SPI, this should be used when
+ * DW3000 SPI CRC mode is used
+ * Takes two separate byte buffers for write header and write data
+ * input parameters:
+ * @param headerLength - number of bytes header being written
+ * @param headerBuffer - pointer to buffer containing the 'headerLength' bytes
+ * of header to be written
+ * @param bodylength - number of bytes data being written
+ * @param bodyBuffer - pointer to buffer containing the 'bodylength' bytes od
+ * data to be written
+ * @param crc8 - 8-bit crc, calculated on the header and data bytes
+ *
+ * output parameters:
+ * returns DWT_SUCCESS for success, or DWT_ERROR for error
+ */
+ int (*writetospiwithcrc)(uint16_t headerLength, const uint8_t *headerBuffer,
+ uint16_t bodyLength, const uint8_t *bodyBuffer,
+ uint8_t crc8);
+
+ /*!
+ *
+ *
+ * ---------------------------------------------------------------------------
+ * @brief setslowrate
+ * Low level abstract function to switch the SPI into slow rate mode
+ *
+ * input parameters:
+ *
+ * output parameters
+ *
+ */
+ void (*setslowrate)(void);
+
+ /*!
+ *
+ *
+ * ---------------------------------------------------------------------------
+ * @brief setspifastrate
+ * Low level abstract function to switch the SPI into fast rate mode
+ *
+ * input parameters:
+ *
+ * output parameters
+ *
+ */
+ void (*setfastrate)(void);
+};
+
+struct rxtx_configure_s
+{
+ dwt_config_t *pdwCfg;
+ dwt_txconfig_t *txConfig;
+ uint16_t frameFilter;
+ uint16_t frameFilterMode;
+ uint16_t txAntDelay;
+ uint16_t rxAntDelay;
+ uint16_t panId;
+ uint16_t shortadd;
+};
+
+typedef struct rxtx_configure_s rxtx_configure_t;
+
+struct dwt_mcps_config_s
+{
+ int mode;
+ int do_reset;
+ int led_mode;
+ int lnapamode;
+ int bitmask_lo;
+ int bitmask_hi;
+ int int_options;
+ struct dwt_configure_sleep_s sleep_config;
+ dwt_sts_cp_key_t *stsKey; /**< AES Key to be used to set the STS */
+ dwt_sts_cp_iv_t *stsIv; /**< AES IV to be used to set the initial IV */
+ rxtx_configure_t *rxtx_config;
+ uint8_t xtalTrim;
+ uint8_t cia_enable_mask;
+ uint8_t loadIv;
+ uint8_t event_counter;
+};
+
+typedef struct dwt_mcps_config_s dwt_mcps_config_t;
+
+/*The contract is that we have the SPI interface to the DW chip*/
+struct dwchip_s
+{
+ /*HAL*/
+ struct dwt_spi_s *SPI; // first
+ void(*wakeup_device_with_io)(void);
+
+ /*Driver*/
+ struct dwt_driver_s *dwt_driver;
+ struct dwt_callbacks_s callbacks;
+
+ /* driver configuration */
+ struct dwt_mcps_config_s *config;
+
+ /* MCPS */
+ struct mcps802154_llhw *llhw;
+ struct mcps802154_ops *mcps_ops;
+ struct dw3000_calibration_data *calib_data;
+ struct dwt_mcps_runtime_s *mcps_runtime;
+ struct dwt_mcps_rx_s *rx;
+
+ /* GPIO used to switch off WIFI while transmitting, for example */
+ int8_t coex_gpio_pin;
+ int8_t coex_gpio_active_state;
+
+ /** driver data*/
+ void *priv; // last
+};
+
+typedef struct dwchip_s dwchip_t;
+
+struct dw_rx_frame_info_s
+{
+ uint32_t rx_date_dtu;
+ uint32_t rx_timeout_pac;
+ int rx_delayed;
+};
+
+struct dw_tx_frame_info_s
+{
+ uint32_t tx_date_dtu; /* 4ns time units: */
+ int rx_delay_dly; /* sy: 1.0256us */
+ uint32_t rx_timeout_pac; /* SFD Timeout ? */
+ int flag; /* flag */
+
+#ifndef MCPS_RANGING_BIT
+#define MCPS_RANGING_BIT 0x40
+#endif
+};
+
+struct dw_addr_filt_s;
+
+struct dwt_ops_s
+{
+ int (*configure)(struct dwchip_s *dw, dwt_config_t *config);
+ int (*write_tx_data)(struct dwchip_s *dw, uint16_t txDataLength,
+ uint8_t *txDataBytes, uint16_t txBufferOffset);
+ void (*write_tx_fctrl)(struct dwchip_s *dw, uint16_t txFrameLength,
+ uint16_t txBufferOffset, uint8_t ranging);
+ void (*read_rx_data)(struct dwchip_s *dw, uint8_t *buffer, uint16_t length,
+ uint16_t rxBufferOffset);
+ void (*read_acc_data)(struct dwchip_s *dw, uint8_t *buffer, uint16_t length,
+ uint16_t accOffset);
+ void (*read_rx_timestamp)(struct dwchip_s *dw, uint8_t *timestamp);
+ void (*configure_tx_rf)(struct dwchip_s *dw, dwt_txconfig_t *config);
+ void (*set_interrupt)(struct dwchip_s *dw, uint32_t bitmask_lo,
+ uint32_t bitmask_hi, dwt_INT_options_e INT_options);
+ int (*rx_enable)(struct dwchip_s *dw, int mode);
+ int (*initialize)(struct dwchip_s *dw, int mode);
+ void (*xfer)(struct dwchip_s *dw, uint32_t regFileID, uint16_t index,
+ uint16_t length, uint8_t *buffer, const spi_modes_e mode);
+
+ int (*ioctl)(struct dwchip_s *, dwt_ioctl_e, int parm, void *ptr);
+
+ void (*isr)(struct dwchip_s *);
+
+ void * (*dbg_fn)(struct dwchip_s *, dwt_ioctl_e, int parm, void *ptr);
+};
+
+struct dwt_mcps_ops_s
+{
+ int (*init)(struct dwchip_s *);
+ void (*deinit)(struct dwchip_s *);
+ int (*tx_frame)(struct dwchip_s *, uint8_t *data, size_t len,
+ struct dw_tx_frame_info_s *info);
+ int (*rx_enable)(struct dwchip_s *, struct dw_rx_frame_info_s *info);
+ int (*rx_disable)(struct dwchip_s *);
+ uint64_t (*get_timestamp)(struct dwchip_s *);
+ void (*get_rx_frame)(struct dwchip_s *, uint8_t *ptr, size_t len);
+ int (*set_hrp_uwb_params)(struct dwchip_s *, int prf, int fsr,
+ int sfd_selector, int phr_rate, int data_rate);
+ int (*set_channel)(struct dwchip_s *, int page, int channel,
+ int preamble_code);
+ int (*set_hw_addr_filt)(struct dwchip_s *, struct dw_addr_filt_s *file,
+ int changed);
+
+ // Compat direct-access fns - Used in dw3000_mcps_mcu.c . This is required for
+ // compatibility purpose with some MCPS functions
+ struct mcps_compat_
+ {
+ int (*sys_status_and_or)(struct dwchip_s *dw, uint32_t _and, uint32_t _or);
+ void (*ack_enable)(struct dwchip_s *dw, int enable);
+ void (*set_interrupt)(struct dwchip_s *dw, uint32_t bitmask_lo,
+ uint32_t bitmask_hi, dwt_INT_options_e INT_options);
+ } mcps_compat;
+
+ int (*ioctl)(struct dwchip_s *, dwt_ioctl_e, int parm, void *ptr);
+
+ void (*isr)(struct dwchip_s *);
+};
+
+struct dwt_driver_s
+{
+ uint32_t devid;
+ uint32_t devmatch;
+ const char *name;
+ const char *version;
+ const struct dwt_ops_s *dwt_ops;
+ const struct dwt_mcps_ops_s *dwt_mcps_ops;
+ uint32_t vernum;
+};
+
+/* STD interface fn() */
+int interface_init(struct dwchip_s *p);
+void interface_deinit(struct dwchip_s *p);
+int interface_tx_frame(struct dwchip_s *dw,
+ uint8_t *data,
+ size_t len,
+ struct dw_tx_frame_info_s *info);
+int interface_rx_enable(struct dwchip_s *dw, struct dw_rx_frame_info_s *info);
+int interface_rx_disable(struct dwchip_s *dw);
+uint64_t interface_get_timestamp(struct dwchip_s *dw);
+void interface_read_rx_frame(struct dwchip_s *dw, uint8_t *ptr, size_t len);
+
+#endif /* DECA_INTERFACE_H_ */
diff --git a/driver/thirdparty/decawave/uwb2_dwm3000/inc/deca_types.h b/driver/thirdparty/decawave/uwb2_dwm3000/inc/deca_types.h
new file mode 100644
index 00000000..549bf760
--- /dev/null
+++ b/driver/thirdparty/decawave/uwb2_dwm3000/inc/deca_types.h
@@ -0,0 +1,90 @@
+/*! ----------------------------------------------------------------------------
+ * @file deca_types.h
+ * @brief Decawave general type definitions
+ *
+ * @attention
+ *
+ * Copyright 2013 - 2021 (c) Decawave Ltd, Dublin, Ireland.
+ *
+ * All rights reserved.
+ *
+ */
+
+#ifndef _DECA_TYPES_D0_H_
+#define _DECA_TYPES_D0_H_
+
+#ifdef __cplusplus
+extern "C"
+{
+#endif
+
+#include
+#include
+
+#ifdef STM32F429xx
+#ifndef uint8_t
+#ifndef _DECA_UINT8_
+#define _DECA_UINT8_
+typedef unsigned char uint8_t;
+#endif
+#endif
+
+#ifndef uint16_t
+#ifndef _DECA_UINT16_
+#define _DECA_UINT16_
+typedef unsigned short uint16_t;
+#endif
+#endif
+
+#ifndef uint32_t
+#ifndef _DECA_UINT32_
+#define _DECA_UINT32_
+typedef unsigned long uint32_t;
+#endif
+#endif
+
+#ifndef int8_t
+#ifndef _DECA_INT8_
+#define _DECA_INT8_
+typedef signed char int8_t;
+#endif
+#endif
+
+#ifndef int16_t
+#ifndef _DECA_INT16_
+#define _DECA_INT16_
+typedef signed short int16_t;
+#endif
+#endif
+
+#ifndef int32_t
+#ifndef _DECA_INT32_
+#define _DECA_INT32_
+typedef signed long int32_t;
+#endif
+#endif
+
+#ifndef uint64_t
+#ifndef _DECA_UINT64_
+#define _DECA_UINT64_
+typedef unsigned long long uint64_t;
+#endif
+#endif
+
+#ifndef int64_t
+#ifndef _DECA_INT64_
+#define _DECA_INT64_
+typedef signed long long int64_t;
+#endif
+#endif
+#endif // STM32F429xx
+
+#ifndef NULL
+#define NULL ((void *)0UL)
+#endif
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* DECA_TYPES_H_ */
diff --git a/driver/thirdparty/decawave/uwb2_dwm3000/inc/deca_version.h b/driver/thirdparty/decawave/uwb2_dwm3000/inc/deca_version.h
new file mode 100644
index 00000000..39cf0c77
--- /dev/null
+++ b/driver/thirdparty/decawave/uwb2_dwm3000/inc/deca_version.h
@@ -0,0 +1,40 @@
+/*! ----------------------------------------------------------------------------
+ * @file deca_version.h
+ * @brief Defines the version info for the DW3XXX device driver including its
+ * API
+ *
+ * @attention
+ *
+ * Copyright 2017 - 2021 (c) Decawave Ltd, Dublin, Ireland.
+ *
+ * All rights reserved.
+ *
+ */
+
+#ifndef _DECA_VERSION_DW3XXX_H_
+#define _DECA_VERSION_DW3XXX_H_ 1
+
+//
+// The DW3XXX device driver is separately version numbered to any version the
+// application using it may have
+//
+// Two symbols are defined here: one hexadecimal value and one string that
+// includes the hex bytes.
+// Both should be updated together in a consistent way when the software is
+// being modified.
+//
+// The format of the hex version is 0xAABBCC and the string ends with AA.BB.CC,
+// where...
+//
+// Quantity CC is updated for minor changes/bug fixes that should not need user
+// code changes
+// Quantity BB is updated for changes/bug fixes that may need user code changes
+// Quantity AA is updated for major changes that will need user code changes
+//
+
+#define DRIVER_NAME "DW3XXX"
+
+#define DRIVER_VERSION_HEX 0x060007
+#define DRIVER_VERSION_STR "DW3XXX Device Driver Version 06.00.07"
+
+#endif
diff --git a/driver/thirdparty/decawave/uwb2_dwm3000/inc/error.h b/driver/thirdparty/decawave/uwb2_dwm3000/inc/error.h
new file mode 100644
index 00000000..3e5a32f1
--- /dev/null
+++ b/driver/thirdparty/decawave/uwb2_dwm3000/inc/error.h
@@ -0,0 +1,106 @@
+/**
+ * @file error.h
+ *
+ * @brief Header file for errors
+ *
+ * @author Decawave
+ *
+ * @attention Copyright 2017-2019 (c) Decawave Ltd, Dublin, Ireland.
+ * All rights reserved.
+ *
+ */
+
+#ifndef INC_ERROR_H_
+#define INC_ERROR_H_
+
+// #include
+
+typedef enum {
+ _NO_ERR = 0,
+ _ERR,
+ _ERR_Busy,
+ _ERR_Timeout,
+ _ERR_DEVID,
+ _ERR_IWDG,
+ _ERR_INSTANCE,
+ _ERR_INIT,
+ _ERR_IMU_INIT,
+ _ERR_TxBuf_Overflow,
+ _ERR_RxBuf_Overflow,
+ _ERR_Usb_Tx,
+ _ERR_Flash_Ob,
+ _ERR_Flash_Prog,
+ _ERR_Flash_Erase,
+ _ERR_Flash_Error,
+ _ERR_Flash_Verify,
+ _ERR_Flash_Protected,
+ _ERR_LSM_R,
+ _ERR_LSM_W,
+ _ERR_SPI,
+ _ERR_SPI_RRX,
+ _ERR_SPI_WTX,
+ _ERR_SPI_DMA,
+ _ERR_UART_DMA,
+ _ERR_UART_INIT,
+ _ERR_UART_RX,
+ _ERR_UART_TX,
+ _ERR_UART_RxCplt,
+ _ERR_UART_RxCplt_Overflow,
+ _ERR_USB_UART_RX,
+ _ERR_TCFM,
+ _ERR_TWR_CANNOT_START,
+ _ERR_MEM_CORRUPTED,
+ _ERR_Configure_WKUP_Timer,
+ _ERR_PLL,
+
+/*TWR*/
+ _ERR_Twr_Bad_State,
+ _ERR_Not_Twr_Frame,
+ _ERR_Unknown_Tag,
+ _ERR_DelayedTX_Late,
+ _ERR_Range_Calculation,
+ _ERR_Ranging_Config,
+ _ERR_RC_Version_Unknown,
+ _ERR_Non_Compatible_TWR_Parameters,
+ _NO_Err_New_Tag,
+ _NO_Err_Tx_Sent,
+ _NO_Err_Start_Rx,
+ _NO_Err_Final,
+ _NO_Err_Ranging_Config,
+ _NO_Err_Ranging_Update,
+ _NO_Err_Response,
+ _NO_Err_Idata,
+ _NO_Err_Rdata,
+ _NO_Err_Can_Sleep,
+
+/*USB2SPI*/
+ _ERR_Usb2Spi_ptr_busy,
+ _ERR_Usb2Spi_ptr_alloc,
+
+/*RTOS*/
+ _ERR_General_Error,
+ _ERR_Create_Task_Bad,
+ _ERR_Timer_Create_Bad,
+ _ERR_Timer_Start_Bad,
+ _ERR_Signal_Bad,
+ _ERR_Cannot_Delete_Timer,
+ _ERR_Cannot_Delete_Task,
+ _ERR_Cannot_Delete_usb2spiTask,
+ _ERR_Cannot_Delete_tcfmTask,
+ _ERR_Cannot_Delete_tcwmTask,
+ _ERR_Cannot_Delete_imuTask,
+ _ERR_Cannot_Delete_rtlsTask,
+ _ERR_Cannot_Delete_rxTask,
+ _ERR_Cannot_Delete_calcTask,
+ _ERR_Cannot_Delete_twrTask,
+ _ERR_Cannot_Delete_commTask,
+ _ERR_Cannot_Send_Mail,
+ _ERR_Cannot_Alloc_Mail,
+ _ERR_Cannot_Alloc_Memory,
+ _ERR_Cannot_Alloc_NodeMemory,
+ _ERR_Malloc_Failed, // 71
+ _ERR_Stack_Overflow,
+ _ERR_No_pTwrInfo
+}error_e;
+
+#endif /* INC_ERROR_H_ */
diff --git a/driver/thirdparty/decawave/uwb2_dwm3000/inc/rtls_interface.h b/driver/thirdparty/decawave/uwb2_dwm3000/inc/rtls_interface.h
new file mode 100644
index 00000000..c1956408
--- /dev/null
+++ b/driver/thirdparty/decawave/uwb2_dwm3000/inc/rtls_interface.h
@@ -0,0 +1,415 @@
+/**
+ * @file rtls_interface.h
+ *
+ * @brief Decawave RTLS CLE / RTLS anchor common definitions / APIs
+ *
+ * @author Decawave
+ *
+ * @attention Copyright 2017-2019 (c) Decawave Ltd, Dublin, Ireland.
+ * All rights reserved.
+ *
+ */
+
+#ifndef RTLS_INTERFACE_H_
+#define RTLS_INTERFACE_H_ 1
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#include "uwb_frames.h"
+
+// Protocol structs and enums :
+enum RTLS_CMD {
+ RTLS_CMD_PARM_STOP = 0, RTLS_CMD_PARM_START = 1,
+
+ RTLS_CMD_REQ_CFG = 0x42, // Anchor: request configuration
+ RTLS_CMD_SET_CFG_CCP = 0x44, // CLE: response on RTLS_CMD_REQ_CFG request
+
+ // Anchor -> LE
+ RTLS_CMD_DEBUG = 0x37, // Anchor: Debug Message
+
+ RTLS_CMD_REPORT_TOA = 0x3A, // v.3 TDOA
+ RTLS_CMD_REPORT_TOA_EX = 0x3B, // v.3 TDOA with extra data (e.g. IMU data)
+ RTLS_CMD_REPORT_TX_CS = 0x3E, // v.3 CCP Tx report
+ RTLS_CMD_REPORT_RX_CS = 0x3F, // v.3 CCP Rx report
+
+ RTLS_CMD_REPORT_TX_CS_V4 = 0x30, // v.4 CCP Tx report
+ RTLS_CMD_REPORT_RX_CS_V4 = 0x31, // v.4 CCP Rx report
+ RTLS_CMD_REPORT_TOA_V4 = 0x32, // v.4 TDOA with FP
+ RTLS_CMD_REPORT_TOA_IMU_V4 = 0x33, // v.4 TDOA with FP and IMU data
+
+ // LE -> Anchor
+ RTLS_COMM_TEST_START_REQ = 0x53,
+ RTLS_COMM_TEST_RESULT_REQ = 0x54,
+ RTLS_RANGE_MEAS_REQ = 0x55,
+ RTLS_INIT_REQ = 0x56,
+ RTLS_START_REQ = 0x57,
+ RTLS_POWER_TEST_START_REQ = 0x58,
+ RTLS_RESET_REQ = 0x59,
+ RTLS_SINGLE_TWR_MODE_REQ = 0x5A,
+ RTLS_ASYMM_TWR_MODE_REQ = 0x5B,
+
+ RTLS_CFG_IND = 0x80,
+ RTLS_COMM_TEST_DONE_IND = 0x81,
+ RTLS_COMM_TEST_RESULT_IND = 0x82,
+ RTLS_RANGE_MEAS_IND = 0x83,
+ RTLS_RANGE_MEAS_IND_FINAL = 0x84,
+ RTLS_POWER_TEST_DONE_IND = 0x85,
+
+ RTLS_TEMP_VBAT_IND = 0x87, // Temperature and VBAT
+ RTLS_LOG_ACCUMULATOR_REQ = 0x88, // Request Accumulator for CCP or Blink
+ RTLS_LOG_ACCUMULATOR_IND = 0x91 // Accumulator Report for CCP or Blink
+};
+
+#define RTLS_CMD_SET_CFG_CCP_LEN sizeof(cmd_config_t)
+#define RTLS_POWER_TEST_START_LEN sizeof(cmd_power_test_t)
+#define RTLS_COMM_TEST_START_LEN sizeof(cmd_comm_test_t)
+#define RTLS_COMM_TEST_RESULT_REQ_LEN (1)
+#define RTLS_RANGE_MEAS_REQ_LEN (21)
+#define RTLS_SINGLE_TWR_MODE_REQ_LEN (17)
+#define RTLS_ASYMM_TWR_MODE_REQ_LEN (27)
+#define RTLS_START_REQ_LEN (2)
+#define RTLS_LOG_ACC_REQ_LEN (4)
+#define RTLS_RESET_REQ_LEN (18)
+
+#define RTLS_CMD_REPORT_TOA_LEN (16)
+
+/* minimum length of longer TDoA report, extra byte, specifying extra data
+ * length */
+#define RTLS_CMD_REPORT_TOA_EX_LEN (17)
+#define RTLS_CMD_REPORT_TX_CS_LEN (8)
+#define RTLS_CMD_REPORT_RX_CS_LEN (16)
+
+#define RTLS_CMD_REPORT_TOA_V4_LEN (18)
+#define RTLS_CMD_REPORT_TX_CS_V4_LEN (8)
+#define RTLS_CMD_REPORT_RX_CS_V4_LEN (18)
+
+#define RTLS_CMD_DEBUG_LEN (3)
+
+#define RTLS_POWER_TEST_DONE_IND_LEN (1)
+#define RTLS_COMM_TEST_DONE_IND_LEN (1)
+#define RTLS_COMM_TEST_RESULT_IND_LEN (5)
+#define RTLS_RANGE_MEAS_IND_LEN (14)
+#define RTLS_TEMP_VBAT_IND_LEN (12)
+
+/* 1 byte (MSG ID) + 1 byte frame type (CCP or Blink) + 1 byte seq Num +
+ * 4 bytes log Num + 8 bytes of source address (CCP Master or Blink Tag)
+ */
+#define RTLS_ACC_LOG_HEADER_LEN (15)
+
+/* fpIndex, maxNoise, firstPathAmp1, stdNoise, firstPathAmp2, firstPathAmp3,
+ * maxGrowthCIR, rxPreamCount
+ */
+#define RTLS_ACC_LOG_REG_LEN (16)
+
+/* 16M PRF is 992*4+1 */
+#define RTLS_DW_ACCUMULATOR_LEN_16 (992 * 4 + 1)
+
+/* 64M PRF is 1016*4+1 */
+#define RTLS_DW_ACCUMULATOR_LEN_64 (1016 * 4 + 1)
+
+#define RTLS_LOG_ACCUMULATOR_IND_LEN_16 (RTLS_ACC_LOG_HEADER_LEN \
+ + RTLS_ACC_LOG_REG_LEN \
+ + \
+ RTLS_DW_ACCUMULATOR_LEN_16)
+#define RTLS_LOG_ACCUMULATOR_IND_LEN_64 (RTLS_ACC_LOG_HEADER_LEN \
+ + RTLS_ACC_LOG_REG_LEN \
+ + \
+ RTLS_DW_ACCUMULATOR_LEN_64)
+#define RTLS_LOG_ACCUMULATOR_IND_LEN (( \
+ RTLS_LOG_ACCUMULATOR_IND_LEN_16 \
+ < \
+ RTLS_LOG_ACCUMULATOR_IND_LEN_64) \
+ ? \
+ RTLS_LOG_ACCUMULATOR_IND_LEN_16 \
+ : \
+ RTLS_LOG_ACCUMULATOR_IND_LEN_64)
+
+/* accumulator reading is only used to read blinks and CCPs */
+#define ACCUM_TYPE_BLINK 0xA1
+
+/* accumulator reading is only used to read blinks and CCPs */
+#define ACCUM_TYPE_CCP 0xA2
+
+#define DWT_DIAGNOSTIC_LOG_REV_5 (5)
+#define DWT_DIAGNOSTIC_LOG_V_5 (5)
+#define DWT_SIZEOFDIAGNOSTICDATA_5 (66)
+#define DWT_SIZE_OF_IMUDATA (30)
+
+#define DWT_LOG_NUM_SIZE (4)
+
+/* The data is framed as follows :
+ *.....>
+ * STX = 0x2
+ * LEN is the length of data message(16 bits)
+ * CRC is the 16 - bit CRC of the data bytes
+ * ETX = 0x3
+ * FC = is the function code(API code)
+ *
+ */
+#define FRAME_HEADER_LEN (6)
+#define FRAME_START_IDX (0)
+#define FRAME_LENGTH_IDX (1)
+#define FRAME_DATA_IDX (3)
+
+enum RTLS_DATA {
+ RTLS_DATA_ANCHOR_REQ = 0x41,
+
+ RTLS_DATA_ANCHOR = 0x61,
+ RTLS_DATA_BLINK = 0x62,
+ RTLS_DATA_STATS = 0x63,
+ RTLS_DATA_IMU = 0x64,
+ RTLS_DATA_BLINK_EXT = 0x65
+};
+
+/* Network commands
+ * use byte access if in doubt
+ */
+
+#define UN16(x) union { uint16_t x ## 16; uint8_t x[2];}
+
+#define UN32(x) union { uint32_t x ## 32; uint8_t x[4];}
+
+/* Wire format of messages from Anchor to CLE */
+#pragma pack (push, 1)
+
+/* Standard Diagnostics v5 */
+struct diag_v5_s {
+ // NOTE: diagnostics data format rev 5 (DWT_DIAGNOSTIC_LOG_REV_5)
+ uint8_t header; // 00 this could be a header (format version number)
+ uint8_t r0F[5]; // 01 register 0xF - length 5 bytes
+ uint8_t r10[4]; // 06 register 0x10 - length 4 bytes
+ uint8_t r12[8]; // 10 register 0x12 - length 8 bytes
+ uint8_t r13[4]; // 18 register 0x13 - length 4 bytes
+ uint8_t r14[5]; // 22 register 0x14 - length 5 bytes
+ uint8_t r15[14]; // 27 register 0x15 - length 14 bytes (5 TS, 2 FP, 2
+ // Diag, 5 TSraw)
+ uint8_t r25[16]; // 41 register 0x25 @FP (first path) -> 16 bytes
+ // starting at FP + 1 dummy
+ uint8_t r2E[2]; // 58 register 0x2E (0x1000) - 2 bytes
+ uint8_t r27[4]; // 60 register 0x27 (0x28) - 4 bytes
+ uint8_t r2E2[2]; // 64 register 0x2E (0x1002) - 2 bytes
+ uint8_t dummy;
+ // 66 total
+};
+
+typedef struct diag_v5_s diag_v5_t;
+
+struct ccp_rx_v4_s {
+ uint8_t type; // 0 : type = CCP RX timestamp
+ uint8_t seqNum; // 1 : CCP Seq Num
+ uint8_t masterID[ADDR_BYTE_SIZE_L]; // 2-9 : master anchor ID (that sent
+ // the CCP frame)
+ uint8_t csRxTime[TS_40B_SIZE]; // 10-14 : CCP Rx time
+ UN16(firstPath); // 15-16 : raw Firstpath
+ uint8_t extLen; // 17 : length of ext below
+};
+
+typedef struct ccp_rx_v4_s ccp_rx_v4_t;
+
+struct toa_v4_s {
+ uint8_t type; // 0 : type = TOA report
+ uint8_t seqNum; // 1 : Blink message sequence number
+ uint8_t tagID[ADDR_BYTE_SIZE_L]; // 2-9 : tag ID
+ uint8_t rawTOA[TS_40B_SIZE]; // 10-14 : raw timestamp
+ UN16(firstPath); // 15-16 : raw Firstpath
+ uint8_t extLen; // 17 : length of ext below
+};
+
+typedef struct toa_v4_s toa_v4_t;
+
+/* RTLS_CMD_REPORT_TOA_IMU_V4 */
+struct report_toa_imu_v4_s {
+ toa_v4_t toa;
+ union {
+ uint8_t ext[DWT_SIZE_OF_IMUDATA + sizeof(uint32_t) + sizeof(diag_v5_t)];
+ struct {
+ uint8_t dataIMU[DWT_SIZE_OF_IMUDATA]; // : IMU data sent from the
+ // tag(2 (ench + exth) + 1
+ // (dwh)+27 (dwp))
+ UN32(logNum);
+ diag_v5_t diag;
+ };
+ };
+};
+
+typedef struct report_toa_imu_v4_s report_toa_imu_v4_t;
+
+/* RTLS_CMD_REPORT_TOA_V4 */
+struct report_toa_v4_s {
+ toa_v4_t toa;
+ union {
+ uint8_t ext[sizeof(uint32_t) + sizeof(diag_v5_t)];
+ struct {
+ UN32(logNum);
+ diag_v5_t diag;
+ };
+ };
+};
+
+typedef struct report_toa_v4_s report_toa_v4_t;
+
+/* RTLS_CMD_REPORT_RX_CS_V4 */
+struct report_ccp_rx_v4_s {
+ ccp_rx_v4_t ccp;
+
+ union {
+ uint8_t ext[sizeof(uint32_t) + sizeof(diag_v5_t)];
+ struct {
+ UN32(logNum);
+ diag_v5_t diag;
+ };
+ };
+};
+
+typedef struct report_ccp_rx_v4_s report_ccp_rx_v4_t;
+
+/* RTLS_CMD_REPORT_TX_CS_V4 */
+struct report_ccp_tx_v4_s {
+ uint8_t type; // 0 : type = CCP TX timestamp
+ uint8_t seqNum; // 1 : CCP Seq Num
+ uint8_t csTxTime[TS_40B_SIZE]; // 2-6 : CCP Tx time
+ uint8_t extLen; // 7 : length of ext below
+ union {
+ uint8_t ext[sizeof(uint32_t)];
+ UN32(logNum);
+ };
+};
+
+typedef struct report_ccp_tx_v4_s report_ccp_tx_v4_t;
+
+/* RTLS_TEMP_VBAT_IND */
+struct report_temp_vbat_s {
+ uint8_t type; // 0: type = Battery abnd Voltage Level
+ // report
+ uint8_t bat; // 1 : battery voltage value
+ uint8_t temp; // 2 : temperature value
+ UN16(atemp); // 3-4 : ambient Sensor
+ // temperature value
+ uint8_t apress[3]; // 5-7 : ambient Sensor pressure
+ // value
+ UN32(logNum); // 8-11 : log number
+};
+
+typedef struct report_temp_vbat_s report_temp_vbat_t;
+
+/* to be structured:
+ * RTLS_COMM_TEST_RESULT_REQ
+ * RTLS_START_REQ
+ * RTLS_LOG_ACCUMULATOR_REQ
+ * RTLS_RESET_REQ
+ */
+
+/* RTLS_CMD_SET_CFG_CCP */
+struct cmd_config_s {
+ uint8_t command; // 0
+ uint8_t id; // 1
+ uint8_t master; // 2
+ uint8_t prf_ch; // 3
+ uint8_t datarate; // 4
+ uint8_t code; // 5
+ uint8_t txPreambLength; // 6
+ uint8_t nsSFD_rxPAC; // 7
+ UN16(delay_rx); // 8-9
+ UN16(delay_tx); // 10-11
+ uint8_t free_12; // 12
+ uint8_t debug_logs; // 13
+ uint8_t eui64_to_follow[8]; // 14-21
+ UN32(lag_delay); // 22-25
+};
+
+typedef struct cmd_config_s cmd_config_t;
+
+/* RTLS_SINGLE_TWR_MODE_REQ */
+struct cmd_twr_single_s {
+ uint8_t command; // 0 : RTLS_SINGLE_TWR_MODE_REQ
+ uint8_t role; // 1 : initiator==1 responder==0
+ uint8_t use_ant_delay; // 2
+ UN16(delay_tx); // 3-4
+ UN16(delay_rx); // 5-6
+ UN16(response_delay); // 7-8
+ UN16(addr); // 9-10
+ uint8_t lna_on; // 11
+ UN32(power); // 12-15
+ uint8_t log_all; // 16
+};
+
+typedef struct cmd_twr_single_s cmd_twr_single_t;
+
+/* RTLS_RANGE_MEAS_REQ */
+struct cmd_twr_s {
+ uint8_t command; // 0 : RTLS_RANGE_MEAS_REQ
+ uint8_t log_all; // 1
+ uint8_t role; // 2
+ UN16(num_ranges); // 3-4
+ uint8_t use_ant_delay; // 5
+ UN16(delay_tx); // 6-7
+ UN16(delay_rx); // 8-9
+ UN16(response_delay); // 10-11
+ UN16(initiator_addr); // 12-13
+ UN16(responder_addr); // 14-15
+ uint8_t lna_on; // 16
+ UN32(power); // 17-20
+};
+
+typedef struct cmd_twr_s cmd_twr_t;
+
+/* RTLS_RANGE_MEAS_REQ */
+struct cmd_twr_asymm_s {
+ uint8_t command; // 0 : RTLS_RANGE_MEAS_REQ
+ uint8_t log_all; // 1
+ uint8_t role; // 2
+ UN16(num_ranges); // 3-4
+ uint8_t use_ant_delay; // 5
+ UN16(delay_tx); // 6-7
+ UN16(delay_rx); // 8-9
+ UN16(response_delay); // 10-11
+ UN16(final_delay); // 12-13
+ UN16(report_delay); // 14-15
+ UN16(poll_period); // 16-17
+ UN16(initiator_addr); // 18-19
+ UN16(responder_addr); // 20-21
+ uint8_t lna_on; // 22
+ UN32(power); // 23-26
+};
+
+typedef struct cmd_twr_asymm_s cmd_twr_asymm_t;
+
+/* RTLS_POWER_TEST_START_REQ */
+struct cmd_power_test_s {
+ uint8_t command; // 0
+ uint8_t start; // 1
+ UN16(duration); // 2-3
+};
+
+typedef struct cmd_power_test_s cmd_power_test_t;
+
+/* RTLS_COMM_TEST_START_REQ */
+struct cmd_comm_test_s {
+ uint8_t command; // 0
+ uint8_t transmit[1]; // 1
+ UN16(data); // 2-3
+};
+
+typedef struct cmd_comm_test_s cmd_comm_test_t;
+
+/* */
+struct request_configCle_s
+{
+ uint8_t head;
+ uint8_t uid[ADDR_BYTE_SIZE_L];
+ char ver[64 - (ADDR_BYTE_SIZE_L + 1)]; // hardcoded to be 64 bytes long
+};
+
+typedef struct request_configCle_s request_configCle_t;
+
+#pragma pack(pop)
+
+#undef UN16
+#undef UN32
+
+#ifdef __cplusplus
+}
+#endif
+#endif //RTLS_INTERFACE_H
diff --git a/driver/thirdparty/decawave/uwb2_dwm3000/inc/uwb_frames.h b/driver/thirdparty/decawave/uwb2_dwm3000/inc/uwb_frames.h
new file mode 100644
index 00000000..4e68e5fe
--- /dev/null
+++ b/driver/thirdparty/decawave/uwb2_dwm3000/inc/uwb_frames.h
@@ -0,0 +1,450 @@
+/**
+ * @file uwb_frames.h
+ *
+ * @brief UWB message frames definitions and typedefs
+ *
+ * @author Decawave
+ *
+ * @attention Copyright 2017-2019 (c) Decawave Ltd, Dublin, Ireland.
+ * All rights reserved.
+ *
+ */
+
+#ifndef UWB_FRAMES_H_
+#define UWB_FRAMES_H_ 1
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#include
+
+#define STANDARD_FRAME_SIZE 127
+
+#define ADDR_BYTE_SIZE_L (8)
+#define ADDR_BYTE_SIZE_S (2)
+
+#define TS_40B_SIZE (5)
+#define TS_UWB_SIZE (5)
+
+#define FRAME_CONTROL_BYTES 2
+#define FRAME_SEQ_NUM_BYTES 1
+#define FRAME_PANID 2
+#define FRAME_CRC 2
+#define FRAME_SOURCE_ADDRESS_S (ADDR_BYTE_SIZE_S)
+#define FRAME_DEST_ADDRESS_S (ADDR_BYTE_SIZE_S)
+#define FRAME_SOURCE_ADDRESS_L (ADDR_BYTE_SIZE_L)
+#define FRAME_DEST_ADDRESS_L (ADDR_BYTE_SIZE_L)
+
+/* 5 Bytes */
+#define FRAME_CTRLP (FRAME_CONTROL_BYTES + FRAME_SEQ_NUM_BYTES \
+ + FRAME_PANID)
+
+/* 21 bytes for 64-bit addresses) */
+#define FRAME_CTRL_AND_ADDRESS_L (FRAME_DEST_ADDRESS_L \
+ + FRAME_SOURCE_ADDRESS_L + FRAME_CTRLP)
+
+/* 9 bytes for 16-bit addresses) */
+#define FRAME_CTRL_AND_ADDRESS_S (FRAME_DEST_ADDRESS_S \
+ + FRAME_SOURCE_ADDRESS_S + FRAME_CTRLP)
+
+/* 15 bytes for 1 16-bit address and 1 64-bit address) */
+#define FRAME_CTRL_AND_ADDRESS_LS (FRAME_DEST_ADDRESS_L \
+ + FRAME_SOURCE_ADDRESS_S + FRAME_CTRLP)
+
+/* 127 - 21 - 2 = 104 */
+#define MAX_USER_PAYLOAD_STRING_LL (STANDARD_FRAME_SIZE \
+ - FRAME_CTRL_AND_ADDRESS_L - FRAME_CRC)
+
+/* 127 - 9 - 2 = 116 */
+#define MAX_USER_PAYLOAD_STRING_SS (STANDARD_FRAME_SIZE \
+ - FRAME_CTRL_AND_ADDRESS_S - FRAME_CRC)
+
+/* 127 - 15 - 2 = 110 */
+#define MAX_USER_PAYLOAD_STRING_LS (STANDARD_FRAME_SIZE \
+ - FRAME_CTRL_AND_ADDRESS_LS - FRAME_CRC)
+
+#define FRAME_DEST_ADDRESS_S_IDX (FRAME_CTRLP)
+#define FRAME_SRC_ADDRESS_S_IDX (FRAME_CTRLP + ADDR_BYTE_SIZE_S)
+// NOTE: the user payload assumes that there are only 88 "free" bytes to be used
+// for the user message (it does not scale according to the addressing modes)
+#define MAX_USER_PAYLOAD_STRING MAX_USER_PAYLOAD_STRING_LL
+
+#define RC_VERSION_PDOA (3)
+#define RC_VERSION_DR (4)
+
+enum {
+ Head_Msg_BLINK = 0xC5,
+ Head_Msg_STD = (0x40 | 0x01),
+ Head_Msg_STD_AR = (0x40 | 0x20 | 0x01),
+ Frame_Ctrl_SS = (0x80 | 0x08), // Message addressing: destination
+ // short (16-bit), source short
+ // (16-bit)
+ Frame_Ctrl_LS = (0x80 | 0x0C), // Message addressing: destination
+ // long (64-bit), source short
+ // (16-bit)
+ Frame_Ctrl_MASK = 0xCC
+};
+
+/* enumeration of function codes used in PDoA TWR protocol */
+typedef enum {
+ Twr_Fcode_Not_Defined = 0xFF, // Special : nothing
+ Twr_Fcode_Blink = 0xEE, // Special : Blink
+ Twr_Fcode_Rng_Config = 0x20, // Responder (Node) Ranging Config
+ // message : reply to blink
+ Twr_Fcode_Tag_Poll = 0x84, // Initiator (Tag) Poll message
+ // : twr start
+ // message
+ Twr_Fcode_Resp_Ext = 0x72, // Responder (Node) Response Extended
+ // : reply to Poll with
+ // X/Y previous results
+ Twr_Fcode_Tag_Final = 0x88, // Initiator (Tag) Final message back
+ // to Responder : reply to Response
+ Twr_Fcode_Tag_Accel_Final = 0x89, // Initiator (Tag) Final message back
+ // to Responder : reply to Response +
+ // Accelerometer data
+}fcode_e;
+
+// TDOA TWR
+enum {
+ RTLS_TWR_MSG_RNG_INIT = Twr_Fcode_Rng_Config, // Ranging
+ // initiation
+ // message
+ RTLS_TWR_MSG_TAG_POLL = 0x81, // Initiator (Tag) poll message
+ RTLS_TWR_MSG_ANCH_RESP = 0x70, // Responder (Anchor) response to
+ // poll
+ RTLS_TWR_MSG_TAG_FINAL = 0x82, // Initiator (Tag) final message
+ // back to Responder
+ RTLS_TWR_MSG_ANCH_TOFR = 0x71, // Responder (Anchor) TOF Report
+ // message to Initiator
+
+ RTLS_MSG_ANCH_CLK_SYNC = 0x2C, // Anchor CLK SYNC message
+ // (broadcast)
+
+ HEAD_MSG_BLINK = Head_Msg_BLINK, // Tag standard Blink
+ // message
+ HEAD_MSG_STD = Head_Msg_STD, // Std message header
+
+ APP_MSG_DATA = 0x7A, // Data Transfer Message (this is
+ // Communications Test function
+ // code)
+
+ APP_MSG_UWB_BH_DWNSTREAM = 0x7B, // UWB Command from CLE via Master
+ // to Slave
+ APP_MSG_UWB_BH_UPSTREAM = 0x7C, // UWB Data Backhaul back from Slave
+ // to CLE via Master
+};
+
+/* UWB packet types : MAC headers */
+typedef struct
+{
+ uint8_t frameCtrl[2]; // frame control bytes 00-01
+ uint8_t seqNum; // sequence_number 02
+ uint8_t panID[2]; // PAN ID 03-04
+ uint8_t destAddr[ADDR_BYTE_SIZE_S]; // 05-06
+ uint8_t sourceAddr[ADDR_BYTE_SIZE_S]; // 07-08
+}__attribute__((packed))
+mac_header_ss_t;
+
+typedef struct
+{
+ uint8_t frameCtrl[2]; // frame control bytes 00-01
+ uint8_t seqNum; // sequence_number 02
+ uint8_t panID[2]; // PAN ID 03-04
+ uint8_t destAddr[ADDR_BYTE_SIZE_L]; // 05-12 or using 64 bit
+ // addresses (05-12)
+ uint8_t sourceAddr[ADDR_BYTE_SIZE_L]; // 13-20 or using 64 bit
+ // addresses (13-20)
+}__attribute__((packed))
+mac_header_ll_t;
+
+typedef struct
+{
+ uint8_t frameCtrl[2]; // frame control bytes 00-01
+ uint8_t seqNum; // sequence_number 02
+ uint8_t panID[2]; // PAN ID 03-04
+ uint8_t destAddr[ADDR_BYTE_SIZE_L]; // 05-12 using 64 bit addresses
+ uint8_t sourceAddr[ADDR_BYTE_SIZE_S]; // 13-14
+}__attribute__((packed))
+mac_header_ls_t;
+
+typedef struct
+{
+ uint8_t frameCtrl[2]; // frame control bytes 00-01
+ uint8_t seqNum; // sequence_number 02
+ uint8_t panID[2]; // PAN ID 03-04
+ uint8_t destAddr[ADDR_BYTE_SIZE_S]; // 05-06
+ uint8_t sourceAddr[ADDR_BYTE_SIZE_L]; // 7-14 using 64 bit addresses
+}__attribute__((packed))
+mac_header_sl_t;
+
+/* General UWB packet types : Messages */
+typedef struct
+{
+ mac_header_ll_t mac;
+ uint8_t messageData[MAX_USER_PAYLOAD_STRING_LL]; // 21-124
+ // (application
+ // data and any
+ // user payload)
+ uint8_t fcs[2]; // 125-126 we allow space for the CRC as it is
+ // logically part of the message.
+ // DW1000 calculates and adds these bytes.
+}__attribute__((packed))
+std_msg_ll_t;
+
+typedef struct
+{
+ mac_header_ss_t mac;
+ uint8_t messageData[MAX_USER_PAYLOAD_STRING_SS]; // 09-124
+ // (application
+ // data and any
+ // user payload)
+ uint8_t fcs[2];
+}__attribute__((packed))
+std_msg_ss_t;
+
+typedef struct
+{
+ mac_header_ls_t mac;
+ uint8_t messageData[MAX_USER_PAYLOAD_STRING_LS]; // 15-124
+ // (application
+ // data and any
+ // user payload)
+ uint8_t fcs[2];
+}__attribute__((packed))
+std_msg_ls_t;
+
+// 12 octets for Minimum IEEE ID blink
+typedef struct
+{
+ uint8_t frameCtrl[1]; // frame control bytes 00
+ uint8_t seqNum; // sequence_number 01
+ uint8_t tagID[ADDR_BYTE_SIZE_L]; // 02-09 64 bit addresses
+ uint8_t fcs[2];
+}__attribute__((packed))
+blink_msg_t;
+
+/* Ranging Config rest of configuration.
+ * The Node's address and PanId, are in the MAC header */
+typedef struct
+{
+ /* Compatibility to the EVK's Ranging Init */
+ uint8_t fCode;
+ uint8_t tagAddr[ADDR_BYTE_SIZE_S]; // tag's short address
+ uint8_t ANC_RESP_DLY[2]; // backward compatibility to EVK1000 RI
+ // message : delayRx_us + poll_us,
+ // coded in us with bit 15 == 0, coded
+ // in ms when bit 15 == 1
+ uint8_t TAG_RESP_DLY[2]; // backward compatibility to EVK1000 RI
+ // message : , coded in us with bit 15
+ // == 0, coded in ms when bit 15 == 1
+
+ /* PDOA TWR unique message */
+ uint8_t version; // version
+
+ uint8_t sframePeriod_ms[2]; // Super Frame period, ms
+ uint8_t pollTxToFinalTx_us[2]; // time from the RMARKER of Poll to the
+ // RMARKER of Final that the Tag shall
+ // set.
+ uint8_t delayRx_us[2]; // time from end of transmission of the Poll
+ // to start of reception of Response, that
+ // the Tag shall set.
+ uint8_t slotCorr_us[4]; // Slot correction for current reception
+ // (i.e. for blink), us
+ uint8_t pollMultFast[2]; // multiplier for fast ranging in Super
+ // Frame counts
+ uint8_t pollMultSlow[2]; // multiplier for slow ranging in Super
+ // Frame counts
+
+ union
+ {
+ uint8_t mode[2]; // bitfields for mode of operation: IMU
+ // on/off, etc.
+ struct
+ {
+ uint8_t imuOn : 1; // currently only IMU ON switch is
+ // defined/used
+ };
+ };
+}__attribute__((packed))
+rng_cfg_t;
+
+typedef struct
+{
+ uint8_t fCode; // msgdata+0
+ uint8_t rNum;
+}__attribute__((packed))
+poll_t;
+
+typedef struct
+{
+ uint8_t fCode; // msgdata+0
+ uint8_t slotCorr_us[4];
+ uint8_t rNum;
+ uint8_t x_cm[2]; // X coordinate of Tag wrt Node in
+ // centimeters [0..65535cm]
+ uint8_t y_cm[2]; // Y coordinate of Tag wrt Node in
+ // centimeters [0..65535cm]
+ uint8_t clkOffset_pphm[2]; // part per (hundreds of millions) =
+ // (100*ppm)
+}__attribute__((packed))
+resp_tag_t;
+
+typedef struct
+{
+ uint8_t fCode; // msgdata+0
+ uint8_t rNum;
+ uint8_t pollTx_ts[TS_UWB_SIZE];
+ uint8_t responseRx_ts[TS_UWB_SIZE];
+ uint8_t finalTx_ts[TS_UWB_SIZE];
+ uint8_t flag; // 1 data bytes bitfields. IMU:0
+ uint8_t acc_x[2]; // Normalized accel data X from the
+ // Tag, mg
+ uint8_t acc_y[2]; // Normalized accel data Y from the
+ // Tag, mg
+ uint8_t acc_z[2]; // Normalized accel data Z from the
+ // Tag, mg
+}__attribute__((packed))
+final_accel_t;
+
+/* UWB packet types : Application-specific messages */
+
+/* Ranging Config message during Discovery
+ * the Node's address and PanId are in the MAC header */
+typedef struct
+{
+ mac_header_ls_t mac;
+ rng_cfg_t rngCfg;
+ uint8_t fcs[2];
+}__attribute__((packed))
+rng_cfg_msg_t;
+
+typedef struct
+{
+ mac_header_ss_t mac;
+ rng_cfg_t rngCfg;
+ uint8_t fcs[2];
+}__attribute__((packed))
+rng_cfg_upd_msg_t;
+
+typedef struct
+{
+ mac_header_ss_t mac;
+ poll_t poll;
+ uint8_t fcs[2];
+}__attribute__((packed))
+poll_msg_t;
+
+typedef struct
+{
+ mac_header_ss_t mac;
+ resp_tag_t resp;
+ uint8_t fcs[2];
+}__attribute__((packed))
+resp_pdoa_msg_t;
+
+typedef struct
+{
+ mac_header_ss_t mac;
+ final_accel_t final;
+ uint8_t fcs[2];
+}__attribute__((packed))
+final_msg_accel_t;
+
+typedef struct
+{
+ mac_header_sl_t mac;
+ uint8_t messageData[1]; // 09 or 15
+ // header(1)
+ uint8_t fcs[2]; // 15-16 or
+ // 21-22 we
+ // allow space
+ // for the CRC
+ // as it is
+ // logically
+ // part of the
+ // message.
+ // However
+ // ScenSor TX
+ // calculates
+ // and adds
+ // these bytes.
+}__attribute__((__packed__))
+ccp_msg_t;
+
+typedef struct
+{
+ mac_header_sl_t mac;
+ uint8_t messageData[MAX_USER_PAYLOAD_STRING_LS]; // 15-124 (application
+ // data and any user
+ // payload)
+ uint8_t fcs[2]; // 125-126 we allow
+ // space for the CRC as
+ // it is logically part
+ // of the message.
+ // However ScenSor TX
+ // calculates and adds
+ // these bytes.
+}__attribute__((packed))
+bcast_msg_t;
+
+// Up to 42 octets for extended blink message with IMU and other data as defined
+// below
+typedef struct
+{
+ uint8_t frameCtrl[1]; // frame control bytes 00
+ uint8_t seqNum; // sequence_number 01
+ uint8_t tagID[ADDR_BYTE_SIZE_L]; // 02-09 64 bit addresses
+ uint8_t ench; // 10 - encoding header
+ // (0x43: No Extended ID, no
+ // Temperature Data, No
+ // Battery Status)
+ uint8_t exth; // 11 - extension header
+ // (0x00: No blink
+ // Rate/Listening or other
+ // Data)
+ uint8_t dwh; // 12 - Decawave Blink
+ // Header: 0x01: SENSOR DATA
+ // TYPE 1
+ // [According to ISO
+ // 24730-62, this octet and
+ // any subsequent data can
+ // only be interpreted if we
+ // identify from the Tag ID
+ // field that this is a
+ // Decawave tag]
+ uint8_t dwp[27]; // 13 - 39 Decawave Blink
+ // Payload Defined below
+ // for Sensor Data Type 1
+ // [0] - mask, [1] DWtemp,
+ // [2] DWvbat, [3] DWGPIO,
+ // [4-9] Magneto, [10-15]
+ // Accel, [16-21] Gyro,
+ // [22-24] Atmosph Pressure,
+ // [25-26] Atmosph Temp
+ uint8_t fcs[2]; // 40-41 we allow space for
+ // the CRC as it is
+ // logically part of the
+ // message. However ScenSor
+ // TX calculates and adds
+ // these bytes.
+}__attribute__((packed))
+blinkIMU_msg_t;
+
+typedef struct
+{
+ uint8_t frameCtrl[2]; // frame control bytes
+ // 00-01
+ uint8_t seqNum; // sequence_number 02
+ uint8_t fcs[2]; // 03-04 CRC
+}__attribute__((packed))
+ack_msg_t;
+
+typedef std_msg_ll_t std_msg_t;
+typedef std_msg_ss_t twr_msg_t;
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* UWB_FRAMES_H_ */
diff --git a/driver/thirdparty/decawave/uwb2_dwm3000/inc/version.h b/driver/thirdparty/decawave/uwb2_dwm3000/inc/version.h
new file mode 100644
index 00000000..6903505f
--- /dev/null
+++ b/driver/thirdparty/decawave/uwb2_dwm3000/inc/version.h
@@ -0,0 +1,111 @@
+/**
+ * @file version.h
+ *
+ * @brief version number
+ * Construct the version name as "MAJOR.MINOR.YYMMDD"
+ * VER_MAJOR 0..999
+ * VER_MINOR 0..999
+ *
+ * @author Decawave
+ *
+ * @attention Copyright 2017-2019 (c) Decawave Ltd, Dublin, Ireland.
+ * All rights reserved.
+ *
+ */
+
+#ifndef VERSION_H_
+#define VERSION_H_ 1
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#define VER_MAJOR 6
+#define VER_MINOR 0
+
+/**
+ * construction of the version name as "MAJOR.MINOR.YYMMDD"
+ * e.g. "Oct 7 2014" => "141007"
+ **/
+
+#define YEAR_CH2 (__DATE__[9])
+#define YEAR_CH3 (__DATE__[10])
+
+#define MONTH_IS_JAN (__DATE__[0] == 'J' && __DATE__[1] == 'a' \
+ && __DATE__[2] == 'n')
+#define MONTH_IS_FEB (__DATE__[0] == 'F')
+#define MONTH_IS_MAR (__DATE__[0] == 'M' && __DATE__[1] == 'a' \
+ && __DATE__[2] == 'r')
+#define MONTH_IS_APR (__DATE__[0] == 'A' && __DATE__[1] == 'p')
+#define MONTH_IS_MAY (__DATE__[0] == 'M' && __DATE__[1] == 'a' \
+ && __DATE__[2] == 'y')
+#define MONTH_IS_JUN (__DATE__[0] == 'J' && __DATE__[1] == 'u' \
+ && __DATE__[2] == 'n')
+#define MONTH_IS_JUL (__DATE__[0] == 'J' && __DATE__[2] == 'l')
+#define MONTH_IS_AUG (__DATE__[0] == 'A' && __DATE__[1] == 'u')
+#define MONTH_IS_SEP (__DATE__[0] == 'S')
+#define MONTH_IS_OCT (__DATE__[0] == 'O')
+#define MONTH_IS_NOV (__DATE__[0] == 'N')
+#define MONTH_IS_DEC (__DATE__[0] == 'D')
+
+#define MONTH_CH0 ((MONTH_IS_OCT || MONTH_IS_NOV \
+ || MONTH_IS_DEC) ? '1' : '0')
+
+#define MONTH_CH1 \
+ ((MONTH_IS_JAN) ? '1' : \
+ (MONTH_IS_FEB) ? '2' : \
+ (MONTH_IS_MAR) ? '3' : \
+ (MONTH_IS_APR) ? '4' : \
+ (MONTH_IS_MAY) ? '5' : \
+ (MONTH_IS_JUN) ? '6' : \
+ (MONTH_IS_JUL) ? '7' : \
+ (MONTH_IS_AUG) ? '8' : \
+ (MONTH_IS_SEP) ? '9' : \
+ (MONTH_IS_OCT) ? '0' : \
+ (MONTH_IS_NOV) ? '1' : \
+ (MONTH_IS_DEC) ? '2' : \
+ /* default */ '?' \
+ )
+
+#define DAY_CH0 ((__DATE__[4] >= '0') ? (__DATE__[4]) : '0')
+#define DAY_CH1 (__DATE__[5])
+
+#if VER_MAJOR >= 100
+#define VMAJOR ((VER_MAJOR / 100) + '0'), \
+ (((VER_MAJOR % 100) / 10) + '0'), \
+ ((VER_MAJOR % 10) + '0')
+#elif VER_MAJOR >= 10
+#define VMAJOR ((VER_MAJOR / 10) + '0'), \
+ ((VER_MAJOR % 10) + '0')
+#else
+#define VMAJOR (VER_MAJOR + '0')
+#endif
+
+#if VER_MINOR >= 100
+#define VMINOR ((VER_MINOR / 100) + '0'), \
+ (((VER_MINOR % 100) / 10) + '0'), \
+ ((VER_MINOR % 10) + '0')
+#elif VER_MINOR >= 10
+#define VMINOR ((VER_MINOR / 10) + '0'), \
+ ((VER_MINOR % 10) + '0')
+#else
+#define VMINOR (VER_MINOR + '0')
+#endif
+
+/* VERSION */
+#define FULL_VERSION { VMAJOR, '.', VMINOR, '.', \
+ YEAR_CH2, YEAR_CH3, \
+ MONTH_CH0, MONTH_CH1, \
+ DAY_CH0, DAY_CH1, \
+ '\0' }
+
+#define DATE_VERSION { YEAR_CH2, YEAR_CH3, MONTH_CH0, MONTH_CH1, DAY_CH0, \
+ DAY_CH1, '\0' }
+
+#define RTLS_APP_VERSION FULL_VERSION
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif // VERSION_H_
diff --git a/driver/thirdparty/decawave/uwb2_dwm3000/lib/libdwt_uwb_driver-m33-hfp-6.0.7.a b/driver/thirdparty/decawave/uwb2_dwm3000/lib/libdwt_uwb_driver-m33-hfp-6.0.7.a
new file mode 100644
index 00000000..54fe918c
Binary files /dev/null and b/driver/thirdparty/decawave/uwb2_dwm3000/lib/libdwt_uwb_driver-m33-hfp-6.0.7.a differ
diff --git a/driver/thirdparty/decawave/uwb2_dwm3000/lib/libdwt_uwb_driver-m4-hfp-6.0.7.a b/driver/thirdparty/decawave/uwb2_dwm3000/lib/libdwt_uwb_driver-m4-hfp-6.0.7.a
new file mode 100644
index 00000000..7d15e893
Binary files /dev/null and b/driver/thirdparty/decawave/uwb2_dwm3000/lib/libdwt_uwb_driver-m4-hfp-6.0.7.a differ
diff --git a/templates.xml b/templates.xml
index 983b6517..e07cb47b 100644
--- a/templates.xml
+++ b/templates.xml
@@ -1529,4 +1529,19 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/third_party_hw_drivers.slce b/third_party_hw_drivers.slce
index 2e3e6f57..2190a591 100644
--- a/third_party_hw_drivers.slce
+++ b/third_party_hw_drivers.slce
@@ -2,7 +2,7 @@ id: third_party_hw_drivers
label: Third Party Hardware Drivers
description: >
Third Party Hardware Driver extension for the Gecko SDK Suite
-version: 2.0.1
+version: 2.0.2
sdk:
id: gecko_sdk
version: 4.4.0
diff --git a/third_party_hw_drivers.slsdk b/third_party_hw_drivers.slsdk
index 209a4d75..29140365 100644
--- a/third_party_hw_drivers.slsdk
+++ b/third_party_hw_drivers.slsdk
@@ -1,10 +1,10 @@
# Properties file for Simplicity Studio metadata
id=uc.extension.third_party_hw_drivers
-version=2.0.1
+version=2.0.2
label=Third Party Hardware Drivers
description=Third Party Hardware Drivers
prop.file.templatesFile=templates.xml
-prop.subLabel=Third\\ Party\\ Hardware\\ Drivers\\ 2.0.1
+prop.subLabel=Third\\ Party\\ Hardware\\ Drivers\\ 2.0.2