You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
libiec61850/src/goose/goose_publisher.h

214 lines
6.1 KiB
C

/*
* goose_publisher.h
*
* Copyright 2013-2020 Michael Zillgith
*
* This file is part of libIEC61850.
*
* libIEC61850 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
* (at your option) any later version.
*
* libIEC61850 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.
*
* You should have received a copy of the GNU General Public License
* along with libIEC61850. If not, see <http://www.gnu.org/licenses/>.
*
* See COPYING file for the complete license text.
*/
#ifndef GOOSE_PUBLISHER_H_
#define GOOSE_PUBLISHER_H_
#include "libiec61850_platform_includes.h"
#include "linked_list.h"
#include "mms_value.h"
#ifdef __cplusplus
extern "C" {
#endif
#ifndef GOOSE_SV_COMM_PARAMETERS
#define GOOSE_SV_COMM_PARAMETERS
typedef struct sCommParameters {
uint8_t vlanPriority;
uint16_t vlanId;
uint16_t appId;
uint8_t dstAddress[6];
} CommParameters;
#endif
typedef struct sGoosePublisher* GoosePublisher;
/**
* \brief Create a new GoosePublisher instance
*
* NOTE: The created GoosePublisher instance uses VLAN tags
*
* \param parameters GOOSE communication parameters
* \param interfaceId name of the Ethernet interface to use (e.g. "eth0")
*/
LIB61850_API GoosePublisher
GoosePublisher_create(CommParameters* parameters, const char* interfaceID);
/**
* \brief Create a new GoosePublisher instance
*
* \param parameters GOOSE communication parameters
* \param interfaceId name of the Ethernet interface to use (e.g. "eth0")
* \param useVlanTag enable or disable the usage of VLAN tags in GOOSE messages
*/
LIB61850_API GoosePublisher
GoosePublisher_createEx(CommParameters* parameters, const char* interfaceID, bool useVlanTag);
/**
* \brief Release all resources of the GoosePublisher instance
*
* \param self GoosePublisher instance
*/
LIB61850_API void
GoosePublisher_destroy(GoosePublisher self);
/**
* \brief Publish a GOOSE message
*
* NOTE: This function also increased the sequence number of the GOOSE publisher
*
* \param self GoosePublisher instance
* \param dataSet the GOOSE data set to send
*/
LIB61850_API int
GoosePublisher_publish(GoosePublisher self, LinkedList dataSet);
/**
* \brief Publish a GOOSE message and store the sent message in the provided buffer
*
* \param self GoosePublisher instance
* \param dataSet the GOOSE data set to send
* \param msgBuf to store the sent message
* \param[out] msgLen the length of the sent message
* \param bufSize the size of the buffer to store the sent message
*/
LIB61850_API int
GoosePublisher_publishAndDump(GoosePublisher self, LinkedList dataSet, char* msgBuf, int32_t* msgLen, int32_t bufSize);
/**
* \brief Sets the GoID used by the GoosePublisher instance
*
* \param self GoosePublisher instance
* \param goID the GoId string
*/
LIB61850_API void
GoosePublisher_setGoID(GoosePublisher self, char* goID);
/**
* \brief Sets the GoCB reference used by the GoosePublisher instance
*
* \param self GoosePublisher instance
* \param goCbRef the GoCB reference string
*/
LIB61850_API void
GoosePublisher_setGoCbRef(GoosePublisher self, char* goCbRef);
/**
* \brief Sets the time allowed to live value of the GOOSE messages
*
* \param self GoosePublisher instance
* \param timeAllowedToLive the time allowed to live value in milliseconds
*/
LIB61850_API void
GoosePublisher_setTimeAllowedToLive(GoosePublisher self, uint32_t timeAllowedToLive);
/**
* \brief Sets the data set reference used by the GoosePublisher instance
*
* \param self GoosePublisher instance
* \param dataSetRef the data set reference string
*/
LIB61850_API void
GoosePublisher_setDataSetRef(GoosePublisher self, char* dataSetRef);
/**
* \brief Sets the configuration revision used by the GoosePublisher instance
*
* \param self GoosePublisher instance
* \param confRev the configuration revision value
*/
LIB61850_API void
GoosePublisher_setConfRev(GoosePublisher self, uint32_t confRev);
/**
* \brief Sets simulation flag in sent GOOSE messages
*
* \param self GoosePublisher instance
* \param simulation the value of the simulation flag
*/
LIB61850_API void
GoosePublisher_setSimulation(GoosePublisher self, bool simulation);
/**
* \brief Manually sets the state number (stNum) of the GoosePublisher instance
*
* NOTE: Only for testing! Use \ref GoosePublisher_increaseStNum instead whenever
* a data set member changes.
*
* \param self GoosePublisher instance
* \param stNum the state number of the next GOOSE message to send
*/
LIB61850_API void
GoosePublisher_setStNum(GoosePublisher self, uint32_t stNum);
/**
* \brief Manually sets the sequence number (sqNum) of the GoosePublisher instance
*
* NOTE: Only for testing! The sequence number is increase manually whenever \ref GoosePublisher_publish is called.
*
* \param self GoosePublisher instance
* \param stNum the state number of the next GOOSE message to send
*/
LIB61850_API void
GoosePublisher_setSqNum(GoosePublisher self, uint32_t sqNum);
/**
* \brief Sets the needs commission flag in sent GOOSE messages
*
* \param self GoosePublisher instance
* \param ndsCom the value of the needs commission flag
*/
LIB61850_API void
GoosePublisher_setNeedsCommission(GoosePublisher self, bool ndsCom);
/**
* \brief Increase the state number (stNum) of the GoosePublisher instance
*
* The state number should be increased whenever a member of the GOOSE data set changed
*
* NOTE: This function also resets the sequence number (sqNum)
*
* \param self GoosePublisher instance
*/
LIB61850_API uint64_t
GoosePublisher_increaseStNum(GoosePublisher self);
/**
* \brief Reset state and sequence number of the GoosePublisher instance
*
* This function will set the state number (stNum) to 1 and the sequence number (sqNum) to 0.
*
* \param self GoosePublisher instance
*/
LIB61850_API void
GoosePublisher_reset(GoosePublisher self);
#ifdef __cplusplus
}
#endif
#endif /* GOOSE_PUBLISHER_H_ */