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
app/SerialDisplay.cpp@0:6cc76d70e2a1, 2017-04-06 (annotated)
- 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?
User | Revision | Line number | New 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 | } |