EEPROM for SX1272
Dependencies: X_NUCLEO_IKS01A1 driver_mbed_TH02 LoRaWAN-lib-v1_0_1 SX1272Lib mbed
Fork of Canada-SX1272-LoRaWAN-Bootcamp by
Diff: app/LoRaApp.cpp
- Revision:
- 0:6cc76d70e2a1
- Child:
- 2:19dd7bfcacf7
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/app/LoRaApp.cpp Thu Apr 06 21:59:50 2017 +0000 @@ -0,0 +1,404 @@ +/* + / _____) _ | | +( (____ _____ ____ _| |_ _____ ____| |__ + \____ \| ___ | (_ _) ___ |/ ___) _ \ + _____) ) ____| | | || |_| ____( (___| | | | +(______/|_____)_|_|_| \__)_____)\____)_| |_| + (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 1 Byte to TX buffer + case AppBat: + { + if( ( BuffPtr + 1 ) <= LORAWAN_APP_DATA_SIZE ) + { + BuffAddr[BuffPtr++] = BoardGetBatteryLevel( ); // Per LoRaWAN spec; 0 = Charging; 1...254 = level, 255 = N/A + } + break; + } + + // Appends incremental values of 1 Byte each to TX buffer until Full + case AppRamp: + { + int32_t i, j; + + // Populate Tx Buffer with increasing byte values starting from 0x00, 0x01, 0x02 ... + for( i = BuffPtr, j = 0; i < LORAWAN_APP_DATA_SIZE; i++ ) + { + BuffAddr[i] = j++; + } + BuffPtr = LORAWAN_APP_DATA_SIZE; + break; + } + + // Appends 2 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; + } + + default: + { + break; + } + } +} + +/* +static void OnRedLedTimerEvent( void ) +{ + TimerStop( &RedLedTimer.LedTimer ); + + if( RedLed == LED_OFF ) + { + RedLed = LED_ON; + } + else + { + RedLed = LED_OFF; + } +} + +static void OnYellowLedTimerEvent( void ) +{ + TimerStop( &YellowLedTimer.LedTimer ); + + if( YellowLed == LED_OFF ) + { + YellowLed = LED_ON; + } + else + { + YellowLed = LED_OFF; + } +} + +static void OnGreenLedTimerEvent( void ) +{ + TimerStop( &GreenLedTimer.LedTimer ); + + if( GreenLed == LED_OFF ) + { + GreenLed = LED_ON; + } + else + { + GreenLed = LED_OFF; + } +} + +TimerLed::TimerLed( eLedType led ) +{ + switch( led ) + { + case Red: + { + TimerInit( &LedTimer, OnRedLedTimerEvent ); + break; + } + + case Yellow: + { + TimerInit( &LedTimer, OnYellowLedTimerEvent ); + break; + } + + case Green: + { + TimerInit( &LedTimer, OnGreenLedTimerEvent ); + break; + } + } + +} + +TimerLed::~TimerLed( ) +{ +} + +void BlinkLED( eLedType led, uint32_t time ) +{ + switch( led ) + { + case Red: + { + TimerSetValue( &RedLedTimer.LedTimer, time ); + TimerStart( &RedLedTimer.LedTimer ); + RedLed = LED_ON; + break; + } + + case Yellow: + { + TimerSetValue( &YellowLedTimer.LedTimer, time ); + TimerStart( &YellowLedTimer.LedTimer ); + YellowLed = LED_ON; + break; + } + + case Green: + { + TimerSetValue( &GreenLedTimer.LedTimer, time ); + TimerStart( &GreenLedTimer.LedTimer ); + GreenLed = LED_ON; + break; + } + } +} + +void ToggleLED( eLedType led ) +{ + switch( led ) + { + case Red: + { + if( RedLed == LED_OFF ) + { + RedLed = LED_ON; + } + else + { + RedLed = LED_OFF; + } + break; + } + + case Yellow: + { + if( YellowLed == LED_OFF ) + { + YellowLed = LED_ON; + } + else + { + YellowLed = LED_OFF; + } + break; + } + + case Green: + { + if( GreenLed == LED_OFF ) + { + GreenLed = LED_ON; + } + else + { + GreenLed = LED_OFF; + } + break; + } + } +} + +void CtrlLED( eLedType led, uint8_t state ) +{ + switch( led ) + { + case Red: + { + RedLed = state; + break; + } + + case Yellow: + { + YellowLed = state; + break; + } + + case Green: + { + GreenLed = state; + break; + } + + case Usr: + { + if( state ) + { + UsrLed = LED_ON; + } + else + { + UsrLed = LED_OFF; + } + break; + } + } +} +*/ +void CheckOrientation( void ) +{ + /* + uint8_t statusReg; + + // Read the PS_STATUS register + statusReg = Mma8451q.read_single( MMA8451_PL_STATUS ); + + // If Orientation of the Mote changed then populate Upper Nibble of 0th Byte of Tx Buffer + if( ( statusReg & 0x40 ) != 0 ) + { + CtrlLED( Green, LED_OFF ); + VerticalStatus = false; // horizontal + } + else + { + CtrlLED( Green, LED_ON ); + VerticalStatus = true; // vertical + } + */ +} \ No newline at end of file