DriveWorks SDK Reference
5.14.77 Release
For Test and Development only

Sensors.h
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) 2016-2023 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
54#ifndef DW_SENSORS_SENSORS_H_
55#define DW_SENSORS_SENSORS_H_
56
58#include <dw/core/base/Types.h>
62
63#ifdef __cplusplus
64extern "C" {
65#endif
66
68typedef enum dwPlatformOS {
71
74
77
81
83typedef struct dwSALObject* dwSALHandle_t;
84
86typedef struct dwSensorObject* dwSensorHandle_t;
87
89#define DW_SENSOR_MAX_PROTOCOL_NAME_LENGTH 32
91#define DW_SENSOR_MAX_PARAMETER_STRING_LENGTH 512
92
94typedef struct dwSensorParams
95{
99 const char8_t* protocol;
100
106 const char8_t* parameters;
107
113 const void* auxiliarydata;
114
116
121
124
127
130
133
137
139typedef struct dwSensorStats
140{
142 uint64_t events;
143
145 uint64_t errors;
146
148 uint64_t drops;
149
153
157
161
165
169
173
177
181
185
189
191 uint64_t crcErrors;
193
195typedef enum dwSensorType {
217
220{
223
225 uint64_t event;
226
228 uint64_t offset;
229
231 uint64_t size;
232
234
246
251{
252 struct
253 {
258
261
264
267
271
273#define DW_SENSOR_ERROR_ID_OFFSET_BIT 24U
275#define DW_SENSOR_ERROR_ID_OFFSET (1U << DW_SENSOR_ERROR_ID_OFFSET_BIT)
276
281typedef enum dwSensorErrorID {
287
300
312
326
345
362
376
389
402dwStatus dwSAL_getPlatformInfo(char8_t const** const osName, dwPlatformOS const os, dwSALHandle_t const sal);
403
419dwStatus dwSAL_getNumSensors(uint32_t* const num, dwPlatformOS const os, dwSALHandle_t const sal);
420
434dwStatus dwSAL_getSensorProtocol(const char** const name, uint32_t const idx, dwPlatformOS const os, dwSALHandle_t const sal);
435
451dwStatus dwSAL_getSensorParameterString(const char** const parameters, uint32_t const idx,
452 dwPlatformOS const os, dwSALHandle_t const sal);
453
467
489
502
515
538dwStatus dwSensor_readRawData(const uint8_t** const data, size_t* const size,
539 dwTime_t const timeoutUs,
540 dwSensorHandle_t const sensor);
541
556dwStatus dwSensor_returnRawData(const uint8_t* const data, dwSensorHandle_t const sensor);
557
574dwStatus dwSensor_getSeekRange(size_t* const eventCount,
575 dwTime_t* const startTimestampUs, dwTime_t* const endTimestampUs,
576 dwSensorHandle_t const sensor);
577
593
594/*
595 * Returns a pointer to the shared buffer with the contents of the sensor header and bufferSize
596 * will contain the number of valid bytes in the buffer.
597 *
598 * @param[out] - buffer A pointer to the buffer owned by sensor which holds the header information.
599 * @param[out] - bufferSize A pointer to variable indicating number of valid bytes in the buffer
600 * @param[in] - sensor Handle to the sensor to which the header info is requested
601 *
602 * @return DW_INVALID_HANDLE - if given sensor handle is invalid
603 * DW_INVALID_ARGUMENTS - if given arguments are invalid
604 * DW_SUCCESS - if call is successful.
605 */
606dwStatus dwSensor_getHeader(uint8_t const** const buffer, size_t* bufferSize, dwSensorHandle_t const sensor);
607
624dwStatus dwSensor_seekToTime(dwTime_t const timestampUs, dwSensorHandle_t const sensor);
625
641dwStatus dwSensor_seekToEvent(size_t const event, dwSensorHandle_t const sensor);
642
661
675
690dwStatus dwSensor_getSeekTableEntries(dwSensorSeekTableEntry* const entries, size_t const numEntries, dwSensorHandle_t const sensor);
691
715dwStatus dwSensor_saveSeekTable(const char* const fileName, dwSensorHandle_t const sensor);
716
737dwStatus dwSensor_setThreadPriority(int32_t const priority, dwSensorHandle_t const sensor);
738
759dwStatus dwSensor_setThreadAffinity(uint32_t const affinityMask, dwSensorHandle_t const sensor);
760
774
775#ifdef __cplusplus
776}
777#endif
778
780#endif // DW_SENSORS_SENSORS_H_
NVIDIA DriveWorks API: Core Methods
dwStatus
Status definition.
Definition: ErrorDefs.h:45
NVIDIA DriveWorks API: Health Signal Methods
DriveWorks API: Signal Status Library
NVIDIA DriveWorks API: Core Types
NVIDIA DriveWorks API: Core Exports
float float32_t
Specifies POD types.
Definition: BasicTypes.h:59
int64_t dwTime_t
Specifies a timestamp unit, in microseconds.
Definition: BasicTypes.h:65
double float64_t
Definition: BasicTypes.h:60
struct dwContextObject * dwContextHandle_t
Context handle.
Definition: Context.h:86
#define DW_API_PUBLIC
Definition: Exports.h:54
uint8_t dwSignalValidity
The type of the encoded status field.
Definition: SignalStatus.h:57
dwTime_t timeDeltaMax
Maximum observed host timestamp difference between two consecutive packets.
Definition: Sensors.h:160
float64_t standardDeviationDelta[DW_SENSOR_STATE_SENSOR_STAT_COUNT]
Array of Variance of all the deltas between consecutive timestamps as per the dwSensorStatTimeDiffere...
Definition: Sensors.h:184
uint64_t event
counter of this event
Definition: Sensors.h:225
uint64_t offset
offset into a file of this event
Definition: Sensors.h:228
const void * auxiliarydata
Additional data to pass to sensor creation function.
Definition: Sensors.h:113
dwTime_t minDelta[DW_SENSOR_STATE_SENSOR_STAT_COUNT]
Array of Minimum observed time difference between two consecutive packets as per the dwSensorStatTime...
Definition: Sensors.h:176
uint64_t crcErrors
Number of CRC errors.
Definition: Sensors.h:191
uint64_t errors
Number of encountered errors.
Definition: Sensors.h:145
uint64_t drops
Number of events dropped.
Definition: Sensors.h:148
uint64_t events
Number of normal events (excluding errors and drops).
Definition: Sensors.h:142
float64_t meanDelta[DW_SENSOR_STATE_SENSOR_STAT_COUNT]
Array of Mean of all the deltas between consecutive timestamps as per the dwSensorStatTimeDifference.
Definition: Sensors.h:188
dwTime_t timestamp_us
Timestamp for the current message.
Definition: Sensors.h:260
dwTime_t timeDeltaMin
Minimum observed host timestamp difference between two consecutive packets.
Definition: Sensors.h:156
float64_t timeDeltaStandardDeviation
Variance of all the deltas between consecutive host timestamps.
Definition: Sensors.h:164
dwTime_t currentDelta[DW_SENSOR_STATE_SENSOR_STAT_COUNT]
Array of Current time difference between two consecutive packets as per the dwSensorStatTimeDifferenc...
Definition: Sensors.h:172
dwSensorDrivingDirection direction
driving direction
Definition: Sensors.h:269
float32_t speed
vehicle velocity (m/s)
Definition: Sensors.h:263
struct dwSensorVehicleState::@3 validityInfo
dwTime_t maxDelta[DW_SENSOR_STATE_SENSOR_STAT_COUNT]
Array of Maximum observed time difference between two consecutive packets as per the dwSensorStatTime...
Definition: Sensors.h:180
float64_t timeDeltaMean
Mean of all the deltas between consecutive host timestamps.
Definition: Sensors.h:168
const char8_t * parameters
Array of additional parameters provided to sensor creation.
Definition: Sensors.h:106
dwTime_t timeDeltaCur
Current host timestamp difference between two consecutive packets.
Definition: Sensors.h:152
uint64_t size
size of the event present in the virtual data file, in bytes
Definition: Sensors.h:231
const char8_t * protocol
Name of the protocol.
Definition: Sensors.h:99
dwTime_t timestamp
timestamp of this entry [us]
Definition: Sensors.h:222
float32_t temperature
ambient temperature (C)
Definition: Sensors.h:266
DW_API_PUBLIC dwStatus dwSensor_getNumSeekTableEntries(size_t *const size, dwSensorHandle_t const hsensor)
Get the number of entries in the seek Table.
DW_API_PUBLIC dwStatus dwSensor_createSeekTable(dwSensorHandle_t const sensor)
Forces recreation of the seek table, for sensors that support seeking.
DW_API_PUBLIC dwStatus dwSensor_getStats(dwSensorStats *const stats, dwSensorHandle_t const sensor)
Gets sensor statistics (if available).
dwSensorStatTimeDifference
Defines the various delta used in statistics.
Definition: Sensors.h:118
DW_API_PUBLIC dwStatus dwSensor_reset(dwSensorHandle_t const sensor)
Resets the sensor.
DW_API_PUBLIC dwStatus dwSAL_getPlatform(dwPlatformOS *const os, dwSALHandle_t sal)
Gets current platform the SDK is running on.
DW_API_PUBLIC dwStatus dwSensor_setThreadPriority(int32_t const priority, dwSensorHandle_t const sensor)
Sets the priority of the internal thread, for sensors that use an internal thread to communicate to t...
DW_API_PUBLIC dwStatus dwSensor_saveSeekTable(const char *const fileName, dwSensorHandle_t const sensor)
Saves the seek table for the sensor to a file, for sensors that support seek tables.
DW_API_PUBLIC dwStatus dwSAL_setVehicleState(dwSensorVehicleState *const vehicleState, dwSALHandle_t const sal)
Pass vehicle state to all sensors.
dwStatus dwSensor_getHeader(uint8_t const **const buffer, size_t *bufferSize, dwSensorHandle_t const sensor)
DW_API_PUBLIC dwStatus dwSAL_createSensor(dwSensorHandle_t *const sensor, dwSensorParams const params, dwSALHandle_t const sal)
Creates a new sensor managed by the SAL module with the given parameters.
DW_API_PUBLIC dwStatus dwSensor_start(dwSensorHandle_t const sensor)
Starts the sensor previously successfully created with 'dwSAL_createSensor()'.
DW_API_PUBLIC dwStatus dwSAL_start(dwSALHandle_t const sal)
Bootstraps all sensors managed by the SAL module.
struct dwSALObject * dwSALHandle_t
Handle representing the Sensor Abstraction Layer interface.
Definition: Sensors.h:83
DW_API_PUBLIC dwStatus dwSensor_getSeekRange(size_t *const eventCount, dwTime_t *const startTimestampUs, dwTime_t *const endTimestampUs, dwSensorHandle_t const sensor)
Retrieves the valid range of seek parameters, for sensors that support seeking.
DW_API_PUBLIC dwStatus dwSAL_release(dwSALHandle_t const sal)
Releases the SAL (sensor abstraction layer) module.
DW_API_PUBLIC dwStatus dwSensor_seekToEvent(size_t const event, dwSensorHandle_t const sensor)
Seeks the sensor to an event, for sensors that support seeking.
DW_API_PUBLIC dwStatus dwSAL_getNumSensors(uint32_t *const num, dwPlatformOS const os, dwSALHandle_t const sal)
Gets number of available sensors for a platform.
DW_API_PUBLIC dwStatus dwSensor_stop(dwSensorHandle_t const sensor)
Stops the sensor.
DW_API_PUBLIC dwStatus dwSAL_initialize(dwSALHandle_t *const sal, dwContextHandle_t const context)
Creates and initializes a SAL (sensor abstraction layer) module.
dwSensorDrivingDirection
Driving Direction options.
Definition: Sensors.h:238
DW_API_PUBLIC dwStatus dwSensor_readRawData(const uint8_t **const data, size_t *const size, dwTime_t const timeoutUs, dwSensorHandle_t const sensor)
Reads RAW data from sensor as byte array at a given time (TimeoutUs).
DW_API_PUBLIC dwStatus dwSensor_returnRawData(const uint8_t *const data, dwSensorHandle_t const sensor)
Returns RAW data to sensor as a byte array.
DW_API_PUBLIC dwStatus dwSAL_getPlatformInfo(char8_t const **const osName, dwPlatformOS const os, dwSALHandle_t const sal)
Gets detailed information about the running hardware platform and operating system.
DW_API_PUBLIC dwStatus dwSAL_getSensorProtocol(const char **const name, uint32_t const idx, dwPlatformOS const os, dwSALHandle_t const sal)
Gets protocol name of a sensor for a given index, e.g., 'camera.gmsl' or 'can.file'.
DW_API_PUBLIC dwStatus dwSAL_releaseSensor(dwSensorHandle_t const sensor)
Releases a sensor managed by the SAL module.
dwSensorType
Defines the type of sensors that are available in DriveWorks.
Definition: Sensors.h:195
dwPlatformOS
Defines the operating system in use.
Definition: Sensors.h:68
DW_API_PUBLIC dwStatus dwSensor_setThreadAffinity(uint32_t const affinityMask, dwSensorHandle_t const sensor)
Sets the affinity of the internal thread, for sensors that use an internal thread to communicate to t...
DW_API_PUBLIC dwStatus dwSAL_getSensorParameterString(const char **const parameters, uint32_t const idx, dwPlatformOS const os, dwSALHandle_t const sal)
Gets the parameter string acceptable by a sensor whose type is determined by the index.
DW_API_PUBLIC dwStatus dwSensor_getSeekTableEntries(dwSensorSeekTableEntry *const entries, size_t const numEntries, dwSensorHandle_t const sensor)
Fill in the pre-allocated dwSensorSeekTableEntry array.
dwSensorErrorID
Sensor Error ID to be used in, e.g., dwErrorSignal.errorID[31:24] when DW_SENSOR_ERROR_CODE_OFFSET_BI...
Definition: Sensors.h:281
struct dwSensorObject * dwSensorHandle_t
Handle representing a sensor.
Definition: Sensors.h:86
DW_API_PUBLIC dwStatus dwSensor_getCurrentSeekPosition(size_t *const event, dwSensorHandle_t const sensor)
Gets the current seek position of the sensor.
DW_API_PUBLIC dwStatus dwSensor_seekToTime(dwTime_t const timestampUs, dwSensorHandle_t const sensor)
Seeks the sensor to a specific timestamp, for sensors that support seeking.
DW_API_PUBLIC dwStatus dwSAL_reset(dwSALHandle_t const sal)
Resets the SAL (sensor abstraction layer) module.
@ DW_SENSOR_STATE_DELTA_HOST_AND_SENSOR_TIME
Difference between host timestamp and sensor timestamp.
Definition: Sensors.h:126
@ DW_SENSOR_STATE_DELTA_READ_AND_RETURN_FRAME_TIME
Difference between readFrame and returnFrame time.
Definition: Sensors.h:132
@ DW_SENSOR_STATE_DELTA_HOST_AND_HOST_TIME
Difference between two consecutive host timestamp.
Definition: Sensors.h:120
@ DW_SENSOR_STATE_SENSOR_STAT_COUNT
Count which the type value is less than.
Definition: Sensors.h:135
@ DW_SENSOR_STATE_DELTA_SENSOR_AND_SENSOR_TIME
Difference between two consecutive sensor timestamp.
Definition: Sensors.h:123
@ DW_SENSOR_STATE_DELTA_CURRENT_AND_HOST_TIME
Difference between current time and the last host timestamp when sensor data was received.
Definition: Sensors.h:129
@ DW_SENSOR_DRIVING_DIRECTION_UNKNOWN
Driving direction is unknown or no moving.
Definition: Sensors.h:240
@ DW_SENSOR_DRIVING_DIRECTION_FORWARD
Driving direction is fowarding.
Definition: Sensors.h:242
@ DW_SENSOR_DRIVING_DIRECTION_BACKWARD
Driving direction is backwarding.
Definition: Sensors.h:244
@ DW_SENSOR_LIDAR
Lidar.
Definition: Sensors.h:199
@ DW_SENSOR_ULTRASONIC
Ultrasonic.
Definition: Sensors.h:213
@ DW_SENSOR_COUNT
Sensor count which the sensor type value is less than.
Definition: Sensors.h:215
@ DW_SENSOR_CAN
CAN.
Definition: Sensors.h:205
@ DW_SENSOR_IMU
IMU.
Definition: Sensors.h:203
@ DW_SENSOR_RADAR
RADAR.
Definition: Sensors.h:207
@ DW_SENSOR_CAMERA
CAMERA.
Definition: Sensors.h:197
@ DW_SENSOR_GPS
GPS.
Definition: Sensors.h:201
@ DW_SENSOR_TIME
TIME.
Definition: Sensors.h:209
@ DW_SENSOR_DATA
DATA.
Definition: Sensors.h:211
@ DW_PLATFORM_OS_V5Q
aarch64 based Drive 5 QNX.
Definition: Sensors.h:76
@ DW_PLATFORM_OS_V5L
aarch64 based Drive 5 Linux.
Definition: Sensors.h:73
@ DW_PLATFORM_OS_LINUX
Default Linux based platform.
Definition: Sensors.h:70
@ DW_PLATFORM_NUM
Number of available platforms.
Definition: Sensors.h:79
@ DW_SENSOR_ERROR_CODE_NO_NEW_DATA
no new data received
Definition: Sensors.h:285
@ DW_SENSOR_ERROR_CODE_INVALID
sensor ok
Definition: Sensors.h:283
Holds sets of parameters for sensor creation.
Definition: Sensors.h:95
A seek structure is made of memory offset, eventcount and timestamp.
Definition: Sensors.h:220
Holds the available statistics for a sensor.
Definition: Sensors.h:140
Vehicle State inputs.
Definition: Sensors.h:251