1
0
Fork 0
mirror of https://git.rwth-aachen.de/acs/public/villas/node/ synced 2025-03-23 00:00:01 +01:00
VILLASnode/include/villas/formats/msg_format.hpp

90 lines
3.1 KiB
C++
Raw Normal View History

/** Message format
*
* @file
2015-06-02 21:53:04 +02:00
* @author Steffen Vogel <stvogel@eonerc.rwth-aachen.de>
* @copyright 2014-2021, Institute for Automation of Complex Power Systems, EONERC
2017-04-27 12:56:43 +02:00
* @license GNU General Public License (version 3)
*
* VILLASnode
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* any later version.
*
2017-04-27 12:56:43 +02:00
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
2017-04-27 12:56:43 +02:00
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
2015-06-02 21:53:04 +02:00
*********************************************************************************/
2017-02-16 09:04:12 -03:00
#pragma once
#include <cstdint>
/** The current version number for the message format */
2018-06-29 08:37:14 +02:00
#define MSG_VERSION 2
/** @todo Implement more message types */
2018-06-29 08:37:14 +02:00
#define MSG_TYPE_DATA 0 /**< Message contains float / integer values */
#define MSG_TYPE_START 1 /**< Message marks the beginning of a new simulation case */
#define MSG_TYPE_STOP 2 /**< Message marks the end of a simulation case */
2015-10-09 13:04:52 +02:00
/** The total size in bytes of a message */
#define MSG_LEN(values) (sizeof(struct Message) + MSG_DATA_LEN(values))
2016-06-08 22:38:21 +02:00
/** The length of \p values values in bytes. */
2018-06-29 08:37:14 +02:00
#define MSG_DATA_LEN(values) (sizeof(float) * (values))
2016-06-08 22:38:21 +02:00
/** The offset to the first data value in a message. */
#define MSG_DATA_OFFSET(msg) ((char *) (msg) + offsetof(struct Message, data))
2016-06-08 22:38:21 +02:00
2015-10-09 13:04:52 +02:00
/** The timestamp of a message in struct timespec format */
2019-05-08 15:44:19 +02:00
#define MSG_TS(msg, i) \
i.tv_sec = (msg)->ts.sec; \
i.tv_nsec = (msg)->ts.nsec;
namespace villas {
namespace node {
/** This message format is used by all clients
*
* @diafile msg_format.dia
**/
struct Message
2018-06-29 08:37:14 +02:00
{
2017-06-29 20:43:03 +02:00
#if BYTE_ORDER == BIG_ENDIAN
2018-06-29 08:37:14 +02:00
unsigned version: 4; /**< Specifies the format of the remaining message (see MGS_VERSION) */
unsigned type : 2; /**< Data or control message (see MSG_TYPE_*) */
2019-09-03 22:06:23 +02:00
unsigned reserved1 : 2; /**< Reserved bits */
2017-06-29 20:43:03 +02:00
#elif BYTE_ORDER == LITTLE_ENDIAN
2019-09-03 22:06:23 +02:00
unsigned reserved1 : 2; /**< Reserved bits */
2018-06-29 08:37:14 +02:00
unsigned type : 2; /**< Data or control message (see MSG_TYPE_*) */
unsigned version: 4; /**< Specifies the format of the remaining message (see MGS_VERSION) */
#else
#error Invalid byte-order
2017-06-26 07:10:42 +00:00
#endif
uint8_t source_index; /**< An id which identifies the source of this sample. */
2018-06-29 08:37:14 +02:00
uint16_t length; /**< The number of values in msg::data[]. */
uint32_t sequence; /**< The sequence number is incremented by one for consecutive messages. */
/** A timestamp per message. */
2015-06-02 22:36:17 +02:00
struct {
2018-06-29 08:37:14 +02:00
uint32_t sec; /**< Seconds since 1970-01-01 00:00:00 */
uint32_t nsec; /**< Nanoseconds of the current second. */
2015-06-02 22:36:17 +02:00
} ts;
/** The message payload. */
union {
2018-06-29 08:37:14 +02:00
float f; /**< Floating point values. */
uint32_t i; /**< Integer values. */
} data[];
2017-06-26 07:10:42 +00:00
} __attribute__((packed));
} /* namespace node */
} /* namespace villas */