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
3 // found in the LICENSE file.
5 #ifndef MEDIA_BASE_ANDROID_MEDIA_CODEC_BRIDGE_H_
6 #define MEDIA_BASE_ANDROID_MEDIA_CODEC_BRIDGE_H_
11 #include "base/android/scoped_java_ref.h"
12 #include "base/time/time.h"
13 #include "media/base/audio_decoder_config.h"
14 #include "media/base/video_decoder_config.h"
15 #include "ui/gfx/geometry/size.h"
19 struct SubsampleEntry
;
21 // These must be in sync with MediaCodecBridge.MEDIA_CODEC_XXX constants in
22 // MediaCodecBridge.java.
23 enum MediaCodecStatus
{
25 MEDIA_CODEC_DEQUEUE_INPUT_AGAIN_LATER
,
26 MEDIA_CODEC_DEQUEUE_OUTPUT_AGAIN_LATER
,
27 MEDIA_CODEC_OUTPUT_BUFFERS_CHANGED
,
28 MEDIA_CODEC_OUTPUT_FORMAT_CHANGED
,
29 MEDIA_CODEC_INPUT_END_OF_STREAM
,
30 MEDIA_CODEC_OUTPUT_END_OF_STREAM
,
36 // Codec direction. Keep this in sync with MediaCodecBridge.java.
37 enum MediaCodecDirection
{
42 // This class serves as a bridge for native code to call java functions inside
43 // Android MediaCodec class. For more information on Android MediaCodec, check
44 // http://developer.android.com/reference/android/media/MediaCodec.html
45 // Note: MediaCodec is only available on JB and greater.
46 // Use AudioCodecBridge or VideoCodecBridge to create an instance of this
49 // TODO(fischman,xhwang): replace this (and the enums that go with it) with
50 // chromium's JNI auto-generation hotness.
51 class MEDIA_EXPORT MediaCodecBridge
{
53 // Returns true if MediaCodec is available on the device.
54 // All other static methods check IsAvailable() internally. There's no need
55 // to check IsAvailable() explicitly before calling them.
56 static bool IsAvailable();
58 // Returns true if MediaCodec.setParameters() is available on the device.
59 static bool SupportsSetParameters();
61 // Returns true if MediaCodec.getName() is available on the device.
62 static bool SupportsGetName();
64 // Returns whether MediaCodecBridge has a decoder that |is_secure| and can
65 // decode |codec| type.
66 static bool CanDecode(const std::string
& codec
, bool is_secure
);
68 // Represents supported codecs on android.
69 // TODO(qinmin): Currently the codecs string only contains one codec. Do we
70 // need to support codecs separated by comma. (e.g. "vp8" -> "vp8, vp8.0")?
72 std::string codecs
; // E.g. "vp8" or "avc1".
73 std::string name
; // E.g. "OMX.google.vp8.decoder".
74 MediaCodecDirection direction
;
77 // Get a list of supported codecs.
78 static std::vector
<CodecsInfo
> GetCodecsInfo();
80 // Get default codec name for |mime_type|.
81 static std::string
GetDefaultCodecName(const std::string
& mime_type
,
82 MediaCodecDirection direction
);
84 // Get a list of encoder supported color formats for |mime_type|.
85 // The mapping of color format name and its value refers to
86 // MediaCodecInfo.CodecCapabilities.
87 static std::set
<int> GetEncoderColorFormats(const std::string
& mime_type
);
89 virtual ~MediaCodecBridge();
91 // Resets both input and output, all indices previously returned in calls to
92 // DequeueInputBuffer() and DequeueOutputBuffer() become invalid.
93 // Please note that this clears all the inputs in the media codec. In other
94 // words, there will be no outputs until new input is provided.
95 // Returns MEDIA_CODEC_ERROR if an unexpected error happens, or Media_CODEC_OK
97 MediaCodecStatus
Reset();
99 // Finishes the decode/encode session. The instance remains active
100 // and ready to be StartAudio/Video()ed again. HOWEVER, due to the buggy
101 // vendor's implementation , b/8125974, Stop() -> StartAudio/Video() may not
102 // work on some devices. For reliability, Stop() -> delete and recreate new
103 // instance -> StartAudio/Video() is recommended.
106 // Used for getting output format. This is valid after DequeueInputBuffer()
107 // returns a format change by returning INFO_OUTPUT_FORMAT_CHANGED
108 void GetOutputFormat(int* width
, int* height
);
110 // Used for checking for new sampling rate after DequeueInputBuffer() returns
111 // INFO_OUTPUT_FORMAT_CHANGED
112 int GetOutputSamplingRate();
114 // Submits a byte array to the given input buffer. Call this after getting an
115 // available buffer from DequeueInputBuffer(). If |data| is NULL, assume the
116 // input buffer has already been populated (but still obey |size|).
117 // |data_size| must be less than kint32max (because Java).
118 MediaCodecStatus
QueueInputBuffer(int index
,
121 const base::TimeDelta
& presentation_time
);
123 // Similar to the above call, but submits a buffer that is encrypted. Note:
124 // NULL |subsamples| indicates the whole buffer is encrypted. If |data| is
125 // NULL, assume the input buffer has already been populated (but still obey
126 // |data_size|). |data_size| must be less than kint32max (because Java).
127 MediaCodecStatus
QueueSecureInputBuffer(
135 const SubsampleEntry
* subsamples
,
137 const base::TimeDelta
& presentation_time
);
139 // Submits an empty buffer with a EOS (END OF STREAM) flag.
140 void QueueEOS(int input_buffer_index
);
143 // MEDIA_CODEC_OK if an input buffer is ready to be filled with valid data,
144 // MEDIA_CODEC_ENQUEUE_INPUT_AGAIN_LATER if no such buffer is available, or
145 // MEDIA_CODEC_ERROR if unexpected error happens.
146 // Note: Never use infinite timeout as this would block the decoder thread and
147 // prevent the decoder job from being released.
148 MediaCodecStatus
DequeueInputBuffer(const base::TimeDelta
& timeout
,
151 // Dequeues an output buffer, block at most timeout_us microseconds.
152 // Returns the status of this operation. If OK is returned, the output
153 // parameters should be populated. Otherwise, the values of output parameters
154 // should not be used. Output parameters other than index/offset/size are
155 // optional and only set if not NULL.
156 // Note: Never use infinite timeout as this would block the decoder thread and
157 // prevent the decoder job from being released.
158 // TODO(xhwang): Can we drop |end_of_stream| and return
159 // MEDIA_CODEC_OUTPUT_END_OF_STREAM?
160 MediaCodecStatus
DequeueOutputBuffer(const base::TimeDelta
& timeout
,
164 base::TimeDelta
* presentation_time
,
168 // Returns the buffer to the codec. If you previously specified a surface when
169 // configuring this video decoder you can optionally render the buffer.
170 void ReleaseOutputBuffer(int index
, bool render
);
172 // Returns the number of output buffers used by the codec.
173 // TODO(qinmin): this call is deprecated in Lollipop.
174 int GetOutputBuffersCount();
176 // Returns the capacity of each output buffer used by the codec.
177 // TODO(qinmin): this call is deprecated in Lollipop.
178 size_t GetOutputBuffersCapacity();
180 // Returns an input buffer's base pointer and capacity.
181 void GetInputBuffer(int input_buffer_index
, uint8
** data
, size_t* capacity
);
183 // Copy |dst_size| bytes from output buffer |index|'s |offset| onwards into
185 bool CopyFromOutputBuffer(int index
, size_t offset
, void* dst
, int dst_size
);
187 static bool RegisterMediaCodecBridge(JNIEnv
* env
);
190 // Returns true if |mime_type| is known to be unaccelerated (i.e. backed by a
191 // software codec instead of a hardware one).
192 static bool IsKnownUnaccelerated(const std::string
& mime_type
,
193 MediaCodecDirection direction
);
195 MediaCodecBridge(const std::string
& mime
,
197 MediaCodecDirection direction
);
199 // Calls start() against the media codec instance. Used in StartXXX() after
200 // configuring media codec. Returns whether media codec was successfully
202 bool StartInternal() WARN_UNUSED_RESULT
;
204 jobject
media_codec() { return j_media_codec_
.obj(); }
205 MediaCodecDirection direction_
;
208 // Fills a particular input buffer; returns false if |data_size| exceeds the
209 // input buffer's capacity (and doesn't touch the input buffer in that case).
210 bool FillInputBuffer(int index
,
212 size_t data_size
) WARN_UNUSED_RESULT
;
214 // Java MediaCodec instance.
215 base::android::ScopedJavaGlobalRef
<jobject
> j_media_codec_
;
217 DISALLOW_COPY_AND_ASSIGN(MediaCodecBridge
);
220 class AudioCodecBridge
: public MediaCodecBridge
{
222 // Returns an AudioCodecBridge instance if |codec| is supported, or a NULL
223 // pointer otherwise.
224 static AudioCodecBridge
* Create(const AudioCodec
& codec
);
226 // See MediaCodecBridge::IsKnownUnaccelerated().
227 static bool IsKnownUnaccelerated(const AudioCodec
& codec
);
229 // Start the audio codec bridge.
230 bool Start(const AudioCodec
& codec
, int sample_rate
, int channel_count
,
231 const uint8
* extra_data
, size_t extra_data_size
,
232 int64 codec_delay_ns
, int64 seek_preroll_ns
,
233 bool play_audio
, jobject media_crypto
) WARN_UNUSED_RESULT
;
235 // Play the output buffer. This call must be called after
236 // DequeueOutputBuffer() and before ReleaseOutputBuffer. Returns the playback
237 // head position expressed in frames.
238 int64
PlayOutputBuffer(int index
, size_t size
);
240 // Set the volume of the audio output.
241 void SetVolume(double volume
);
244 explicit AudioCodecBridge(const std::string
& mime
);
246 // Configure the java MediaFormat object with the extra codec data passed in.
247 bool ConfigureMediaFormat(jobject j_format
, const AudioCodec
& codec
,
248 const uint8
* extra_data
, size_t extra_data_size
,
249 int64 codec_delay_ns
, int64 seek_preroll_ns
);
252 class MEDIA_EXPORT VideoCodecBridge
: public MediaCodecBridge
{
254 // See MediaCodecBridge::IsKnownUnaccelerated().
255 static bool IsKnownUnaccelerated(const VideoCodec
& codec
,
256 MediaCodecDirection direction
);
258 // Create, start, and return a VideoCodecBridge decoder or NULL on failure.
259 static VideoCodecBridge
* CreateDecoder(
260 const VideoCodec
& codec
, // e.g. media::kCodecVP8
262 const gfx::Size
& size
, // Output frame size.
263 jobject surface
, // Output surface, optional.
264 jobject media_crypto
); // MediaCrypto object, optional.
266 // Create, start, and return a VideoCodecBridge encoder or NULL on failure.
267 static VideoCodecBridge
* CreateEncoder(
268 const VideoCodec
& codec
, // e.g. media::kCodecVP8
269 const gfx::Size
& size
, // input frame size
270 int bit_rate
, // bits/second
271 int frame_rate
, // frames/second
272 int i_frame_interval
, // count
273 int color_format
); // MediaCodecInfo.CodecCapabilities.
275 void SetVideoBitrate(int bps
);
276 void RequestKeyFrameSoon();
278 // Returns whether adaptive playback is supported for this object given
280 bool IsAdaptivePlaybackSupported(int width
, int height
);
282 // Test-only method to set the return value of IsAdaptivePlaybackSupported().
283 // Without this function, the return value of that function will be device
284 // dependent. If |adaptive_playback_supported| is equal to 0, the return value
285 // will be false. If |adaptive_playback_supported| is larger than 0, the
286 // return value will be true.
287 void set_adaptive_playback_supported_for_testing(
288 int adaptive_playback_supported
) {
289 adaptive_playback_supported_for_testing_
= adaptive_playback_supported
;
293 VideoCodecBridge(const std::string
& mime
,
295 MediaCodecDirection direction
);
297 int adaptive_playback_supported_for_testing_
;
302 #endif // MEDIA_BASE_ANDROID_MEDIA_CODEC_BRIDGE_H_