From 5ac4b23b7c3219ef2e7103293b0aeebdd0bd4eda Mon Sep 17 00:00:00 2001 From: Anatoly Baksheev Date: Fri, 22 Oct 2010 16:57:22 +0000 Subject: [PATCH] added PtrStep structure to pass in __global__ functions --- modules/gpu/include/opencv2/gpu/devmem2d.hpp | 32 +++++++++++++++++--- 1 file changed, 27 insertions(+), 5 deletions(-) diff --git a/modules/gpu/include/opencv2/gpu/devmem2d.hpp b/modules/gpu/include/opencv2/gpu/devmem2d.hpp index 80290ed2e9..f3293c027a 100644 --- a/modules/gpu/include/opencv2/gpu/devmem2d.hpp +++ b/modules/gpu/include/opencv2/gpu/devmem2d.hpp @@ -47,30 +47,52 @@ namespace cv { namespace gpu { - // Simple lightweight structure that encapsulates image ptr on device, its pitch and its sizes. + // Simple lightweight structures that encapsulates information about an image on device. // It is intended to pass to nvcc-compiled code. GpuMat depends on headers that nvcc can't compile - template - struct DevMem2D_ + template struct PtrStep_ { - typedef T elem_t; - enum { elem_size = sizeof(elem_t) }; + T* ptr; + size_t step; + + typedef T elem_type; + enum { elem_size = sizeof(elem_type) }; +#if defined(__CUDACC__) + __host__ __device__ +#endif + size_t elemSize() const { return elem_size; } + }; + + template struct DevMem2D_ + { int cols; int rows; T* ptr; size_t step; size_t elem_step; + /*__host__*/ DevMem2D_() : cols(0), rows(0), ptr(0), step(0), elem_step(0) {} + /*__host__*/ DevMem2D_(int rows_, int cols_, T *ptr_, size_t step_) : cols(cols_), rows(rows_), ptr(ptr_), step(step_), elem_step(step_ / sizeof(T)) {} template + /*__host__*/ explicit DevMem2D_(const DevMem2D_& d) : cols(d.cols), rows(d.rows), ptr((T*)d.ptr), step(d.step), elem_step(d.step / sizeof(T)) {} + template + /*__host__*/ + operator PtrStep_() const { PtrStep_ dt; dt.ptr = ptr; dt.step = step; return dt; } + + typedef typename PtrStep_::elem_type elem_type; + enum { elem_size = PtrStep_::elem_size }; +#if defined(__CUDACC__) + __host__ __device__ +#endif size_t elemSize() const { return elem_size; } };