Compute Graph Framework SDK Reference  5.8
Node.hpp
Go to the documentation of this file.
1
2//
3// Notice
4// ALL NVIDIA DESIGN SPECIFICATIONS AND CODE ("MATERIALS") ARE PROVIDED "AS IS" NVIDIA MAKES
5// NO REPRESENTATIONS, WARRANTIES, EXPRESSED, IMPLIED, STATUTORY, OR OTHERWISE WITH RESPECT TO
6// THE MATERIALS, AND EXPRESSLY DISCLAIMS ANY IMPLIED WARRANTIES OF NONINFRINGEMENT,
7// MERCHANTABILITY, OR FITNESS FOR A PARTICULAR PURPOSE.
8//
9// NVIDIA CORPORATION & AFFILIATES assumes no responsibility for the consequences of use of such
10// information or for any infringement of patents or other rights of third parties that may
11// result from its use. No license is granted by implication or otherwise under any patent
12// or patent rights of NVIDIA CORPORATION & AFFILIATES. No third party distribution is allowed unless
13// expressly authorized by NVIDIA. Details are subject to change without notice.
14// This code supersedes and replaces all information previously supplied.
15// NVIDIA CORPORATION & AFFILIATES products are not authorized for use as critical
16// components in life support devices or systems without express written approval of
17// NVIDIA CORPORATION & AFFILIATES.
18//
19// SPDX-FileCopyrightText: Copyright (c) 2017-2022 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
20// SPDX-License-Identifier: LicenseRef-NvidiaProprietary
21//
22// NVIDIA CORPORATION, its affiliates and licensors retain all intellectual
23// property and proprietary rights in and to this material, related
24// documentation and any modifications thereto. Any use, reproduction,
25// disclosure or distribution of this material and related documentation
26// without an express license agreement from NVIDIA CORPORATION or
27// its affiliates is strictly prohibited.
28//
30
31#ifndef DW_FRAMEWORK_BASECLASS_NODE_HPP_
32#define DW_FRAMEWORK_BASECLASS_NODE_HPP_
33
34#include <map>
35
36#include <dw/core/base/Types.h>
37#include <dw/core/context/ObjectExtra.h>
38
39#include <dwcgf/Types.hpp>
41#include <dwcgf/pass/Pass.hpp>
44#include <dw/core/container/VectorFixed.hpp>
45#include <dw/core/container/BaseString.hpp>
46
47#include <string>
48#include <memory>
49#include <atomic>
50
51namespace dw
52{
53namespace framework
54{
55using dw::core::FixedString;
56using dw::core::VectorFixed;
57class ParameterProvider;
58
59#define _DW_CGF_STRINGIFY(x) #x
60// std::char_traits<char8_t>::length() is not constexpr before C++17, use "sizeof() - 1" as WAR
61#define STRING_VIEW_OF_FIXED_STRING_TEMPLATE_TYPE(x) dw::core::StringView("dw::core::FixedString<" _DW_CGF_STRINGIFY(x) ">", sizeof("dw::core::FixedString<" _DW_CGF_STRINGIFY(x) ">") - 1)
62
63class Node
64{
65public:
66 static constexpr size_t MAX_NAME_LEN = 128;
67 using Name_t = FixedString<MAX_NAME_LEN>;
68
69 static constexpr uint32_t MAX_PORT_COUNT = 256;
70
71 static constexpr uint32_t MAX_PASS_COUNT = 256;
72 static constexpr uint8_t PASS_SETUP = std::numeric_limits<uint8_t>::max() - 1;
73 static constexpr uint8_t PASS_TEARDOWN = std::numeric_limits<uint8_t>::max();
74
75 virtual ~Node() = default;
76
81 virtual dwStatus reset() = 0;
82
89 virtual dwStatus setInputChannel(ChannelObject* channel, uint8_t portID) = 0;
90
98 virtual dwStatus setInputChannel(ChannelObject* channel, uint8_t portID, dwSerializationType dataType) = 0;
99
106 virtual dwStatus setOutputChannel(ChannelObject* channel, uint8_t portID) = 0;
107
117 virtual dwStatus validate() = 0;
118
123 virtual dwStatus run() = 0;
124
129 virtual size_t getPassCount() const noexcept = 0;
130
136 virtual dwStatus runPassByID(uint8_t passID) = 0;
137
143 virtual dwStatus runPass(size_t passIndex) = 0;
144
150 virtual dwStatus getPasses(VectorFixed<Pass*>& passList) = 0;
151
159 virtual dwStatus getPasses(VectorFixed<Pass*>& passList,
160 dwProcessorType processorType,
161 dwProcessType processType) = 0;
162
168 virtual dwStatus setName(const char* name) = 0;
169
175 virtual dwStatus getName(const char** name) = 0;
176
182 virtual dwStatus getErrorSignal(dwGraphErrorSignal*& errorSignal) = 0;
183
190 virtual dwStatus getHealthSignal(dwGraphHealthSignal*& healthSignals, bool updateFromModule = false) = 0;
191
200 virtual dwStatus reportCurrentErrorSignal(dwGraphErrorSignal& signal) = 0;
201
210 virtual dwStatus reportCurrentHealthSignal(dwGraphHealthSignal& signal) = 0;
211
217 virtual dwStatus setIterationCount(uint32_t iterationCount) = 0;
218
226 virtual dwStatus setState(const char* state) = 0;
227
231 virtual void resetPorts() = 0;
232};
233
235{
236public:
241 virtual dwStatus start() = 0;
242
247 virtual dwStatus stop() = 0;
248
253 virtual dwStatus setAffinityMask(uint) = 0;
254
259 virtual dwStatus setThreadPriority(int) = 0;
260
265 virtual dwStatus setStartTime(dwTime_t) = 0;
266
271 virtual dwStatus setEndTime(dwTime_t) = 0;
272
277 virtual dwStatus isVirtual(bool* isVirtualBool) = 0;
278
279 enum class DataEventType
280 {
281 PRODUCE, // sensor node produces data for a node-run
282 DROP, // sensor node drops data in the next node-run
283 NONE, // sensor node does not produce data for a node-run
284 };
285
290 {
302 dwStatus status;
307 dwTime_t timestamp;
308 };
309
310 using DataEventReadCallback = dw::core::Function<bool(DataEvent&)>;
318
319 using DataEventWriteCallback = dw::core::Function<void(DataEvent)>;
327};
328
330{
331public:
334
337
340
343
345 : m_node(node)
346 , m_sensorNode(dynamic_cast<ISensorNode*>(node))
347 {
348 if (m_sensorNode != nullptr)
349 {
350 throw Exception(DW_INVALID_ARGUMENT, "Passed node pointer does not implement ISensorNode.");
351 }
352 }
353
355 {
356 return m_node;
357 }
358
359 Node const* getNode() const
360 {
361 return m_node;
362 }
363
365 {
366 return m_sensorNode;
367 }
368
370 {
371 return m_sensorNode;
372 }
373
374private:
375 Node* m_node{};
376 ISensorNode* m_sensorNode{};
377};
378
387{
388public:
389 virtual ~IContainsPreShutdownAction() = default;
390
395 virtual dwStatus preShutdown() = 0;
396};
397
398// TODO(ajayawardane) WAR: When there is a single SSM pass in the graph, reset could potentially
399// be called while node passes are running. Until STM schedule re-entry is supported, we reset the
400// supported nodes in the setup pass.
402{
403public:
404 virtual ~IAsyncResetable() = default;
405
410 virtual dwStatus setAsyncReset() = 0;
415 virtual dwStatus executeAsyncReset() = 0;
416};
417
423{
424public:
425 virtual ~IChannelsConnectedListener() = default;
426
430 virtual void onChannelsConnected() = 0;
431};
432
435
436} // namespace framework
437} // namespace dw
438
440
441#endif // DW_FRAMEWORK_BASECLASS_NODE_HPP_
Basic error signal that gets reported only when there is an error.
Basic health signal that describes the health status of the graph.
virtual dwStatus setAsyncReset()=0
Set the async reset flag.
virtual dwStatus executeAsyncReset()=0
Executes a reset if the async reset flag is set.
virtual ~IAsyncResetable()=default
virtual void onChannelsConnected()=0
Callback received after channels are connected.
virtual dwStatus preShutdown()=0
actions to be taken before node shutdown
virtual dwStatus setAffinityMask(uint)=0
Sets the affinity mask of the sensor.
virtual dwStatus setDataEventReadCallback(DataEventReadCallback cb)=0
Set read timestamp function for dataset replay. Timestamps not in the sequence returned by the callba...
virtual dwStatus setDataEventWriteCallback(DataEventWriteCallback cb)=0
Set write timestamp function for live case. Each timestamp of data output from the node will be passe...
virtual dwStatus start()=0
Start the sensor.
virtual dwStatus setEndTime(dwTime_t)=0
Set end timestamp for dataset replay.
dw::core::Function< bool(DataEvent &)> DataEventReadCallback
Definition: Node.hpp:310
virtual dwStatus stop()=0
Stop the sensor.
virtual dwStatus isVirtual(bool *isVirtualBool)=0
distinguishes between a live and virtual sensor
dw::core::Function< void(DataEvent)> DataEventWriteCallback
Definition: Node.hpp:319
virtual dwStatus setThreadPriority(int)=0
Sets the thread priority of the sensor.
virtual dwStatus setStartTime(dwTime_t)=0
Set start timestamp for dataset replay.
virtual dwStatus validate()=0
Checks that all mandatory ports are bound. The implementation should validate that all the ports are ...
virtual dwStatus setOutputChannel(ChannelObject *channel, uint8_t portID)=0
Sets an output channel for this node with an accompanying port.
virtual dwStatus runPass(size_t passIndex)=0
Run one pass by index as defined by the pass descriptors.
virtual dwStatus setInputChannel(ChannelObject *channel, uint8_t portID)=0
Sets an input channel for this node with an accompanying port.
static constexpr uint8_t PASS_TEARDOWN
Definition: Node.hpp:73
virtual dwStatus run()=0
Runs all the passes in the node.
virtual ~Node()=default
FixedString< MAX_NAME_LEN > Name_t
Definition: Node.hpp:67
static constexpr uint8_t PASS_SETUP
Definition: Node.hpp:72
virtual dwStatus getErrorSignal(dwGraphErrorSignal *&errorSignal)=0
Get the pointer to the error signal for this node.
static constexpr uint32_t MAX_PORT_COUNT
Definition: Node.hpp:69
virtual size_t getPassCount() const noexcept=0
Get number of passes in the node.
virtual dwStatus getHealthSignal(dwGraphHealthSignal *&healthSignals, bool updateFromModule=false)=0
Get the pointer to the health signal for this node.
virtual dwStatus setIterationCount(uint32_t iterationCount)=0
Sets the node's iteration count.
static constexpr uint32_t MAX_PASS_COUNT
Definition: Node.hpp:71
virtual void resetPorts()=0
Resets all the ports in the node.
virtual dwStatus getPasses(VectorFixed< Pass * > &passList)=0
Get all the passes in the node.
static constexpr size_t MAX_NAME_LEN
Definition: Node.hpp:66
virtual dwStatus runPassByID(uint8_t passID)=0
Run one pass by ID as defined by the PassList enum class.
virtual dwStatus setName(const char *name)=0
Set the name of the node.
virtual dwStatus getName(const char **name)=0
Get the name of the node.
virtual dwStatus reportCurrentErrorSignal(dwGraphErrorSignal &signal)=0
A function that allows user override to update error signal It is automatically called by dwFramework...
virtual dwStatus reportCurrentHealthSignal(dwGraphHealthSignal &signal)=0
A function that allows user override to update health signal It is automatically called by dwFramewor...
virtual dwStatus reset()=0
Resets the state of the node.
virtual dwStatus setInputChannel(ChannelObject *channel, uint8_t portID, dwSerializationType dataType)=0
Sets an input channel for this node with an accompanying port.
virtual dwStatus setState(const char *state)=0
Set the current state in node. Node implementation of this API need to be thread-safe.
Pass is a runnable describes the metadata of a pass.
Definition: Pass.hpp:49
SensorNode(Node *node)
Definition: Node.hpp:344
ISensorNode::DataEventReadCallback DataEventReadCallback
Definition: Node.hpp:339
Node const * getNode() const
Definition: Node.hpp:359
ISensorNode * getSensorNode()
Definition: Node.hpp:364
ISensorNode const * getSensorNode() const
Definition: Node.hpp:369
ISensorNode::DataEventWriteCallback DataEventWriteCallback
Definition: Node.hpp:342
constexpr size_t passIndex(dw::core::StringView identifier)
Get the the pass index for a pass identified by name.
dwTrivialDataType dataType
Number of levels in the pyramid.
Definition: Exception.hpp:47