Chromium Code Reviews| 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 "base/bind.h" | 5 #include "base/bind.h" |
| 6 #include "base/bind_helpers.h" | 6 #include "base/bind_helpers.h" |
| 7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
| 8 #include "base/hash.h" | 8 #include "base/hash.h" |
| 9 #include "base/json/json_writer.h" | 9 #include "base/json/json_writer.h" |
| 10 #include "base/memory/shared_memory.h" | 10 #include "base/memory/shared_memory.h" |
| (...skipping 922 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 933 if (has_callback) { | 933 if (has_callback) { |
| 934 if (!memory_manager_client_state_) { | 934 if (!memory_manager_client_state_) { |
| 935 memory_manager_client_state_.reset(GetMemoryManager()->CreateClientState( | 935 memory_manager_client_state_.reset(GetMemoryManager()->CreateClientState( |
| 936 this, surface_id_ != 0, true)); | 936 this, surface_id_ != 0, true)); |
| 937 } | 937 } |
| 938 } else { | 938 } else { |
| 939 memory_manager_client_state_.reset(); | 939 memory_manager_client_state_.reset(); |
| 940 } | 940 } |
| 941 } | 941 } |
| 942 | 942 |
| 943 void GpuCommandBufferStub::OnCreateImage(int32 id, | 943 void GpuCommandBufferStub::OnCreateImage( |
| 944 gfx::GpuMemoryBufferHandle handle, | 944 int32 id, |
| 945 gfx::Size size, | 945 std::vector<gfx::GpuMemoryBufferHandle> handles, |
| 946 gfx::GpuMemoryBuffer::Format format, | 946 gfx::Size size, |
| 947 uint32 internalformat) { | 947 std::vector<gfx::GpuMemoryBuffer::Format> formats, |
| 948 uint32 internalformat) { | |
| 948 TRACE_EVENT0("gpu", "GpuCommandBufferStub::OnCreateImage"); | 949 TRACE_EVENT0("gpu", "GpuCommandBufferStub::OnCreateImage"); |
| 949 | 950 |
| 950 if (!decoder_) | 951 if (!decoder_) |
| 951 return; | 952 return; |
| 952 | 953 |
| 953 gpu::gles2::ImageManager* image_manager = decoder_->GetImageManager(); | 954 gpu::gles2::ImageManager* image_manager = decoder_->GetImageManager(); |
| 954 DCHECK(image_manager); | 955 DCHECK(image_manager); |
| 955 if (image_manager->LookupImage(id)) { | 956 if (image_manager->LookupImage(id)) { |
| 956 LOG(ERROR) << "Image already exists with same ID."; | 957 LOG(ERROR) << "Image already exists with same ID."; |
| 957 return; | 958 return; |
| 958 } | 959 } |
| 959 | 960 |
| 960 if (!gpu::ImageFactory::IsGpuMemoryBufferFormatSupported( | 961 int num_buffers = |
| 961 format, decoder_->GetCapabilities())) { | 962 gpu::ImageFactory::GpuMemoryBufferCountForImageFormat(internalformat); |
| 962 LOG(ERROR) << "Format is not supported."; | 963 if (num_buffers < 1) { |
| 964 LOG(ERROR) << "Internalformat is not supported."; | |
|
reveman
2015/03/12 19:37:22
Please add an gpu::ImageFactory::IsFormatSupported
emircan
2015/03/12 22:34:26
Done.
| |
| 963 return; | 965 return; |
| 964 } | 966 } |
| 965 | 967 |
| 966 if (!gpu::ImageFactory::IsImageSizeValidForGpuMemoryBufferFormat(size, | 968 // Checks to make sure that the input isn't coming from a malicious renderer. |
| 967 format)) { | 969 if (static_cast<int>(handles.size()) != num_buffers) { |
| 968 LOG(ERROR) << "Invalid image size for format."; | 970 LOG(ERROR) << "Invalid number of GpuMemoryBufferHandle given for " |
| 971 "internalformat."; | |
| 972 return; | |
| 973 } | |
| 974 if (static_cast<int>(formats.size()) != num_buffers) { | |
| 975 LOG(ERROR) << "Invalid number of GpuMemoryBuffer::Format given for " | |
| 976 "internalformat."; | |
| 969 return; | 977 return; |
| 970 } | 978 } |
| 971 | 979 |
| 972 if (!gpu::ImageFactory::IsImageFormatCompatibleWithGpuMemoryBufferFormat( | 980 for (int i = 0; i < num_buffers; ++i) { |
| 973 internalformat, format)) { | 981 const gfx::GpuMemoryBuffer::Format& format = formats[i]; |
| 974 LOG(ERROR) << "Incompatible image format."; | 982 if (!gpu::ImageFactory::IsGpuMemoryBufferFormatSupported( |
| 975 return; | 983 format, decoder_->GetCapabilities())) { |
| 984 LOG(ERROR) << "Format is not supported."; | |
| 985 return; | |
| 986 } | |
| 987 if (!gpu::ImageFactory::IsImageSizeValidForGpuMemoryBufferFormat( | |
| 988 size, format)) { | |
| 989 LOG(ERROR) << "Invalid image size for format."; | |
| 990 return; | |
| 991 } | |
| 992 if (!gpu::ImageFactory::IsImageFormatCompatibleWithGpuMemoryBufferFormat( | |
| 993 internalformat, i, format)) { | |
| 994 LOG(ERROR) << "Incompatible image format."; | |
| 995 return; | |
| 996 } | |
| 976 } | 997 } |
| 977 | 998 |
| 978 scoped_refptr<gfx::GLImage> image = channel()->CreateImageForGpuMemoryBuffer( | 999 scoped_refptr<gfx::GLImage> image = channel()->CreateImageForGpuMemoryBuffers( |
| 979 handle, size, format, internalformat); | 1000 handles, size, formats, internalformat); |
| 980 if (!image.get()) | 1001 if (!image.get()) |
| 981 return; | 1002 return; |
| 982 | 1003 |
| 983 image_manager->AddImage(image.get(), id); | 1004 image_manager->AddImage(image.get(), id); |
| 984 } | 1005 } |
| 985 | 1006 |
| 986 void GpuCommandBufferStub::OnDestroyImage(int32 id) { | 1007 void GpuCommandBufferStub::OnDestroyImage(int32 id) { |
| 987 TRACE_EVENT0("gpu", "GpuCommandBufferStub::OnDestroyImage"); | 1008 TRACE_EVENT0("gpu", "GpuCommandBufferStub::OnDestroyImage"); |
| 988 | 1009 |
| 989 if (!decoder_) | 1010 if (!decoder_) |
| (...skipping 112 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1102 Send(new GpuCommandBufferMsg_SwapBuffersCompleted(route_id_, latency_info)); | 1123 Send(new GpuCommandBufferMsg_SwapBuffersCompleted(route_id_, latency_info)); |
| 1103 } | 1124 } |
| 1104 | 1125 |
| 1105 void GpuCommandBufferStub::SendUpdateVSyncParameters(base::TimeTicks timebase, | 1126 void GpuCommandBufferStub::SendUpdateVSyncParameters(base::TimeTicks timebase, |
| 1106 base::TimeDelta interval) { | 1127 base::TimeDelta interval) { |
| 1107 Send(new GpuCommandBufferMsg_UpdateVSyncParameters(route_id_, timebase, | 1128 Send(new GpuCommandBufferMsg_UpdateVSyncParameters(route_id_, timebase, |
| 1108 interval)); | 1129 interval)); |
| 1109 } | 1130 } |
| 1110 | 1131 |
| 1111 } // namespace content | 1132 } // namespace content |
| OLD | NEW |