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 52a9c4351b47185261d76eba400f20aec9bb0b41..fe8137312fffcc7786e5ac5af0c931a9ffd38e07 100644 |
--- a/gpu/command_buffer/service/gles2_cmd_decoder.cc |
+++ b/gpu/command_buffer/service/gles2_cmd_decoder.cc |
@@ -12055,6 +12055,33 @@ 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; |
+} |
+ |
void GLES2DecoderImpl::OnTextureRefDetachedFromFramebuffer( |
TextureRef* texture_ref) { |
Texture* texture = texture_ref->texture(); |