2012-08-04 02:51:27 +00:00
|
|
|
//
|
2013-07-18 21:19:50 +00:00
|
|
|
// Copyright 2013 Pixar
|
2012-08-04 02:51:27 +00:00
|
|
|
//
|
2013-07-18 21:19:50 +00:00
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License
|
|
|
|
// and the following modification to it: Section 6 Trademarks.
|
|
|
|
// deleted and replaced with:
|
2012-08-04 02:51:27 +00:00
|
|
|
//
|
2013-07-18 21:19:50 +00:00
|
|
|
// 6. Trademarks. This License does not grant permission to use the
|
|
|
|
// trade names, trademarks, service marks, or product names of the
|
|
|
|
// Licensor and its affiliates, except as required for reproducing
|
|
|
|
// the content of the NOTICE file.
|
2012-08-04 02:51:27 +00:00
|
|
|
//
|
2013-07-18 21:19:50 +00:00
|
|
|
// You may obtain a copy of the License at
|
2012-08-04 02:51:27 +00:00
|
|
|
//
|
2013-07-18 21:19:50 +00:00
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing,
|
|
|
|
// software distributed under the License is distributed on an
|
|
|
|
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
|
|
|
|
// either express or implied. See the License for the specific
|
|
|
|
// language governing permissions and limitations under the
|
|
|
|
// License.
|
2012-08-04 02:51:27 +00:00
|
|
|
//
|
2012-06-21 00:11:17 +00:00
|
|
|
|
2013-06-10 22:54:40 +00:00
|
|
|
#include "../osd/cudaGLVertexBuffer.h"
|
|
|
|
#include "../osd/error.h"
|
|
|
|
|
|
|
|
#include "../osd/opengl.h"
|
2012-06-21 00:11:17 +00:00
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
#include <cuda_runtime.h>
|
|
|
|
#include <cuda_gl_interop.h>
|
2012-06-21 00:11:17 +00:00
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
#include <cassert>
|
2012-06-21 00:11:17 +00:00
|
|
|
|
|
|
|
namespace OpenSubdiv {
|
|
|
|
namespace OPENSUBDIV_VERSION {
|
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
OsdCudaGLVertexBuffer::OsdCudaGLVertexBuffer(int numElements, int numVertices)
|
|
|
|
: _numElements(numElements), _numVertices(numVertices),
|
|
|
|
_vbo(0), _devicePtr(0), _cudaResource(0) {
|
2012-06-21 00:11:17 +00:00
|
|
|
}
|
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
OsdCudaGLVertexBuffer::~OsdCudaGLVertexBuffer() {
|
2012-06-21 00:11:17 +00:00
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
unmap();
|
|
|
|
cudaGraphicsUnregisterResource(_cudaResource);
|
|
|
|
glDeleteBuffers(1, &_vbo);
|
|
|
|
}
|
2012-08-04 02:51:27 +00:00
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
OsdCudaGLVertexBuffer *
|
|
|
|
OsdCudaGLVertexBuffer::Create(int numElements, int numVertices) {
|
|
|
|
OsdCudaGLVertexBuffer *instance =
|
|
|
|
new OsdCudaGLVertexBuffer(numElements, numVertices);
|
|
|
|
if (instance->allocate()) return instance;
|
2013-01-26 02:31:40 +00:00
|
|
|
OsdError(OSD_CUDA_GL_ERROR,"OsdCudaGLVertexBuffer::Create failed.\n");
|
2012-12-11 01:15:13 +00:00
|
|
|
delete instance;
|
|
|
|
return NULL;
|
2012-06-21 00:11:17 +00:00
|
|
|
}
|
|
|
|
|
2012-08-04 02:51:27 +00:00
|
|
|
void
|
2013-03-08 01:50:15 +00:00
|
|
|
OsdCudaGLVertexBuffer::UpdateData(const float *src, int startVertex, int numVertices) {
|
2012-08-04 02:51:27 +00:00
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
map();
|
2013-03-08 01:50:15 +00:00
|
|
|
cudaMemcpy((float*)_devicePtr + _numElements * startVertex,
|
|
|
|
src,
|
|
|
|
_numElements * numVertices * sizeof(float),
|
2012-12-11 01:15:13 +00:00
|
|
|
cudaMemcpyHostToDevice);
|
2013-08-29 00:11:19 +00:00
|
|
|
|
2012-06-21 00:11:17 +00:00
|
|
|
}
|
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
int
|
|
|
|
OsdCudaGLVertexBuffer::GetNumElements() const {
|
2012-08-04 02:51:27 +00:00
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
return _numElements;
|
2012-08-04 02:51:27 +00:00
|
|
|
}
|
2012-06-21 00:11:17 +00:00
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
int
|
|
|
|
OsdCudaGLVertexBuffer::GetNumVertices() const {
|
|
|
|
|
|
|
|
return _numVertices;
|
2012-06-21 00:11:17 +00:00
|
|
|
}
|
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
float *
|
|
|
|
OsdCudaGLVertexBuffer::BindCudaBuffer() {
|
2012-08-04 02:51:27 +00:00
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
map();
|
|
|
|
return static_cast<float*>(_devicePtr);
|
2012-06-21 00:11:17 +00:00
|
|
|
}
|
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
GLuint
|
|
|
|
OsdCudaGLVertexBuffer::BindVBO() {
|
2012-08-04 02:51:27 +00:00
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
unmap();
|
|
|
|
return _vbo;
|
2012-06-21 00:11:17 +00:00
|
|
|
}
|
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
bool
|
|
|
|
OsdCudaGLVertexBuffer::allocate() {
|
2012-08-04 02:51:27 +00:00
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
int size = _numElements * _numVertices * sizeof(float);
|
2013-01-26 02:31:40 +00:00
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
glGenBuffers(1, &_vbo);
|
2012-06-21 00:11:17 +00:00
|
|
|
glBindBuffer(GL_ARRAY_BUFFER, _vbo);
|
2013-08-29 00:11:19 +00:00
|
|
|
glBufferData(GL_ARRAY_BUFFER, size, 0, GL_DYNAMIC_DRAW);
|
2013-03-08 01:50:15 +00:00
|
|
|
glBindBuffer(GL_ARRAY_BUFFER, 0);
|
2012-08-04 02:51:27 +00:00
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
// register vbo as cuda resource
|
|
|
|
cudaError_t err = cudaGraphicsGLRegisterBuffer(
|
2013-08-29 00:11:19 +00:00
|
|
|
&_cudaResource, _vbo, cudaGraphicsMapFlagsWriteDiscard);
|
2012-12-11 01:15:13 +00:00
|
|
|
|
|
|
|
if (err != cudaSuccess) return false;
|
|
|
|
return true;
|
2012-06-21 00:11:17 +00:00
|
|
|
}
|
|
|
|
|
2012-12-11 01:15:13 +00:00
|
|
|
void
|
|
|
|
OsdCudaGLVertexBuffer::map() {
|
|
|
|
|
|
|
|
if (_devicePtr) return;
|
|
|
|
size_t num_bytes;
|
|
|
|
void *ptr;
|
|
|
|
|
2013-03-08 01:50:15 +00:00
|
|
|
cudaError_t err = cudaGraphicsMapResources(1, &_cudaResource, 0);
|
|
|
|
if (err != cudaSuccess)
|
|
|
|
OsdError(OSD_CUDA_GL_ERROR, "OsdCudaGLVertexBuffer::map failed.\n%s\n", cudaGetErrorString(err));
|
|
|
|
err = cudaGraphicsResourceGetMappedPointer(&ptr, &num_bytes, _cudaResource);
|
|
|
|
if (err != cudaSuccess)
|
|
|
|
OsdError(OSD_CUDA_GL_ERROR, "OsdCudaGLVertexBuffer::map failed.\n%s\n", cudaGetErrorString(err));
|
2012-12-11 01:15:13 +00:00
|
|
|
_devicePtr = ptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
OsdCudaGLVertexBuffer::unmap() {
|
|
|
|
|
|
|
|
if (_devicePtr == NULL) return;
|
2013-03-08 01:50:15 +00:00
|
|
|
cudaError_t err = cudaGraphicsUnmapResources(1, &_cudaResource, 0);
|
|
|
|
if (err != cudaSuccess)
|
|
|
|
OsdError(OSD_CUDA_GL_ERROR, "OsdCudaGLVertexBuffer::unmap failed.\n%s\n", cudaGetErrorString(err));
|
2012-12-11 01:15:13 +00:00
|
|
|
_devicePtr = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
} // end namespace OPENSUBDIV_VERSION
|
|
|
|
} // end namespace OpenSubdiv
|
2012-06-21 00:11:17 +00:00
|
|
|
|