DriveWorks SDK Reference

| 0.6.67 Release

Interpreter.h
Go to the documentation of this file.
1 // This code contains NVIDIA Confidential Information and is disclosed
3 // under the Mutual Non-Disclosure Agreement.
4 //
5 // Notice
6 // ALL NVIDIA DESIGN SPECIFICATIONS AND CODE ("MATERIALS") ARE PROVIDED "AS IS" NVIDIA MAKES
7 // NO REPRESENTATIONS, WARRANTIES, EXPRESSED, IMPLIED, STATUTORY, OR OTHERWISE WITH RESPECT TO
8 // THE MATERIALS, AND EXPRESSLY DISCLAIMS ANY IMPLIED WARRANTIES OF NONINFRINGEMENT,
9 // MERCHANTABILITY, OR FITNESS FOR A PARTICULAR PURPOSE.
10 //
11 // NVIDIA Corporation assumes no responsibility for the consequences of use of such
12 // information or for any infringement of patents or other rights of third parties that may
13 // result from its use. No license is granted by implication or otherwise under any patent
14 // or patent rights of NVIDIA Corporation. No third party distribution is allowed unless
15 // expressly authorized by NVIDIA. Details are subject to change without notice.
16 // This code supersedes and replaces all information previously supplied.
17 // NVIDIA Corporation products are not authorized for use as critical
18 // components in life support devices or systems without express written approval of
19 // NVIDIA Corporation.
20 //
21 // Copyright (c) 2016 NVIDIA Corporation. All rights reserved.
22 //
23 // NVIDIA Corporation and its licensors retain all intellectual property and proprietary
24 // rights in and to this software and related documentation and any modifications thereto.
25 // Any use, reproduction, disclosure or distribution of this software and related
26 // documentation without an express license agreement from NVIDIA Corporation is
27 // strictly prohibited.
28 //
30 
45 #ifndef DW_SENSORS_CANBUS_INTERPRETER_H__
46 #define DW_SENSORS_CANBUS_INTERPRETER_H__
47 
48 #include <dw/core/Config.h>
49 #include <dw/core/Exports.h>
50 
51 #include <dw/sensors/canbus/CAN.h>
53 
54 #ifdef __cplusplus
55 extern "C" {
56 #endif
57 
59 typedef struct dwCANInterpreterObject *dwCANInterpreterHandle_t;
60 
62 typedef void (*dwCANInterpreterAddMessageFunc_t)(const dwCANMessage *msg, void *userData);
63 
65 typedef uint32_t (*dwCANInterpreterGetNumAvailableFunc_t)(void *userData);
66 
68 typedef dwBool (*dwCANInterpreterGetSignalInfoFunc_t)(const char **name, dwTrivialDataType *type,
69  dwCANVehicleData *data,
70  uint32_t idx, void *userData);
71 
73 typedef dwBool (*dwCANInterpreterGetDataf32Func_t)(float32_t *value, dwTime_t *timestamp_us, uint32_t idx, void *userData);
74 
76 typedef dwBool (*dwCANInterpreterGetDataf64Func_t)(float64_t *value, dwTime_t *timestamp_us, uint32_t idx, void *userData);
77 
79 typedef dwBool (*dwCANInterpreterGetDatai32Func_t)(int32_t *value, dwTime_t *timestamp_us, uint32_t idx, void *userData);
80 
81 
83 typedef struct dwCANInterpreterInterface {
91 
108 dwStatus dwCANInterpreter_buildFromCallbacks(dwCANInterpreterHandle_t *interpreter, dwCANInterpreterInterface callbacks,
109  void *userData, dwContextHandle_t context);
110 
135 dwStatus dwCANInterpreter_buildFromDBC(dwCANInterpreterHandle_t *interpreter,
136  const char *inputDBC,
137  dwContextHandle_t ctx);
138 
152 dwStatus dwCANInterpreter_release(dwCANInterpreterHandle_t *interpreter);
153 
154 
155 
156 // ------------ encoding
174  const dwCANMessage *msg,
175  dwCANInterpreterHandle_t interpreter);
176 
177 
195 dwStatus dwCANInterpreter_getSignalNameInMessage(const char **name, uint32_t idx,
196  const dwCANMessage *msg,
197  dwCANInterpreterHandle_t interpreter);
198 
213 dwStatus dwCANInterpreter_createMessage(dwCANMessage* msg, uint32_t id, dwCANInterpreterHandle_t interpreter);
214 
215 
235 dwStatus dwCANInterpreter_encodef32(float32_t value, const char *signal,
236  dwCANMessage *msg,
237  dwCANInterpreterHandle_t interpreter);
238 
243 dwStatus dwCANInterpreter_encodef64(float64_t value, const char *signal,
244  dwCANMessage *msg,
245  dwCANInterpreterHandle_t interpreter);
246 
251 dwStatus dwCANInterpreter_encodei32(int32_t value, const char *signal,
252  dwCANMessage *msg,
253  dwCANInterpreterHandle_t interpreter);
254 
255 
256 // ----------------- consumption
271  dwCANInterpreterHandle_t interpreter);
272 
287 dwStatus dwCANInterpreter_getNumberSignals(uint32_t *num, dwCANInterpreterHandle_t interpreter);
288 
289 
311  dwCANInterpreterHandle_t interpreter);
312 
313 
328 dwStatus dwCANInterpreter_getSignalName(const char **name, uint32_t idx,
329  dwCANInterpreterHandle_t interpreter);
330 
346  dwCANInterpreterHandle_t interpreter);
347 
370 dwStatus dwCANInterpreter_getf32(float32_t *value, dwTime_t *timestamp_us, uint32_t idx, dwCANInterpreterHandle_t interpreter);
371 
376 dwStatus dwCANInterpreter_getf64(float64_t *value, dwTime_t *timestamp_us, uint32_t idx, dwCANInterpreterHandle_t interpreter);
377 
382 dwStatus dwCANInterpreter_geti32(int32_t *value, dwTime_t *timestamp_us, uint32_t idx, dwCANInterpreterHandle_t interpreter);
383 
384 
385 #ifdef __cplusplus
386 }
387 #endif
388 
389 #endif // DW_SENSORS_CANBUS_INTERPRETER_H__
DW_API_PUBLIC dwStatus dwCANInterpreter_encodef64(float64_t value, const char *signal, dwCANMessage *msg, dwCANInterpreterHandle_t interpreter)
Same as dwCANInterpreter_encodef32, but for float64 types.
float float32_t
Specifies POD types.
Definition: Types.h:77
dwCANInterpreterGetDatai32Func_t getDatai32
Definition: Interpreter.h:89
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.
dwTrivialDataType
Specifies a type indicator of the underlying trivial data type.
Definition: Types.h:104
Interface for callback based CAN data interpreter.
Definition: Interpreter.h:83
dwCANInterpreterGetDataf32Func_t getDataf32
Definition: Interpreter.h:87
dwBool(* dwCANInterpreterGetSignalInfoFunc_t)(const char **name, dwTrivialDataType *type, dwCANVehicleData *data, uint32_t idx, void *userData)
Gets the name and type of a signal; the callback must return DW_FALSE if the query fails...
Definition: Interpreter.h:68
dwCANInterpreterGetDataf64Func_t getDataf64
Definition: Interpreter.h:88
NVIDIA DriveWorks API: Vehicle Data
uint64_t dwTime_t
Specifies a timestamp unit, in microseconds.
Definition: Types.h:89
dwBool(* dwCANInterpreterGetDataf64Func_t)(float64_t *value, dwTime_t *timestamp_us, uint32_t idx, void *userData)
Returns DW_FALSE if no float64 data is available.
Definition: Interpreter.h:76
DW_API_PUBLIC dwStatus dwCANInterpreter_encodei32(int32_t value, const char *signal, dwCANMessage *msg, dwCANInterpreterHandle_t interpreter)
Same as dwCANInterpreter_encodef32, but for int32 types.
dwBool(* dwCANInterpreterGetDataf32Func_t)(float32_t *value, dwTime_t *timestamp_us, uint32_t idx, void *userData)
Returns DW_FALSE if no float32 data is available.
Definition: Interpreter.h:73
NVIDIA DriveWorks API: Core Exports
double float64_t
Definition: Types.h:78
dwCANVehicleData
A set of enumeration constants representing the default data signals.
Definition: VehicleData.h:65
dwCANInterpreterGetNumAvailableFunc_t getNumAvailableSignals
Definition: Interpreter.h:85
dwStatus
Status definition.
Definition: Status.h:167
DW_API_PUBLIC dwStatus dwCANInterpreter_encodef32(float32_t value, const char *signal, dwCANMessage *msg, dwCANInterpreterHandle_t interpreter)
Encodes a value for a signal into a given message.
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.
DW_API_PUBLIC dwStatus dwCANInterpreter_getSignalNameInMessage(const char **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...
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...
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.
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...
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.
DW_API_PUBLIC dwStatus dwCANInterpreter_buildFromDBC(dwCANInterpreterHandle_t *interpreter, const char *inputDBC, dwContextHandle_t ctx)
Creates a CAN data interpreter based on DBC file format.
DW_API_PUBLIC dwStatus dwCANInterpreter_getSignalName(const char **name, uint32_t idx, dwCANInterpreterHandle_t interpreter)
Gets the name of a signal available for consumption by the application as a string.
dwBool(* dwCANInterpreterGetDatai32Func_t)(int32_t *value, dwTime_t *timestamp_us, uint32_t idx, void *userData)
Returns DW_FALSE if no int32 data is available.
Definition: Interpreter.h:79
NVIDIA DriveWorks API: CAN
dwCANInterpreterGetSignalInfoFunc_t getSignalInfo
Definition: Interpreter.h:86
uint8_t dwBool
Definition: Types.h:79
struct dwContextObject * dwContextHandle_t
Context handle.
Definition: Context.h:78
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.
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.
DW_API_PUBLIC dwStatus dwCANInterpreter_release(dwCANInterpreterHandle_t *interpreter)
Closes previously opened interpreter.
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.
void(* dwCANInterpreterAddMessageFunc_t)(const dwCANMessage *msg, void *userData)
Pushes new messages to the interpreter.
Definition: Interpreter.h:62
#define DW_API_PUBLIC
Definition: Exports.h:76
uint32_t(* dwCANInterpreterGetNumAvailableFunc_t)(void *userData)
Gets the number of signals available to be retrieved. The same signal may be available multiple times...
Definition: Interpreter.h:65
DW_API_PUBLIC dwStatus dwCANInterpreter_consume(const dwCANMessage *msg, dwCANInterpreterHandle_t interpreter)
Pushes a new message to the interpreter.
Holds a CAN package.
Definition: CAN.h:109
dwCANInterpreterAddMessageFunc_t addMessage
Definition: Interpreter.h:84
struct dwCANInterpreterObject * dwCANInterpreterHandle_t
CAN message interpreter handle.
Definition: Interpreter.h:59