-
Notifications
You must be signed in to change notification settings - Fork 1
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
Bot
committed
Jun 27, 2024
1 parent
f52f761
commit 3ff9ecc
Showing
1,121 changed files
with
627,918 additions
and
15 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
#exclude licensed wirepas binaries | ||
image/* | ||
|
||
#but include the README still | ||
!image/readme.md | ||
|
||
#exclude license acceptance | ||
.license_accepted | ||
|
||
#do not commit the build outputs | ||
build/ | ||
|
||
#don't commit sensitive bootoader keys | ||
custom_bootloader_keys.ini | ||
|
||
*.pyc |
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,3 @@ | ||
[submodule "projects/doxygen/doxygen-awesome-css"] | ||
path = projects/doxygen/doxygen-awesome-css | ||
url = https://github.com/jothepro/doxygen-awesome-css.git |
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 |
---|---|---|
@@ -1,29 +1,92 @@ | ||
# Wirepas SDK for Mesh 2.4 GHz | ||
# Wirepas SDK for 2.4 GHz | ||
|
||
<img src="WCS-Icons-2.4ghz.png" alt="drawing" width="200"/> | ||
This repository contains Wirepas SDK, which allows the development of an application | ||
to be executed on the same chip as Wirepas Stack. | ||
This application is often referred as a _Single-MCU application_. | ||
|
||
|
||
> :warning: | ||
> | ||
> _To use the SDK, you need to have access to the Wirepas binaries. You need to have a | ||
> software license agreement (SLA) with Wirepas to get them. If you would like to become | ||
> a SLA licensee, please see the right contact from www.wirepas.com/contact_ | ||
> | ||
- [Overview](#overview) | ||
- [Documentation](#documentation) | ||
- [Wirepas binaries](#wirepas-binaries) | ||
- [Environment](#environment) | ||
- [How to build an application](#how-to-build-an-application) | ||
- [License](#license) | ||
|
||
|
||
## Overview | ||
|
||
This repository hosts the __Wirepas SDK for Mesh 2.4 Ghz profiles__. It allows the development of an application | ||
to be executed on the same chip as Wirepas Stack. | ||
This application is often referred as a _Single-MCU application_. | ||
The following diagram, describes the main components of the SDK. | ||
|
||
![Main components][here_main_components] | ||
|
||
|
||
## Documentation | ||
|
||
The documentation for this SDK is written with Doxygen and generated in HTML format. | ||
|
||
It is hosted [here](https://wirepas.github.io/wm-sdk-2_4/). | ||
You can select the desired version depending on the SDK version you are working on. | ||
|
||
Some information is available on this page too, but it is just a subset of what the html documentation | ||
contains. | ||
|
||
__To use this SDK, you need to have access to the Wirepas binaries. You need to have a | ||
software license agreement (SLA) with Wirepas to get them. If you would like to become | ||
a SLA licensee, please see the right contact from www.wirepas.com/contact__ | ||
## Wirepas binaries | ||
|
||
As a Wirepas SLA licensee, you should have received access to protected zipped archive containing the Wirepas binaries. | ||
Please extract them at the root of [image folder][here_image] (All the *.a, *.hex and *.conf files must be at the root of this folder). | ||
|
||
## Version selection | ||
## Environment | ||
|
||
To start using the sdk, please select the desired release. | ||
This SDK relies on GNU Arm toolchain. To use the SDK you will need to fulfill the following requirements: | ||
|
||
They are listed on the [release page](https://github.com/wirepas/wm-sdk-2_4/releases). | ||
1. A GCC Arm toolchain (_version 10.3.1 is recommended_) | ||
2. The make tool | ||
3. python 3.x | ||
4. pycryptodome package for python (_can be installed with pip_) | ||
|
||
Each realease has a tag with following format vx.x.x (Ex: v1.0.0). | ||
In order to validate that your environment is correctly configured, you should be able to build the custom_app application. | ||
|
||
You can switch to a given release with its tag: | ||
For more information, please refer to [Documentation](#documentation) | ||
|
||
```shell | ||
git checkout vx.x.x | ||
## How to build an application | ||
|
||
This SDK supports multiple target boards. All of them are listed under [board folder][here_board] and can be selected with target_board=<target_board> | ||
|
||
This SDK contains multiple application examples that can be found under [source folder][here_source] and can be selected with app_name=<app_name> | ||
|
||
> :warning: | ||
> | ||
> The first time you'll build an application, you'll be prompted to choose bootloader keys. | ||
> Once chosen the first time, they will be used for all your images and must be kept secret | ||
> and in a safe place where they will not be lost or deleted. It is also possible to define | ||
> keys per application. | ||
To build the _custom_app_ application for a given board, please execute following command. | ||
|
||
```shell | ||
make app_name=custom_app target_board=<board_name> | ||
``` | ||
|
||
You can customize verbosity of the log with the option V=value. Value can be 0 (default), 1 for more build info and 2 for even more build info. | ||
|
||
After execution of this command, you should find the _final_image_custom_app.hex_ under _build/<board_name>/custom_app_ folder. | ||
|
||
For more information, please refer to [Documentation](#documentation) | ||
|
||
## License | ||
|
||
See [LICENSE][here_license] for full license details. | ||
|
||
[here_license]: LICENSE.txt | ||
[here_main_components]: projects/doxygen/media/main_components.png | ||
[here_board]: board/ | ||
[here_source]: source/ | ||
[here_image]: image/ | ||
|
Binary file not shown.
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,202 @@ | ||
/* Copyright 2018 Wirepas Ltd. All Rights Reserved. | ||
* | ||
* See file LICENSE.txt for full license details. | ||
* | ||
*/ | ||
|
||
/** | ||
* \file wms_advertiser.h | ||
* | ||
* Application library for direct advertiser functionality. | ||
* | ||
* Library services are accessed via @ref app_lib_advertiser_t "lib_advertiser" | ||
* handle. | ||
* | ||
* For examples on how to use these services, check out | ||
* @ref diradv_example/app.c "example application" | ||
*/ | ||
#ifndef APP_LIB_ADVERTISER_H_ | ||
#define APP_LIB_ADVERTISER_H_ | ||
|
||
#include <stdint.h> | ||
#include <stdbool.h> | ||
|
||
#include "wms_app.h" | ||
|
||
/** \brief Library symbolic name */ | ||
#define APP_LIB_ADVERTISER_NAME 0x06cc5e24 //!< "ADVERT" | ||
|
||
/** \brief Maximum supported library version */ | ||
#define APP_LIB_ADVERTISER_VERSION 0x205 | ||
|
||
/** | ||
* \brief Headnode acknowledges the packet by using this source endpoint | ||
* | ||
* Used in headnode callback function set with @ref | ||
* app_lib_advertiser_ackdatacb_f "lib_advertiser->setBeaconDataAckListenCb()" | ||
* and receiving packet in advertiser in callback function set with @ref | ||
* app_lib_data_set_data_received_cb_f "lib_data->setDataReceivedCb()" | ||
*/ | ||
#define DIRADV_EP_SRC_ACK 249 | ||
/** | ||
* \brief Headnode acknowledges the packet by using this destination endpoint | ||
* | ||
* Used in headnode callback function set with @ref | ||
* app_lib_advertiser_ackdatacb_f "lib_advertiser->setBeaconDataAckListenCb()" | ||
* and receiving packet in advertiser in callback function set with @ref | ||
* app_lib_data_set_data_received_cb_f "lib_data->setDataReceivedCb()" | ||
*/ | ||
#define DIRADV_EP_DEST 248 | ||
|
||
/** | ||
* \brief Absolute maximum size of the ACK message | ||
* | ||
* This can be used for allocating memory structures for callback function set | ||
* with @ref app_lib_advertiser_ackdatacb_f | ||
* "lib_advertiser->setBeaconDataAckListenCb()". | ||
*/ | ||
#define DIRADV_MAX_ACK_LEN 102 | ||
|
||
/** | ||
* \brief Default value used with @ref app_lib_advertiser_set_queuing_time_f | ||
* "lib_advertiser->setQueuingTimeHp()" | ||
*/ | ||
#define DIRADV_DEFAULT_QUEUE_TIME 250 | ||
|
||
/** | ||
* \brief Input data structure for callback function set by @ref | ||
* app_lib_advertiser_ackdatacb_f | ||
* "lib_advertiser->setRouterAckGenCb()" | ||
*/ | ||
typedef struct | ||
{ | ||
/** Address of the sender (advertiser) */ | ||
app_addr_t sender; | ||
/** Max len of the ack payload supported by transmitter whom the ack is sent | ||
*/ | ||
uint8_t ack_length; | ||
/** Source endpoint of packet. Used to distinguish different applications | ||
* sending advertiser packets. | ||
*/ | ||
uint8_t src_endpoint; | ||
/** Destination endpoint of packet. Used to distinguish different | ||
* applications sending advertiser packets. | ||
*/ | ||
uint8_t dest_endpoint; | ||
/** Pointer to data payload sent by advertiser */ | ||
void * data; | ||
/** Amount of data */ | ||
size_t num_bytes; | ||
} ack_gen_input_t; | ||
|
||
/** | ||
* \brief Output structure for for callback function set by @ref | ||
* app_lib_advertiser_ackdatacb_f | ||
* "lib_advertiser->setRouterAckGenCb()" | ||
*/ | ||
typedef struct | ||
{ | ||
/** Acknowledgement payload. Payload can be allocated by @ref | ||
* DIRADV_MAX_ACK_LEN definition. */ | ||
void * data; | ||
/** length of the acknowledgement (maximum size is limited to @ref | ||
* ack_gen_input_t.ack_length "supported ack length" bytes) */ | ||
uint8_t length; | ||
} ack_gen_output_t; | ||
|
||
/** | ||
* \brief Callback function type used with @ref | ||
* app_lib_advertiser_ackdatacb_f | ||
* "lib_advertiser->setRouterAckGenCb()" | ||
* | ||
* \param[in] in | ||
* Information about received advertiser packet | ||
* \param[out] out | ||
* Generated acknowledgement | ||
* \return true: output generated, false: use default acknowledgement | ||
*/ | ||
typedef bool (*app_llhead_acklistener_f)(const ack_gen_input_t * in, | ||
ack_gen_output_t * out); | ||
|
||
/** | ||
* \brief Sets callback function to be called when ack is generated as a | ||
* response for advertiser device transmission (in other devices in | ||
* the network). | ||
* \param callback | ||
* Callback function to be used. NULL to disable | ||
* \note Device must have @ref APP_LIB_SETTINGS_ROLE_FLAG_LL in device | ||
* role (service @ref app_lib_settings_set_node_role_f | ||
* "lib_settings->setNodeRole()" in order for callback to be | ||
* active. | ||
*/ | ||
typedef void (*app_lib_advertiser_ackdatacb_f) | ||
(app_llhead_acklistener_f callback); | ||
|
||
/** | ||
* \brief Set maximum queueing time for advertiser data packets | ||
* \param time_ms | ||
* Time in milliseconds how soon packet should be transmitted | ||
* 0 to disable the feature | ||
* \return Result code, always @ref APP_RES_OK or @ref | ||
* APP_RES_INVALID_CONFIGURATION if device is not configured as | ||
* @ref APP_LIB_SETTINGS_ROLE_ADVERTISER | ||
* | ||
* By using this service, advertiser can set the higher-precision | ||
* TTL and when advertiser sends data to CSMA-CA device, this TTL is also | ||
* checked. | ||
* For time-slotted mode networks, this value has no impact due to nature of the | ||
* time-slotted mode transmission. Neither this service has impact if device is | ||
* not advertiser. | ||
* | ||
* Default value used is @ref DIRADV_DEFAULT_QUEUE_TIME | ||
* | ||
* Recommendation is to use values larger than 80 ms. Smaller values than that | ||
* will cause failed transmission even in normal operation conditions due to the | ||
* time periods when transmission is forbidden. | ||
* | ||
* @note Using @p time_ms with value 0 to disabling the feature may have quite | ||
* a large impact on power consumption. This means that device may make lot of | ||
* transmission attempts to target instead of giving up and trying another | ||
* , alternative, target and thus resulting high power consumption. This could | ||
* happen, for example, when target device is doing network scan. | ||
*/ | ||
typedef app_res_e | ||
(*app_lib_advertiser_set_queuing_time_f)(uint16_t time_ms); | ||
|
||
/** | ||
* @brief Option flags to be used with advertiser | ||
*/ | ||
typedef struct | ||
{ | ||
// If true, advertiser will follow the network in order to have valid target | ||
// to send data to. If false, advertiser does not follow the network and | ||
// should perform scan (service @ref app_lib_state_start_scan_nbors_f | ||
// "lib_state->startScanNbors()") before sending data packets. | ||
// Default value for this is false. | ||
bool follow_network; | ||
} adv_option_t; | ||
|
||
/** | ||
* @brief Set options for advertiser | ||
* @param option | ||
* Options to set | ||
* @return Result code, normally @ref APP_RES_OK. If @p option==NULL, @ref | ||
* APP_RES_INVALID_NULL_POINTER. If role is not @ref | ||
* APP_LIB_SETTINGS_ROLE_ADVERTISER , @ref | ||
* APP_RES_INVALID_CONFIGURATION | ||
*/ | ||
typedef app_res_e | ||
(*app_lib_advertiser_set_options_f)(adv_option_t * option); | ||
|
||
/** | ||
* \brief List of library functions | ||
*/ | ||
|
||
typedef struct | ||
{ | ||
app_lib_advertiser_ackdatacb_f setRouterAckGenCb; | ||
app_lib_advertiser_set_queuing_time_f setQueuingTimeHp; | ||
app_lib_advertiser_set_options_f setOptions; | ||
} app_lib_advertiser_t; | ||
|
||
#endif /* APP_LIB_ADVERTISER_H_ */ |
Oops, something went wrong.