/** Node type: IEC 61850-9-2 (Sampled Values) * * @author Steffen Vogel * @copyright 2017, Institute for Automation of Complex Power Systems, EONERC * @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. * * 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. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . *********************************************************************************/ #include #include "nodes/iec61850_sv.h" #include "plugin.h" int iec61850_sv_reverse(struct node *n) { struct iec61850_sv *i __attribute__((unused)) = n->_vd; return 0; } int iec61850_sv_parse(struct node *n, config_setting_t *cfg) { struct iec61850_sv *i __attribute__((unused)) = n->_vd; return 0; } char * iec61850_sv_print(struct node *n) { char *buf = NULL; struct iec61850_sv *i __attribute__((unused)) = n->_vd; return buf; } int iec61850_sv_start(struct node *n) { struct iec61850_sv *i __attribute__((unused)) = n->_vd; SampledValuesPublisher svPublisher = SampledValuesPublisher_create(interface); SV_ASDU asdu1 = SampledValuesPublisher_addASDU(svPublisher, "svpub1", NULL, 1); int float1 = SV_ASDU_addFLOAT(asdu1); int float2 = SV_ASDU_addFLOAT(asdu1); SampledValuesPublisher_setupComplete(i->publisher); return 0; } int iec61850_sv_stop(struct node *n) { struct iec61850_sv *i = n->_vd; SampledValuesPublisher_destroy(i->publisher.handle); return 0; } int iec61850_sv_read(struct node *n, struct sample *smps[], unsigned cnt) { struct iec61850_sv *i __attribute__((unused)) = n->_vd; return 0; } int iec61850_sv_write(struct node *n, struct sample *smps[], unsigned cnt) { struct iec61850_sv *i = n->_vd; for (int i = 0; i < cnt; i++) { SV_ASDU_setFLOAT(asdu1, float1, fVal1); } for (int j = 0; j < cnt; j++) { SV_ASDU *asdu = (SV_ASDU *) list_at(i->publisher.asdus, j); SV_ASDU_increaseSmpCnt(asdu); } SampledValuesPublisher_publish(i->publisher.handle); return 0; } static struct plugin p = { .name = "iec61850-9-2", .description = "IEC 61850-9-2 (Sampled Values)", .type = PLUGIN_TYPE_NODE, .node = { .vectorize = 0, .size = sizeof(struct iec61850_sv), .reverse = iec61850_sv_reverse, .parse = iec61850_sv_parse, .print = iec61850_sv_print, .start = iec61850_sv_start, .stop = iec61850_sv_stop, .read = iec61850_sv_read, .write = iec61850_sv_write, .instances = LIST_INIT() } }; REGISTER_PLUGIN(&p)