summaryrefslogtreecommitdiffstats
path: root/ui/gl/async_pixel_transfer_delegate_stub.cc
diff options
context:
space:
mode:
authorepenner@chromium.org <epenner@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-12-17 09:01:59 +0000
committerepenner@chromium.org <epenner@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-12-17 09:01:59 +0000
commit32145a9eab73bf02ab820f03ec79dcacdfb43932 (patch)
tree95be4c92661eed312b44e299e54e8076798c1c9e /ui/gl/async_pixel_transfer_delegate_stub.cc
parent3abf5ba76821e9aff27e2bbde17d913c132ff7b0 (diff)
downloadchromium_src-32145a9eab73bf02ab820f03ec79dcacdfb43932.zip
chromium_src-32145a9eab73bf02ab820f03ec79dcacdfb43932.tar.gz
chromium_src-32145a9eab73bf02ab820f03ec79dcacdfb43932.tar.bz2
gpu: Add async pixel transfers.
This adds a generic async pixel transfer interface, a stub/fallback implementation and mocks/tests. NOTRY=true BUG=161337 Review URL: https://chromiumcodereview.appspot.com/11428140 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@173430 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'ui/gl/async_pixel_transfer_delegate_stub.cc')
-rw-r--r--ui/gl/async_pixel_transfer_delegate_stub.cc135
1 files changed, 135 insertions, 0 deletions
diff --git a/ui/gl/async_pixel_transfer_delegate_stub.cc b/ui/gl/async_pixel_transfer_delegate_stub.cc
new file mode 100644
index 0000000..6d92160
--- /dev/null
+++ b/ui/gl/async_pixel_transfer_delegate_stub.cc
@@ -0,0 +1,135 @@
+// Copyright (c) 2012 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "ui/gl/async_pixel_transfer_delegate_stub.h"
+
+#include "base/shared_memory.h"
+#include "build/build_config.h"
+#include "ui/gl/gl_bindings.h"
+
+using base::SharedMemory;
+using base::SharedMemoryHandle;
+
+namespace {
+// Gets the address of the data from shared memory.
+void* GetAddress(SharedMemory* shared_memory,
+ uint32 shm_size,
+ uint32 shm_data_offset,
+ uint32 shm_data_size) {
+ // Memory bounds have already been validated, so there
+ // is just DCHECKS here.
+ DCHECK(shared_memory);
+ DCHECK(shared_memory->memory());
+ DCHECK_LE(shm_data_offset + shm_data_size, shm_size);
+ return static_cast<int8*>(shared_memory->memory()) + shm_data_offset;
+}
+} // namespace
+
+namespace gfx {
+
+scoped_ptr<AsyncPixelTransferDelegate>
+ AsyncPixelTransferDelegate::Create(gfx::GLContext* context) {
+ return AsyncPixelTransferDelegateStub::Create(context);
+}
+
+scoped_ptr<AsyncPixelTransferDelegate>
+ AsyncPixelTransferDelegateStub::Create(gfx::GLContext* context) {
+ return make_scoped_ptr(
+ static_cast<AsyncPixelTransferDelegate*>(
+ new AsyncPixelTransferDelegateStub()));
+}
+
+AsyncTransferStateStub::AsyncTransferStateStub(GLuint texture_id) {
+ static const AsyncTexImage2DParams zero_params = {0, 0, 0, 0, 0, 0, 0, 0};
+ late_bind_define_params_ = zero_params;
+ needs_late_bind_ = false;
+}
+
+AsyncTransferStateStub::~AsyncTransferStateStub() {
+}
+
+bool AsyncTransferStateStub::TransferIsInProgress() {
+ return false;
+}
+
+void AsyncTransferStateStub::BindTransfer(AsyncTexImage2DParams* out_params) {
+ DCHECK(out_params);
+ DCHECK(needs_late_bind_);
+ *out_params = late_bind_define_params_;
+ needs_late_bind_ = false;
+}
+
+AsyncPixelTransferDelegateStub::AsyncPixelTransferDelegateStub() {
+}
+
+AsyncPixelTransferDelegateStub::~AsyncPixelTransferDelegateStub() {
+}
+
+AsyncPixelTransferState*
+ AsyncPixelTransferDelegateStub::CreateRawPixelTransferState(
+ GLuint texture_id) {
+ return static_cast<AsyncPixelTransferState*>(
+ new AsyncTransferStateStub(texture_id));
+}
+
+void AsyncPixelTransferDelegateStub::AsyncNotifyCompletion(
+ const base::Closure& task) {
+ task.Run();
+}
+
+void AsyncPixelTransferDelegateStub::AsyncTexImage2D(
+ AsyncPixelTransferState* transfer_state,
+ const AsyncTexImage2DParams& tex_params,
+ const AsyncMemoryParams& mem_params) {
+ // Save the define params to return later during deferred
+ // binding of the transfer texture.
+ DCHECK(transfer_state);
+ AsyncTransferStateStub* state =
+ static_cast<AsyncTransferStateStub*>(transfer_state);
+ // We don't actually need a late bind since this stub does
+ // everything synchronously, but this tries to be similar
+ // as an async implementation.
+ state->needs_late_bind_ = true;
+ state->late_bind_define_params_ = tex_params;
+ void* data = GetAddress(mem_params.shared_memory,
+ mem_params.shm_size,
+ mem_params.shm_data_offset,
+ mem_params.shm_data_size);
+ glTexImage2D(
+ tex_params.target,
+ tex_params.level,
+ tex_params.internal_format,
+ tex_params.width,
+ tex_params.height,
+ tex_params.border,
+ tex_params.format,
+ tex_params.type,
+ data);
+}
+
+void AsyncPixelTransferDelegateStub::AsyncTexSubImage2D(
+ AsyncPixelTransferState* transfer_state,
+ const AsyncTexSubImage2DParams& tex_params,
+ const AsyncMemoryParams& mem_params) {
+ void* data = GetAddress(mem_params.shared_memory,
+ mem_params.shm_size,
+ mem_params.shm_data_offset,
+ mem_params.shm_data_size);
+ DCHECK(transfer_state);
+ AsyncTransferStateStub* state =
+ static_cast<AsyncTransferStateStub*>(transfer_state);
+ DCHECK(!state->needs_late_bind_);
+ glTexSubImage2D(
+ tex_params.target,
+ tex_params.level,
+ tex_params.xoffset,
+ tex_params.yoffset,
+ tex_params.width,
+ tex_params.height,
+ tex_params.format,
+ tex_params.type,
+ data);
+}
+} // namespace gfx
+