code crashes accessing randomization code

Dependencies:   LoRaWAN-SX1272-Application-24-31-9sec X_NUCLEO_IKS01A1 driver_mbed_TH02 LoRaWAN-lib-v1_0_1 SX1272Lib mbed

Fork of LoRaWAN-SX1272-Application-24-31-9sec by Oleh Zvonarov

Committer:
ubhat
Date:
Thu Apr 06 21:59:50 2017 +0000
Revision:
0:6cc76d70e2a1
Child:
2:19dd7bfcacf7
LoRaWAN SX1272 Application

Who changed what in which revision?

UserRevisionLine numberNew contents of line
ubhat 0:6cc76d70e2a1 1 /*
ubhat 0:6cc76d70e2a1 2 / _____) _ | |
ubhat 0:6cc76d70e2a1 3 ( (____ _____ ____ _| |_ _____ ____| |__
ubhat 0:6cc76d70e2a1 4 \____ \| ___ | (_ _) ___ |/ ___) _ \
ubhat 0:6cc76d70e2a1 5 _____) ) ____| | | || |_| ____( (___| | | |
ubhat 0:6cc76d70e2a1 6 (______/|_____)_|_|_| \__)_____)\____)_| |_|
ubhat 0:6cc76d70e2a1 7 (C)2015 Semtech
ubhat 0:6cc76d70e2a1 8
ubhat 0:6cc76d70e2a1 9 Description: VT100 serial display management
ubhat 0:6cc76d70e2a1 10
ubhat 0:6cc76d70e2a1 11 License: Revised BSD License, see LICENSE.TXT file include in the project
ubhat 0:6cc76d70e2a1 12
ubhat 0:6cc76d70e2a1 13 Maintainer: Miguel Luis and Gregory Cristian
ubhat 0:6cc76d70e2a1 14 */
ubhat 0:6cc76d70e2a1 15
ubhat 0:6cc76d70e2a1 16 #include "SerialDisplay.h"
ubhat 0:6cc76d70e2a1 17
ubhat 0:6cc76d70e2a1 18 VT100 vt( USBTX, USBRX );
ubhat 0:6cc76d70e2a1 19
ubhat 0:6cc76d70e2a1 20 void SerialDisplayJoinUpdate( void )
ubhat 0:6cc76d70e2a1 21 {
ubhat 0:6cc76d70e2a1 22 printf( "###### ===== JOINING ==== ######\r\n" );
ubhat 0:6cc76d70e2a1 23
ubhat 0:6cc76d70e2a1 24 DisplayNetworkParam( );
ubhat 0:6cc76d70e2a1 25
ubhat 0:6cc76d70e2a1 26 printf( "\r\n" );
ubhat 0:6cc76d70e2a1 27 }
ubhat 0:6cc76d70e2a1 28
ubhat 0:6cc76d70e2a1 29 void SerialDisplayTxUpdate(void)
ubhat 0:6cc76d70e2a1 30 {
ubhat 0:6cc76d70e2a1 31 printf( "###### ===== UPLINK FRAME %d ==== ######\r\n", LoRaMacUplinkStatus.UplinkCounter );
ubhat 0:6cc76d70e2a1 32
ubhat 0:6cc76d70e2a1 33 DisplayNetworkParam( );
ubhat 0:6cc76d70e2a1 34
ubhat 0:6cc76d70e2a1 35 printf( "TX PORT: %d\r\n", LoRaMacUplinkStatus.Port );
ubhat 0:6cc76d70e2a1 36
ubhat 0:6cc76d70e2a1 37 if( LoRaMacUplinkStatus.BufferSize != 0 )
ubhat 0:6cc76d70e2a1 38 {
ubhat 0:6cc76d70e2a1 39 printf( "TX DATA: " );
ubhat 0:6cc76d70e2a1 40 if( LoRaMacUplinkStatus.Type == MCPS_CONFIRMED )
ubhat 0:6cc76d70e2a1 41 {
ubhat 0:6cc76d70e2a1 42 printf( "CONFIRMED\r\n" );
ubhat 0:6cc76d70e2a1 43 }
ubhat 0:6cc76d70e2a1 44 else
ubhat 0:6cc76d70e2a1 45 {
ubhat 0:6cc76d70e2a1 46 printf( "UNCONFIRMED\r\n" );
ubhat 0:6cc76d70e2a1 47 }
ubhat 0:6cc76d70e2a1 48 SerialDisplayHex( LoRaMacUplinkStatus.Buffer, LoRaMacUplinkStatus.BufferSize );
ubhat 0:6cc76d70e2a1 49 }
ubhat 0:6cc76d70e2a1 50
ubhat 0:6cc76d70e2a1 51 printf( "DATA RATE: DR%d\r\n", LoRaMacUplinkStatus.Datarate );
ubhat 0:6cc76d70e2a1 52
ubhat 0:6cc76d70e2a1 53 printf( "TX POWER: %d dBm\r\n", 30 - ( LoRaMacUplinkStatus.TxPower << 1 ) );
ubhat 0:6cc76d70e2a1 54
ubhat 0:6cc76d70e2a1 55 printf( "BATTERY: %2.2fV\r\n", BoardGetBatteryLevel( ) );
ubhat 0:6cc76d70e2a1 56
ubhat 0:6cc76d70e2a1 57 printf( "\r\n");
ubhat 0:6cc76d70e2a1 58 }
ubhat 0:6cc76d70e2a1 59
ubhat 0:6cc76d70e2a1 60 void SerialDisplayRxUpdate( void )
ubhat 0:6cc76d70e2a1 61 {
ubhat 0:6cc76d70e2a1 62 printf( "###### ===== DOWNLINK FRAME %d ==== ######\r\n", LoRaMacDownlinkStatus.DownlinkCounter );
ubhat 0:6cc76d70e2a1 63
ubhat 0:6cc76d70e2a1 64 printf( "RX WINDOW: %d\r\n", LoRaMacDownlinkStatus.RxSlot + 1 );
ubhat 0:6cc76d70e2a1 65
ubhat 0:6cc76d70e2a1 66 printf( "RX PORT: %d\r\n", LoRaMacDownlinkStatus.Port );
ubhat 0:6cc76d70e2a1 67
ubhat 0:6cc76d70e2a1 68 if( LoRaMacDownlinkStatus.BufferSize != 0 )
ubhat 0:6cc76d70e2a1 69 {
ubhat 0:6cc76d70e2a1 70 printf( "RX DATA: \r\n" );
ubhat 0:6cc76d70e2a1 71 SerialDisplayHex( LoRaMacDownlinkStatus.Buffer, LoRaMacDownlinkStatus.BufferSize );
ubhat 0:6cc76d70e2a1 72 }
ubhat 0:6cc76d70e2a1 73
ubhat 0:6cc76d70e2a1 74 printf( "RX RSSI: %d\r\n", LoRaMacDownlinkStatus.Rssi );
ubhat 0:6cc76d70e2a1 75
ubhat 0:6cc76d70e2a1 76 printf( "RX SNR: %d\r\n", LoRaMacDownlinkStatus.Snr );
ubhat 0:6cc76d70e2a1 77
ubhat 0:6cc76d70e2a1 78 printf( "\r\n" );
ubhat 0:6cc76d70e2a1 79 }
ubhat 0:6cc76d70e2a1 80
ubhat 0:6cc76d70e2a1 81 void SerialDisplayHex( uint8_t *pData, uint8_t len )
ubhat 0:6cc76d70e2a1 82 {
ubhat 0:6cc76d70e2a1 83 int i;
ubhat 0:6cc76d70e2a1 84 bool newline = 0;
ubhat 0:6cc76d70e2a1 85
ubhat 0:6cc76d70e2a1 86 for( i = 0; i < len; i++ )
ubhat 0:6cc76d70e2a1 87 {
ubhat 0:6cc76d70e2a1 88 if( newline != 0 )
ubhat 0:6cc76d70e2a1 89 {
ubhat 0:6cc76d70e2a1 90 printf( "\r\n" );
ubhat 0:6cc76d70e2a1 91 newline = 0;
ubhat 0:6cc76d70e2a1 92 }
ubhat 0:6cc76d70e2a1 93
ubhat 0:6cc76d70e2a1 94 printf( "%02X ", pData[i] );
ubhat 0:6cc76d70e2a1 95
ubhat 0:6cc76d70e2a1 96 if( ( ( i + 1 ) % 16 ) == 0 )
ubhat 0:6cc76d70e2a1 97 {
ubhat 0:6cc76d70e2a1 98 newline = 1;
ubhat 0:6cc76d70e2a1 99 }
ubhat 0:6cc76d70e2a1 100 }
ubhat 0:6cc76d70e2a1 101 printf( "\r\n" );
ubhat 0:6cc76d70e2a1 102 }
ubhat 0:6cc76d70e2a1 103
ubhat 0:6cc76d70e2a1 104 void SerialAcclMetrDisplay( uint8_t statusReg )
ubhat 0:6cc76d70e2a1 105 {
ubhat 0:6cc76d70e2a1 106 printf( "===== DEVICE ORIENTATION ====\r\n" );
ubhat 0:6cc76d70e2a1 107 if( ( statusReg & 0x40 ) != 0 )
ubhat 0:6cc76d70e2a1 108 {
ubhat 0:6cc76d70e2a1 109 printf( "HORIZONTAL + " );
ubhat 0:6cc76d70e2a1 110 if( ( statusReg & 0x01 ) != 0 )
ubhat 0:6cc76d70e2a1 111 {
ubhat 0:6cc76d70e2a1 112 printf( "FACE DOWN" );
ubhat 0:6cc76d70e2a1 113 }
ubhat 0:6cc76d70e2a1 114 else
ubhat 0:6cc76d70e2a1 115 {
ubhat 0:6cc76d70e2a1 116 printf( "FACE UP" );
ubhat 0:6cc76d70e2a1 117 }
ubhat 0:6cc76d70e2a1 118 }
ubhat 0:6cc76d70e2a1 119 else
ubhat 0:6cc76d70e2a1 120 {
ubhat 0:6cc76d70e2a1 121 printf( "VERTICAL" );
ubhat 0:6cc76d70e2a1 122 }
ubhat 0:6cc76d70e2a1 123 printf( "\r\n\r\n" );
ubhat 0:6cc76d70e2a1 124 }
ubhat 0:6cc76d70e2a1 125
ubhat 0:6cc76d70e2a1 126 void DisplayNetworkParam( void )
ubhat 0:6cc76d70e2a1 127 {
ubhat 0:6cc76d70e2a1 128 #if( OVER_THE_AIR_ACTIVATION != 0 )
ubhat 0:6cc76d70e2a1 129
ubhat 0:6cc76d70e2a1 130 printf( "DEVEUI: " );
ubhat 0:6cc76d70e2a1 131 SerialDisplayHex( DevEui, 8 );
ubhat 0:6cc76d70e2a1 132
ubhat 0:6cc76d70e2a1 133 printf( "APPEUI: " );
ubhat 0:6cc76d70e2a1 134 SerialDisplayHex( AppEui, 8 );
ubhat 0:6cc76d70e2a1 135
ubhat 0:6cc76d70e2a1 136 printf( "APPKEY: " );
ubhat 0:6cc76d70e2a1 137 SerialDisplayHex( AppKey, 16 );
ubhat 0:6cc76d70e2a1 138
ubhat 0:6cc76d70e2a1 139 #else
ubhat 0:6cc76d70e2a1 140
ubhat 0:6cc76d70e2a1 141 printf( "DEVADDR: " );
ubhat 0:6cc76d70e2a1 142
ubhat 0:6cc76d70e2a1 143 uint8_t *pData = ( uint8_t* )&DevAddr;
ubhat 0:6cc76d70e2a1 144 for( int32_t i = 3; i >= 0; i-- )
ubhat 0:6cc76d70e2a1 145 {
ubhat 0:6cc76d70e2a1 146 printf( "%02X ", pData[i] );
ubhat 0:6cc76d70e2a1 147 }
ubhat 0:6cc76d70e2a1 148 printf( "\r\n" );
ubhat 0:6cc76d70e2a1 149
ubhat 0:6cc76d70e2a1 150 printf( "NWKSKEY: " );
ubhat 0:6cc76d70e2a1 151 SerialDisplayHex( NwkSKey, 16 );
ubhat 0:6cc76d70e2a1 152
ubhat 0:6cc76d70e2a1 153 printf( "APPSKEY: " );
ubhat 0:6cc76d70e2a1 154 SerialDisplayHex( AppSKey, 16 );
ubhat 0:6cc76d70e2a1 155
ubhat 0:6cc76d70e2a1 156 #endif
ubhat 0:6cc76d70e2a1 157 }