Chromium Code Reviews| Index: cc/trees/remote_channel_impl.cc |
| diff --git a/cc/trees/remote_channel_impl.cc b/cc/trees/remote_channel_impl.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..b27cf7918b11a186d9d86e721296c88f1b84974e |
| --- /dev/null |
| +++ b/cc/trees/remote_channel_impl.cc |
| @@ -0,0 +1,336 @@ |
| +// Copyright 2015 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 "cc/trees/remote_channel_impl.h" |
| + |
| +#include "base/bind_helpers.h" |
| +#include "base/single_thread_task_runner.h" |
| +#include "cc/proto/compositor_message.pb.h" |
| +#include "cc/proto/compositor_message_to_impl.pb.h" |
| +#include "cc/proto/compositor_message_to_main.pb.h" |
| +#include "cc/trees/layer_tree_host.h" |
| +#include "cc/trees/layer_tree_settings.h" |
| + |
| +namespace cc { |
| + |
| +scoped_ptr<RemoteChannelImpl> RemoteChannelImpl::Create( |
| + LayerTreeHost* layer_tree_host, |
| + RemoteProtoChannel* remote_proto_channel, |
| + TaskRunnerProvider* task_runner_provider) { |
| + return make_scoped_ptr(new RemoteChannelImpl( |
| + layer_tree_host, remote_proto_channel, task_runner_provider)); |
| +} |
| + |
| +RemoteChannelImpl::RemoteChannelImpl(LayerTreeHost* layer_tree_host, |
| + RemoteProtoChannel* remote_proto_channel, |
| + TaskRunnerProvider* task_runner_provider) |
| + : main_thread_vars_unsafe_(layer_tree_host, remote_proto_channel), |
| + task_runner_provider_(task_runner_provider) { |
| + DCHECK(task_runner_provider_->IsMainThread()); |
| + |
| + main().remote_proto_channel->SetProtoReceiver(this); |
| +} |
| + |
| +RemoteChannelImpl::~RemoteChannelImpl() { |
| + DCHECK(task_runner_provider_->IsMainThread()); |
| + DCHECK(!main().started); |
| + |
| + main().remote_proto_channel->SetProtoReceiver(nullptr); |
| +} |
| + |
| +scoped_ptr<ProxyImpl> RemoteChannelImpl::CreateProxyImpl( |
| + ChannelImpl* channel_impl, |
| + LayerTreeHost* layer_tree_host, |
| + TaskRunnerProvider* task_runner_provider, |
| + scoped_ptr<BeginFrameSource> external_begin_frame_source) { |
|
vmpstr
2016/01/11 21:50:15
Is this supported or always null for now?
Khushal
2016/01/13 02:07:12
always null for now. Added a DCHECK.
|
| + DCHECK(task_runner_provider_->IsImplThread()); |
| + return ProxyImpl::Create(channel_impl, layer_tree_host, task_runner_provider, |
| + std::move(external_begin_frame_source)); |
| +} |
| + |
| +void RemoteChannelImpl::OnProtoReceived( |
| + scoped_ptr<proto::CompositorMessage> proto) { |
| + DCHECK(task_runner_provider_->IsMainThread()); |
| + DCHECK(main().started); |
| + DCHECK(proto->has_to_impl()); |
| + |
| + proto::CompositorMessageToImpl to_impl_proto = proto->to_impl(); |
|
vmpstr
2016/01/11 21:50:15
nit: can you move the switch to a new function cal
Khushal
2016/01/13 02:07:12
Done.
|
| + switch (to_impl_proto.message_type()) { |
| + case proto::CompositorMessageToImpl::MainThreadHasStoppedFlingingOnImpl: |
| + ImplThreadTaskRunner()->PostTask( |
| + FROM_HERE, base::Bind(&ProxyImpl::MainThreadHasStoppedFlingingOnImpl, |
| + proxy_impl_weak_ptr_)); |
| + break; |
| + default: |
| + // TODO(khushalsagar): Add more types here. |
| + NOTIMPLEMENTED(); |
| + } |
| +} |
| + |
| +void RemoteChannelImpl::FinishAllRendering() { |
| + NOTREACHED() << "Should be called on the server LayerTreeHost"; |
|
vmpstr
2016/01/11 21:50:15
nit: Can you change the error to be more about wha
Khushal
2016/01/13 02:07:12
Done.
|
| +} |
| + |
| +bool RemoteChannelImpl::IsStarted() const { |
| + DCHECK(task_runner_provider_->IsMainThread()); |
| + return main().started; |
| +} |
| + |
| +bool RemoteChannelImpl::CommitToActiveTree() const { |
| + return false; |
| +} |
| + |
| +void RemoteChannelImpl::SetOutputSurface(OutputSurface* output_surface) { |
| + DCHECK(task_runner_provider_->IsMainThread()); |
| + ImplThreadTaskRunner()->PostTask( |
| + FROM_HERE, base::Bind(&ProxyImpl::InitializeOutputSurfaceOnImpl, |
| + proxy_impl_weak_ptr_, output_surface)); |
| +} |
| + |
| +void RemoteChannelImpl::ReleaseOutputSurface() { |
| + DCHECK(task_runner_provider_->IsMainThread()); |
| + CompletionEvent completion; |
| + DebugScopedSetMainThreadBlocked main_thread_blocked(task_runner_provider_); |
| + ImplThreadTaskRunner()->PostTask( |
| + FROM_HERE, base::Bind(&ProxyImpl::ReleaseOutputSurfaceOnImpl, |
| + proxy_impl_weak_ptr_, &completion)); |
| + completion.Wait(); |
| +} |
| + |
| +void RemoteChannelImpl::SetVisible(bool visible) { |
| + DCHECK(task_runner_provider_->IsMainThread()); |
| + ImplThreadTaskRunner()->PostTask( |
| + FROM_HERE, |
| + base::Bind(&ProxyImpl::SetVisibleOnImpl, proxy_impl_weak_ptr_, visible)); |
| +} |
| + |
| +void RemoteChannelImpl::SetThrottleFrameProduction(bool throttle) { |
| + NOTREACHED() << "Should not be called on the remote client LayerTreeHost"; |
| +} |
| + |
| +const RendererCapabilities& RemoteChannelImpl::GetRendererCapabilities() const { |
| + NOTREACHED() << "Should not be called on the remote client LayerTreeHost"; |
| + return main().renderer_capabilities; |
| +} |
| + |
| +void RemoteChannelImpl::SetNeedsAnimate() { |
| + NOTREACHED() << "Should not be called on the remote client LayerTreeHost"; |
|
vmpstr
2016/01/11 21:50:15
LayerTreeHost or RemoteChannelImpl?
Khushal
2016/01/13 02:07:12
Basically this call should not be made to the prox
|
| +} |
| + |
| +void RemoteChannelImpl::SetNeedsUpdateLayers() { |
| + NOTREACHED() << "Should not be called on the remote client LayerTreeHost"; |
| +} |
| + |
| +void RemoteChannelImpl::SetNeedsCommit() { |
| + NOTREACHED() << "Should not be called on the remote client LayerTreeHost"; |
| +} |
| + |
| +void RemoteChannelImpl::SetNeedsRedraw(const gfx::Rect& damage_rect) { |
| + NOTREACHED() << "Should not be called on the remote client LayerTreeHost"; |
| +} |
| + |
| +void RemoteChannelImpl::SetNextCommitWaitsForActivation() { |
| + NOTREACHED() << "Should not be called on the remote client LayerTreeHost"; |
| +} |
| + |
| +void RemoteChannelImpl::NotifyInputThrottledUntilCommit() { |
| + NOTREACHED() << "Should not be called on the remote client LayerTreeHost"; |
| +} |
| + |
| +void RemoteChannelImpl::SetDeferCommits(bool defer_commits) { |
| + NOTREACHED() << "Should not be called on the remote client LayerTreeHost"; |
| +} |
| + |
| +void RemoteChannelImpl::MainThreadHasStoppedFlinging() { |
| + NOTREACHED() << "Should not be called on the remote client LayerTreeHost"; |
| +} |
| + |
| +bool RemoteChannelImpl::CommitRequested() const { |
| + NOTREACHED() << "Should not be called on the remote client LayerTreeHost"; |
| + return false; |
| +} |
| + |
| +bool RemoteChannelImpl::BeginMainFrameRequested() const { |
| + NOTREACHED() << "Should not be called on the remote client LayerTreeHost"; |
| + return false; |
| +} |
| + |
| +void RemoteChannelImpl::Start( |
| + scoped_ptr<BeginFrameSource> external_begin_frame_source) { |
| + DCHECK(task_runner_provider_->IsMainThread()); |
| + DCHECK(!main().started); |
| + DCHECK(!external_begin_frame_source); |
| + |
| + CompletionEvent completion; |
| + { |
| + DebugScopedSetMainThreadBlocked main_thread_blocked(task_runner_provider_); |
| + ImplThreadTaskRunner()->PostTask( |
| + FROM_HERE, base::Bind(&RemoteChannelImpl::InitializeImplOnImpl, |
| + base::Unretained(this), &completion, |
| + main().layer_tree_host)); |
| + completion.Wait(); |
| + } |
| + main().started = true; |
| +} |
| + |
| +void RemoteChannelImpl::Stop() { |
| + DCHECK(task_runner_provider_->IsMainThread()); |
| + DCHECK(main().started); |
| + |
| + { |
| + CompletionEvent completion; |
| + DebugScopedSetMainThreadBlocked main_thread_blocked(task_runner_provider_); |
| + ImplThreadTaskRunner()->PostTask( |
| + FROM_HERE, base::Bind(&ProxyImpl::FinishGLOnImpl, proxy_impl_weak_ptr_, |
| + &completion)); |
| + completion.Wait(); |
| + } |
| + { |
| + CompletionEvent completion; |
| + DebugScopedSetMainThreadBlocked main_thread_blocked(task_runner_provider_); |
| + ImplThreadTaskRunner()->PostTask( |
| + FROM_HERE, base::Bind(&RemoteChannelImpl::ShutdownImplOnImpl, |
| + base::Unretained(this), &completion)); |
| + completion.Wait(); |
| + } |
| + |
| + main().started = false; |
| +} |
| + |
| +bool RemoteChannelImpl::SupportsImplScrolling() const { |
| + return true; |
| +} |
| + |
| +void RemoteChannelImpl::SetChildrenNeedBeginFrames( |
| + bool children_need_begin_frames) { |
| + NOTREACHED() << "Should not be called on the remote client LayerTreeHost"; |
| +} |
| + |
| +void RemoteChannelImpl::SetAuthoritativeVSyncInterval( |
| + const base::TimeDelta& interval) { |
| + NOTREACHED() << "Should not be called on the remote client LayerTreeHost"; |
| +} |
| + |
| +void RemoteChannelImpl::UpdateTopControlsState(TopControlsState constraints, |
| + TopControlsState current, |
| + bool animate) { |
| + NOTREACHED() << "Should not be called on the remote client LayerTreeHost"; |
| +} |
| + |
| +bool RemoteChannelImpl::MainFrameWillHappenForTesting() { |
| + DCHECK(task_runner_provider_->IsMainThread()); |
| + bool main_frame_will_happen; |
| + { |
| + CompletionEvent completion; |
| + DebugScopedSetMainThreadBlocked main_thread_blocked(task_runner_provider_); |
| + ImplThreadTaskRunner()->PostTask( |
| + FROM_HERE, |
| + base::Bind(&ProxyImpl::MainFrameWillHappenOnImplForTesting, |
| + proxy_impl_weak_ptr_, &completion, &main_frame_will_happen)); |
| + completion.Wait(); |
| + } |
| + return main_frame_will_happen; |
| +} |
| + |
| +void RemoteChannelImpl::DidCompleteSwapBuffers() {} |
| + |
| +void RemoteChannelImpl::SetRendererCapabilitiesMainCopy( |
| + const RendererCapabilities& capabilities) {} |
| + |
| +void RemoteChannelImpl::BeginMainFrameNotExpectedSoon() {} |
| + |
| +void RemoteChannelImpl::DidCommitAndDrawFrame() {} |
| + |
| +void RemoteChannelImpl::SetAnimationEvents( |
| + scoped_ptr<AnimationEventsVector> queue) {} |
| + |
| +void RemoteChannelImpl::DidLoseOutputSurface() {} |
| + |
| +void RemoteChannelImpl::RequestNewOutputSurface() {} |
| + |
| +void RemoteChannelImpl::DidInitializeOutputSurface( |
| + bool success, |
| + const RendererCapabilities& capabilities) {} |
| + |
| +void RemoteChannelImpl::DidCompletePageScaleAnimation() {} |
| + |
| +void RemoteChannelImpl::PostFrameTimingEventsOnMain( |
| + scoped_ptr<FrameTimingTracker::CompositeTimingSet> composite_events, |
| + scoped_ptr<FrameTimingTracker::MainFrameTimingSet> main_frame_events) {} |
| + |
| +void RemoteChannelImpl::BeginMainFrame( |
| + scoped_ptr<BeginMainFrameAndCommitState> begin_main_frame_state) {} |
| + |
| +void RemoteChannelImpl::InitializeImplOnImpl(CompletionEvent* completion, |
| + LayerTreeHost* layer_tree_host) { |
| + DCHECK(task_runner_provider_->IsMainThreadBlocked()); |
| + DCHECK(task_runner_provider_->IsImplThread()); |
| + |
| + impl().proxy_impl = |
| + CreateProxyImpl(this, layer_tree_host, task_runner_provider_, nullptr); |
| + impl().proxy_impl_weak_factory = make_scoped_ptr( |
| + new base::WeakPtrFactory<ProxyImpl>(impl().proxy_impl.get())); |
| + proxy_impl_weak_ptr_ = impl().proxy_impl_weak_factory->GetWeakPtr(); |
| + completion->Signal(); |
| +} |
| + |
| +void RemoteChannelImpl::ShutdownImplOnImpl(CompletionEvent* completion) { |
| + DCHECK(task_runner_provider_->IsMainThreadBlocked()); |
| + DCHECK(task_runner_provider_->IsImplThread()); |
| + |
| + // We must invalidate the proxy_impl weak ptrs and destroy the weak ptr |
| + // factory before destroying proxy_impl. |
| + impl().proxy_impl_weak_factory->InvalidateWeakPtrs(); |
| + impl().proxy_impl_weak_factory.reset(); |
| + |
| + impl().proxy_impl.reset(); |
| + completion->Signal(); |
| +} |
| + |
| +RemoteChannelImpl::MainThreadOnly& RemoteChannelImpl::main() { |
| + DCHECK(task_runner_provider_->IsMainThread()); |
| + return main_thread_vars_unsafe_; |
| +} |
| + |
| +const RemoteChannelImpl::MainThreadOnly& RemoteChannelImpl::main() const { |
| + DCHECK(task_runner_provider_->IsMainThread()); |
| + return main_thread_vars_unsafe_; |
| +} |
| + |
| +RemoteChannelImpl::CompositorThreadOnly& RemoteChannelImpl::impl() { |
| + DCHECK(task_runner_provider_->IsImplThread()); |
| + return compositor_thread_vars_unsafe_; |
| +} |
| + |
| +const RemoteChannelImpl::CompositorThreadOnly& RemoteChannelImpl::impl() const { |
| + DCHECK(task_runner_provider_->IsImplThread()); |
| + return compositor_thread_vars_unsafe_; |
| +} |
| + |
| +base::SingleThreadTaskRunner* RemoteChannelImpl::MainThreadTaskRunner() const { |
| + return task_runner_provider_->MainThreadTaskRunner(); |
| +} |
| + |
| +base::SingleThreadTaskRunner* RemoteChannelImpl::ImplThreadTaskRunner() const { |
| + return task_runner_provider_->ImplThreadTaskRunner(); |
| +} |
| + |
| +RemoteChannelImpl::MainThreadOnly::MainThreadOnly( |
| + LayerTreeHost* layer_tree_host, |
| + RemoteProtoChannel* remote_proto_channel) |
| + : layer_tree_host(layer_tree_host), |
| + remote_proto_channel(remote_proto_channel), |
| + started(false) { |
| + DCHECK(layer_tree_host); |
| + DCHECK(remote_proto_channel); |
| +} |
| + |
| +RemoteChannelImpl::MainThreadOnly::~MainThreadOnly() {} |
| + |
| +RemoteChannelImpl::CompositorThreadOnly::CompositorThreadOnly() |
| + : proxy_impl(nullptr), proxy_impl_weak_factory(nullptr) {} |
| + |
| +RemoteChannelImpl::CompositorThreadOnly::~CompositorThreadOnly() {} |
| + |
| +} // namespace cc |