STM32CubeWL/Projects/NUCLEO-WL55JC/Applications/SubGHz_Phy/SubGHz_Phy_Per
Eya 1555f88ae1 Release v1.1.0 2021-07-23 11:28:25 +01:00
..
Core Release v1.1.0 2021-07-23 11:28:25 +01:00
EWARM Release v1.1.0 2021-07-23 11:28:25 +01:00
MDK-ARM Release v1.1.0 2021-07-23 11:28:25 +01:00
STM32CubeIDE Release v1.1.0 2021-07-23 11:28:25 +01:00
SubGHz_Phy Release v1.1.0 2021-07-23 11:28:25 +01:00
.extSettings Release v1.1.0 2021-07-23 11:28:25 +01:00
SubGHz_Phy_Per.ioc Release v1.1.0 2021-07-23 11:28:25 +01:00
readme.txt Release v1.1.0 2021-07-23 11:28:25 +01:00

readme.txt

/**
  @page SubGHz_Phy_Per Readme file

  @verbatim
  ******************** (C) COPYRIGHT 2020 STMicroelectronics *******************
  * @file    Applications/SubGHz_Phy/SubGHz_Phy_Per/readme.txt
  * @author  MCD Application Team
  * @brief   This application is a simple demo application software between 2
  *          LoRa Objects: a STM32WL Nucleo board and whatever other LoRa Radio
  *          board embedding SubGHz_Phy_Per application too
  ******************************************************************************
  * @attention
  *
  * <h2><center>&copy; Copyright (c) 2020 STMicroelectronics.
  * All rights reserved.</center></h2>
  *
  * This software component is licensed by ST under Ultimate Liberty license
  * SLA0044, the "License"; You may not use this file except in compliance with
  * the License. You may obtain a copy of the License at:
  *                             www.st.com/SLA0044
  *
  ******************************************************************************
  @endverbatim

@par Description

This directory contains a set of source files that implements a PER (Packet Error Rate) tests application
with IBM whitening between one Tx device and one Rx device.

Tx device:
   - in /SubGHz_Phy/App/subghz_phy_app.c update #define TEST_MODE to RADIO_TX, compile and load
   - packet content is : preamble | sync | payload length | payload | crc
     + crc calculated using payload length and payload
     + whitening is calculated over payload length | payload | crc
   - the transmission starts forever in GFSK 50kbit/s with a payload of 64 bytes
   - user button 1 increments "packet length" by 16 bytes
   - user button 2 increments "packet length" by 1 bytes
   - user button 3 toggles packet "payload mode" from ramp (0x00, 0x01..) to prbs9
   - LED blue on while radio in Tx
Rx device:
   - in /SubGHz_Phy/App/subghz_phy_app.c update #define TEST_MODE to RADIO_RX, compile and load
   - LED green on when Rx OK, LED red when Rx KO

  ******************************************************************************

@par Keywords

Applications, SubGHz_Phy, PER, SingleCore

@par Directory contents


  - SubGHz_Phy_Per/Core/Inc/dma.h                                               This file contains all the function prototypes for
                                                                                the dma.c file
  - SubGHz_Phy_Per/Core/Inc/main.h                                              : Header for main.c file.
                                                                                This file contains the common defines of the application.
  - SubGHz_Phy_Per/Core/Inc/platform.h                                          Header for General HW instances configuration
  - SubGHz_Phy_Per/Core/Inc/rtc.h                                               This file contains all the function prototypes for
                                                                                the rtc.c file
  - SubGHz_Phy_Per/Core/Inc/stm32wlxx_hal_conf.h                                HAL configuration file.
  - SubGHz_Phy_Per/Core/Inc/stm32wlxx_it.h                                      This file contains the headers of the interrupt handlers.
  - SubGHz_Phy_Per/Core/Inc/stm32wlxx_nucleo_conf.h                             STM32WLxx_Nucleo board configuration file.
  - SubGHz_Phy_Per/Core/Inc/stm32_lpm_if.h                                      Header for Low Power Manager interface configuration
  - SubGHz_Phy_Per/Core/Inc/subghz.h                                            This file contains all the function prototypes for
                                                                                the subghz.c file
  - SubGHz_Phy_Per/Core/Inc/sys_app.h                                           Function prototypes for sys_app.c file
  - SubGHz_Phy_Per/Core/Inc/sys_conf.h                                          Applicative configuration, e.g. : debug, trace, low power, sensors
  - SubGHz_Phy_Per/Core/Inc/sys_debug.h                                         Configuration of the debug.c instances
  - SubGHz_Phy_Per/Core/Inc/timer_if.h                                          configuration of the timer_if.c instances
  - SubGHz_Phy_Per/Core/Inc/usart.h                                             This file contains all the function prototypes for
                                                                                the usart.c file
  - SubGHz_Phy_Per/Core/Inc/usart_if.h                                          Header for USART interface configuration
  - SubGHz_Phy_Per/Core/Inc/utilities_conf.h                                    Header for configuration file to utilities
  - SubGHz_Phy_Per/Core/Inc/utilities_def.h                                     Definitions for modules requiring utilities
  - SubGHz_Phy_Per/SubGHz_Phy/App/app_subghz_phy.h                              Header of application of the SubGHz_Phy Middleware
  - SubGHz_Phy_Per/SubGHz_Phy/App/app_version.h                                 Definition the version of the application
  - SubGHz_Phy_Per/SubGHz_Phy/App/subghz_phy_app.h                              Header of application of the SubGHz_Phy Middleware
  - SubGHz_Phy_Per/SubGHz_Phy/Target/mw_log_conf.h                              Configure (enable/disable) traces for CM0
  - SubGHz_Phy_Per/SubGHz_Phy/Target/radio_board_if.h                           Header for Radio interface configuration
  - SubGHz_Phy_Per/SubGHz_Phy/Target/radio_conf.h                               Header of Radio configuration
  - SubGHz_Phy_Per/SubGHz_Phy/Target/timer.h                                    Wrapper to timer server

  - SubGHz_Phy_Per/Core/Src/dma.c                                               This file provides code for the configuration
                                                                                of all the requested memory to memory DMA transfers.
  - SubGHz_Phy_Per/Core/Src/main.c                                              : Main program body
  - SubGHz_Phy_Per/Core/Src/rtc.c                                               This file provides code for the configuration
                                                                                of the RTC instances.
  - SubGHz_Phy_Per/Core/Src/stm32wlxx_hal_msp.c                                 This file provides code for the MSP Initialization
                                                                                and de-Initialization codes.
  - SubGHz_Phy_Per/Core/Src/stm32wlxx_it.c                                      Interrupt Service Routines.
  - SubGHz_Phy_Per/Core/Src/stm32_lpm_if.c                                      Low layer function to enter/exit low power modes (stop, sleep)
  - SubGHz_Phy_Per/Core/Src/subghz.c                                            This file provides code for the configuration
                                                                                of the SUBGHZ instances.
  - SubGHz_Phy_Per/Core/Src/system_stm32wlxx.c                                  CMSIS Cortex Device Peripheral Access Layer System Source File
  - SubGHz_Phy_Per/Core/Src/sys_app.c                                           Initializes HW and SW system entities (not related to the radio)
  - SubGHz_Phy_Per/Core/Src/sys_debug.c                                         Enables 4 debug pins for internal signals RealTime debugging
  - SubGHz_Phy_Per/Core/Src/timer_if.c                                          Configure RTC Alarm, Tick and Calendar manager
  - SubGHz_Phy_Per/Core/Src/usart.c                                             This file provides code for the configuration
                                                                                of the USART instances.
  - SubGHz_Phy_Per/Core/Src/usart_if.c                                          Configuration of UART driver interface for hyperterminal communication
  - SubGHz_Phy_Per/STM32CubeIDE/Application/User/Core/syscalls.c                STM32CubeIDE Minimal System calls file
  - SubGHz_Phy_Per/STM32CubeIDE/Application/User/Core/sysmem.c                  STM32CubeIDE System Memory calls file
  - SubGHz_Phy_Per/SubGHz_Phy/App/app_subghz_phy.c                              Application of the SubGHz_Phy Middleware
  - SubGHz_Phy_Per/SubGHz_Phy/App/subghz_phy_app.c                              Application of the SubGHz_Phy Middleware
  - SubGHz_Phy_Per/SubGHz_Phy/Target/radio_board_if.c                           This file provides an interface layer between MW and Radio Board


@par Hardware and Software environment

  - This example runs on the STM32WLxx Nucleo board.

  - STM32WLxx Nucleo board Set-up
    - Connect the Nucleo board to your PC with a USB cable type A to micro-B
      to ST-LINK connector.
    - Please ensure that the ST-LINK connector jumpers are fitted.

  - Configure the software via the configuration files:
    - sys_conf.h, radio_conf.h, mw_log_conf.h, main.h, etc

  -Set Up:

             --------------------------  V    V  --------------------------
             |         Tx Device      |  |    |  |         Rx Device      |
             |                        |  |    |  |                        |
   ComPort<--|                        |--|    |--|                        |-->ComPort
             |                        |          |                        |
             --------------------------          --------------------------

@par How to use it ?
In order to make the program work, you must do the following :
  - Open your preferred toolchain
  - Rebuild all files and load your image into target memory
  - Do the same for second board
  - Reset the two boards
  - Run the example on two boards
  - Open two Terminals, each connected to their respective Tx or Rx Device
  - UART Config = 115200, 8b, 1 stopbit, no parity, no flow control

@par How to debug ?
  - make sure the flag DEBUGGER_ENABLED to 1 in sys_conf.h
  - simpler to define the flag LOW_POWER_DISABLE to 1 as well
  - compile, download and attach

 * <h3><center>&copy; COPYRIGHT STMicroelectronics</center></h3>
 */