-
Notifications
You must be signed in to change notification settings - Fork 8
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
59d7a0a
commit b8cd7a2
Showing
25 changed files
with
2,107 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,109 @@ | ||
# Platform - IADC Tailgating # | ||
![Type badge](https://img.shields.io/badge/dynamic/json?url=https://raw.githubusercontent.com/SiliconLabs/application_examples_ci/master/platform_applications/platform_iadc_tailgating_common.json&label=Type&query=type&color=green) | ||
![Technology badge](https://img.shields.io/badge/dynamic/json?url=https://raw.githubusercontent.com/SiliconLabs/application_examples_ci/master/platform_applications/platform_iadc_tailgating_common.json&label=Technology&query=technology&color=green) | ||
![License badge](https://img.shields.io/badge/dynamic/json?url=https://raw.githubusercontent.com/SiliconLabs/application_examples_ci/master/platform_applications/platform_iadc_tailgating_common.json&label=License&query=license&color=green) | ||
![SDK badge](https://img.shields.io/badge/dynamic/json?url=https://raw.githubusercontent.com/SiliconLabs/application_examples_ci/master/platform_applications/platform_iadc_tailgating_common.json&label=SDK&query=sdk&color=green) | ||
![Build badge](https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/SiliconLabs/application_examples_ci/master/platform_applications/platform_iadc_tailgating_build_status.json) | ||
![Flash badge](https://img.shields.io/badge/dynamic/json?url=https://raw.githubusercontent.com/SiliconLabs/application_examples_ci/master/platform_applications/platform_iadc_tailgating_common.json&label=Flash&query=flash&color=blue) | ||
![RAM badge](https://img.shields.io/badge/dynamic/json?url=https://raw.githubusercontent.com/SiliconLabs/application_examples_ci/master/platform_applications/platform_iadc_tailgating_common.json&label=RAM&query=ram&color=blue) | ||
|
||
## Overview ## | ||
|
||
This example project demonstrates the usage of the IADC in tailgating mode. This mode gives ultimate priority to the Scan queue. The IADC will only perform single conversions immediately after completing a scan sequence. This allows the system to use the scan queue for high-priority conversions with tight timing requirements, and the single queue for low-priority, on-demand conversion events. | ||
|
||
Note that this setting should only be used when scan conversions are guaranteed to trigger. If no scan sequence is triggered, any single conversion trigger will remain pending indefinitely. It is also important to note that if there is not enough time between scan conversions to service a single conversion, the next scan sequence will be delayed. | ||
|
||
## Gecko SDK version ## | ||
|
||
- GSDK v4.4.3 | ||
|
||
## Hardware Required ## | ||
|
||
- [EFM32PG23 Pro Kit](https://www.silabs.com/development-tools/mcu/32-bit/efm32pg23-pro-kit?tab=overview) | ||
|
||
**Note:** | ||
|
||
- Tested boards for working with this example: | ||
|
||
| Board ID | Description | | ||
| ---------------------- | ------ | | ||
| BRD4181b | [EFR32xG21A Wireless Gecko 2.4 GHz +10 dBm Radio Board with Secure Vault](https://www.silabs.com/development-tools/wireless/slwrb4181b-efr32xg21-wireless-gecko-radio-board?tab=overview)| | ||
| BRD4182a | [EFR32xG22 Wireless Gecko 2.4 GHz +6 dBm 5x5, QFN40 Radio Board](https://www.silabs.com/development-tools/wireless/slwrb4182a-efr32xg22-wireless-gecko-radio-board?tab=overview)| | ||
| BRD4210a | [EFR32XG23 868-915 MHz +20 dBm Radio Board](https://www.silabs.com/development-tools/wireless/xg23-rb4210a-efr32xg23-868-915-mhz-20-dbm-radio-board?tab=overview)| | ||
| BRD4186c | [EFR32xG24 Wireless 2.4 GHz +10 dBm Radio Board](https://www.silabs.com/development-tools/wireless/xg24-rb4186c-efr32xg24-wireless-gecko-radio-board?tab=overview)| | ||
| BRD4270b | [EFR32FG25 902-928 MHz +16 dBm Radio Board](https://www.silabs.com/development-tools/wireless/proprietary/fg25-rb4270b-efr32fg25-radio-board?tab=overview)| | ||
| BRD4194a | [EFR32xG27 Wireless 2.4 GHz +8 dBm Radio Board](https://www.silabs.com/development-tools/wireless/xg27-rb4194a-efr32xg27-8-dbm-wireless-radio-board?tab=overview)| | ||
| BRD4400c | [EFR32xG28 2.4 GHz BLE and +14 dBm Radio Board](https://www.silabs.com/development-tools/wireless/xg28-rb4400c-efr32xg28-2-4-ghz-ble-and-14-dbm-radio-board?tab=overview)| | ||
|
||
## Connections Required ## | ||
|
||
Connect the board via the connector cable to your PC to flash the example. | ||
|
||
## Setup ## | ||
|
||
To test this application, you can either create a project based on an example or start with an "Empty C Project" project based on your hardware. | ||
|
||
### Create a project based on an example project ### | ||
|
||
1. Make sure that this repository is added to [Preferences > Simplicity Studio > External Repos](https://docs.silabs.com/simplicity-studio-5-users-guide/latest/ss-5-users-guide-about-the-launcher/welcome-and-device-tabs). | ||
|
||
2. From the Launcher Home, add your product name to My Products, click on it, and click on the **EXAMPLE PROJECTS & DEMOS** tab. Find the example project filtering by "tailgating". | ||
|
||
3. Click the **Create** button on **Platform - IADC Tailgating** example. Example project creation dialog pops up -> click Create and Finish and the project should be generated. | ||
|
||
![create_project](image/create_project.png) | ||
|
||
4. Build and flash this example to the board. | ||
|
||
### Start with an "Empty C Project" project ### | ||
|
||
1. Create an **Empty C Project** project for your hardware using Simplicity Studio 5. | ||
|
||
2. Copy all files in the `inc` and `src` folders into the project root folder (overwriting the existing file). | ||
|
||
3. Install the software components: | ||
|
||
3.1. Open the .slcp file in the project | ||
|
||
3.2. Select the SOFTWARE COMPONENTS tab | ||
|
||
3.3. Install the following components: | ||
|
||
- [Platform] → [Peripheral] → [IADC] | ||
|
||
- [Platform] → [Peripheral] → [PRS] | ||
|
||
- [Services] → [IO Stream] → [Driver] → [IO Stream: USART] | ||
|
||
- [Services] → [IO Stream] → [IO Stream: Retarget STDIO] | ||
|
||
- [Services] → [IO Stream] → [IO Stream: STDLIB Configuration] | ||
|
||
4. Enable Virtual COM UART | ||
|
||
- [Platform] → [Board] → [Board Control] → [Configure] → [Enable Virtual COM UART] | ||
|
||
5. Enable floating point print() | ||
|
||
- [Floating point print() with GCC](https://community.silabs.com/s/article/floating-point-print-with-gcc?language=en_US) | ||
|
||
6. Build and flash the project to your board. | ||
|
||
## How It Works ## | ||
|
||
The example uses conversion tailgating which is shown in the picture below. In the example, the Scan queue is configured to trigger a two-channel conversion periodically (5ms) on the IADC local timer, while the Single queue is configured to trigger on-demand from software. When a single conversion is requested by pressing BTN0, it waits until after the scan sequence is complete, and then the single conversion is performed. The scan conversions and the single conversion is using the same configuration 0, so a warmup delay is not inserted between the end of the scan and the beginning of the single conversion cycle. Note that this example provides plenty of time between IADC scan conversions for the single conversion to occur, thus no scan conversions are delayed. | ||
|
||
![how_to_work](image/how_to_work.png) | ||
|
||
The sampled value is printed out over the UART interface. Additionally, a PRS debug signal SCANENTRYDONE and SINGLEDONE is added to the project for test purposes. | ||
|
||
### Pin Routing ### | ||
| Pin Name | BRD2504A | BRD4181b | BRD4182a | BRD4210a | BRD4186c | BRD4270b | BRD4194A | BRD4400C | | ||
| --- | --- | --- | --- | --- | --- | --- | --- | --- | | ||
| IADC SCAN0 | AN 0, SMA | EXP10 (PC3) | EXP16 (PB3) | EXP16 (PC7) | EXP16 (PC7) | EXP16 (PB3) | EXP16 (PB3) | EXP16 (PC7) | | ||
| IADC SCAN1 | EXP11 (PB4)| EXP4 (PC0) | EXP15 (PB2) | EXP15 (PC5) | EXP15 (PC5) | EXP15 (PB2) | EXP15 (PB2) | EXP15 (PC5) | | ||
| IADC SINGLE | EXP16 (PA7)| EXP9 (PB1) | EXP9 (PB1) | EXP9 (PD2) | EXP9 (PD2) | EXP10 (PB4) | EXP9 (PB1) | EXP9 (PA14) | | ||
| SCANENTRYDONE | PC8 | EXP13 (PD3) | EXP13 (PD3) | EXP13 (PA7) | EXP13 (PA7) | EXP13 (PA7) | EXP13 (PA8) | EXP13 (PB5) | | ||
| SINGLEDONE | EXP13 (PC9) | EXP11 (PD2) | EXP11 (PD2) | EXP11 (PA6) | EXP11 (PA6) | EXP11 (PA6) | EXP10 (PC3) | EXP11 (PB4) | | ||
|
||
|
76 changes: 76 additions & 0 deletions
76
platform_iadc_tailgating/SimplicityStudio/platform_iadc_tailgating.slcp
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,76 @@ | ||
# Silicon Labs Project Configuration Tools: slcp, v0, Component selection file. | ||
project_name: platform_iadc_tailgating | ||
label: platform_iadc_tailgating | ||
|
||
description: | | ||
This example project shows the IADC tailgating conversation mode. | ||
|
||
category: Example|Platform | ||
package: Platform | ||
quality: experimental | ||
|
||
filter: | ||
- name: Device Type | ||
value: [SoC] | ||
- name: MCU | ||
value: [32-bit MCU] | ||
- name: Project Difficulty | ||
value: [Beginner] | ||
|
||
readme: | ||
- path: ../README.md | ||
|
||
source: | ||
- path: ../src/app.c | ||
- path: ../src/main.c | ||
|
||
include: | ||
- path: ../inc | ||
file_list: | ||
- path: brd2504a/app.h | ||
condition: [brd2504a] | ||
- path: brd4181b/app.h | ||
condition: [brd4181b] | ||
- path: brd4182a/app.h | ||
condition: [brd4182a] | ||
- path: brd4210a/app.h | ||
condition: [brd4210a] | ||
- path: brd4186c/app.h | ||
condition: [brd4186c] | ||
- path: brd4270b/app.h | ||
condition: [brd4270b] | ||
- path: brd4194a/app.h | ||
condition: [brd4194a] | ||
- path: brd4400c/app.h | ||
condition: [brd4400c] | ||
|
||
component: | ||
- id: sl_system | ||
- id: device_init | ||
- id: emlib_iadc | ||
- id: emlib_prs | ||
- id: iostream_retarget_stdio | ||
- id: iostream_stdlib_config | ||
- id: iostream_recommended_stream | ||
- id: simple_button | ||
instance: [btn0] | ||
|
||
define: | ||
- name: DEBUG_EFM | ||
|
||
configuration: | ||
- {name: SL_BOARD_ENABLE_VCOM, value: '1'} | ||
|
||
toolchain_settings: | ||
- {value: -u _printf_float, option: gcc_linker_option} | ||
|
||
ui_hints: | ||
highlight: | ||
- path: README.md | ||
focus: true | ||
|
||
other_file: | ||
- path: ../image/create_project.png | ||
directory: "image" | ||
- path: ../image/how_to_work.png | ||
directory: "image" |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,82 @@ | ||
/***************************************************************************//** | ||
* @file | ||
* @brief Top level application functions | ||
******************************************************************************* | ||
* # License | ||
* <b>Copyright 2020 Silicon Laboratories Inc. www.silabs.com</b> | ||
******************************************************************************* | ||
* | ||
* 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 | ||
|
||
/******************************************************************************* | ||
******************************* DEFINES *********************************** | ||
******************************************************************************/ | ||
|
||
// Set CLK_ADC to 40 MHz - this will be adjusted to HFXO frequency in the | ||
// initialization process | ||
// (The CLK_ADC clock possible dived values are 1,2,3,4) | ||
#define CLK_SRC_ADC_FREQ HFXO_FREQ / 4 // CLK_SRC_ADC - 40 MHz max | ||
#define CLK_ADC_FREQ 100000 // ADC_CLK - 10 MHz max in normal mode | ||
|
||
// Desired conversation interval in Hz | ||
// min 150 Hz if the CLK_ADC is 9.75MHz | ||
#define CLK_TIMER 200 | ||
|
||
// Number of scan channels | ||
#define NUM_INPUTS 2 | ||
|
||
/* | ||
* Specify the IADC input using the IADC_PosInput_t typedef. This | ||
* must be paired with a corresponding macro definition that allocates | ||
* the corresponding ABUS to the IADC. These are... | ||
* | ||
* GPIO->ABUSALLOC |= GPIO_ABUSALLOC_AEVEN0_ADC0 | ||
* GPIO->ABUSALLOC |= GPIO_ABUSALLOC_AODD0_ADC0 | ||
* GPIO->BBUSALLOC |= GPIO_BBUSALLOC_BEVEN0_ADC0 | ||
* GPIO->BBUSALLOC |= GPIO_BBUSALLOC_BODD0_ADC0 | ||
* GPIO->CDBUSALLOC |= GPIO_CDBUSALLOC_CDEVEN0_ADC0 | ||
* GPIO->CDBUSALLOC |= GPIO_CDBUSALLOC_CDODD0_ADC0 | ||
* | ||
* ...for port A, port B, and port C/D pins, even and odd, respectively. | ||
*/ | ||
#define IADC_INPUT_0_PORT_PIN iadcPosInputPadAna0; | ||
#define IADC_INPUT_1_PORT_PIN iadcPosInputPortBPin4; | ||
#define IADC_INPUT_2_PORT_PIN iadcPosInputPortAPin7; | ||
|
||
#define IADC_INPUT_1_BUS BBUSALLOC | ||
#define IADC_INPUT_1_BUSALLOC GPIO_BBUSALLOC_BEVEN0_ADC0 | ||
|
||
#define IADC_INPUT_2_BUS ABUSALLOC | ||
#define IADC_INPUT_2_BUSALLOC GPIO_ABUSALLOC_AODD0_ADC0 | ||
|
||
// PRS Channel 0-5 can be routed to port A/B and Channel 6-11 to port C/D | ||
#define SCANENTRYDONE_PRS_CHANNEL 6 | ||
#define SCANENTRYDONE_PORT gpioPortC | ||
#define SCANENTRYDONE_PIN 8 | ||
|
||
// PRS Channel 0-5 can be routed to port A/B and Channel 6-11 to port C/D | ||
#define SINGLEDONE_PRS_CHANNEL 7 | ||
#define SINGLEDONE_PORT gpioPortC | ||
#define SINGLEDONE_PIN 9 | ||
|
||
/***************************************************************************//** | ||
* Initialize application. | ||
******************************************************************************/ | ||
void app_init(void); | ||
|
||
/***************************************************************************//** | ||
* App ticking function. | ||
******************************************************************************/ | ||
void app_process_action(void); | ||
|
||
#endif // APP_H |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,85 @@ | ||
/***************************************************************************//** | ||
* @file | ||
* @brief Top level application functions | ||
******************************************************************************* | ||
* # License | ||
* <b>Copyright 2020 Silicon Laboratories Inc. www.silabs.com</b> | ||
******************************************************************************* | ||
* | ||
* 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 | ||
|
||
/******************************************************************************* | ||
******************************* DEFINES *********************************** | ||
******************************************************************************/ | ||
|
||
// Set CLK_ADC to 40 MHz - this will be adjusted to HFXO frequency in the | ||
// initialization process | ||
// (The CLK_ADC clock possible dived values are 1,2,3,4) | ||
#define CLK_SRC_ADC_FREQ HFXO_FREQ / 4 // CLK_SRC_ADC - 40 MHz max | ||
#define CLK_ADC_FREQ 100000 // ADC_CLK - 10 MHz max in normal mode | ||
|
||
// Desired conversation interval in Hz | ||
// min 150 Hz if the CLK_ADC is 9.75MHz | ||
#define CLK_TIMER 200 | ||
|
||
// Number of scan channels | ||
#define NUM_INPUTS 2 | ||
|
||
/* | ||
* Specify the IADC input using the IADC_PosInput_t typedef. This | ||
* must be paired with a corresponding macro definition that allocates | ||
* the corresponding ABUS to the IADC. These are... | ||
* | ||
* GPIO->ABUSALLOC |= GPIO_ABUSALLOC_AEVEN0_ADC0 | ||
* GPIO->ABUSALLOC |= GPIO_ABUSALLOC_AODD0_ADC0 | ||
* GPIO->BBUSALLOC |= GPIO_BBUSALLOC_BEVEN0_ADC0 | ||
* GPIO->BBUSALLOC |= GPIO_BBUSALLOC_BODD0_ADC0 | ||
* GPIO->CDBUSALLOC |= GPIO_CDBUSALLOC_CDEVEN0_ADC0 | ||
* GPIO->CDBUSALLOC |= GPIO_CDBUSALLOC_CDODD0_ADC0 | ||
* | ||
* ...for port A, port B, and port C/D pins, even and odd, respectively. | ||
*/ | ||
#define IADC_INPUT_0_PORT_PIN iadcPosInputPortCPin3; | ||
#define IADC_INPUT_1_PORT_PIN iadcPosInputPortCPin0; | ||
#define IADC_INPUT_2_PORT_PIN iadcPosInputPortBPin1; | ||
|
||
#define IADC_INPUT_0_BUS CDBUSALLOC | ||
#define IADC_INPUT_0_BUSALLOC GPIO_CDBUSALLOC_CDODD0_ADC0 | ||
|
||
#define IADC_INPUT_1_BUS CDBUSALLOC | ||
#define IADC_INPUT_1_BUSALLOC GPIO_CDBUSALLOC_CDEVEN0_ADC0 | ||
|
||
#define IADC_INPUT_2_BUS BBUSALLOC | ||
#define IADC_INPUT_2_BUSALLOC GPIO_BBUSALLOC_BODD0_ADC0 | ||
|
||
// PRS Channel 0-5 can be routed to port A/B and Channel 6-11 to port C/D | ||
#define SCANENTRYDONE_PRS_CHANNEL 6 | ||
#define SCANENTRYDONE_PORT gpioPortD | ||
#define SCANENTRYDONE_PIN 3 | ||
|
||
// PRS Channel 0-5 can be routed to port A/B and Channel 6-11 to port C/D | ||
#define SINGLEDONE_PRS_CHANNEL 7 | ||
#define SINGLEDONE_PORT gpioPortD | ||
#define SINGLEDONE_PIN 2 | ||
|
||
/***************************************************************************//** | ||
* Initialize application. | ||
******************************************************************************/ | ||
void app_init(void); | ||
|
||
/***************************************************************************//** | ||
* App ticking function. | ||
******************************************************************************/ | ||
void app_process_action(void); | ||
|
||
#endif // APP_H |
Oops, something went wrong.