OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "content/browser/gpu/gpu_process_host.h" | 5 #include "content/browser/gpu/gpu_process_host.h" |
6 | 6 |
7 #include "base/base64.h" | 7 #include "base/base64.h" |
8 #include "base/base_switches.h" | 8 #include "base/base_switches.h" |
9 #include "base/basictypes.h" | 9 #include "base/basictypes.h" |
10 #include "base/bind.h" | 10 #include "base/bind.h" |
(...skipping 547 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
558 process_->GetHost()->AddFilter(filter); | 558 process_->GetHost()->AddFilter(filter); |
559 } | 559 } |
560 | 560 |
561 bool GpuProcessHost::OnMessageReceived(const IPC::Message& message) { | 561 bool GpuProcessHost::OnMessageReceived(const IPC::Message& message) { |
562 DCHECK(CalledOnValidThread()); | 562 DCHECK(CalledOnValidThread()); |
563 IPC_BEGIN_MESSAGE_MAP(GpuProcessHost, message) | 563 IPC_BEGIN_MESSAGE_MAP(GpuProcessHost, message) |
564 IPC_MESSAGE_HANDLER(GpuHostMsg_Initialized, OnInitialized) | 564 IPC_MESSAGE_HANDLER(GpuHostMsg_Initialized, OnInitialized) |
565 IPC_MESSAGE_HANDLER(GpuHostMsg_ChannelEstablished, OnChannelEstablished) | 565 IPC_MESSAGE_HANDLER(GpuHostMsg_ChannelEstablished, OnChannelEstablished) |
566 IPC_MESSAGE_HANDLER(GpuHostMsg_CommandBufferCreated, OnCommandBufferCreated) | 566 IPC_MESSAGE_HANDLER(GpuHostMsg_CommandBufferCreated, OnCommandBufferCreated) |
567 IPC_MESSAGE_HANDLER(GpuHostMsg_DestroyCommandBuffer, OnDestroyCommandBuffer) | 567 IPC_MESSAGE_HANDLER(GpuHostMsg_DestroyCommandBuffer, OnDestroyCommandBuffer) |
568 IPC_MESSAGE_HANDLER(GpuHostMsg_ImageCreated, OnImageCreated) | |
569 IPC_MESSAGE_HANDLER(GpuHostMsg_GpuMemoryBufferCreated, | 568 IPC_MESSAGE_HANDLER(GpuHostMsg_GpuMemoryBufferCreated, |
570 OnGpuMemoryBufferCreated) | 569 OnGpuMemoryBufferCreated) |
571 IPC_MESSAGE_HANDLER(GpuHostMsg_DidCreateOffscreenContext, | 570 IPC_MESSAGE_HANDLER(GpuHostMsg_DidCreateOffscreenContext, |
572 OnDidCreateOffscreenContext) | 571 OnDidCreateOffscreenContext) |
573 IPC_MESSAGE_HANDLER(GpuHostMsg_DidLoseContext, OnDidLoseContext) | 572 IPC_MESSAGE_HANDLER(GpuHostMsg_DidLoseContext, OnDidLoseContext) |
574 IPC_MESSAGE_HANDLER(GpuHostMsg_DidDestroyOffscreenContext, | 573 IPC_MESSAGE_HANDLER(GpuHostMsg_DidDestroyOffscreenContext, |
575 OnDidDestroyOffscreenContext) | 574 OnDidDestroyOffscreenContext) |
576 IPC_MESSAGE_HANDLER(GpuHostMsg_GpuMemoryUmaStats, | 575 IPC_MESSAGE_HANDLER(GpuHostMsg_GpuMemoryUmaStats, |
577 OnGpuMemoryUmaStatsReceived) | 576 OnGpuMemoryUmaStatsReceived) |
578 #if defined(OS_MACOSX) | 577 #if defined(OS_MACOSX) |
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
641 Send(new GpuMsg_CreateViewCommandBuffer( | 640 Send(new GpuMsg_CreateViewCommandBuffer( |
642 compositing_surface, surface_id, client_id, init_params, route_id))) { | 641 compositing_surface, surface_id, client_id, init_params, route_id))) { |
643 create_command_buffer_requests_.push(callback); | 642 create_command_buffer_requests_.push(callback); |
644 surface_refs_.insert(std::make_pair(surface_id, | 643 surface_refs_.insert(std::make_pair(surface_id, |
645 GpuSurfaceTracker::GetInstance()->GetSurfaceRefForSurface(surface_id))); | 644 GpuSurfaceTracker::GetInstance()->GetSurfaceRefForSurface(surface_id))); |
646 } else { | 645 } else { |
647 callback.Run(false); | 646 callback.Run(false); |
648 } | 647 } |
649 } | 648 } |
650 | 649 |
651 void GpuProcessHost::CreateImage(gfx::PluginWindowHandle window, | |
652 int client_id, | |
653 int image_id, | |
654 const CreateImageCallback& callback) { | |
655 TRACE_EVENT0("gpu", "GpuProcessHost::CreateImage"); | |
656 | |
657 DCHECK(CalledOnValidThread()); | |
658 | |
659 if (Send(new GpuMsg_CreateImage(window, client_id, image_id))) { | |
660 create_image_requests_.push(callback); | |
661 } else { | |
662 callback.Run(gfx::Size()); | |
663 } | |
664 } | |
665 | |
666 void GpuProcessHost::DeleteImage(int client_id, | |
667 int image_id, | |
668 int sync_point) { | |
669 TRACE_EVENT0("gpu", "GpuProcessHost::DeleteImage"); | |
670 | |
671 DCHECK(CalledOnValidThread()); | |
672 | |
673 Send(new GpuMsg_DeleteImage(client_id, image_id, sync_point)); | |
674 } | |
675 | |
676 void GpuProcessHost::CreateGpuMemoryBuffer( | 650 void GpuProcessHost::CreateGpuMemoryBuffer( |
677 const gfx::GpuMemoryBufferHandle& handle, | 651 const gfx::GpuMemoryBufferHandle& handle, |
678 const gfx::Size& size, | 652 const gfx::Size& size, |
679 unsigned internalformat, | 653 unsigned internalformat, |
680 unsigned usage, | 654 unsigned usage, |
681 const CreateGpuMemoryBufferCallback& callback) { | 655 const CreateGpuMemoryBufferCallback& callback) { |
682 TRACE_EVENT0("gpu", "GpuProcessHost::CreateGpuMemoryBuffer"); | 656 TRACE_EVENT0("gpu", "GpuProcessHost::CreateGpuMemoryBuffer"); |
683 | 657 |
684 DCHECK(CalledOnValidThread()); | 658 DCHECK(CalledOnValidThread()); |
685 | 659 |
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
756 } | 730 } |
757 | 731 |
758 void GpuProcessHost::OnDestroyCommandBuffer(int32 surface_id) { | 732 void GpuProcessHost::OnDestroyCommandBuffer(int32 surface_id) { |
759 TRACE_EVENT0("gpu", "GpuProcessHost::OnDestroyCommandBuffer"); | 733 TRACE_EVENT0("gpu", "GpuProcessHost::OnDestroyCommandBuffer"); |
760 SurfaceRefMap::iterator it = surface_refs_.find(surface_id); | 734 SurfaceRefMap::iterator it = surface_refs_.find(surface_id); |
761 if (it != surface_refs_.end()) { | 735 if (it != surface_refs_.end()) { |
762 surface_refs_.erase(it); | 736 surface_refs_.erase(it); |
763 } | 737 } |
764 } | 738 } |
765 | 739 |
766 void GpuProcessHost::OnImageCreated(const gfx::Size size) { | |
767 TRACE_EVENT0("gpu", "GpuProcessHost::OnImageCreated"); | |
768 | |
769 if (create_image_requests_.empty()) | |
770 return; | |
771 | |
772 CreateImageCallback callback = create_image_requests_.front(); | |
773 create_image_requests_.pop(); | |
774 callback.Run(size); | |
775 } | |
776 | |
777 void GpuProcessHost::OnGpuMemoryBufferCreated( | 740 void GpuProcessHost::OnGpuMemoryBufferCreated( |
778 const gfx::GpuMemoryBufferHandle& handle) { | 741 const gfx::GpuMemoryBufferHandle& handle) { |
779 TRACE_EVENT0("gpu", "GpuProcessHost::OnGpuMemoryBufferCreated"); | 742 TRACE_EVENT0("gpu", "GpuProcessHost::OnGpuMemoryBufferCreated"); |
780 | 743 |
781 if (create_gpu_memory_buffer_requests_.empty()) | 744 if (create_gpu_memory_buffer_requests_.empty()) |
782 return; | 745 return; |
783 | 746 |
784 CreateGpuMemoryBufferCallback callback = | 747 CreateGpuMemoryBufferCallback callback = |
785 create_gpu_memory_buffer_requests_.front(); | 748 create_gpu_memory_buffer_requests_.front(); |
786 create_gpu_memory_buffer_requests_.pop(); | 749 create_gpu_memory_buffer_requests_.pop(); |
(...skipping 325 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1112 TRACE_EVENT0("gpu", "GpuProcessHost::OnCacheShader"); | 1075 TRACE_EVENT0("gpu", "GpuProcessHost::OnCacheShader"); |
1113 ClientIdToShaderCacheMap::iterator iter = | 1076 ClientIdToShaderCacheMap::iterator iter = |
1114 client_id_to_shader_cache_.find(client_id); | 1077 client_id_to_shader_cache_.find(client_id); |
1115 // If the cache doesn't exist then this is an off the record profile. | 1078 // If the cache doesn't exist then this is an off the record profile. |
1116 if (iter == client_id_to_shader_cache_.end()) | 1079 if (iter == client_id_to_shader_cache_.end()) |
1117 return; | 1080 return; |
1118 iter->second->Cache(GetShaderPrefixKey() + ":" + key, shader); | 1081 iter->second->Cache(GetShaderPrefixKey() + ":" + key, shader); |
1119 } | 1082 } |
1120 | 1083 |
1121 } // namespace content | 1084 } // namespace content |
OLD | NEW |