Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(836)

Unified Diff: content/renderer/pepper/ppb_graphics_3d_impl.cc

Issue 1964793002: Revert of [Reland 1] Pepper takes ownership of a mailbox before passing it to the texture layer. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « content/renderer/pepper/ppb_graphics_3d_impl.h ('k') | gpu/command_buffer/service/gles2_cmd_decoder.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: content/renderer/pepper/ppb_graphics_3d_impl.cc
diff --git a/content/renderer/pepper/ppb_graphics_3d_impl.cc b/content/renderer/pepper/ppb_graphics_3d_impl.cc
index 59093934f383bfad90c544aae09b92ec73e860d3..f1a00da143adc79283601b0c222cad53438acb32 100644
--- a/content/renderer/pepper/ppb_graphics_3d_impl.cc
+++ b/content/renderer/pepper/ppb_graphics_3d_impl.cc
@@ -28,7 +28,6 @@
#include "third_party/WebKit/public/web/WebElement.h"
#include "third_party/WebKit/public/web/WebLocalFrame.h"
#include "third_party/WebKit/public/web/WebPluginContainer.h"
-#include "third_party/khronos/GLES2/gl2.h"
using ppapi::thunk::EnterResourceNoLock;
using ppapi::thunk::PPB_Graphics3D_API;
@@ -115,22 +114,6 @@
command_buffer_->EnsureWorkVisible();
}
-void PPB_Graphics3D_Impl::TakeFrontBuffer() {
- if (!taken_front_buffer_.IsZero()) {
- DLOG(ERROR)
- << "TakeFrontBuffer should only be called once before DoSwapBuffers";
- return;
- }
- taken_front_buffer_ = GenerateMailbox();
- command_buffer_->TakeFrontBuffer(taken_front_buffer_);
-}
-
-void PPB_Graphics3D_Impl::ReturnFrontBuffer(const gpu::Mailbox& mailbox,
- const gpu::SyncToken& sync_token,
- bool is_lost) {
- command_buffer_->ReturnFrontBuffer(mailbox, sync_token, is_lost);
-}
-
bool PPB_Graphics3D_Impl::BindToInstance(bool bind) {
bound_to_instance_ = bind;
return true;
@@ -160,10 +143,8 @@
int32_t PPB_Graphics3D_Impl::DoSwapBuffers(const gpu::SyncToken& sync_token) {
DCHECK(command_buffer_);
- if (taken_front_buffer_.IsZero()) {
- DLOG(ERROR) << "TakeFrontBuffer should be called before DoSwapBuffers";
- return PP_ERROR_FAILED;
- }
+ if (sync_token.HasData())
+ sync_token_ = sync_token;
if (bound_to_instance_) {
// If we are bound to the instance, we need to ask the compositor
@@ -173,18 +154,14 @@
//
// Don't need to check for NULL from GetPluginInstance since when we're
// bound, we know our instance is valid.
- cc::TextureMailbox texture_mailbox(taken_front_buffer_, sync_token,
- GL_TEXTURE_2D);
- taken_front_buffer_.SetZero();
- HostGlobals::Get()
- ->GetInstance(pp_instance())
- ->CommitTextureMailbox(texture_mailbox);
+ HostGlobals::Get()->GetInstance(pp_instance())->CommitBackingTexture();
commit_pending_ = true;
} else {
// Wait for the command to complete on the GPU to allow for throttling.
command_buffer_->SignalSyncToken(
- sync_token, base::Bind(&PPB_Graphics3D_Impl::OnSwapBuffers,
- weak_ptr_factory_.GetWeakPtr()));
+ sync_token_,
+ base::Bind(&PPB_Graphics3D_Impl::OnSwapBuffers,
+ weak_ptr_factory_.GetWeakPtr()));
}
return PP_OK_COMPLETIONPENDING;
@@ -283,6 +260,10 @@
if (command_buffer_id)
*command_buffer_id = command_buffer_->GetCommandBufferID();
+ mailbox_ = gpu::Mailbox::Generate();
+ if (!command_buffer_->ProduceFrontBuffer(mailbox_))
+ return false;
+
return true;
}
@@ -360,14 +341,4 @@
ppp_graphics_3d->Graphics3DContextLost(this_pp_instance);
}
-gpu::Mailbox PPB_Graphics3D_Impl::GenerateMailbox() {
- if (!mailboxes_to_reuse_.empty()) {
- gpu::Mailbox mailbox = mailboxes_to_reuse_.back();
- mailboxes_to_reuse_.pop_back();
- return mailbox;
- }
-
- return gpu::Mailbox::Generate();
-}
-
} // namespace content
« no previous file with comments | « content/renderer/pepper/ppb_graphics_3d_impl.h ('k') | gpu/command_buffer/service/gles2_cmd_decoder.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698