/**************************************************************************** * 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_sendstats.h" #include #include #include #include uint32_t AQH_MsgSendStats_GetTimestamp(const AQH_MSG *msg) { if ((AQH_Msg_GetMsgType(msg)==AQH_MSG_TYPE_COMSENDSTATS) && (AQH_Msg_GetBytesInBuffer(msg)>=AQH_MSG_SENDSTATS_MINSIZE)) { const uint8_t *ptr; ptr=AQH_Msg_GetConstBuffer(msg)+AQH_MSG_OFFS_ALL_DATA_BEGIN+AQH_MSG_OFFS_SENDSTATS_TIMESTAMP; return (uint32_t)(ptr[0])+(ptr[1]<<8)+(ptr[2]<<16)+(ptr[3]<<24); } return 0; } uint16_t AQH_MsgSendStats_GetPacketsOut(const AQH_MSG *msg) { if ((AQH_Msg_GetMsgType(msg)==AQH_MSG_TYPE_COMSENDSTATS) && (AQH_Msg_GetBytesInBuffer(msg)>=AQH_MSG_SENDSTATS_MINSIZE)) { const uint8_t *ptr; ptr=AQH_Msg_GetConstBuffer(msg)+AQH_MSG_OFFS_ALL_DATA_BEGIN+AQH_MSG_OFFS_SENDSTATS_PACKETSOUT; return (uint16_t)(ptr[0])+(ptr[1]<<8); } return 0; } uint16_t AQH_MsgSendStats_GetCollisions(const AQH_MSG *msg) { if ((AQH_Msg_GetMsgType(msg)==AQH_MSG_TYPE_COMSENDSTATS) && (AQH_Msg_GetBytesInBuffer(msg)>=AQH_MSG_SENDSTATS_MINSIZE)) { const uint8_t *ptr; ptr=AQH_Msg_GetConstBuffer(msg)+AQH_MSG_OFFS_ALL_DATA_BEGIN+AQH_MSG_OFFS_SENDSTATS_COLLISIONS; return (uint16_t)(ptr[0])+(ptr[1]<<8); } return 0; } uint16_t AQH_MsgSendStats_GetAborted(const AQH_MSG *msg) { if ((AQH_Msg_GetMsgType(msg)==AQH_MSG_TYPE_COMSENDSTATS) && (AQH_Msg_GetBytesInBuffer(msg)>=AQH_MSG_SENDSTATS_MINSIZE)) { const uint8_t *ptr; ptr=AQH_Msg_GetConstBuffer(msg)+AQH_MSG_OFFS_ALL_DATA_BEGIN+AQH_MSG_OFFS_SENDSTATS_ABORTED; return (uint16_t)(ptr[0])+(ptr[1]<<8); } return 0; } void AQH_MsgSendStats_DumpToBuffer(const AQH_MSG *msg, GWEN_BUFFER *dbuf, const char *sText) { if ((AQH_Msg_GetMsgType(msg)==AQH_MSG_TYPE_COMSENDSTATS) && (AQH_Msg_GetBytesInBuffer(msg)>=AQH_MSG_SENDSTATS_MINSIZE)) { GWEN_Buffer_AppendArgs(dbuf, "0x%02x->0x%02x: SENDSTATS %s (timestamp=0x%08x, out=%d, collisions=%d, aborted=%d)\n", AQH_Msg_GetSourceAddress(msg), AQH_Msg_GetDestAddress(msg), sText, (unsigned int) AQH_MsgSendStats_GetTimestamp(msg), AQH_MsgSendStats_GetPacketsOut(msg), AQH_MsgSendStats_GetCollisions(msg), AQH_MsgSendStats_GetAborted(msg)); } }