Reputation: 29041
I've previously been able to populate textures in CUDA for use in OpenGL by:
gl::GenTextures()
, etc.)In the update/render loop:
cudaGraphicsMapResource()
with the PBOcudaGraphicsUnmapResource()
the PBO from CUDAHowever, I'm wondering if PBOs are still the best way to write a texture from a kernel. I've seen articles like this one (updated for v5 here) which don't appear to use PBOs at all.
I've seen some references to cudaTextureObject
and cudaSurfaceObject
, but their role in OpenGL interop is unclear to me.
Are PBOs still the recommended approach? If not, what are the alternatives I should be investigating?
(I'm specifically targeting Kepler and newer architectures.)
Upvotes: 4
Views: 3728
Reputation: 772
You may want to look at this very recent CUDA GL Interop example from NVIDIA:
https://github.com/nvpro-samples/gl_cuda_interop_pingpong_st
Upvotes: 2
Reputation: 1259
You can see on the official example in CUDA 6 SDK, it's called "simpleCUDA2GL" in "3_Imaging" directory. It has two different approaches to access texture inside CUDA kernel. One of them (I think the old one) uses the PBO, and it is 3 times slower on my machine.
Upvotes: 2