NVIDIA DriveOS Linux NSR SDK API Reference

7.0.3.0 Release
Interpreter.h
Go to the documentation of this file.
1 /*
2  * SPDX-FileCopyrightText: Copyright (c) 2016-2024 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
3  * SPDX-License-Identifier: LicenseRef-NvidiaProprietary
4  *
5  * NVIDIA CORPORATION, its affiliates and licensors retain all intellectual
6  * property and proprietary rights in and to this material, related
7  * documentation and any modifications thereto. Any use, reproduction,
8  * disclosure or distribution of this material and related documentation
9  * without an express license agreement from NVIDIA CORPORATION or
10  * its affiliates is strictly prohibited.
11  */
12 
28 #ifndef DW_SENSORS_CANBUS_INTERPRETER_H_
29 #define DW_SENSORS_CANBUS_INTERPRETER_H_
30 
31 #include <dw/core/base/Config.h>
32 #include <dw/core/base/Exports.h>
33 
34 #include <dw/sensors/canbus/CAN.h>
35 #include <dw/sensors/canbus/VehicleData.h>
36 
38 #define DW_SENSORS_CAN_INTERPRETER_MESSAGE_MAX_SIGNALS 128
39 
41 #define DW_SENSORS_CAN_INTERPRETER_MAX_MESSAGE_NAME_LEN 32
42 
44 #define DW_SENSORS_CAN_INTERPRETER_MAX_SIGNAL_NAME_LEN 32
45 
46 #ifdef __cplusplus
47 extern "C" {
48 #endif
49 
51 typedef struct dwCANInterpreterObject* dwCANInterpreterHandle_t;
52 
55 typedef void (*dwCANInterpreterAddMessageFunc_t)(const dwCANMessage* msg, void* userData);
56 
59 typedef uint32_t (*dwCANInterpreterGetNumAvailableFunc_t)(void* userData);
60 
65  dwCANVehicleData* data,
66  uint32_t idx, void* userData);
67 
70 typedef bool (*dwCANInterpreterGetDataf32Func_t)(float32_t* value, dwTime_t* timestamp_us, uint32_t idx, void* userData);
71 
74 typedef bool (*dwCANInterpreterGetDataf64Func_t)(float64_t* value, dwTime_t* timestamp_us, uint32_t idx, void* userData);
75 
78 typedef bool (*dwCANInterpreterGetDatai32Func_t)(int32_t* value, dwTime_t* timestamp_us, uint32_t idx, void* userData);
79 
82 {
95 
97 
121  void* userData, dwContextHandle_t context);
122 
150  const char8_t* inputDBC,
152 
172  const char8_t* dbc,
174 
193 
194 // ------------ encoding
216  const dwCANMessage* msg,
217  dwCANInterpreterHandle_t interpreter);
218 
240 dwStatus dwCANInterpreter_getSignalNameInMessage(const char8_t** name, uint32_t idx,
241  const dwCANMessage* msg,
242  dwCANInterpreterHandle_t interpreter);
243 
264 
283  dwCANInterpreterHandle_t interpreter);
284 
309  dwCANMessage* msg,
310  dwCANInterpreterHandle_t interpreter);
311 
323  dwCANMessage* msg,
324  dwCANInterpreterHandle_t interpreter);
325 
336 dwStatus dwCANInterpreter_encodei32(int32_t value, const char8_t* signal,
337  dwCANMessage* msg,
338  dwCANInterpreterHandle_t interpreter);
339 
340 // ----------------- consumption
359  dwCANInterpreterHandle_t interpreter);
360 
379 
403  dwCANInterpreterHandle_t interpreter);
404 
421 dwStatus dwCANInterpreter_getSignalName(const char8_t** name, uint32_t idx,
422  dwCANInterpreterHandle_t interpreter);
423 
442  dwCANInterpreterHandle_t interpreter);
443 
461 dwStatus dwCANInterpreter_getSignalRange(float64_t* minimum, float64_t* maximum, uint32_t idx,
462  dwCANInterpreterHandle_t interpreter);
463 
489 
501 
512 dwStatus dwCANInterpreter_geti32(int32_t* value, dwTime_t* timestamp_us, uint32_t idx, dwCANInterpreterHandle_t interpreter);
513 
514 #ifdef __cplusplus
515 }
516 #endif
517 
518 #endif // DW_SENSORS_CANBUS_INTERPRETER_H_
dwCANInterpreterGetNumAvailableFunc_t
uint32_t(* dwCANInterpreterGetNumAvailableFunc_t)(void *userData)
Gets the number of signals available to be retrieved.
Definition: Interpreter.h:59
dwCANInterpreter_createMessage
DW_API_PUBLIC dwStatus dwCANInterpreter_createMessage(dwCANMessage *msg, uint32_t id, dwCANInterpreterHandle_t interpreter)
Initializes an empty CAN message an interpreter can encoded signals into.
dwCANInterpreter_getSignalRange
DW_API_PUBLIC dwStatus dwCANInterpreter_getSignalRange(float64_t *minimum, float64_t *maximum, uint32_t idx, dwCANInterpreterHandle_t interpreter)
Returns the range of validity of data for a signal available for consumption by the application.
ctx
DW_API_PUBLIC dwPointCloudRangeImageCreatorParams const *const const dwContextHandle_t ctx
Definition: PointCloudRangeImageCreator.h:293
dwCANInterpreterGetDatai32Func_t
bool(* dwCANInterpreterGetDatai32Func_t)(int32_t *value, dwTime_t *timestamp_us, uint32_t idx, void *userData)
Returns false if no int32 data is available, true otherwise For the user-function expected behavior s...
Definition: Interpreter.h:78
dwCANInterpreter_geti32
DW_API_PUBLIC dwStatus dwCANInterpreter_geti32(int32_t *value, dwTime_t *timestamp_us, uint32_t idx, dwCANInterpreterHandle_t interpreter)
Same as dwCANInterpreter_getf32, but for int32 types.
dwCANInterpreterAddMessageFunc_t
void(* dwCANInterpreterAddMessageFunc_t)(const dwCANMessage *msg, void *userData)
Pushes new messages to the interpreter.
Definition: Interpreter.h:55
dwCANInterpreter_buildFromCallbacks
DW_API_PUBLIC dwStatus dwCANInterpreter_buildFromCallbacks(dwCANInterpreterHandle_t *interpreter, dwCANInterpreterInterface callbacks, void *userData, dwContextHandle_t context)
Creates a CAN data interpreter based on user provided callbacks.
dwCANInterpreter_release
DW_API_PUBLIC dwStatus dwCANInterpreter_release(dwCANInterpreterHandle_t interpreter)
Closes previously opened interpreter.
dwCANInterpreter_getDataSignalIndex
DW_API_PUBLIC dwStatus dwCANInterpreter_getDataSignalIndex(uint32_t *idx, dwCANVehicleData data, dwCANInterpreterHandle_t interpreter)
Gets the index of a signal of the last consumed message that corresponds to a certain predefined data...
dwCANInterpreter_buildFromDBCString
DW_API_PUBLIC dwStatus dwCANInterpreter_buildFromDBCString(dwCANInterpreterHandle_t *interpreter, const char8_t *dbc, dwContextHandle_t ctx)
Creates a CAN data interpreter based on DBC file format and initializes the interpreter from a string...
dwCANMessage
Holds a CAN package.
Definition: CANTypes.h:89
dwCANInterpreterInterface
Interface for callback based CAN data interpreter.
Definition: Interpreter.h:81
dwCANInterpreter_consume
DW_API_PUBLIC dwStatus dwCANInterpreter_consume(const dwCANMessage *msg, dwCANInterpreterHandle_t interpreter)
Pushes a new message to the interpreter.
dwCANInterpreter_getf64
DW_API_PUBLIC dwStatus dwCANInterpreter_getf64(float64_t *value, dwTime_t *timestamp_us, uint32_t idx, dwCANInterpreterHandle_t interpreter)
Same as dwCANInterpreter_getf32, but for float64 types.
dwCANInterpreterGetDataf32Func_t
bool(* dwCANInterpreterGetDataf32Func_t)(float32_t *value, dwTime_t *timestamp_us, uint32_t idx, void *userData)
Returns false if no float32 data is available, true otherwise For the user-function expected behavior...
Definition: Interpreter.h:70
dwCANVehicleData
dwCANVehicleData
A set of enumeration constants representing the default data signals.
Definition: VehicleData.h:48
dwTime_t
int64_t dwTime_t
Specifies a timestamp unit, in microseconds.
Definition: BasicTypes.h:54
float32_t
float float32_t
Specifies POD types.
Definition: BasicTypes.h:41
dwCANInterpreterInterface::getDatai32
dwCANInterpreterGetDatai32Func_t getDatai32
getDatai32 callback function.
Definition: Interpreter.h:94
char8_t
char char8_t
Definition: BasicTypes.h:47
dwCANInterpreter_getNumberSignalsInMessage
DW_API_PUBLIC dwStatus dwCANInterpreter_getNumberSignalsInMessage(uint32_t *num, const dwCANMessage *msg, dwCANInterpreterHandle_t interpreter)
Gets the number of signals a CAN interpreter can encode into the provided message.
dwCANInterpreter_getSignalNameInMessage
DW_API_PUBLIC dwStatus dwCANInterpreter_getSignalNameInMessage(const char8_t **name, uint32_t idx, const dwCANMessage *msg, dwCANInterpreterHandle_t interpreter)
Gets the name of a signal that the CAN interpreter can encode in the currently active encoded message...
dwCANInterpreter_getNumberSignals
DW_API_PUBLIC dwStatus dwCANInterpreter_getNumberSignals(uint32_t *num, dwCANInterpreterHandle_t interpreter)
Gets the number of signals decoded and available for consumption by the application side.
WFDCommitType
WFDCommitType
Definition: wfd.h:112
void
typedef void(WFD_APIENTRY PFNWFDBINDSOURCETOPIPELINEWITHTIMESTAMPNV)(const WFDDevice device
dwCANInterpreterInterface::getNumAvailableSignals
dwCANInterpreterGetNumAvailableFunc_t getNumAvailableSignals
getNumAvailableSignals callback function.
Definition: Interpreter.h:86
float64_t
double float64_t
Definition: BasicTypes.h:42
dwContextHandle_t
struct dwContextObject * dwContextHandle_t
Context handle.
Definition: Context.h:74
timestamp_us
dwTime_t timestamp_us
Definition: IMUTypes.h:9
dwCANInterpreterHandle_t
struct dwCANInterpreterObject * dwCANInterpreterHandle_t
CAN message interpreter handle.
Definition: Interpreter.h:51
dwCANInterpreterInterface
struct dwCANInterpreterInterface dwCANInterpreterInterface
Interface for callback based CAN data interpreter.
dwCANInterpreter_getSignalName
DW_API_PUBLIC dwStatus dwCANInterpreter_getSignalName(const char8_t **name, uint32_t idx, dwCANInterpreterHandle_t interpreter)
Gets the name of a signal available for consumption by the application as a string.
dwCANInterpreter_encodef32
DW_API_PUBLIC dwStatus dwCANInterpreter_encodef32(float32_t value, const char8_t *signal, dwCANMessage *msg, dwCANInterpreterHandle_t interpreter)
Encodes a value for a signal into a given message.
dwCANInterpreterGetSignalInfoFunc_t
bool(* dwCANInterpreterGetSignalInfoFunc_t)(const char8_t **name, dwTrivialDataType *type, dwCANVehicleData *data, uint32_t idx, void *userData)
Gets the name and type of a signal; the callback must return false if the query fails,...
Definition: Interpreter.h:64
dwCANInterpreter_createMessageFromName
DW_API_PUBLIC dwStatus dwCANInterpreter_createMessageFromName(dwCANMessage *msg, const char8_t *msgName, dwCANInterpreterHandle_t interpreter)
Initializes an empty can message an interpreter can encoded signals into.
dwStatus
dwStatus
Status definition.
Definition: ErrorDefs.h:27
dwCANInterpreterGetDataf64Func_t
bool(* dwCANInterpreterGetDataf64Func_t)(float64_t *value, dwTime_t *timestamp_us, uint32_t idx, void *userData)
Returns false if no float64 data is available, true otherwise For the user-function expected behavior...
Definition: Interpreter.h:74
dwCANInterpreterInterface::getDataf64
dwCANInterpreterGetDataf64Func_t getDataf64
getDataf64 callback function.
Definition: Interpreter.h:92
dwCANInterpreter_getf32
DW_API_PUBLIC dwStatus dwCANInterpreter_getf32(float32_t *value, dwTime_t *timestamp_us, uint32_t idx, dwCANInterpreterHandle_t interpreter)
Gets a 'float32_t' value from the available values.
dwCANInterpreter_encodei32
DW_API_PUBLIC dwStatus dwCANInterpreter_encodei32(int32_t value, const char8_t *signal, dwCANMessage *msg, dwCANInterpreterHandle_t interpreter)
Same as dwCANInterpreter_encodef32, but for int32 types.
DW_API_PUBLIC
#define DW_API_PUBLIC
Definition: Exports.h:38
dwCANInterpreterInterface::addMessage
dwCANInterpreterAddMessageFunc_t addMessage
addMessage callback function.
Definition: Interpreter.h:84
dwCANInterpreter_encodef64
DW_API_PUBLIC dwStatus dwCANInterpreter_encodef64(float64_t value, const char8_t *signal, dwCANMessage *msg, dwCANInterpreterHandle_t interpreter)
Same as dwCANInterpreter_encodef32, but for float64 types.
dwTrivialDataType
dwTrivialDataType
Specifies a type indicator of the underlying trivial data type.
Definition: TypesExtra.h:42
dwCANInterpreter_buildFromDBC
DW_API_PUBLIC dwStatus dwCANInterpreter_buildFromDBC(dwCANInterpreterHandle_t *interpreter, const char8_t *inputDBC, dwContextHandle_t ctx)
Creates a CAN data interpreter based on DBC file format.
dwCANInterpreterInterface::getSignalInfo
dwCANInterpreterGetSignalInfoFunc_t getSignalInfo
getSignalInfo callback function.
Definition: Interpreter.h:88
type
const WFDCommitType type
Definition: wfdext.h:123
dwCANInterpreterInterface::getDataf32
dwCANInterpreterGetDataf32Func_t getDataf32
getDataf32 callback function.
Definition: Interpreter.h:90
dwCANInterpreter_getSignalType
DW_API_PUBLIC dwStatus dwCANInterpreter_getSignalType(dwTrivialDataType *type, uint32_t idx, dwCANInterpreterHandle_t interpreter)
Returns the type of the value of a signal available for consumption by the application.