* PUSH_CODE_LOG_RX_DATA: is now just: {snr*4},{rssi},{raw-lora-packet}
This commit is contained in:
@@ -436,19 +436,13 @@ protected:
|
|||||||
return (int) ((pow(_prefs.rx_delay_base, 0.85f - score) - 1.0) * air_time);
|
return (int) ((pow(_prefs.rx_delay_base, 0.85f - score) - 1.0) * air_time);
|
||||||
}
|
}
|
||||||
|
|
||||||
void logRx(mesh::Packet* pkt, int len, float score) override {
|
void logRxRaw(float snr, float rssi, const uint8_t raw[], int len) override {
|
||||||
if (_serial->isConnected()) {
|
if (_serial->isConnected()) {
|
||||||
int i = 0;
|
int i = 0;
|
||||||
out_frame[i++] = PUSH_CODE_LOG_RX_DATA;
|
out_frame[i++] = PUSH_CODE_LOG_RX_DATA;
|
||||||
out_frame[i++] = (int8_t)(_radio->getLastSNR() * 4);
|
out_frame[i++] = (int8_t)(snr * 4);
|
||||||
out_frame[i++] = (int8_t)(_radio->getLastRSSI());
|
out_frame[i++] = (int8_t)(rssi);
|
||||||
if (pkt->isRouteFlood()) {
|
memcpy(&out_frame[i], raw, len); i += len;
|
||||||
out_frame[i++] = pkt->path_len;
|
|
||||||
memcpy(&out_frame[i], pkt->path, pkt->path_len); i += pkt->path_len;
|
|
||||||
} else {
|
|
||||||
out_frame[i++] = 0xFF;
|
|
||||||
}
|
|
||||||
memcpy(&out_frame[i], pkt->payload, pkt->payload_len); i += pkt->payload_len;
|
|
||||||
|
|
||||||
_serial->writeFrame(out_frame, i);
|
_serial->writeFrame(out_frame, i);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -78,9 +78,11 @@ void Dispatcher::checkRecv() {
|
|||||||
float score;
|
float score;
|
||||||
uint32_t air_time;
|
uint32_t air_time;
|
||||||
{
|
{
|
||||||
uint8_t raw[MAX_TRANS_UNIT];
|
uint8_t raw[MAX_TRANS_UNIT+1];
|
||||||
int len = _radio->recvRaw(raw, MAX_TRANS_UNIT);
|
int len = _radio->recvRaw(raw, MAX_TRANS_UNIT);
|
||||||
if (len > 0) {
|
if (len > 0) {
|
||||||
|
logRxRaw(_radio->getLastSNR(), _radio->getLastRSSI(), raw, len);
|
||||||
|
|
||||||
pkt = _mgr->allocNew();
|
pkt = _mgr->allocNew();
|
||||||
if (pkt == NULL) {
|
if (pkt == NULL) {
|
||||||
MESH_DEBUG_PRINTLN("%s Dispatcher::checkRecv(): WARNING: received data, no unused packets available!", getLogDateTime());
|
MESH_DEBUG_PRINTLN("%s Dispatcher::checkRecv(): WARNING: received data, no unused packets available!", getLogDateTime());
|
||||||
|
|||||||
@@ -117,6 +117,8 @@ protected:
|
|||||||
|
|
||||||
virtual DispatcherAction onRecvPacket(Packet* pkt) = 0;
|
virtual DispatcherAction onRecvPacket(Packet* pkt) = 0;
|
||||||
|
|
||||||
|
virtual void logRxRaw(float snr, float rssi, const uint8_t raw[], int len) { } // custom hook
|
||||||
|
|
||||||
virtual void logRx(Packet* packet, int len, float score) { } // hooks for custom logging
|
virtual void logRx(Packet* packet, int len, float score) { } // hooks for custom logging
|
||||||
virtual void logTx(Packet* packet, int len) { }
|
virtual void logTx(Packet* packet, int len) { }
|
||||||
virtual void logTxFail(Packet* packet, int len) { }
|
virtual void logTxFail(Packet* packet, int len) { }
|
||||||
|
|||||||
Reference in New Issue
Block a user