/**************************************************************************** * This file is part of the project AqHome. * AqHome (c) by 2023 Martin Preuss, all rights reserved. * * The license for this file can be found in the file COPYING which you * should have received along with this file. ****************************************************************************/ #ifdef HAVE_CONFIG_H # include #endif #include "aqhome/msg/msg_sendstats.h" #include #include #include #include #define AQH_MSG_OFFS_SENDSTATS_UID 0 /* 4 bytes */ #define AQH_MSG_OFFS_SENDSTATS_PACKETSOUT 4 /* 2 bytes */ #define AQH_MSG_OFFS_SENDSTATS_COLLISIONS 6 /* 2 bytes */ #define AQH_MSG_OFFS_SENDSTATS_BUSY 8 /* 2 bytes */ #define AQH_MSG_SENDSTATS_MINSIZE (AQH_MSG_OFFS_ALL_DATA_BEGIN+AQH_MSG_OFFS_SENDSTATS_BUSY+2) uint32_t AQH_SendStatsMsg_GetUid(const GWEN_MSG *msg) { return GWEN_Msg_GetUint32At(msg, AQH_MSG_OFFS_ALL_DATA_BEGIN+AQH_MSG_OFFS_SENDSTATS_UID, 0); } uint16_t AQH_SendStatsMsg_GetPacketsOut(const GWEN_MSG *msg) { return GWEN_Msg_GetUint16At(msg, AQH_MSG_OFFS_ALL_DATA_BEGIN+AQH_MSG_OFFS_SENDSTATS_PACKETSOUT, 0); } uint16_t AQH_SendStatsMsg_GetCollisions(const GWEN_MSG *msg) { return GWEN_Msg_GetUint16At(msg, AQH_MSG_OFFS_ALL_DATA_BEGIN+AQH_MSG_OFFS_SENDSTATS_COLLISIONS, 0); } uint16_t AQH_SendStatsMsg_GetBusyErrors(const GWEN_MSG *msg) { return GWEN_Msg_GetUint16At(msg, AQH_MSG_OFFS_ALL_DATA_BEGIN+AQH_MSG_OFFS_SENDSTATS_BUSY, 0); } void AQH_SendStatsMsg_DumpToBuffer(const GWEN_MSG *msg, GWEN_BUFFER *dbuf, const char *sText) { if ((AQH_NodeMsg_GetMsgType(msg)==AQH_MSG_TYPE_COMSENDSTATS) && (GWEN_Msg_GetBytesInBuffer(msg)>=AQH_MSG_SENDSTATS_MINSIZE)) { GWEN_Buffer_AppendArgs(dbuf, "0x%02x->0x%02x: SENDSTATS %s (uid=0x%08x, out=%d, collisions=%d, busy line=%d)\n", AQH_NodeMsg_GetSourceAddress(msg), AQH_NodeMsg_GetDestAddress(msg), sText, (unsigned int) AQH_SendStatsMsg_GetUid(msg), AQH_SendStatsMsg_GetPacketsOut(msg), AQH_SendStatsMsg_GetCollisions(msg), AQH_SendStatsMsg_GetBusyErrors(msg)); } }