Skip to content

Commit

Permalink
radiolink: add log variables for statistics
Browse files Browse the repository at this point in the history
* radio.numRxBc counts the number of broadcasts received
* radio.numRxUc counts the number of unicasts received
  • Loading branch information
whoenig committed Jan 19, 2024
1 parent 101de77 commit 0bacd86
Showing 1 changed file with 29 additions and 1 deletion.
30 changes: 29 additions & 1 deletion src/hal/src/radiolink.c
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,8 @@ static int radiolinkReceiveCRTPPacket(CRTPPacket *p);
static uint8_t rssi;
static bool isConnected;
static uint32_t lastPacketTick;
static uint16_t count_rx_broadcast;
static uint16_t count_rx_unicast;

static volatile P2PCallback p2p_callback;

Expand Down Expand Up @@ -162,6 +164,7 @@ void radiolinkSyslinkDispatch(SyslinkPacket *slp)
slp->length--; // Decrease to get CRTP size.
// Assert that we are not dropping any packets
ASSERT(xQueueSend(crtpPacketDelivery, &slp->length, 0) == pdPASS);
++count_rx_unicast;
ledseqRun(&seq_linkUp);
// If a radio packet is received, one can be sent
if (xQueueReceive(txQueue, &txPacket, 0) == pdTRUE)
Expand All @@ -173,7 +176,11 @@ void radiolinkSyslinkDispatch(SyslinkPacket *slp)
{
slp->length--; // Decrease to get CRTP size.
// broadcasts are best effort, so no need to handle the case where the queue is full
xQueueSend(crtpPacketDelivery, &slp->length, 0);
BaseType_t result = xQueueSend(crtpPacketDelivery, &slp->length, 0);
// only increment the received counter, if we were able to put it in the queue
if (result == pdPASS) {
++count_rx_broadcast;
}
ledseqRun(&seq_linkUp);
// no ack for broadcasts
} else if (slp->type == SYSLINK_RADIO_RSSI)
Expand Down Expand Up @@ -259,7 +266,28 @@ static int radiolinkSetEnable(bool enable)
return 0;
}

/**
* Radio link log variables.
*/
LOG_GROUP_START(radio)
/**
* @brief Radio Signal Strength Indicator [dBm]
*/
LOG_ADD_CORE(LOG_UINT8, rssi, &rssi)
/**
* @brief Indicator if a packet was received from the radio within the last RADIO_ACTIVITY_TIMEOUT_MS.
*/
LOG_ADD_CORE(LOG_UINT8, isConnected, &isConnected)
/**
* @brief Number of broadcast packets received.
*
* Note that this is only 16 bits and overflows. Use overflow correction on the client side.
*/
LOG_ADD_CORE(LOG_UINT16, numRxBc, &count_rx_broadcast)
/**
* @brief Number of unicast packets received.
*
* Note that this is only 16 bits and overflows. Use overflow correction on the client side.
*/
LOG_ADD_CORE(LOG_UINT16, numRxUc, &count_rx_unicast)
LOG_GROUP_STOP(radio)

0 comments on commit 0bacd86

Please sign in to comment.