DriveWorks SDK Reference
5.4.5418 Release
For Test and Development only

ImageStreamer.h
Go to the documentation of this file.
1 //
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-2021 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 
47 #ifndef DW_IMAGE_IMAGESTREAMER_H_
48 #define DW_IMAGE_IMAGESTREAMER_H_
49 
50 #include <dw/core/Config.h>
51 #include <dw/core/base/Exports.h>
53 
54 #include <dw/image/Image.h>
55 
56 #ifdef __cplusplus
57 extern "C" {
58 #endif
59 
61 typedef struct dwImageStreamerObject* dwImageStreamerHandle_t;
62 
64 
70 
73 {
74 
81  const char* parameters;
82 
85  dwImageStreamerCrossProcessMode mode;
87 
103 dwStatus dwImageStreamer_setCUDAStream(cudaStream_t stream, dwImageStreamerHandle_t streamer);
104 
116 dwStatus dwImageStreamer_getCUDAStream(cudaStream_t* stream, dwImageStreamerHandle_t streamer);
117 
132 dwStatus dwImageStreamer_getOutputProperties(dwImageProperties* props, dwImageStreamerHandle_t const streamer);
133 
161 dwStatus dwImageStreamer_initialize(dwImageStreamerHandle_t* streamer,
162  const dwImageProperties* from, dwImageType to,
163  dwContextHandle_t ctx);
164 
183 DW_DEPRECATED("EGL based and legacy behavior will be deprecated")
184 dwStatus dwImageStreamer_initializeLegacy(dwImageStreamerHandle_t* streamer,
185  const dwImageProperties* from, dwImageType to,
186  dwContextHandle_t ctx);
187 
188 #ifdef VIBRANTE
189 
211 DW_DEPRECATED("The cross process streamer is deprecated and will be removed in the next version. The dwChannel can be used instead for cross process image streaming")
212 dwStatus dwImageStreamer_initializeCrossProcess(dwImageStreamerHandle_t* streamer,
213  const dwImageProperties* from, dwImageType to,
215  dwContextHandle_t ctx);
216 
237 DW_DEPRECATED("The EGL based cross process streamer is deprecated and will be removed in the next version.")
238 dwStatus dwImageStreamer_initializeCrossProcessEGL(dwImageStreamerHandle_t* streamer,
239  const dwImageProperties* from, dwImageType to,
241  dwContextHandle_t ctx);
242 #endif
243 
261 dwStatus dwImageStreamer_producerSend(dwImageHandle_t image, dwImageStreamerHandle_t const streamer);
262 
280  dwImageStreamerHandle_t const streamer);
281 
298  dwImageStreamerHandle_t const streamer);
299 
313 dwStatus dwImageStreamer_consumerReturn(dwImageHandle_t* image, dwImageStreamerHandle_t const streamer);
314 
325 dwStatus dwImageStreamer_release(dwImageStreamerHandle_t streamer);
326 
327 #ifdef __cplusplus
328 }
329 #endif
330 
332 #endif // DW_IMAGE_IMAGESSTREAMER_H_
DW_API_PUBLIC dwStatus dwImageStreamer_producerReturn(dwImageHandle_t *const image, dwTime_t const timeoutUs, dwImageStreamerHandle_t const streamer)
The producer streamer waits for the image sent to be returned by the consumer.
struct dwImageObject * dwImageHandle_t
Definition: Image.h:105
DW_API_PUBLIC dwStatus dwImageStreamer_getOutputProperties(dwImageProperties *props, dwImageStreamerHandle_t const streamer)
Get image properties of the image received from the streamer.
struct dwImageStreamerObject * dwImageStreamerHandle_t
Definition: ImageStreamer.h:61
dwImageStreamerCrossProcessMode
Definition: ImageStreamer.h:66
NVIDIA DriveWorks API: Image Conversion and Streaming Functionality
DW_API_PUBLIC dwStatus dwImageStreamer_initializeLegacy(dwImageStreamerHandle_t *streamer, const dwImageProperties *from, dwImageType to, dwContextHandle_t ctx)
Same as dwImageStreamer_initialize, but with EGL and Legacy behavior as backend.
DW_API_PUBLIC dwStatus dwImageStreamer_initializeCrossProcessEGL(dwImageStreamerHandle_t *streamer, const dwImageProperties *from, dwImageType to, dwImageStreamerCrossProcessModeParams params, dwContextHandle_t ctx)
Creates a variant of the cross process streamer based on EGL.
dwStatus
Status definition.
Definition: Status.h:180
int64_t dwTime_t
Specifies a timestamp unit, in microseconds.
Definition: Types.h:82
DW_API_PUBLIC dwStatus dwImageStreamer_producerSend(dwImageHandle_t image, dwImageStreamerHandle_t const streamer)
Sends an image through the streamer acting as the producer.
#define DW_DEPRECATED(msg)
Definition: Exports.h:66
dwImageType
Specifies the image type.
Definition: Image.h:93
DW_API_PUBLIC dwStatus dwImageStreamer_consumerReturn(dwImageHandle_t *image, dwImageStreamerHandle_t const streamer)
Return the received image back to the producer.
DW_API_PUBLIC dwStatus dwImageStreamer_initializeCrossProcess(dwImageStreamerHandle_t *streamer, const dwImageProperties *from, dwImageType to, dwImageStreamerCrossProcessModeParams params, dwContextHandle_t ctx)
Creates and initializes the image streamer capable of moving images between different API types acros...
DW_API_PUBLIC dwStatus dwImageStreamer_initialize(dwImageStreamerHandle_t *streamer, const dwImageProperties *from, dwImageType to, dwContextHandle_t ctx)
Creates and initializes the image streamer capable of moving images between different API types...
DW_API_PUBLIC dwStatus dwImageStreamer_setCUDAStream(cudaStream_t stream, dwImageStreamerHandle_t streamer)
Sets the CUDA stream for CUDA related streaming operations such as post and receive.
struct dwContextObject * dwContextHandle_t
Context handle.
Definition: Context.h:79
NVIDIA DriveWorks API: Core Methods
dwImageStreamerCrossProcessMode mode
Operation mode of the cross-process image streamer.
Definition: ImageStreamer.h:85
DW_API_PUBLIC dwStatus dwImageStreamer_consumerReceive(dwImageHandle_t *image, dwTime_t const timeoutUs, dwImageStreamerHandle_t const streamer)
Receive a pointer to a dwImageHandle_t from the streamer, acting as a consumer.
Sets of parameters for cross-process image streamer creation.
Definition: ImageStreamer.h:72
DW_API_PUBLIC dwStatus dwImageStreamer_release(dwImageStreamerHandle_t streamer)
Releases the image streamer.
const char * parameters
Array to additional parameters provided to cross-process image streamer creation. ...
Definition: ImageStreamer.h:81
#define DW_API_PUBLIC
Definition: Exports.h:54
Defines the properties of the image.
Definition: Image.h:367
NVIDIA DriveWorks API: Core Exports
DW_API_PUBLIC dwStatus dwImageStreamer_getCUDAStream(cudaStream_t *stream, dwImageStreamerHandle_t streamer)
Get CUDA stream used by the image streamer.