OLD | NEW |
---|---|
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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/common/gpu/media/android_video_decode_accelerator.h" | 5 #include "content/common/gpu/media/android_video_decode_accelerator.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 | 8 |
9 #include "base/android/build_info.h" | 9 #include "base/android/build_info.h" |
10 #include "base/auto_reset.h" | 10 #include "base/auto_reset.h" |
11 #include "base/bind.h" | 11 #include "base/bind.h" |
12 #include "base/bind_helpers.h" | 12 #include "base/bind_helpers.h" |
13 #include "base/command_line.h" | 13 #include "base/command_line.h" |
14 #include "base/lazy_instance.h" | 14 #include "base/lazy_instance.h" |
15 #include "base/logging.h" | 15 #include "base/logging.h" |
16 #include "base/message_loop/message_loop.h" | 16 #include "base/message_loop/message_loop.h" |
17 #include "base/metrics/histogram.h" | 17 #include "base/metrics/histogram.h" |
18 #include "base/trace_event/trace_event.h" | 18 #include "base/trace_event/trace_event.h" |
19 #include "content/common/gpu/gpu_channel.h" | 19 #include "content/common/gpu/gpu_channel.h" |
20 #include "content/common/gpu/media/android_copying_backing_strategy.h" | 20 #include "content/common/gpu/media/android_copying_backing_strategy.h" |
21 #include "content/common/gpu/media/android_deferred_rendering_backing_strategy.h " | 21 #include "content/common/gpu/media/android_deferred_rendering_backing_strategy.h " |
22 #include "content/common/gpu/media/avda_return_on_failure.h" | 22 #include "content/common/gpu/media/avda_return_on_failure.h" |
23 #include "content/common/gpu/media/shared_memory_region.h" | 23 #include "content/common/gpu/media/shared_memory_region.h" |
24 #include "gpu/command_buffer/service/gles2_cmd_decoder.h" | 24 #include "gpu/command_buffer/service/gles2_cmd_decoder.h" |
25 #include "gpu/command_buffer/service/gpu_switches.h" | |
26 #include "gpu/command_buffer/service/mailbox_manager.h" | 25 #include "gpu/command_buffer/service/mailbox_manager.h" |
27 #include "media/base/android/media_codec_bridge.h" | 26 #include "media/base/android/media_codec_bridge.h" |
28 #include "media/base/android/media_codec_util.h" | 27 #include "media/base/android/media_codec_util.h" |
29 #include "media/base/bind_to_current_loop.h" | 28 #include "media/base/bind_to_current_loop.h" |
30 #include "media/base/bitstream_buffer.h" | 29 #include "media/base/bitstream_buffer.h" |
31 #include "media/base/limits.h" | 30 #include "media/base/limits.h" |
32 #include "media/base/media.h" | 31 #include "media/base/media.h" |
33 #include "media/base/timestamp_constants.h" | 32 #include "media/base/timestamp_constants.h" |
34 #include "media/base/video_decoder_config.h" | 33 #include "media/base/video_decoder_config.h" |
35 #include "media/video/picture.h" | 34 #include "media/video/picture.h" |
(...skipping 1112 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1148 } else { | 1147 } else { |
1149 most_recent_work_ = now; | 1148 most_recent_work_ = now; |
1150 } | 1149 } |
1151 | 1150 |
1152 if (should_be_running) | 1151 if (should_be_running) |
1153 g_avda_timer.Pointer()->StartTimer(this); | 1152 g_avda_timer.Pointer()->StartTimer(this); |
1154 else | 1153 else |
1155 g_avda_timer.Pointer()->StopTimer(this); | 1154 g_avda_timer.Pointer()->StopTimer(this); |
1156 } | 1155 } |
1157 | 1156 |
1158 // static | |
1159 bool AndroidVideoDecodeAccelerator::UseDeferredRenderingStrategy() { | 1157 bool AndroidVideoDecodeAccelerator::UseDeferredRenderingStrategy() { |
1160 const base::CommandLine* cmd_line = base::CommandLine::ForCurrentProcess(); | |
1161 // TODO(liberato, watk): Figure out what we want to do about zero copy for | 1158 // TODO(liberato, watk): Figure out what we want to do about zero copy for |
1162 // fullscreen external SurfaceView in WebView. http://crbug.com/582170. | 1159 // fullscreen external SurfaceView in WebView. http://crbug.com/582170. |
1163 return !cmd_line->HasSwitch(switches::kEnableThreadedTextureMailboxes); | 1160 const gpu::GpuPreferences& gpu_preferences = |
liberato (no reviews please)
2016/03/22 21:22:08
i was thinking that you might pass in the GpuPrefe
william.xie
2016/03/22 23:11:07
Thanks Frank, per https://codereview.chromium.org/
DaleCurtis
2016/03/22 23:14:32
I believe Frank just means you should have UseDefe
william.xie
2016/03/22 23:37:26
Done.
| |
1161 gl_decoder_->GetContextGroup()->gpu_preferences(); | |
1162 return !gpu_preferences.enable_threaded_texture_mailboxes; | |
1164 } | 1163 } |
1165 | 1164 |
1166 // static | 1165 // static |
1167 media::VideoDecodeAccelerator::Capabilities | 1166 media::VideoDecodeAccelerator::Capabilities |
1168 AndroidVideoDecodeAccelerator::GetCapabilities() { | 1167 AndroidVideoDecodeAccelerator::GetCapabilities( |
1168 const gpu::GpuPreferences& gpu_preferences) { | |
1169 Capabilities capabilities; | 1169 Capabilities capabilities; |
1170 SupportedProfiles& profiles = capabilities.supported_profiles; | 1170 SupportedProfiles& profiles = capabilities.supported_profiles; |
1171 | 1171 |
1172 SupportedProfile profile; | 1172 SupportedProfile profile; |
1173 | 1173 |
1174 if (media::MediaCodecUtil::IsVp8DecoderAvailable()) { | 1174 if (media::MediaCodecUtil::IsVp8DecoderAvailable()) { |
1175 profile.profile = media::VP8PROFILE_ANY; | 1175 profile.profile = media::VP8PROFILE_ANY; |
1176 profile.min_resolution.SetSize(0, 0); | 1176 profile.min_resolution.SetSize(0, 0); |
1177 profile.max_resolution.SetSize(1920, 1088); | 1177 profile.max_resolution.SetSize(1920, 1088); |
1178 profiles.push_back(profile); | 1178 profiles.push_back(profile); |
(...skipping 10 matching lines...) Expand all Loading... | |
1189 SupportedProfile profile; | 1189 SupportedProfile profile; |
1190 profile.profile = supported_profile; | 1190 profile.profile = supported_profile; |
1191 profile.min_resolution.SetSize(0, 0); | 1191 profile.min_resolution.SetSize(0, 0); |
1192 // Advertise support for 4k and let the MediaCodec fail when decoding if it | 1192 // Advertise support for 4k and let the MediaCodec fail when decoding if it |
1193 // doesn't support the resolution. It's assumed that consumers won't have | 1193 // doesn't support the resolution. It's assumed that consumers won't have |
1194 // software fallback for H264 on Android anyway. | 1194 // software fallback for H264 on Android anyway. |
1195 profile.max_resolution.SetSize(3840, 2160); | 1195 profile.max_resolution.SetSize(3840, 2160); |
1196 profiles.push_back(profile); | 1196 profiles.push_back(profile); |
1197 } | 1197 } |
1198 | 1198 |
1199 if (UseDeferredRenderingStrategy()) { | 1199 if (!gpu_preferences.enable_threaded_texture_mailboxes) { |
1200 capabilities.flags = media::VideoDecodeAccelerator::Capabilities:: | 1200 capabilities.flags = media::VideoDecodeAccelerator::Capabilities:: |
1201 NEEDS_ALL_PICTURE_BUFFERS_TO_DECODE | | 1201 NEEDS_ALL_PICTURE_BUFFERS_TO_DECODE | |
1202 media::VideoDecodeAccelerator::Capabilities:: | 1202 media::VideoDecodeAccelerator::Capabilities:: |
1203 SUPPORTS_EXTERNAL_OUTPUT_SURFACE; | 1203 SUPPORTS_EXTERNAL_OUTPUT_SURFACE; |
1204 } | 1204 } |
1205 | 1205 |
1206 return capabilities; | 1206 return capabilities; |
1207 } | 1207 } |
1208 | 1208 |
1209 } // namespace content | 1209 } // namespace content |
OLD | NEW |