Index: gpu/command_buffer/service/gles2_cmd_decoder.cc |
diff --git a/gpu/command_buffer/service/gles2_cmd_decoder.cc b/gpu/command_buffer/service/gles2_cmd_decoder.cc |
index 6b254e0966bb8ad2de4ee746bf53e6f7cb3dc269..52a9c4351b47185261d76eba400f20aec9bb0b41 100644 |
--- a/gpu/command_buffer/service/gles2_cmd_decoder.cc |
+++ b/gpu/command_buffer/service/gles2_cmd_decoder.cc |
@@ -3099,16 +3099,11 @@ void GLES2DecoderImpl::DeleteFramebuffersHelper( |
GetFramebuffer(client_ids[ii]); |
if (framebuffer && !framebuffer->IsDeleted()) { |
if (framebuffer == framebuffer_state_.bound_draw_framebuffer.get()) { |
+ framebuffer_state_.bound_draw_framebuffer = NULL; |
+ framebuffer_state_.clear_state_dirty = true; |
GLenum target = supports_separate_framebuffer_binds ? |
GL_DRAW_FRAMEBUFFER_EXT : GL_FRAMEBUFFER; |
- |
- // Unbind attachments on FBO before deletion. |
- if (workarounds().unbind_attachments_on_bound_render_fbo_delete) |
- framebuffer->DoUnbindGLAttachmentsForWorkaround(target); |
- |
glBindFramebufferEXT(target, GetBackbufferServiceId()); |
- framebuffer_state_.bound_draw_framebuffer = NULL; |
- framebuffer_state_.clear_state_dirty = true; |
} |
if (framebuffer == framebuffer_state_.bound_read_framebuffer.get()) { |
framebuffer_state_.bound_read_framebuffer = NULL; |
@@ -12060,51 +12055,6 @@ error::Error GLES2DecoderImpl::HandleUniformBlockBinding( |
return error::kNoError; |
} |
-error::Error GLES2DecoderImpl::HandleClientWaitSync( |
- uint32_t immediate_data_size, const void* cmd_data) { |
- if (!unsafe_es3_apis_enabled()) |
- return error::kUnknownCommand; |
- const gles2::cmds::ClientWaitSync& c = |
- *static_cast<const gles2::cmds::ClientWaitSync*>(cmd_data); |
- GLuint sync = static_cast<GLuint>(c.sync); |
- GLbitfield flags = static_cast<GLbitfield>(c.flags); |
- GLuint64 timeout = GLES2Util::MapTwoUint32ToUint64(c.timeout_0, c.timeout_1); |
- typedef cmds::ClientWaitSync::Result Result; |
- Result* result_dst = GetSharedMemoryAs<Result*>( |
- c.result_shm_id, c.result_shm_offset, sizeof(*result_dst)); |
- if (!result_dst) { |
- return error::kOutOfBounds; |
- } |
- if (*result_dst != GL_WAIT_FAILED) { |
- return error::kInvalidArguments; |
- } |
- GLsync service_sync = 0; |
- if (!group_->GetSyncServiceId(sync, &service_sync)) { |
- LOCAL_SET_GL_ERROR(GL_INVALID_VALUE, "ClientWaitSync", "invalid sync"); |
- return error::kNoError; |
- } |
- *result_dst = glClientWaitSync(service_sync, flags, timeout); |
- return error::kNoError; |
-} |
- |
-error::Error GLES2DecoderImpl::HandleWaitSync( |
- uint32_t immediate_data_size, const void* cmd_data) { |
- if (!unsafe_es3_apis_enabled()) |
- return error::kUnknownCommand; |
- const gles2::cmds::WaitSync& c = |
- *static_cast<const gles2::cmds::WaitSync*>(cmd_data); |
- GLuint sync = static_cast<GLuint>(c.sync); |
- GLbitfield flags = static_cast<GLbitfield>(c.flags); |
- GLuint64 timeout = GLES2Util::MapTwoUint32ToUint64(c.timeout_0, c.timeout_1); |
- GLsync service_sync = 0; |
- if (!group_->GetSyncServiceId(sync, &service_sync)) { |
- LOCAL_SET_GL_ERROR(GL_INVALID_VALUE, "WaitSync", "invalid sync"); |
- return error::kNoError; |
- } |
- glWaitSync(service_sync, flags, timeout); |
- return error::kNoError; |
-} |
- |
void GLES2DecoderImpl::OnTextureRefDetachedFromFramebuffer( |
TextureRef* texture_ref) { |
Texture* texture = texture_ref->texture(); |