DriveWorks SDK Reference

| 0.6.67 Release

ImageStreamer.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 
46 #ifndef DW_IMAGE_IMAGESTREAMER_H__
47 #define DW_IMAGE_IMAGESTREAMER_H__
48 
49 #include <dw/core/Config.h>
50 #include <dw/core/Exports.h>
51 #include <dw/core/Context.h>
52 
53 #include <dw/image/Image.h>
54 
55 #ifdef __cplusplus
56 extern "C" {
57 #endif
58 
60 typedef struct dwImageStreamerObject *dwImageStreamerHandle_t;
61 
89 DW_API_PUBLIC dwStatus dwImageStreamer_initialize(dwImageStreamerHandle_t *streamer,
90  const dwImageProperties *from, dwImageType to,
91  dwContextHandle_t ctx);
92 
94 
100 
103 
111  const char *parameters;
112 
115  dwImageStreamerCrossProcessMode mode;
117 
119 
139 DW_API_PUBLIC dwStatus dwImageStreamer_initializeCrossProcess(dwImageStreamerHandle_t *streamer,
140  const dwImageProperties *from, dwImageType to,
142  dwContextHandle_t ctx);
143 
153 DW_API_PUBLIC dwStatus dwImageStreamer_release(dwImageStreamerHandle_t *streamer);
154 
170 dwStatus dwImageStreamer_setCUDAStream(cudaStream_t stream, dwImageStreamerHandle_t streamer);
171 
183 dwStatus dwImageStreamer_getCUDAStream(cudaStream_t *stream, dwImageStreamerHandle_t streamer);
184 
199 dwStatus dwImageStreamer_getOutputProperties(dwImageProperties* props, dwImageStreamerHandle_t streamer);
200 
201 // ---------- push -----------------
217 DW_API_PUBLIC dwStatus dwImageStreamer_postCPU(dwImageCPU *image, dwImageStreamerHandle_t streamer);
218 
222 DW_API_PUBLIC dwStatus dwImageStreamer_postGL(dwImageGL *image, dwImageStreamerHandle_t streamer);
223 
227 DW_API_PUBLIC dwStatus dwImageStreamer_postCUDA(dwImageCUDA *image, dwImageStreamerHandle_t streamer);
228 
229 // ---------- pop -----------------
244  dwTime_t timeout_us,
245  dwImageStreamerHandle_t streamer);
246 
251  dwTime_t timeout_us,
252  dwImageStreamerHandle_t streamer);
253 
258  dwTime_t timeout_us,
259  dwImageStreamerHandle_t streamer);
260 
261 // ---------- lease -----------------
276  dwTime_t timeout_us,
277  dwImageStreamerHandle_t streamer);
278 
283  dwTime_t timeout_us,
284  dwImageStreamerHandle_t streamer);
285 
290  dwTime_t timeout_us,
291  dwImageStreamerHandle_t streamer);
292 
293 // ---------- return -----------------
307  dwImageStreamerHandle_t streamer);
308 
313  dwImageStreamerHandle_t streamer);
314 
319  dwImageStreamerHandle_t streamer);
320 #ifdef __cplusplus
321 }
322 #endif
323 
325 // OS-specific
326 #ifdef VIBRANTE
327 #include "ImageStreamer_vibrante.h"
328 #endif
329 
330 
331 #endif // DW_IMAGE_IMAGESSTREAMER_H__
DW_API_PUBLIC dwStatus dwImageStreamer_waitPostedCPU(dwImageCPU **image, dwTime_t timeout_us, dwImageStreamerHandle_t streamer)
The producer streamer waits for the image sent to be returned by the consumer.
DW_API_PUBLIC dwStatus dwImageStreamer_postGL(dwImageGL *image, dwImageStreamerHandle_t streamer)
Same as dwImageStreamer_postCPU, but for dwImageGL.
struct dwImageStreamerObject * dwImageStreamerHandle_t
Definition: ImageStreamer.h:60
Defines a CUDA image.
Definition: Image.h:263
uint64_t dwTime_t
Specifies a timestamp unit, in microseconds.
Definition: Types.h:89
DW_API_PUBLIC dwStatus dwImageStreamer_returnReceivedGL(dwImageGL *image, dwImageStreamerHandle_t streamer)
Same as dwImageStreamer_returnReceivedCPU, but for dwImageGL.
DW_API_PUBLIC dwStatus dwImageStreamer_returnReceivedCPU(dwImageCPU *image, dwImageStreamerHandle_t streamer)
Return the received image back to the producer.
dwImageStreamerCrossProcessMode
Definition: ImageStreamer.h:96
DW_API_PUBLIC dwStatus dwImageStreamer_receiveCUDA(dwImageCUDA **image, dwTime_t timeout_us, dwImageStreamerHandle_t streamer)
Same as dwImageStreamer_receiveCPU, but for dwImageCUDA.
NVIDIA DriveWorks API: Core Methods
DW_API_PUBLIC dwStatus dwImageStreamer_waitPostedGL(dwImageGL **image, dwTime_t timeout_us, dwImageStreamerHandle_t streamer)
Same as dwImageStreamer_waitPostedCPU, but for dwImageGL.
NVIDIA DriveWorks API: Core Exports
NVIDIA DriveWorks API: Image Conversion and Streaming Functionality
dwStatus
Status definition.
Definition: Status.h:167
DW_API_PUBLIC dwStatus dwImageStreamer_postCUDA(dwImageCUDA *image, dwImageStreamerHandle_t streamer)
Same as dwImageStreamer_postCPU, but for dwImageCUDA.
DW_API_PUBLIC dwStatus dwImageStreamer_getOutputProperties(dwImageProperties *props, dwImageStreamerHandle_t streamer)
Get image properties of the image received from the streamer.
dwImageType
Specifies the image type.
Definition: Image.h:83
NVIDIA DriveWorks API: Image Streamer
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_waitPostedCUDA(dwImageCUDA **image, dwTime_t timeout_us, dwImageStreamerHandle_t streamer)
Same as dwImageStreamer_waitPostedCPU, but for dwImageCUDA.
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.
DW_API_PUBLIC dwStatus dwImageStreamer_postCPU(dwImageCPU *image, dwImageStreamerHandle_t streamer)
Sends an image through the streamer acting as the producer.
DW_API_PUBLIC dwStatus dwImageStreamer_receiveCPU(dwImageCPU **image, dwTime_t timeout_us, dwImageStreamerHandle_t streamer)
Receive a pointer to a dwImageCPU from the streamer, acting as a consumer.
Defines a GL texture image.
Definition: Image.h:251
struct dwContextObject * dwContextHandle_t
Context handle.
Definition: Context.h:78
dwImageStreamerCrossProcessMode mode
Operation mode of the cross-process image streamer.
Sets of parameters for cross-process image streamer creation.
DW_API_PUBLIC dwStatus dwImageStreamer_returnReceivedCUDA(dwImageCUDA *image, dwImageStreamerHandle_t streamer)
Same as dwImageStreamer_returnReceivedCPU, but for dwImageCUDA.
const char * parameters
Array to additional parameters provided to cross-process image streamer creation. ...
#define DW_API_PUBLIC
Definition: Exports.h:76
Defines the properties of the image.
Definition: Image.h:220
DW_API_PUBLIC dwStatus dwImageStreamer_release(dwImageStreamerHandle_t *streamer)
Releases the image streamer.
DW_API_PUBLIC dwStatus dwImageStreamer_receiveGL(dwImageGL **image, dwTime_t timeout_us, dwImageStreamerHandle_t streamer)
Same as dwImageStreamer_receiveCPU, but for dwImageGL.
Defines a CPU-based image.
Definition: Image.h:239
DW_API_PUBLIC dwStatus dwImageStreamer_getCUDAStream(cudaStream_t *stream, dwImageStreamerHandle_t streamer)
Get CUDA stream used by the image streamer.