F´ Flight Software - C/C++ Documentation  devel
A framework for building embedded system applications to NASA flight quality standards.
VersionComponentAc.cpp
Go to the documentation of this file.
1 // ======================================================================
2 // \title VersionComponentAc.cpp
3 // \author Generated by fpp-to-cpp
4 // \brief cpp file for Version component base class
5 // ======================================================================
6 
8 #include "Fw/Types/Assert.hpp"
10 #if FW_ENABLE_TEXT_LOGGING
11 #include "Fw/Types/String.hpp"
12 #endif
13 
14 namespace Svc {
15 
16  // ----------------------------------------------------------------------
17  // Component initialization
18  // ----------------------------------------------------------------------
19 
21  init(FwEnumStoreType instance)
22  {
23  // Initialize base class
25 
26  // Connect input port cmdIn
27  for (
28  FwIndexType port = 0;
29  port < static_cast<FwIndexType>(this->getNum_cmdIn_InputPorts());
30  port++
31  ) {
32  this->m_cmdIn_InputPort[port].init();
33  this->m_cmdIn_InputPort[port].addCallComp(
34  this,
35  m_p_cmdIn_in
36  );
37  this->m_cmdIn_InputPort[port].setPortNum(port);
38 
39 #if FW_OBJECT_NAMES == 1
40  Fw::ObjectName portName;
41  portName.format(
42  "%s_cmdIn_InputPort[%" PRI_PlatformIntType "]",
43  this->m_objName.toChar(),
44  port
45  );
46  this->m_cmdIn_InputPort[port].setObjName(portName.toChar());
47 #endif
48  }
49 
50  // Connect input port getVersion
51  for (
52  FwIndexType port = 0;
53  port < static_cast<FwIndexType>(this->getNum_getVersion_InputPorts());
54  port++
55  ) {
56  this->m_getVersion_InputPort[port].init();
57  this->m_getVersion_InputPort[port].addCallComp(
58  this,
59  m_p_getVersion_in
60  );
61  this->m_getVersion_InputPort[port].setPortNum(port);
62 
63 #if FW_OBJECT_NAMES == 1
64  Fw::ObjectName portName;
65  portName.format(
66  "%s_getVersion_InputPort[%" PRI_PlatformIntType "]",
67  this->m_objName.toChar(),
68  port
69  );
70  this->m_getVersion_InputPort[port].setObjName(portName.toChar());
71 #endif
72  }
73 
74  // Connect input port setVersion
75  for (
76  FwIndexType port = 0;
77  port < static_cast<FwIndexType>(this->getNum_setVersion_InputPorts());
78  port++
79  ) {
80  this->m_setVersion_InputPort[port].init();
81  this->m_setVersion_InputPort[port].addCallComp(
82  this,
83  m_p_setVersion_in
84  );
85  this->m_setVersion_InputPort[port].setPortNum(port);
86 
87 #if FW_OBJECT_NAMES == 1
88  Fw::ObjectName portName;
89  portName.format(
90  "%s_setVersion_InputPort[%" PRI_PlatformIntType "]",
91  this->m_objName.toChar(),
92  port
93  );
94  this->m_setVersion_InputPort[port].setObjName(portName.toChar());
95 #endif
96  }
97 
98  // Connect output port cmdRegOut
99  for (
100  FwIndexType port = 0;
101  port < static_cast<FwIndexType>(this->getNum_cmdRegOut_OutputPorts());
102  port++
103  ) {
104  this->m_cmdRegOut_OutputPort[port].init();
105 
106 #if FW_OBJECT_NAMES == 1
107  Fw::ObjectName portName;
108  portName.format(
109  "%s_cmdRegOut_OutputPort[%" PRI_PlatformIntType "]",
110  this->m_objName.toChar(),
111  port
112  );
113  this->m_cmdRegOut_OutputPort[port].setObjName(portName.toChar());
114 #endif
115  }
116 
117  // Connect output port cmdResponseOut
118  for (
119  FwIndexType port = 0;
120  port < static_cast<FwIndexType>(this->getNum_cmdResponseOut_OutputPorts());
121  port++
122  ) {
123  this->m_cmdResponseOut_OutputPort[port].init();
124 
125 #if FW_OBJECT_NAMES == 1
126  Fw::ObjectName portName;
127  portName.format(
128  "%s_cmdResponseOut_OutputPort[%" PRI_PlatformIntType "]",
129  this->m_objName.toChar(),
130  port
131  );
132  this->m_cmdResponseOut_OutputPort[port].setObjName(portName.toChar());
133 #endif
134  }
135 
136  // Connect output port logOut
137  for (
138  FwIndexType port = 0;
139  port < static_cast<FwIndexType>(this->getNum_logOut_OutputPorts());
140  port++
141  ) {
142  this->m_logOut_OutputPort[port].init();
143 
144 #if FW_OBJECT_NAMES == 1
145  Fw::ObjectName portName;
146  portName.format(
147  "%s_logOut_OutputPort[%" PRI_PlatformIntType "]",
148  this->m_objName.toChar(),
149  port
150  );
151  this->m_logOut_OutputPort[port].setObjName(portName.toChar());
152 #endif
153  }
154 
155 #if FW_ENABLE_TEXT_LOGGING == 1
156  // Connect output port logTextOut
157  for (
158  FwIndexType port = 0;
159  port < static_cast<FwIndexType>(this->getNum_logTextOut_OutputPorts());
160  port++
161  ) {
162  this->m_logTextOut_OutputPort[port].init();
163 
164 #if FW_OBJECT_NAMES == 1
165  Fw::ObjectName portName;
166  portName.format(
167  "%s_logTextOut_OutputPort[%" PRI_PlatformIntType "]",
168  this->m_objName.toChar(),
169  port
170  );
171  this->m_logTextOut_OutputPort[port].setObjName(portName.toChar());
172 #endif
173  }
174 #endif
175 
176  // Connect output port timeCaller
177  for (
178  FwIndexType port = 0;
179  port < static_cast<FwIndexType>(this->getNum_timeCaller_OutputPorts());
180  port++
181  ) {
182  this->m_timeCaller_OutputPort[port].init();
183 
184 #if FW_OBJECT_NAMES == 1
185  Fw::ObjectName portName;
186  portName.format(
187  "%s_timeCaller_OutputPort[%" PRI_PlatformIntType "]",
188  this->m_objName.toChar(),
189  port
190  );
191  this->m_timeCaller_OutputPort[port].setObjName(portName.toChar());
192 #endif
193  }
194 
195  // Connect output port tlmOut
196  for (
197  FwIndexType port = 0;
198  port < static_cast<FwIndexType>(this->getNum_tlmOut_OutputPorts());
199  port++
200  ) {
201  this->m_tlmOut_OutputPort[port].init();
202 
203 #if FW_OBJECT_NAMES == 1
204  Fw::ObjectName portName;
205  portName.format(
206  "%s_tlmOut_OutputPort[%" PRI_PlatformIntType "]",
207  this->m_objName.toChar(),
208  port
209  );
210  this->m_tlmOut_OutputPort[port].setObjName(portName.toChar());
211 #endif
212  }
213  }
214 
215  // ----------------------------------------------------------------------
216  // Getters for special input ports
217  // ----------------------------------------------------------------------
218 
221  {
222  FW_ASSERT(
223  portNum < this->getNum_cmdIn_InputPorts(),
224  static_cast<FwAssertArgType>(portNum)
225  );
226 
227  return &this->m_cmdIn_InputPort[portNum];
228  }
229 
230  // ----------------------------------------------------------------------
231  // Getters for typed input ports
232  // ----------------------------------------------------------------------
233 
236  {
237  FW_ASSERT(
238  portNum < this->getNum_getVersion_InputPorts(),
239  static_cast<FwAssertArgType>(portNum)
240  );
241 
242  return &this->m_getVersion_InputPort[portNum];
243  }
244 
247  {
248  FW_ASSERT(
249  portNum < this->getNum_setVersion_InputPorts(),
250  static_cast<FwAssertArgType>(portNum)
251  );
252 
253  return &this->m_setVersion_InputPort[portNum];
254  }
255 
256  // ----------------------------------------------------------------------
257  // Connect input ports to special output ports
258  // ----------------------------------------------------------------------
259 
262  FwIndexType portNum,
263  Fw::InputCmdRegPort* port
264  )
265  {
266  FW_ASSERT(
267  portNum < this->getNum_cmdRegOut_OutputPorts(),
268  static_cast<FwAssertArgType>(portNum)
269  );
270 
271  this->m_cmdRegOut_OutputPort[portNum].addCallPort(port);
272  }
273 
276  FwIndexType portNum,
278  )
279  {
280  FW_ASSERT(
281  portNum < this->getNum_cmdResponseOut_OutputPorts(),
282  static_cast<FwAssertArgType>(portNum)
283  );
284 
285  this->m_cmdResponseOut_OutputPort[portNum].addCallPort(port);
286  }
287 
290  FwIndexType portNum,
291  Fw::InputLogPort* port
292  )
293  {
294  FW_ASSERT(
295  portNum < this->getNum_logOut_OutputPorts(),
296  static_cast<FwAssertArgType>(portNum)
297  );
298 
299  this->m_logOut_OutputPort[portNum].addCallPort(port);
300  }
301 
302 #if FW_ENABLE_TEXT_LOGGING == 1
303 
304  void VersionComponentBase ::
305  set_logTextOut_OutputPort(
306  FwIndexType portNum,
308  )
309  {
310  FW_ASSERT(
311  portNum < this->getNum_logTextOut_OutputPorts(),
312  static_cast<FwAssertArgType>(portNum)
313  );
314 
315  this->m_logTextOut_OutputPort[portNum].addCallPort(port);
316  }
317 
318 #endif
319 
322  FwIndexType portNum,
323  Fw::InputTimePort* port
324  )
325  {
326  FW_ASSERT(
327  portNum < this->getNum_timeCaller_OutputPorts(),
328  static_cast<FwAssertArgType>(portNum)
329  );
330 
331  this->m_timeCaller_OutputPort[portNum].addCallPort(port);
332  }
333 
336  FwIndexType portNum,
337  Fw::InputTlmPort* port
338  )
339  {
340  FW_ASSERT(
341  portNum < this->getNum_tlmOut_OutputPorts(),
342  static_cast<FwAssertArgType>(portNum)
343  );
344 
345  this->m_tlmOut_OutputPort[portNum].addCallPort(port);
346  }
347 
348 #if FW_PORT_SERIALIZATION
349 
350  // ----------------------------------------------------------------------
351  // Connect serial input ports to special output ports
352  // ----------------------------------------------------------------------
353 
356  FwIndexType portNum,
357  Fw::InputSerializePort* port
358  )
359  {
360  FW_ASSERT(
361  portNum < this->getNum_cmdRegOut_OutputPorts(),
362  static_cast<FwAssertArgType>(portNum)
363  );
364 
365  this->m_cmdRegOut_OutputPort[portNum].registerSerialPort(port);
366  }
367 
370  FwIndexType portNum,
371  Fw::InputSerializePort* port
372  )
373  {
374  FW_ASSERT(
375  portNum < this->getNum_cmdResponseOut_OutputPorts(),
376  static_cast<FwAssertArgType>(portNum)
377  );
378 
379  this->m_cmdResponseOut_OutputPort[portNum].registerSerialPort(port);
380  }
381 
384  FwIndexType portNum,
385  Fw::InputSerializePort* port
386  )
387  {
388  FW_ASSERT(
389  portNum < this->getNum_logOut_OutputPorts(),
390  static_cast<FwAssertArgType>(portNum)
391  );
392 
393  this->m_logOut_OutputPort[portNum].registerSerialPort(port);
394  }
395 
396 #if FW_ENABLE_TEXT_LOGGING == 1
397 
398  void VersionComponentBase ::
399  set_logTextOut_OutputPort(
400  FwIndexType portNum,
401  Fw::InputSerializePort* port
402  )
403  {
404  FW_ASSERT(
405  portNum < this->getNum_logTextOut_OutputPorts(),
406  static_cast<FwAssertArgType>(portNum)
407  );
408 
409  this->m_logTextOut_OutputPort[portNum].registerSerialPort(port);
410  }
411 
412 #endif
413 
416  FwIndexType portNum,
417  Fw::InputSerializePort* port
418  )
419  {
420  FW_ASSERT(
421  portNum < this->getNum_timeCaller_OutputPorts(),
422  static_cast<FwAssertArgType>(portNum)
423  );
424 
425  this->m_timeCaller_OutputPort[portNum].registerSerialPort(port);
426  }
427 
430  FwIndexType portNum,
431  Fw::InputSerializePort* port
432  )
433  {
434  FW_ASSERT(
435  portNum < this->getNum_tlmOut_OutputPorts(),
436  static_cast<FwAssertArgType>(portNum)
437  );
438 
439  this->m_tlmOut_OutputPort[portNum].registerSerialPort(port);
440  }
441 
442 #endif
443 
444  // ----------------------------------------------------------------------
445  // Command registration
446  // ----------------------------------------------------------------------
447 
449  regCommands()
450  {
451  FW_ASSERT(this->m_cmdRegOut_OutputPort[0].isConnected());
452 
453  this->m_cmdRegOut_OutputPort[0].invoke(
454  this->getIdBase() + OPCODE_ENABLE
455  );
456 
457  this->m_cmdRegOut_OutputPort[0].invoke(
458  this->getIdBase() + OPCODE_VERSION
459  );
460  }
461 
462  // ----------------------------------------------------------------------
463  // Component construction and destruction
464  // ----------------------------------------------------------------------
465 
467  VersionComponentBase(const char* compName) :
468  Fw::PassiveComponentBase(compName)
469  {
470 
471  }
472 
475  {
476 
477  }
478 
479  // ----------------------------------------------------------------------
480  // Getters for numbers of special input ports
481  // ----------------------------------------------------------------------
482 
485  {
486  return static_cast<FwIndexType>(FW_NUM_ARRAY_ELEMENTS(this->m_cmdIn_InputPort));
487  }
488 
489  // ----------------------------------------------------------------------
490  // Getters for numbers of typed input ports
491  // ----------------------------------------------------------------------
492 
495  {
496  return static_cast<FwIndexType>(FW_NUM_ARRAY_ELEMENTS(this->m_getVersion_InputPort));
497  }
498 
501  {
502  return static_cast<FwIndexType>(FW_NUM_ARRAY_ELEMENTS(this->m_setVersion_InputPort));
503  }
504 
505  // ----------------------------------------------------------------------
506  // Getters for numbers of special output ports
507  // ----------------------------------------------------------------------
508 
511  {
512  return static_cast<FwIndexType>(FW_NUM_ARRAY_ELEMENTS(this->m_cmdRegOut_OutputPort));
513  }
514 
517  {
518  return static_cast<FwIndexType>(FW_NUM_ARRAY_ELEMENTS(this->m_cmdResponseOut_OutputPort));
519  }
520 
523  {
524  return static_cast<FwIndexType>(FW_NUM_ARRAY_ELEMENTS(this->m_logOut_OutputPort));
525  }
526 
527 #if FW_ENABLE_TEXT_LOGGING == 1
528 
529  FwIndexType VersionComponentBase ::
530  getNum_logTextOut_OutputPorts() const
531  {
532  return static_cast<FwIndexType>(FW_NUM_ARRAY_ELEMENTS(this->m_logTextOut_OutputPort));
533  }
534 
535 #endif
536 
539  {
540  return static_cast<FwIndexType>(FW_NUM_ARRAY_ELEMENTS(this->m_timeCaller_OutputPort));
541  }
542 
545  {
546  return static_cast<FwIndexType>(FW_NUM_ARRAY_ELEMENTS(this->m_tlmOut_OutputPort));
547  }
548 
549  // ----------------------------------------------------------------------
550  // Connection status queries for special output ports
551  // ----------------------------------------------------------------------
552 
555  {
556  FW_ASSERT(
557  portNum < this->getNum_cmdRegOut_OutputPorts(),
558  static_cast<FwAssertArgType>(portNum)
559  );
560 
561  return this->m_cmdRegOut_OutputPort[portNum].isConnected();
562  }
563 
566  {
567  FW_ASSERT(
568  portNum < this->getNum_cmdResponseOut_OutputPorts(),
569  static_cast<FwAssertArgType>(portNum)
570  );
571 
572  return this->m_cmdResponseOut_OutputPort[portNum].isConnected();
573  }
574 
577  {
578  FW_ASSERT(
579  portNum < this->getNum_logOut_OutputPorts(),
580  static_cast<FwAssertArgType>(portNum)
581  );
582 
583  return this->m_logOut_OutputPort[portNum].isConnected();
584  }
585 
586 #if FW_ENABLE_TEXT_LOGGING == 1
587 
588  bool VersionComponentBase ::
589  isConnected_logTextOut_OutputPort(FwIndexType portNum)
590  {
591  FW_ASSERT(
592  portNum < this->getNum_logTextOut_OutputPorts(),
593  static_cast<FwAssertArgType>(portNum)
594  );
595 
596  return this->m_logTextOut_OutputPort[portNum].isConnected();
597  }
598 
599 #endif
600 
603  {
604  FW_ASSERT(
605  portNum < this->getNum_timeCaller_OutputPorts(),
606  static_cast<FwAssertArgType>(portNum)
607  );
608 
609  return this->m_timeCaller_OutputPort[portNum].isConnected();
610  }
611 
614  {
615  FW_ASSERT(
616  portNum < this->getNum_tlmOut_OutputPorts(),
617  static_cast<FwAssertArgType>(portNum)
618  );
619 
620  return this->m_tlmOut_OutputPort[portNum].isConnected();
621  }
622 
623  // ----------------------------------------------------------------------
624  // Port handler base-class functions for typed input ports
625  //
626  // Call these functions directly to bypass the corresponding ports
627  // ----------------------------------------------------------------------
628 
631  FwIndexType portNum,
632  const Svc::VersionCfg::VersionEnum& version_id,
633  Fw::StringBase& version_string,
634  Svc::VersionStatus& status
635  )
636  {
637  // Make sure port number is valid
638  FW_ASSERT(
639  portNum < this->getNum_getVersion_InputPorts(),
640  static_cast<FwAssertArgType>(portNum)
641  );
642 
643  // Lock guard mutex before calling
644  this->lock();
645 
646  // Call handler function
647  this->getVersion_handler(
648  portNum,
649  version_id,
650  version_string,
651  status
652  );
653 
654  // Unlock guard mutex
655  this->unLock();
656  }
657 
660  FwIndexType portNum,
661  const Svc::VersionCfg::VersionEnum& version_id,
662  Fw::StringBase& version_string,
663  Svc::VersionStatus& status
664  )
665  {
666  // Make sure port number is valid
667  FW_ASSERT(
668  portNum < this->getNum_setVersion_InputPorts(),
669  static_cast<FwAssertArgType>(portNum)
670  );
671 
672  // Lock guard mutex before calling
673  this->lock();
674 
675  // Call handler function
676  this->setVersion_handler(
677  portNum,
678  version_id,
679  version_string,
680  status
681  );
682 
683  // Unlock guard mutex
684  this->unLock();
685  }
686 
687  // ----------------------------------------------------------------------
688  // Command response
689  // ----------------------------------------------------------------------
690 
693  FwOpcodeType opCode,
694  U32 cmdSeq,
695  Fw::CmdResponse response
696  )
697  {
698  FW_ASSERT(this->m_cmdResponseOut_OutputPort[0].isConnected());
699  this->m_cmdResponseOut_OutputPort[0].invoke(opCode, cmdSeq, response);
700  }
701 
702  // ----------------------------------------------------------------------
703  // Command handler base-class functions
704  //
705  // Call these functions directly to bypass the command input port
706  // ----------------------------------------------------------------------
707 
710  FwOpcodeType opCode,
711  U32 cmdSeq,
712  Fw::CmdArgBuffer& args
713  )
714  {
715  // Deserialize the arguments
717 
718  // Reset the buffer
719  args.resetDeser();
720 
721  Svc::VersionEnabled enable;
722  _status = args.deserialize(enable);
723  if (_status != Fw::FW_SERIALIZE_OK) {
724  if (this->m_cmdResponseOut_OutputPort[0].isConnected()) {
725  this->m_cmdResponseOut_OutputPort[0].invoke(
726  opCode,
727  cmdSeq,
729  );
730  }
731  return;
732  }
733 
734 #if FW_CMD_CHECK_RESIDUAL
735  // Make sure there was no data left over.
736  // That means the argument buffer size was incorrect.
737  if (args.getBuffLeft() != 0) {
738  if (this->m_cmdResponseOut_OutputPort[0].isConnected()) {
739  this->m_cmdResponseOut_OutputPort[0].invoke(
740  opCode,
741  cmdSeq,
743  );
744  }
745  return;
746  }
747 #endif
748 
749  this->lock();
750 
751  this->ENABLE_cmdHandler(
752  opCode, cmdSeq,
753  enable
754  );
755 
756  this->unLock();
757  }
758 
761  FwOpcodeType opCode,
762  U32 cmdSeq,
763  Fw::CmdArgBuffer& args
764  )
765  {
766  // Deserialize the arguments
768 
769  // Reset the buffer
770  args.resetDeser();
771 
772  Svc::VersionType version_type;
773  _status = args.deserialize(version_type);
774  if (_status != Fw::FW_SERIALIZE_OK) {
775  if (this->m_cmdResponseOut_OutputPort[0].isConnected()) {
776  this->m_cmdResponseOut_OutputPort[0].invoke(
777  opCode,
778  cmdSeq,
780  );
781  }
782  return;
783  }
784 
785 #if FW_CMD_CHECK_RESIDUAL
786  // Make sure there was no data left over.
787  // That means the argument buffer size was incorrect.
788  if (args.getBuffLeft() != 0) {
789  if (this->m_cmdResponseOut_OutputPort[0].isConnected()) {
790  this->m_cmdResponseOut_OutputPort[0].invoke(
791  opCode,
792  cmdSeq,
794  );
795  }
796  return;
797  }
798 #endif
799 
800  this->lock();
801 
802  this->VERSION_cmdHandler(
803  opCode, cmdSeq,
804  version_type
805  );
806 
807  this->unLock();
808  }
809 
810  // ----------------------------------------------------------------------
811  // Event logging functions
812  // ----------------------------------------------------------------------
813 
816  {
817  // Get the time
818  Fw::Time _logTime;
819  if (this->m_timeCaller_OutputPort[0].isConnected()) {
820  this->m_timeCaller_OutputPort[0].invoke(_logTime);
821  }
822 
823  FwEventIdType _id = static_cast<FwEventIdType>(0);
824 
825  _id = this->getIdBase() + EVENTID_FRAMEWORKVERSION;
826 
827  // Emit the event on the log port
828  if (this->m_logOut_OutputPort[0].isConnected()) {
829  Fw::LogBuffer _logBuff;
831 
832 #if FW_AMPCS_COMPATIBLE
833  // Serialize the number of arguments
834  _status = _logBuff.serialize(static_cast<U8>(1));
835  FW_ASSERT(
836  _status == Fw::FW_SERIALIZE_OK,
837  static_cast<FwAssertArgType>(_status)
838  );
839 #endif
840 
841  _status = version.serialize(_logBuff, FW_MIN(FW_LOG_STRING_MAX_SIZE, 40));
842  FW_ASSERT(
843  _status == Fw::FW_SERIALIZE_OK,
844  static_cast<FwAssertArgType>(_status)
845  );
846 
847  this->m_logOut_OutputPort[0].invoke(
848  _id,
849  _logTime,
851  _logBuff
852  );
853  }
854 
855  // Emit the event on the text log port
856 #if FW_ENABLE_TEXT_LOGGING
857  if (this->m_logTextOut_OutputPort[0].isConnected()) {
858 #if FW_OBJECT_NAMES == 1
859  const char* _formatString =
860  "(%s) %s: Framework Version: [%s]";
861 #else
862  const char* _formatString =
863  "%s: Framework Version: [%s]";
864 #endif
865 
866  Fw::TextLogString _logString;
867  _logString.format(
868  _formatString,
869 #if FW_OBJECT_NAMES == 1
870  this->m_objName.toChar(),
871 #endif
872  "FrameworkVersion ",
873  version.toChar()
874  );
875 
876  this->m_logTextOut_OutputPort[0].invoke(
877  _id,
878  _logTime,
880  _logString
881  );
882  }
883 #endif
884  }
885 
888  {
889  // Get the time
890  Fw::Time _logTime;
891  if (this->m_timeCaller_OutputPort[0].isConnected()) {
892  this->m_timeCaller_OutputPort[0].invoke(_logTime);
893  }
894 
895  FwEventIdType _id = static_cast<FwEventIdType>(0);
896 
897  _id = this->getIdBase() + EVENTID_PROJECTVERSION;
898 
899  // Emit the event on the log port
900  if (this->m_logOut_OutputPort[0].isConnected()) {
901  Fw::LogBuffer _logBuff;
903 
904 #if FW_AMPCS_COMPATIBLE
905  // Serialize the number of arguments
906  _status = _logBuff.serialize(static_cast<U8>(1));
907  FW_ASSERT(
908  _status == Fw::FW_SERIALIZE_OK,
909  static_cast<FwAssertArgType>(_status)
910  );
911 #endif
912 
913  _status = version.serialize(_logBuff, FW_MIN(FW_LOG_STRING_MAX_SIZE, 40));
914  FW_ASSERT(
915  _status == Fw::FW_SERIALIZE_OK,
916  static_cast<FwAssertArgType>(_status)
917  );
918 
919  this->m_logOut_OutputPort[0].invoke(
920  _id,
921  _logTime,
923  _logBuff
924  );
925  }
926 
927  // Emit the event on the text log port
928 #if FW_ENABLE_TEXT_LOGGING
929  if (this->m_logTextOut_OutputPort[0].isConnected()) {
930 #if FW_OBJECT_NAMES == 1
931  const char* _formatString =
932  "(%s) %s: Project Version: [%s]";
933 #else
934  const char* _formatString =
935  "%s: Project Version: [%s]";
936 #endif
937 
938  Fw::TextLogString _logString;
939  _logString.format(
940  _formatString,
941 #if FW_OBJECT_NAMES == 1
942  this->m_objName.toChar(),
943 #endif
944  "ProjectVersion ",
945  version.toChar()
946  );
947 
948  this->m_logTextOut_OutputPort[0].invoke(
949  _id,
950  _logTime,
952  _logString
953  );
954  }
955 #endif
956  }
957 
960  {
961  // Get the time
962  Fw::Time _logTime;
963  if (this->m_timeCaller_OutputPort[0].isConnected()) {
964  this->m_timeCaller_OutputPort[0].invoke(_logTime);
965  }
966 
967  FwEventIdType _id = static_cast<FwEventIdType>(0);
968 
969  _id = this->getIdBase() + EVENTID_LIBRARYVERSIONS;
970 
971  // Emit the event on the log port
972  if (this->m_logOut_OutputPort[0].isConnected()) {
973  Fw::LogBuffer _logBuff;
975 
976 #if FW_AMPCS_COMPATIBLE
977  // Serialize the number of arguments
978  _status = _logBuff.serialize(static_cast<U8>(1));
979  FW_ASSERT(
980  _status == Fw::FW_SERIALIZE_OK,
981  static_cast<FwAssertArgType>(_status)
982  );
983 #endif
984 
985  _status = version.serialize(_logBuff, FW_MIN(FW_LOG_STRING_MAX_SIZE, 40));
986  FW_ASSERT(
987  _status == Fw::FW_SERIALIZE_OK,
988  static_cast<FwAssertArgType>(_status)
989  );
990 
991  this->m_logOut_OutputPort[0].invoke(
992  _id,
993  _logTime,
995  _logBuff
996  );
997  }
998 
999  // Emit the event on the text log port
1000 #if FW_ENABLE_TEXT_LOGGING
1001  if (this->m_logTextOut_OutputPort[0].isConnected()) {
1002 #if FW_OBJECT_NAMES == 1
1003  const char* _formatString =
1004  "(%s) %s: Library Versions: [%s]";
1005 #else
1006  const char* _formatString =
1007  "%s: Library Versions: [%s]";
1008 #endif
1009 
1010  Fw::TextLogString _logString;
1011  _logString.format(
1012  _formatString,
1013 #if FW_OBJECT_NAMES == 1
1014  this->m_objName.toChar(),
1015 #endif
1016  "LibraryVersions ",
1017  version.toChar()
1018  );
1019 
1020  this->m_logTextOut_OutputPort[0].invoke(
1021  _id,
1022  _logTime,
1024  _logString
1025  );
1026  }
1027 #endif
1028  }
1029 
1032  Svc::VersionCfg::VersionEnum version_enum,
1033  const Fw::StringBase& version_value
1034  )
1035  {
1036  // Get the time
1037  Fw::Time _logTime;
1038  if (this->m_timeCaller_OutputPort[0].isConnected()) {
1039  this->m_timeCaller_OutputPort[0].invoke(_logTime);
1040  }
1041 
1042  FwEventIdType _id = static_cast<FwEventIdType>(0);
1043 
1044  _id = this->getIdBase() + EVENTID_CUSTOMVERSIONS;
1045 
1046  // Emit the event on the log port
1047  if (this->m_logOut_OutputPort[0].isConnected()) {
1048  Fw::LogBuffer _logBuff;
1050 
1051 #if FW_AMPCS_COMPATIBLE
1052  // Serialize the number of arguments
1053  _status = _logBuff.serialize(static_cast<U8>(2));
1054  FW_ASSERT(
1055  _status == Fw::FW_SERIALIZE_OK,
1056  static_cast<FwAssertArgType>(_status)
1057  );
1058 #endif
1059 
1060 #if FW_AMPCS_COMPATIBLE
1061  // Serialize the argument size
1062  _status = _logBuff.serialize(
1064  );
1065  FW_ASSERT(
1066  _status == Fw::FW_SERIALIZE_OK,
1067  static_cast<FwAssertArgType>(_status)
1068  );
1069 #endif
1070  _status = _logBuff.serialize(version_enum);
1071  FW_ASSERT(
1072  _status == Fw::FW_SERIALIZE_OK,
1073  static_cast<FwAssertArgType>(_status)
1074  );
1075 
1076  _status = version_value.serialize(_logBuff, FW_MIN(FW_LOG_STRING_MAX_SIZE, 40));
1077  FW_ASSERT(
1078  _status == Fw::FW_SERIALIZE_OK,
1079  static_cast<FwAssertArgType>(_status)
1080  );
1081 
1082  this->m_logOut_OutputPort[0].invoke(
1083  _id,
1084  _logTime,
1086  _logBuff
1087  );
1088  }
1089 
1090  // Emit the event on the text log port
1091 #if FW_ENABLE_TEXT_LOGGING
1092  if (this->m_logTextOut_OutputPort[0].isConnected()) {
1093 #if FW_OBJECT_NAMES == 1
1094  const char* _formatString =
1095  "(%s) %s: Custom Versions: [%s] [%s]";
1096 #else
1097  const char* _formatString =
1098  "%s: Custom Versions: [%s] [%s]";
1099 #endif
1100 
1101  Fw::String version_enumStr;
1102  version_enum.toString(version_enumStr);
1103 
1104  Fw::TextLogString _logString;
1105  _logString.format(
1106  _formatString,
1107 #if FW_OBJECT_NAMES == 1
1108  this->m_objName.toChar(),
1109 #endif
1110  "CustomVersions ",
1111  version_enumStr.toChar(),
1112  version_value.toChar()
1113  );
1114 
1115  this->m_logTextOut_OutputPort[0].invoke(
1116  _id,
1117  _logTime,
1119  _logString
1120  );
1121  }
1122 #endif
1123  }
1124 
1125  // ----------------------------------------------------------------------
1126  // Telemetry write functions
1127  // ----------------------------------------------------------------------
1128 
1131  const Fw::StringBase& arg,
1132  Fw::Time _tlmTime
1133  )
1134  {
1135  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1136  if (
1137  this->m_timeCaller_OutputPort[0].isConnected() &&
1138  (_tlmTime == Fw::ZERO_TIME)
1139  ) {
1140  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1141  }
1142 
1143  Fw::TlmBuffer _tlmBuff;
1144  Fw::SerializeStatus _stat = arg.serialize(_tlmBuff, FW_MIN(FW_TLM_STRING_MAX_SIZE, 40));
1145  FW_ASSERT(
1146  _stat == Fw::FW_SERIALIZE_OK,
1147  static_cast<FwAssertArgType>(_stat)
1148  );
1149 
1150  FwChanIdType _id;
1151 
1152  _id = this->getIdBase() + CHANNELID_FRAMEWORKVERSION;
1153 
1154  this->m_tlmOut_OutputPort[0].invoke(
1155  _id,
1156  _tlmTime,
1157  _tlmBuff
1158  );
1159  }
1160  }
1161 
1164  const Fw::StringBase& arg,
1165  Fw::Time _tlmTime
1166  )
1167  {
1168  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1169  if (
1170  this->m_timeCaller_OutputPort[0].isConnected() &&
1171  (_tlmTime == Fw::ZERO_TIME)
1172  ) {
1173  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1174  }
1175 
1176  Fw::TlmBuffer _tlmBuff;
1177  Fw::SerializeStatus _stat = arg.serialize(_tlmBuff, FW_MIN(FW_TLM_STRING_MAX_SIZE, 40));
1178  FW_ASSERT(
1179  _stat == Fw::FW_SERIALIZE_OK,
1180  static_cast<FwAssertArgType>(_stat)
1181  );
1182 
1183  FwChanIdType _id;
1184 
1185  _id = this->getIdBase() + CHANNELID_PROJECTVERSION;
1186 
1187  this->m_tlmOut_OutputPort[0].invoke(
1188  _id,
1189  _tlmTime,
1190  _tlmBuff
1191  );
1192  }
1193  }
1194 
1197  const Svc::CustomVersionDb& arg,
1198  Fw::Time _tlmTime
1199  )
1200  {
1201  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1202  if (
1203  this->m_timeCaller_OutputPort[0].isConnected() &&
1204  (_tlmTime == Fw::ZERO_TIME)
1205  ) {
1206  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1207  }
1208 
1209  Fw::TlmBuffer _tlmBuff;
1210  Fw::SerializeStatus _stat = _tlmBuff.serialize(arg);
1211  FW_ASSERT(
1212  _stat == Fw::FW_SERIALIZE_OK,
1213  static_cast<FwAssertArgType>(_stat)
1214  );
1215 
1216  FwChanIdType _id;
1217 
1218  _id = this->getIdBase() + CHANNELID_CUSTOMVERSION01;
1219 
1220  this->m_tlmOut_OutputPort[0].invoke(
1221  _id,
1222  _tlmTime,
1223  _tlmBuff
1224  );
1225  }
1226  }
1227 
1230  const Svc::CustomVersionDb& arg,
1231  Fw::Time _tlmTime
1232  )
1233  {
1234  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1235  if (
1236  this->m_timeCaller_OutputPort[0].isConnected() &&
1237  (_tlmTime == Fw::ZERO_TIME)
1238  ) {
1239  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1240  }
1241 
1242  Fw::TlmBuffer _tlmBuff;
1243  Fw::SerializeStatus _stat = _tlmBuff.serialize(arg);
1244  FW_ASSERT(
1245  _stat == Fw::FW_SERIALIZE_OK,
1246  static_cast<FwAssertArgType>(_stat)
1247  );
1248 
1249  FwChanIdType _id;
1250 
1251  _id = this->getIdBase() + CHANNELID_CUSTOMVERSION02;
1252 
1253  this->m_tlmOut_OutputPort[0].invoke(
1254  _id,
1255  _tlmTime,
1256  _tlmBuff
1257  );
1258  }
1259  }
1260 
1263  const Svc::CustomVersionDb& arg,
1264  Fw::Time _tlmTime
1265  )
1266  {
1267  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1268  if (
1269  this->m_timeCaller_OutputPort[0].isConnected() &&
1270  (_tlmTime == Fw::ZERO_TIME)
1271  ) {
1272  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1273  }
1274 
1275  Fw::TlmBuffer _tlmBuff;
1276  Fw::SerializeStatus _stat = _tlmBuff.serialize(arg);
1277  FW_ASSERT(
1278  _stat == Fw::FW_SERIALIZE_OK,
1279  static_cast<FwAssertArgType>(_stat)
1280  );
1281 
1282  FwChanIdType _id;
1283 
1284  _id = this->getIdBase() + CHANNELID_CUSTOMVERSION03;
1285 
1286  this->m_tlmOut_OutputPort[0].invoke(
1287  _id,
1288  _tlmTime,
1289  _tlmBuff
1290  );
1291  }
1292  }
1293 
1296  const Svc::CustomVersionDb& arg,
1297  Fw::Time _tlmTime
1298  )
1299  {
1300  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1301  if (
1302  this->m_timeCaller_OutputPort[0].isConnected() &&
1303  (_tlmTime == Fw::ZERO_TIME)
1304  ) {
1305  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1306  }
1307 
1308  Fw::TlmBuffer _tlmBuff;
1309  Fw::SerializeStatus _stat = _tlmBuff.serialize(arg);
1310  FW_ASSERT(
1311  _stat == Fw::FW_SERIALIZE_OK,
1312  static_cast<FwAssertArgType>(_stat)
1313  );
1314 
1315  FwChanIdType _id;
1316 
1317  _id = this->getIdBase() + CHANNELID_CUSTOMVERSION04;
1318 
1319  this->m_tlmOut_OutputPort[0].invoke(
1320  _id,
1321  _tlmTime,
1322  _tlmBuff
1323  );
1324  }
1325  }
1326 
1329  const Svc::CustomVersionDb& arg,
1330  Fw::Time _tlmTime
1331  )
1332  {
1333  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1334  if (
1335  this->m_timeCaller_OutputPort[0].isConnected() &&
1336  (_tlmTime == Fw::ZERO_TIME)
1337  ) {
1338  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1339  }
1340 
1341  Fw::TlmBuffer _tlmBuff;
1342  Fw::SerializeStatus _stat = _tlmBuff.serialize(arg);
1343  FW_ASSERT(
1344  _stat == Fw::FW_SERIALIZE_OK,
1345  static_cast<FwAssertArgType>(_stat)
1346  );
1347 
1348  FwChanIdType _id;
1349 
1350  _id = this->getIdBase() + CHANNELID_CUSTOMVERSION05;
1351 
1352  this->m_tlmOut_OutputPort[0].invoke(
1353  _id,
1354  _tlmTime,
1355  _tlmBuff
1356  );
1357  }
1358  }
1359 
1362  const Svc::CustomVersionDb& arg,
1363  Fw::Time _tlmTime
1364  )
1365  {
1366  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1367  if (
1368  this->m_timeCaller_OutputPort[0].isConnected() &&
1369  (_tlmTime == Fw::ZERO_TIME)
1370  ) {
1371  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1372  }
1373 
1374  Fw::TlmBuffer _tlmBuff;
1375  Fw::SerializeStatus _stat = _tlmBuff.serialize(arg);
1376  FW_ASSERT(
1377  _stat == Fw::FW_SERIALIZE_OK,
1378  static_cast<FwAssertArgType>(_stat)
1379  );
1380 
1381  FwChanIdType _id;
1382 
1383  _id = this->getIdBase() + CHANNELID_CUSTOMVERSION06;
1384 
1385  this->m_tlmOut_OutputPort[0].invoke(
1386  _id,
1387  _tlmTime,
1388  _tlmBuff
1389  );
1390  }
1391  }
1392 
1395  const Svc::CustomVersionDb& arg,
1396  Fw::Time _tlmTime
1397  )
1398  {
1399  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1400  if (
1401  this->m_timeCaller_OutputPort[0].isConnected() &&
1402  (_tlmTime == Fw::ZERO_TIME)
1403  ) {
1404  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1405  }
1406 
1407  Fw::TlmBuffer _tlmBuff;
1408  Fw::SerializeStatus _stat = _tlmBuff.serialize(arg);
1409  FW_ASSERT(
1410  _stat == Fw::FW_SERIALIZE_OK,
1411  static_cast<FwAssertArgType>(_stat)
1412  );
1413 
1414  FwChanIdType _id;
1415 
1416  _id = this->getIdBase() + CHANNELID_CUSTOMVERSION07;
1417 
1418  this->m_tlmOut_OutputPort[0].invoke(
1419  _id,
1420  _tlmTime,
1421  _tlmBuff
1422  );
1423  }
1424  }
1425 
1428  const Svc::CustomVersionDb& arg,
1429  Fw::Time _tlmTime
1430  )
1431  {
1432  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1433  if (
1434  this->m_timeCaller_OutputPort[0].isConnected() &&
1435  (_tlmTime == Fw::ZERO_TIME)
1436  ) {
1437  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1438  }
1439 
1440  Fw::TlmBuffer _tlmBuff;
1441  Fw::SerializeStatus _stat = _tlmBuff.serialize(arg);
1442  FW_ASSERT(
1443  _stat == Fw::FW_SERIALIZE_OK,
1444  static_cast<FwAssertArgType>(_stat)
1445  );
1446 
1447  FwChanIdType _id;
1448 
1449  _id = this->getIdBase() + CHANNELID_CUSTOMVERSION08;
1450 
1451  this->m_tlmOut_OutputPort[0].invoke(
1452  _id,
1453  _tlmTime,
1454  _tlmBuff
1455  );
1456  }
1457  }
1458 
1461  const Svc::CustomVersionDb& arg,
1462  Fw::Time _tlmTime
1463  )
1464  {
1465  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1466  if (
1467  this->m_timeCaller_OutputPort[0].isConnected() &&
1468  (_tlmTime == Fw::ZERO_TIME)
1469  ) {
1470  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1471  }
1472 
1473  Fw::TlmBuffer _tlmBuff;
1474  Fw::SerializeStatus _stat = _tlmBuff.serialize(arg);
1475  FW_ASSERT(
1476  _stat == Fw::FW_SERIALIZE_OK,
1477  static_cast<FwAssertArgType>(_stat)
1478  );
1479 
1480  FwChanIdType _id;
1481 
1482  _id = this->getIdBase() + CHANNELID_CUSTOMVERSION09;
1483 
1484  this->m_tlmOut_OutputPort[0].invoke(
1485  _id,
1486  _tlmTime,
1487  _tlmBuff
1488  );
1489  }
1490  }
1491 
1494  const Svc::CustomVersionDb& arg,
1495  Fw::Time _tlmTime
1496  )
1497  {
1498  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1499  if (
1500  this->m_timeCaller_OutputPort[0].isConnected() &&
1501  (_tlmTime == Fw::ZERO_TIME)
1502  ) {
1503  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1504  }
1505 
1506  Fw::TlmBuffer _tlmBuff;
1507  Fw::SerializeStatus _stat = _tlmBuff.serialize(arg);
1508  FW_ASSERT(
1509  _stat == Fw::FW_SERIALIZE_OK,
1510  static_cast<FwAssertArgType>(_stat)
1511  );
1512 
1513  FwChanIdType _id;
1514 
1515  _id = this->getIdBase() + CHANNELID_CUSTOMVERSION10;
1516 
1517  this->m_tlmOut_OutputPort[0].invoke(
1518  _id,
1519  _tlmTime,
1520  _tlmBuff
1521  );
1522  }
1523  }
1524 
1527  const Fw::StringBase& arg,
1528  Fw::Time _tlmTime
1529  )
1530  {
1531  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1532  if (
1533  this->m_timeCaller_OutputPort[0].isConnected() &&
1534  (_tlmTime == Fw::ZERO_TIME)
1535  ) {
1536  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1537  }
1538 
1539  Fw::TlmBuffer _tlmBuff;
1540  Fw::SerializeStatus _stat = arg.serialize(_tlmBuff, FW_MIN(FW_TLM_STRING_MAX_SIZE, 40));
1541  FW_ASSERT(
1542  _stat == Fw::FW_SERIALIZE_OK,
1543  static_cast<FwAssertArgType>(_stat)
1544  );
1545 
1546  FwChanIdType _id;
1547 
1548  _id = this->getIdBase() + CHANNELID_LIBRARYVERSION01;
1549 
1550  this->m_tlmOut_OutputPort[0].invoke(
1551  _id,
1552  _tlmTime,
1553  _tlmBuff
1554  );
1555  }
1556  }
1557 
1560  const Fw::StringBase& arg,
1561  Fw::Time _tlmTime
1562  )
1563  {
1564  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1565  if (
1566  this->m_timeCaller_OutputPort[0].isConnected() &&
1567  (_tlmTime == Fw::ZERO_TIME)
1568  ) {
1569  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1570  }
1571 
1572  Fw::TlmBuffer _tlmBuff;
1573  Fw::SerializeStatus _stat = arg.serialize(_tlmBuff, FW_MIN(FW_TLM_STRING_MAX_SIZE, 40));
1574  FW_ASSERT(
1575  _stat == Fw::FW_SERIALIZE_OK,
1576  static_cast<FwAssertArgType>(_stat)
1577  );
1578 
1579  FwChanIdType _id;
1580 
1581  _id = this->getIdBase() + CHANNELID_LIBRARYVERSION02;
1582 
1583  this->m_tlmOut_OutputPort[0].invoke(
1584  _id,
1585  _tlmTime,
1586  _tlmBuff
1587  );
1588  }
1589  }
1590 
1593  const Fw::StringBase& arg,
1594  Fw::Time _tlmTime
1595  )
1596  {
1597  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1598  if (
1599  this->m_timeCaller_OutputPort[0].isConnected() &&
1600  (_tlmTime == Fw::ZERO_TIME)
1601  ) {
1602  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1603  }
1604 
1605  Fw::TlmBuffer _tlmBuff;
1606  Fw::SerializeStatus _stat = arg.serialize(_tlmBuff, FW_MIN(FW_TLM_STRING_MAX_SIZE, 40));
1607  FW_ASSERT(
1608  _stat == Fw::FW_SERIALIZE_OK,
1609  static_cast<FwAssertArgType>(_stat)
1610  );
1611 
1612  FwChanIdType _id;
1613 
1614  _id = this->getIdBase() + CHANNELID_LIBRARYVERSION03;
1615 
1616  this->m_tlmOut_OutputPort[0].invoke(
1617  _id,
1618  _tlmTime,
1619  _tlmBuff
1620  );
1621  }
1622  }
1623 
1626  const Fw::StringBase& arg,
1627  Fw::Time _tlmTime
1628  )
1629  {
1630  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1631  if (
1632  this->m_timeCaller_OutputPort[0].isConnected() &&
1633  (_tlmTime == Fw::ZERO_TIME)
1634  ) {
1635  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1636  }
1637 
1638  Fw::TlmBuffer _tlmBuff;
1639  Fw::SerializeStatus _stat = arg.serialize(_tlmBuff, FW_MIN(FW_TLM_STRING_MAX_SIZE, 40));
1640  FW_ASSERT(
1641  _stat == Fw::FW_SERIALIZE_OK,
1642  static_cast<FwAssertArgType>(_stat)
1643  );
1644 
1645  FwChanIdType _id;
1646 
1647  _id = this->getIdBase() + CHANNELID_LIBRARYVERSION04;
1648 
1649  this->m_tlmOut_OutputPort[0].invoke(
1650  _id,
1651  _tlmTime,
1652  _tlmBuff
1653  );
1654  }
1655  }
1656 
1659  const Fw::StringBase& arg,
1660  Fw::Time _tlmTime
1661  )
1662  {
1663  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1664  if (
1665  this->m_timeCaller_OutputPort[0].isConnected() &&
1666  (_tlmTime == Fw::ZERO_TIME)
1667  ) {
1668  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1669  }
1670 
1671  Fw::TlmBuffer _tlmBuff;
1672  Fw::SerializeStatus _stat = arg.serialize(_tlmBuff, FW_MIN(FW_TLM_STRING_MAX_SIZE, 40));
1673  FW_ASSERT(
1674  _stat == Fw::FW_SERIALIZE_OK,
1675  static_cast<FwAssertArgType>(_stat)
1676  );
1677 
1678  FwChanIdType _id;
1679 
1680  _id = this->getIdBase() + CHANNELID_LIBRARYVERSION05;
1681 
1682  this->m_tlmOut_OutputPort[0].invoke(
1683  _id,
1684  _tlmTime,
1685  _tlmBuff
1686  );
1687  }
1688  }
1689 
1692  const Fw::StringBase& arg,
1693  Fw::Time _tlmTime
1694  )
1695  {
1696  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1697  if (
1698  this->m_timeCaller_OutputPort[0].isConnected() &&
1699  (_tlmTime == Fw::ZERO_TIME)
1700  ) {
1701  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1702  }
1703 
1704  Fw::TlmBuffer _tlmBuff;
1705  Fw::SerializeStatus _stat = arg.serialize(_tlmBuff, FW_MIN(FW_TLM_STRING_MAX_SIZE, 40));
1706  FW_ASSERT(
1707  _stat == Fw::FW_SERIALIZE_OK,
1708  static_cast<FwAssertArgType>(_stat)
1709  );
1710 
1711  FwChanIdType _id;
1712 
1713  _id = this->getIdBase() + CHANNELID_LIBRARYVERSION06;
1714 
1715  this->m_tlmOut_OutputPort[0].invoke(
1716  _id,
1717  _tlmTime,
1718  _tlmBuff
1719  );
1720  }
1721  }
1722 
1725  const Fw::StringBase& arg,
1726  Fw::Time _tlmTime
1727  )
1728  {
1729  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1730  if (
1731  this->m_timeCaller_OutputPort[0].isConnected() &&
1732  (_tlmTime == Fw::ZERO_TIME)
1733  ) {
1734  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1735  }
1736 
1737  Fw::TlmBuffer _tlmBuff;
1738  Fw::SerializeStatus _stat = arg.serialize(_tlmBuff, FW_MIN(FW_TLM_STRING_MAX_SIZE, 40));
1739  FW_ASSERT(
1740  _stat == Fw::FW_SERIALIZE_OK,
1741  static_cast<FwAssertArgType>(_stat)
1742  );
1743 
1744  FwChanIdType _id;
1745 
1746  _id = this->getIdBase() + CHANNELID_LIBRARYVERSION07;
1747 
1748  this->m_tlmOut_OutputPort[0].invoke(
1749  _id,
1750  _tlmTime,
1751  _tlmBuff
1752  );
1753  }
1754  }
1755 
1758  const Fw::StringBase& arg,
1759  Fw::Time _tlmTime
1760  )
1761  {
1762  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1763  if (
1764  this->m_timeCaller_OutputPort[0].isConnected() &&
1765  (_tlmTime == Fw::ZERO_TIME)
1766  ) {
1767  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1768  }
1769 
1770  Fw::TlmBuffer _tlmBuff;
1771  Fw::SerializeStatus _stat = arg.serialize(_tlmBuff, FW_MIN(FW_TLM_STRING_MAX_SIZE, 40));
1772  FW_ASSERT(
1773  _stat == Fw::FW_SERIALIZE_OK,
1774  static_cast<FwAssertArgType>(_stat)
1775  );
1776 
1777  FwChanIdType _id;
1778 
1779  _id = this->getIdBase() + CHANNELID_LIBRARYVERSION08;
1780 
1781  this->m_tlmOut_OutputPort[0].invoke(
1782  _id,
1783  _tlmTime,
1784  _tlmBuff
1785  );
1786  }
1787  }
1788 
1791  const Fw::StringBase& arg,
1792  Fw::Time _tlmTime
1793  )
1794  {
1795  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1796  if (
1797  this->m_timeCaller_OutputPort[0].isConnected() &&
1798  (_tlmTime == Fw::ZERO_TIME)
1799  ) {
1800  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1801  }
1802 
1803  Fw::TlmBuffer _tlmBuff;
1804  Fw::SerializeStatus _stat = arg.serialize(_tlmBuff, FW_MIN(FW_TLM_STRING_MAX_SIZE, 40));
1805  FW_ASSERT(
1806  _stat == Fw::FW_SERIALIZE_OK,
1807  static_cast<FwAssertArgType>(_stat)
1808  );
1809 
1810  FwChanIdType _id;
1811 
1812  _id = this->getIdBase() + CHANNELID_LIBRARYVERSION09;
1813 
1814  this->m_tlmOut_OutputPort[0].invoke(
1815  _id,
1816  _tlmTime,
1817  _tlmBuff
1818  );
1819  }
1820  }
1821 
1824  const Fw::StringBase& arg,
1825  Fw::Time _tlmTime
1826  )
1827  {
1828  if (this->m_tlmOut_OutputPort[0].isConnected()) {
1829  if (
1830  this->m_timeCaller_OutputPort[0].isConnected() &&
1831  (_tlmTime == Fw::ZERO_TIME)
1832  ) {
1833  this->m_timeCaller_OutputPort[0].invoke(_tlmTime);
1834  }
1835 
1836  Fw::TlmBuffer _tlmBuff;
1837  Fw::SerializeStatus _stat = arg.serialize(_tlmBuff, FW_MIN(FW_TLM_STRING_MAX_SIZE, 40));
1838  FW_ASSERT(
1839  _stat == Fw::FW_SERIALIZE_OK,
1840  static_cast<FwAssertArgType>(_stat)
1841  );
1842 
1843  FwChanIdType _id;
1844 
1845  _id = this->getIdBase() + CHANNELID_LIBRARYVERSION10;
1846 
1847  this->m_tlmOut_OutputPort[0].invoke(
1848  _id,
1849  _tlmTime,
1850  _tlmBuff
1851  );
1852  }
1853  }
1854 
1855  // ----------------------------------------------------------------------
1856  // Time
1857  // ----------------------------------------------------------------------
1858 
1860  getTime()
1861  {
1862  if (this->m_timeCaller_OutputPort[0].isConnected()) {
1863  Fw::Time _time;
1864  this->m_timeCaller_OutputPort[0].invoke(_time);
1865  return _time;
1866  }
1867  else {
1868  return Fw::Time(TB_NONE, 0, 0);
1869  }
1870  }
1871 
1872  // ----------------------------------------------------------------------
1873  // Mutex operations for guarded ports
1874  //
1875  // You can override these operations to provide more sophisticated
1876  // synchronization
1877  // ----------------------------------------------------------------------
1878 
1880  lock()
1881  {
1882  this->m_guardedPortMutex.lock();
1883  }
1884 
1886  unLock()
1887  {
1888  this->m_guardedPortMutex.unLock();
1889  }
1890 
1891  // ----------------------------------------------------------------------
1892  // Calls for messages received on special input ports
1893  // ----------------------------------------------------------------------
1894 
1895  void VersionComponentBase ::
1896  m_p_cmdIn_in(
1897  Fw::PassiveComponentBase* callComp,
1898  FwIndexType portNum,
1899  FwOpcodeType opCode,
1900  U32 cmdSeq,
1901  Fw::CmdArgBuffer& args
1902  )
1903  {
1904  FW_ASSERT(callComp);
1905  VersionComponentBase* compPtr = static_cast<VersionComponentBase*>(callComp);
1906 
1907  const U32 idBase = callComp->getIdBase();
1908  FW_ASSERT(opCode >= idBase, static_cast<FwAssertArgType>(opCode), static_cast<FwAssertArgType>(idBase));
1909 
1910  // Select base class function based on opcode
1911  switch (opCode - idBase) {
1912  case OPCODE_ENABLE: {
1913  compPtr->ENABLE_cmdHandlerBase(
1914  opCode,
1915  cmdSeq,
1916  args
1917  );
1918  break;
1919  }
1920 
1921  case OPCODE_VERSION: {
1922  compPtr->VERSION_cmdHandlerBase(
1923  opCode,
1924  cmdSeq,
1925  args
1926  );
1927  break;
1928  }
1929  }
1930  }
1931 
1932  // ----------------------------------------------------------------------
1933  // Calls for messages received on typed input ports
1934  // ----------------------------------------------------------------------
1935 
1936  void VersionComponentBase ::
1937  m_p_getVersion_in(
1938  Fw::PassiveComponentBase* callComp,
1939  FwIndexType portNum,
1940  const Svc::VersionCfg::VersionEnum& version_id,
1941  Fw::StringBase& version_string,
1942  Svc::VersionStatus& status
1943  )
1944  {
1945  FW_ASSERT(callComp);
1946  VersionComponentBase* compPtr = static_cast<VersionComponentBase*>(callComp);
1947  compPtr->getVersion_handlerBase(
1948  portNum,
1949  version_id,
1950  version_string,
1951  status
1952  );
1953  }
1954 
1955  void VersionComponentBase ::
1956  m_p_setVersion_in(
1957  Fw::PassiveComponentBase* callComp,
1958  FwIndexType portNum,
1959  const Svc::VersionCfg::VersionEnum& version_id,
1960  Fw::StringBase& version_string,
1961  Svc::VersionStatus& status
1962  )
1963  {
1964  FW_ASSERT(callComp);
1965  VersionComponentBase* compPtr = static_cast<VersionComponentBase*>(callComp);
1966  compPtr->setVersion_handlerBase(
1967  portNum,
1968  version_id,
1969  version_string,
1970  status
1971  );
1972  }
1973 
1974 }
#define FW_ASSERT(...)
Definition: Assert.hpp:14
#define FW_MIN(a, b)
MIN macro.
Definition: BasicTypes.h:68
uint8_t U8
8-bit unsigned integer
Definition: BasicTypes.h:26
#define FW_NUM_ARRAY_ELEMENTS(a)
number of elements in an array
Definition: BasicTypes.h:66
#define PRI_PlatformIntType
@ TB_NONE
No time base has been established.
Definition: FpConfig.h:57
I32 FwEnumStoreType
Definition: FpConfig.h:51
PlatformAssertArgType FwAssertArgType
Definition: FpConfig.h:34
U32 FwChanIdType
Definition: FpConfig.h:82
U32 FwEventIdType
Definition: FpConfig.h:86
#define FW_TLM_STRING_MAX_SIZE
Max size of channelized telemetry string type.
Definition: FpConfig.h:310
U32 FwOpcodeType
Definition: FpConfig.h:78
#define FW_LOG_STRING_MAX_SIZE
Max size of log string parameter type.
Definition: FpConfig.h:300
PlatformIndexType FwIndexType
Definition: FpConfig.h:20
#define FW_OBJECT_NAMES
Indicates whether or not object names are stored (more memory, can be used for tracking objects)
Definition: FpConfig.h:135
Enum representing a command response.
@ FORMAT_ERROR
Command failed to deserialize.
void addCallComp(Fw::PassiveComponentBase *callComp, CompFuncPtr funcPtr)
Register a component.
Definition: CmdPortAc.cpp:62
void init()
Initialization function.
Definition: CmdPortAc.cpp:56
void setPortNum(NATIVE_INT_TYPE portNum)
@ ACTIVITY_LO
Less important informational events.
void init()
Object initializer.
Definition: ObjBase.cpp:27
const char * toChar() const
Definition: ObjectName.hpp:50
void addCallPort(InputCmdRegPort *callPort)
Register an input port.
void invoke(FwOpcodeType opCode)
Invoke a port interface.
void init()
Initialization function.
void init()
Initialization function.
void addCallPort(InputCmdResponsePort *callPort)
Register an input port.
void invoke(FwOpcodeType opCode, U32 cmdSeq, const Fw::CmdResponse &response)
Invoke a port interface.
void init()
Initialization function.
Definition: LogPortAc.cpp:151
void invoke(FwEventIdType id, Fw::Time &timeTag, const Fw::LogSeverity &severity, Fw::LogBuffer &args)
Invoke a port interface.
Definition: LogPortAc.cpp:170
void addCallPort(InputLogPort *callPort)
Register an input port.
Definition: LogPortAc.cpp:157
void addCallPort(InputTimePort *callPort)
Register an input port.
Definition: TimePortAc.cpp:134
void invoke(Fw::Time &time)
Invoke a port interface.
Definition: TimePortAc.cpp:147
void init()
Initialization function.
Definition: TimePortAc.cpp:128
void addCallPort(InputTlmPort *callPort)
Register an input port.
Definition: TlmPortAc.cpp:150
void init()
Initialization function.
Definition: TlmPortAc.cpp:144
void invoke(FwChanIdType id, Fw::Time &timeTag, Fw::TlmBuffer &val)
Invoke a port interface.
Definition: TlmPortAc.cpp:163
bool isConnected()
Definition: PortBase.cpp:41
void resetDeser()
reset deserialization to beginning
Serializable::SizeType getBuffLeft() const
returns how much deserialization buffer is left
SerializeStatus deserialize(U8 &val)
deserialize 8-bit unsigned int
SerializeStatus serialize(U8 val)
serialize 8-bit unsigned int
virtual const CHAR * toChar() const =0
void format(const CHAR *formatString,...)
write formatted string to buffer
Definition: StringBase.cpp:56
virtual SerializeStatus serialize(SerializeBufferBase &buffer) const
serialization function
Definition: StringBase.cpp:137
const char * toChar() const
Definition: String.hpp:50
Definition: Time.hpp:9
void unLock()
unlock the mutex
Definition: Mutex.cpp:13
void lock()
lock the mutex
Definition: Mutex.cpp:12
Data Structure for custom version Tlm.
void init()
Initialization function.
void addCallComp(Fw::PassiveComponentBase *callComp, CompFuncPtr funcPtr)
Register a component.
@ SERIALIZED_SIZE
The size of the serial representation.
Auto-generated base for Version component.
virtual void ENABLE_cmdHandler(FwOpcodeType opCode, U32 cmdSeq, Svc::VersionEnabled enable)=0
Fw::InputCmdPort * get_cmdIn_InputPort(FwIndexType portNum)
void tlmWrite_CustomVersion04(const Svc::CustomVersionDb &arg, Fw::Time _tlmTime=Fw::Time())
Write telemetry channel CustomVersion04.
bool isConnected_logOut_OutputPort(FwIndexType portNum)
void getVersion_handlerBase(FwIndexType portNum, const Svc::VersionCfg::VersionEnum &version_id, Fw::StringBase &version_string, Svc::VersionStatus &status)
Handler base-class function for input port getVersion.
FwIndexType getNum_setVersion_InputPorts() const
void log_ACTIVITY_LO_CustomVersions(Svc::VersionCfg::VersionEnum version_enum, const Fw::StringBase &version_value)
void tlmWrite_ProjectVersion(const Fw::StringBase &arg, Fw::Time _tlmTime=Fw::Time())
void tlmWrite_FrameworkVersion(const Fw::StringBase &arg, Fw::Time _tlmTime=Fw::Time())
void set_logOut_OutputPort(FwIndexType portNum, Fw::InputLogPort *port)
Connect port to logOut[portNum].
void tlmWrite_CustomVersion03(const Svc::CustomVersionDb &arg, Fw::Time _tlmTime=Fw::Time())
Write telemetry channel CustomVersion03.
void set_cmdResponseOut_OutputPort(FwIndexType portNum, Fw::InputCmdResponsePort *port)
Connect port to cmdResponseOut[portNum].
virtual void setVersion_handler(FwIndexType portNum, const Svc::VersionCfg::VersionEnum &version_id, Fw::StringBase &version_string, Svc::VersionStatus &status)=0
Handler for input port setVersion.
virtual void getVersion_handler(FwIndexType portNum, const Svc::VersionCfg::VersionEnum &version_id, Fw::StringBase &version_string, Svc::VersionStatus &status)=0
Handler for input port getVersion.
void tlmWrite_LibraryVersion09(const Fw::StringBase &arg, Fw::Time _tlmTime=Fw::Time())
Write telemetry channel LibraryVersion09.
void tlmWrite_LibraryVersion03(const Fw::StringBase &arg, Fw::Time _tlmTime=Fw::Time())
Write telemetry channel LibraryVersion03.
void tlmWrite_CustomVersion07(const Svc::CustomVersionDb &arg, Fw::Time _tlmTime=Fw::Time())
Write telemetry channel CustomVersion07.
void ENABLE_cmdHandlerBase(FwOpcodeType opCode, U32 cmdSeq, Fw::CmdArgBuffer &args)
void VERSION_cmdHandlerBase(FwOpcodeType opCode, U32 cmdSeq, Fw::CmdArgBuffer &args)
void tlmWrite_LibraryVersion05(const Fw::StringBase &arg, Fw::Time _tlmTime=Fw::Time())
Write telemetry channel LibraryVersion05.
void log_ACTIVITY_LO_FrameworkVersion(const Fw::StringBase &version)
FwIndexType getNum_timeCaller_OutputPorts() const
@ EVENTID_PROJECTVERSION
Version of the git repository.
@ EVENTID_CUSTOMVERSIONS
Version of the git repository.
@ EVENTID_FRAMEWORKVERSION
Version of the git repository.
@ EVENTID_LIBRARYVERSIONS
Version of the git repository.
FwIndexType getNum_cmdRegOut_OutputPorts() const
void tlmWrite_CustomVersion01(const Svc::CustomVersionDb &arg, Fw::Time _tlmTime=Fw::Time())
void set_cmdRegOut_OutputPort(FwIndexType portNum, Fw::InputCmdRegPort *port)
Connect port to cmdRegOut[portNum].
void regCommands()
Register commands with the Command Dispatcher.
void set_tlmOut_OutputPort(FwIndexType portNum, Fw::InputTlmPort *port)
Connect port to tlmOut[portNum].
void tlmWrite_LibraryVersion04(const Fw::StringBase &arg, Fw::Time _tlmTime=Fw::Time())
Write telemetry channel LibraryVersion04.
virtual void lock()
Lock the guarded mutex.
virtual void VERSION_cmdHandler(FwOpcodeType opCode, U32 cmdSeq, Svc::VersionType version_type)=0
void tlmWrite_CustomVersion08(const Svc::CustomVersionDb &arg, Fw::Time _tlmTime=Fw::Time())
Write telemetry channel CustomVersion08.
void log_ACTIVITY_LO_LibraryVersions(const Fw::StringBase &version)
void tlmWrite_LibraryVersion08(const Fw::StringBase &arg, Fw::Time _tlmTime=Fw::Time())
Write telemetry channel LibraryVersion08.
bool isConnected_timeCaller_OutputPort(FwIndexType portNum)
bool isConnected_cmdResponseOut_OutputPort(FwIndexType portNum)
FwIndexType getNum_getVersion_InputPorts() const
void set_timeCaller_OutputPort(FwIndexType portNum, Fw::InputTimePort *port)
Connect port to timeCaller[portNum].
FwIndexType getNum_tlmOut_OutputPorts() const
void tlmWrite_LibraryVersion07(const Fw::StringBase &arg, Fw::Time _tlmTime=Fw::Time())
Write telemetry channel LibraryVersion07.
void tlmWrite_CustomVersion09(const Svc::CustomVersionDb &arg, Fw::Time _tlmTime=Fw::Time())
Write telemetry channel CustomVersion09.
void tlmWrite_LibraryVersion01(const Fw::StringBase &arg, Fw::Time _tlmTime=Fw::Time())
void log_ACTIVITY_LO_ProjectVersion(const Fw::StringBase &version)
void tlmWrite_LibraryVersion06(const Fw::StringBase &arg, Fw::Time _tlmTime=Fw::Time())
Write telemetry channel LibraryVersion06.
bool isConnected_cmdRegOut_OutputPort(FwIndexType portNum)
void tlmWrite_CustomVersion02(const Svc::CustomVersionDb &arg, Fw::Time _tlmTime=Fw::Time())
Write telemetry channel CustomVersion02.
virtual void unLock()
Unlock the guarded mutex.
Svc::InputVersionPort * get_getVersion_InputPort(FwIndexType portNum)
void cmdResponse_out(FwOpcodeType opCode, U32 cmdSeq, Fw::CmdResponse response)
Emit command response.
void tlmWrite_LibraryVersion02(const Fw::StringBase &arg, Fw::Time _tlmTime=Fw::Time())
Write telemetry channel LibraryVersion02.
virtual ~VersionComponentBase()
Destroy VersionComponentBase object.
bool isConnected_tlmOut_OutputPort(FwIndexType portNum)
void tlmWrite_CustomVersion05(const Svc::CustomVersionDb &arg, Fw::Time _tlmTime=Fw::Time())
Write telemetry channel CustomVersion05.
void setVersion_handlerBase(FwIndexType portNum, const Svc::VersionCfg::VersionEnum &version_id, Fw::StringBase &version_string, Svc::VersionStatus &status)
Handler base-class function for input port setVersion.
FwIndexType getNum_cmdIn_InputPorts() const
void tlmWrite_LibraryVersion10(const Fw::StringBase &arg, Fw::Time _tlmTime=Fw::Time())
Write telemetry channel LibraryVersion10.
FwIndexType getNum_cmdResponseOut_OutputPorts() const
@ CHANNELID_LIBRARYVERSION03
Channel ID for LibraryVersion03.
@ CHANNELID_LIBRARYVERSION09
Channel ID for LibraryVersion09.
@ CHANNELID_CUSTOMVERSION05
Channel ID for CustomVersion05.
@ CHANNELID_CUSTOMVERSION09
Channel ID for CustomVersion09.
@ CHANNELID_CUSTOMVERSION03
Channel ID for CustomVersion03.
@ CHANNELID_CUSTOMVERSION06
Channel ID for CustomVersion06.
@ CHANNELID_CUSTOMVERSION07
Channel ID for CustomVersion07.
@ CHANNELID_CUSTOMVERSION04
Channel ID for CustomVersion04.
@ CHANNELID_LIBRARYVERSION05
Channel ID for LibraryVersion05.
@ CHANNELID_CUSTOMVERSION08
Channel ID for CustomVersion08.
@ CHANNELID_CUSTOMVERSION01
Channel ID for CustomVersion01.
@ CHANNELID_LIBRARYVERSION08
Channel ID for LibraryVersion08.
@ CHANNELID_CUSTOMVERSION10
Channel ID for CustomVersion10.
@ CHANNELID_LIBRARYVERSION02
Channel ID for LibraryVersion02.
@ CHANNELID_LIBRARYVERSION07
Channel ID for LibraryVersion07.
@ CHANNELID_LIBRARYVERSION10
Channel ID for LibraryVersion10.
@ CHANNELID_PROJECTVERSION
Channel ID for ProjectVersion.
@ CHANNELID_LIBRARYVERSION06
Channel ID for LibraryVersion06.
@ CHANNELID_LIBRARYVERSION01
Channel ID for LibraryVersion01.
@ CHANNELID_LIBRARYVERSION04
Channel ID for LibraryVersion04.
@ CHANNELID_CUSTOMVERSION02
Channel ID for CustomVersion02.
@ CHANNELID_FRAMEWORKVERSION
Channel ID for FrameworkVersion.
Svc::InputVersionPort * get_setVersion_InputPort(FwIndexType portNum)
FwIndexType getNum_logOut_OutputPorts() const
void tlmWrite_CustomVersion06(const Svc::CustomVersionDb &arg, Fw::Time _tlmTime=Fw::Time())
Write telemetry channel CustomVersion06.
void tlmWrite_CustomVersion10(const Svc::CustomVersionDb &arg, Fw::Time _tlmTime=Fw::Time())
Write telemetry channel CustomVersion10.
@ OPCODE_ENABLE
A command to enable or disable Event verbosity and Telemetry.
@ OPCODE_VERSION
Report version as Event.
VersionComponentBase(const char *compName="")
Construct VersionComponentBase object.
Tracks versions for project, framework and user defined versions etc.
An enumeration for version status.
An enumeration for Version Type.
SerializeStatus
forward declaration for string
@ FW_SERIALIZE_OK
Serialization/Deserialization operation was successful.
const Time ZERO_TIME
Definition: Time.cpp:5