// 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 "ppapi/shared_impl/ppb_video_decoder_shared.h" #include "base/logging.h" #include "gpu/command_buffer/client/gles2_implementation.h" #include "ppapi/c/pp_errors.h" #include "ppapi/shared_impl/resource_tracker.h" #include "ppapi/thunk/enter.h" namespace ppapi { PPB_VideoDecoder_Shared::PPB_VideoDecoder_Shared(PP_Instance instance) : Resource(OBJECT_IS_IMPL, instance), graphics_context_(0), gles2_impl_(NULL) { } PPB_VideoDecoder_Shared::PPB_VideoDecoder_Shared( const HostResource& host_resource) : Resource(OBJECT_IS_PROXY, host_resource), graphics_context_(0), gles2_impl_(NULL) { } PPB_VideoDecoder_Shared::~PPB_VideoDecoder_Shared() { } thunk::PPB_VideoDecoder_API* PPB_VideoDecoder_Shared::AsPPB_VideoDecoder_API() { return this; } void PPB_VideoDecoder_Shared::InitCommon( PP_Resource graphics_context, gpu::gles2::GLES2Implementation* gles2_impl) { DCHECK(graphics_context); DCHECK(!gles2_impl_ && !graphics_context_); gles2_impl_ = gles2_impl; PpapiGlobals::Get()->GetResourceTracker()->AddRefResource(graphics_context); graphics_context_ = graphics_context; } void PPB_VideoDecoder_Shared::Destroy() { graphics_context_ = 0; gles2_impl_ = NULL; PpapiGlobals::Get()->GetResourceTracker()->ReleaseResource(graphics_context_); } bool PPB_VideoDecoder_Shared::SetFlushCallback(PP_CompletionCallback callback) { CHECK(callback.func); if (flush_callback_.get()) return false; flush_callback_ = new TrackedCallback(this, callback); return true; } bool PPB_VideoDecoder_Shared::SetResetCallback(PP_CompletionCallback callback) { CHECK(callback.func); if (TrackedCallback::IsPending(reset_callback_)) return false; reset_callback_ = new TrackedCallback(this, callback); return true; } bool PPB_VideoDecoder_Shared::SetBitstreamBufferCallback( int32 bitstream_buffer_id, PP_CompletionCallback callback) { return bitstream_buffer_callbacks_.insert( std::make_pair(bitstream_buffer_id, new TrackedCallback(this, callback))).second; } void PPB_VideoDecoder_Shared::RunFlushCallback(int32 result) { TrackedCallback::ClearAndRun(&flush_callback_, result); } void PPB_VideoDecoder_Shared::RunResetCallback(int32 result) { TrackedCallback::ClearAndRun(&reset_callback_, result); } void PPB_VideoDecoder_Shared::RunBitstreamBufferCallback( int32 bitstream_buffer_id, int32 result) { CallbackById::iterator it = bitstream_buffer_callbacks_.find(bitstream_buffer_id); DCHECK(it != bitstream_buffer_callbacks_.end()); scoped_refptr cc = it->second; bitstream_buffer_callbacks_.erase(it); cc->Run(PP_OK); } void PPB_VideoDecoder_Shared::FlushCommandBuffer() { if (gles2_impl_) gles2_impl_->Flush(); } } // namespace ppapi