add rotary
Dependencies: X_NUCLEO_IKS01A1 LoRaWAN-lib SX1272Lib mbed
Fork of Canada-SX1272-LoRaWAN-Bootcamp by
LoRaWAN-SX1272-Mbed-Shield
Overview
LoRaWAN-SX1272-Mbed-Shield application demo is a LoRaWAN Class-A device example project using LoRaWAN-lib and SX1272Lib libraries that send out sensors data.
Prerequisites
1. NUCLEO_L152RE board.
2. SX1272-mbed-shield board.
3. X-NUCLEO-IKS01A1.
4. Grove Red LED.
5. Grove Button.
6. Grove Rotary Angle Sensor.
7. mbed online compiler.
8. Tera Term.
Hardware Configuration
Application 8, 9, 11
1. Connect NUCLEO_L152RE with X-NUCLEO-IKS01A1.
2. On top of X-NUCLEO-IKS01A1, connect SX1272-mbed-shield.
Application 13
1. Connect NUCLEO_L152RE with SX1272-mbed-shield.
2. Connect Grove Red LED with DIO_D6 port on SX1272-mbed-shield.
3. Connect Grove Button with DIO_D8 port on SX1272-mbed-shield.
4. Connect Grove Rotary Angle Sensor with ANA_A1 port SX1272-mbed-shield.
Software Configuration
The end-device must be configured with the following parameters:
- Commissioning.h
- Activation Type: OTA or ABP
- OTA: #define OVER_THE_AIR_ACTIVATION 1
- Network Type: Public or Private
- Public: #define LORAWAN_PUBLIC_NETWORK true
- LORAWAN_DEVICE_EUI (8 Bytes) : Fist 3 Bytes is the Organizationally Unique Identifier (OUI) followed by 5 bytes of unique ID. If not defined by user, then the firmware automatically assigns one to the end-device. (For OTA)
- #define IEEE_OUI 0x00, 0x00, 0x00
- #define LORAWAN_DEVICE_EUI { IEEE_OUI, 0x00, 0x00, 0x00, 0x00, 0x00 }
- #define IEEE_OUI 0x00, 0x00, 0x00
- LORAWAN_APPLICATION_EUI (8 Bytes) (For OTA)
- #define LORAWAN_APPLICATION_EUI { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }
- LORAWAN_APPLICATION_KEY (16 Bytes) (For OTA)
- #define LORAWAN_APPLICATION_KEY { 0x00, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x88, 0x99, 0xaa, 0xbb, 0xcc, 0xdd, 0xee, 0xff }
- #define LORAWAN_APPLICATION_KEY { 0x00, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x88, 0x99, 0xaa, 0xbb, 0xcc, 0xdd, 0xee, 0xff }
- LORAWAN_DEVICE_ADDRESS (For ABP)
- #define LORAWAN_DEVICE_ADDRESS ( uint32_t )0x0
- LORAWAN_NWKSKEY (For ABP)
- #define LORAWAN_NWKSKEY { 0x2B, 0x7E, 0x15, 0x16, 0x28, 0xAE, 0xD2, 0xA6, 0xAB, 0xF7, 0x15, 0x88, 0x09, 0xCF, 0x4F, 0x3C }
- LORAWAN_APPSKEY (For ABP)
- #define LORAWAN_APPSKEY { 0x2B, 0x7E, 0x15, 0x16, 0x28, 0xAE, 0xD2, 0xA6, 0xAB, 0xF7, 0x15, 0x88, 0x09, 0xCF, 0x4F, 0x3C }
- Activation Type: OTA or ABP
- Configure.h
- Communication Type: Hybrid or FHSS
- Hybrid: #define USE_BAND_915_HYBRID
- Join request Period:
- 5 sec: #define OVER_THE_AIR_ACTIVATION_DUTYCYCLE 5000000 value in us
- TX Period:
- 5 sec: #define APP_TX_DUTYCYCLE 5000000 value in us
- Uplink message: Confirmed or Unconfirmed
- Confirmed: #define LORAWAN_CONFIRMED_MSG_ON 1
- ADR(Adaptive Data Rate): ON or OFF
- OFF: #define LORAWAN_ADR_ON 0
- Default data rate: DR_0 or DR_1 or DR_2 or DR_3 or DR_4
- DR_0: #define LORAWAN_DEFAULT_DATARATE DR_0
- Application Type: 8 (IKS01A1) or 9 (IKS01A1+Cayenne) or 11 (Push Button) or 13 (rotary+Cayenne)
- 9: #define LORAWAN_APP_PORT 9
- Tx Power: 10 to 30
- 20 dBm: #define LORAWAN_TX_POWER TX_POWER_20_DBM
- Communication Type: Hybrid or FHSS
Serial Terminal Display
- Use Tera Term to see the sending message (baud rate: 115200):
- button = 0 (if not press) button = 1 (if pressed)
- rotary = 0 ~ 300
- button = 0 (if not press) button = 1 (if pressed)
app/LoRaApp.cpp
- Committer:
- terence304
- Date:
- 2018-02-10
- Revision:
- 17:a822234a2299
- Parent:
- 8:b1f612e91735
File content as of revision 17:a822234a2299:
/* / _____) _ | | ( (____ _____ ____ _| |_ _____ ____| |__ \____ \| ___ | (_ _) ___ |/ ___) _ \ _____) ) ____| | | || |_| ____( (___| | | | (______/|_____)_|_|_| \__)_____)\____)_| |_| (C)2015 Semtech Description: User-defined applications such as GPS, Temp, Accelerometer, LED indications etc. Event based actions such as LED blink on Tx, LED toggle on downlink etc License: Revised BSD License, see LICENSE.TXT file include in the project Maintainer: Uttam Bhat */ #include "LoRaApp.h" #ifdef USE_IKS01A1_SENSOR float iks01a1_data; int32_t Accl_Value[3] = {0}; #endif #ifdef USE_CAYENNE_LPP /* .... Pressure .... Temperature .... Humidity .... Accelerometer */ uint8_t maxLPPsize[4] = {4, 4, 3, 8}; #endif bool VerticalStatus = false; Application::Application( uint8_t * memptr ) { BuffAddr = memptr; memset( BuffAddr, 0, LORAWAN_APP_DATA_MAX_SIZE ); BuffPtr = 0; } Application::~Application( ) { } void Application::ApplicationAppendData( uint8_t *pData, uint8_t len ) { memcpy( BuffAddr + BuffPtr, pData, len ); BuffPtr += len; } void Application::ApplicationPtrPos( uint8_t ptrPos ) { BuffPtr = ptrPos; } void Application::ApplicationCall( eAppType App ) { switch( App ) { // Appends 1 Byte to TX buffer case AppTemp: { #ifdef USE_IKS01A1_SENSOR temp_sensor2->GetTemperature(&iks01a1_data); printf("Temp = %f, %d\r\n", iks01a1_data, (int8_t) iks01a1_data); if( ( BuffPtr + 1 ) <= LORAWAN_APP_DATA_SIZE ) { #ifdef USE_CAYENNE_LPP BuffAddr[BuffPtr++] = 0; BuffAddr[BuffPtr++] = (int8_t) ( iks01a1_data * 10 ); #else BuffAddr[BuffPtr++] = (int8_t) iks01a1_data; #endif } #endif break; } // Appends 2 Bytes to TX buffer case AppPressr: { #ifdef USE_IKS01A1_SENSOR pressure_sensor->GetPressure(&iks01a1_data); printf("Pressure = %f, %d\r\n", iks01a1_data, (uint16_t) iks01a1_data); if( ( BuffPtr + 2 ) <= LORAWAN_APP_DATA_SIZE ) { #ifdef USE_CAYENNE_LPP int16_t tmp; tmp = (int16_t) ( iks01a1_data * 10 ); BuffAddr[BuffPtr++] = ( tmp >> 8 ) & 0xFF; BuffAddr[BuffPtr++] = ( tmp ) & 0xFF; #else BuffAddr[BuffPtr++] = ( (int16_t) iks01a1_data >> 8 ) & 0xFF; BuffAddr[BuffPtr++] = ( (int16_t) iks01a1_data ) & 0xFF; #endif } #endif break; } // Appends 2 Bytes to TX buffer case AppHumid: { #ifdef USE_IKS01A1_SENSOR humidity_sensor->GetHumidity(&iks01a1_data); printf("Humidity = %f, %d\r\n", iks01a1_data, (uint8_t) iks01a1_data); if( ( BuffPtr + 1 ) <= LORAWAN_APP_DATA_SIZE ) { #ifdef USE_CAYENNE_LPP BuffAddr[BuffPtr++] = (uint8_t) ( iks01a1_data * 2 ); #else BuffAddr[BuffPtr++] = (int8_t) iks01a1_data; #endif } #endif break; } // Appends 6 Bytes to TX buffer case AppAccl: { #ifdef USE_IKS01A1_SENSOR accelerometer->Get_X_Axes(Accl_Value); printf("X/Y/Z = %d/%d/%d\r\n", Accl_Value[0], Accl_Value[1], Accl_Value[2]); if( ( BuffPtr + 6 ) <= LORAWAN_APP_DATA_SIZE ) { BuffAddr[BuffPtr++] = ( (int16_t) Accl_Value[0] >> 8 ) & 0xFF; BuffAddr[BuffPtr++] = ( (int16_t) Accl_Value[0] ) & 0xFF; BuffAddr[BuffPtr++] = ( (int16_t) Accl_Value[1] >> 8 ) & 0xFF; BuffAddr[BuffPtr++] = ( (int16_t) Accl_Value[1] ) & 0xFF; BuffAddr[BuffPtr++] = ( (int16_t) Accl_Value[2] >> 8 ) & 0xFF; BuffAddr[BuffPtr++] = ( (int16_t) Accl_Value[2] ) & 0xFF; } #endif break; } case AppPushButton: { uint16_t PushButtonCnt; uint8_t *p = (uint8_t *) &PushButtonCnt; PushButtonCnt = LoRaMacUplinkStatus.UplinkCounter; memcpy( &BuffAddr[BuffPtr], p, sizeof(uint16_t) ); break; } case AppButton: { int button_val = 0; if (1 == ext_button) button_val = 1; printf("button: %d\r\n", button_val); BuffAddr[BuffPtr++] = button_val; break; } case AppRotary: { uint16_t degree = (uint16_t)(ext_rotary.read() * 300); printf("rotary angle: %d\r\n", degree); BuffAddr[BuffPtr++] = ((degree * 100) >> 8) & 0xff; BuffAddr[BuffPtr++] = (degree * 100) & 0xff; break; } default: { break; } } } void CheckOrientation( void ) { }