Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(68)

Side by Side Diff: services/media/framework_ffmpeg/ffmpeg_video_decoder.h

Issue 1923763002: Motown: Ffmpeg video decoder (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Created 4 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 #ifndef SERVICES_MEDIA_FRAMEWORK_FFMPEG_FFMPEG_VIDEO_DECODER_H_ 5 #ifndef SERVICES_MEDIA_FRAMEWORK_FFMPEG_FFMPEG_VIDEO_DECODER_H_
6 #define SERVICES_MEDIA_FRAMEWORK_FFMPEG_FFMPEG_VIDEO_DECODER_H_ 6 #define SERVICES_MEDIA_FRAMEWORK_FFMPEG_FFMPEG_VIDEO_DECODER_H_
7 7
8 #include "services/media/framework_ffmpeg/ffmpeg_decoder_base.h" 8 #include "services/media/framework_ffmpeg/ffmpeg_decoder_base.h"
9 9
10 namespace mojo { 10 namespace mojo {
11 namespace media { 11 namespace media {
12 12
13 // Decoder implementation employing and ffmpeg video decoder. 13 // Decoder implementation employing and ffmpeg video decoder.
14 // TODO(dalesat): Complete this. 14 // TODO(dalesat): Complete this.
15 class FfmpegVideoDecoder : public FfmpegDecoderBase { 15 class FfmpegVideoDecoder : public FfmpegDecoderBase {
16 public: 16 public:
17 FfmpegVideoDecoder(AvCodecContextPtr av_codec_context); 17 FfmpegVideoDecoder(AvCodecContextPtr av_codec_context);
18 18
19 ~FfmpegVideoDecoder() override; 19 ~FfmpegVideoDecoder() override;
20 20
21 protected: 21 protected:
22 // FfmpegDecoderBase overrides. 22 // FfmpegDecoderBase overrides.
23 void Flush() override;
24
23 int Decode(const AVPacket& av_packet, 25 int Decode(const AVPacket& av_packet,
24 const ffmpeg::AvFramePtr& av_frame_ptr, 26 const ffmpeg::AvFramePtr& av_frame_ptr,
25 PayloadAllocator* allocator, 27 PayloadAllocator* allocator,
26 bool* frame_decoded_out) override; 28 bool* frame_decoded_out) override;
27 29
28 PacketPtr CreateOutputPacket(const AVFrame& av_frame, 30 PacketPtr CreateOutputPacket(const AVFrame& av_frame,
29 PayloadAllocator* allocator) override; 31 PayloadAllocator* allocator) override;
30 32
31 PacketPtr CreateOutputEndOfStreamPacket() override; 33 PacketPtr CreateOutputEndOfStreamPacket() override;
32 34
33 private: 35 private:
36 using Extent = VideoStreamType::Extent;
37
34 // Callback used by the ffmpeg decoder to acquire a buffer. 38 // Callback used by the ffmpeg decoder to acquire a buffer.
35 static int AllocateBufferForAvFrame(AVCodecContext* av_codec_context, 39 static int AllocateBufferForAvFrame(AVCodecContext* av_codec_context,
36 AVFrame* av_frame, 40 AVFrame* av_frame,
37 int flags); 41 int flags);
38 42
39 // Callback used by the ffmpeg decoder to release a buffer. 43 // Callback used by the ffmpeg decoder to release a buffer.
40 static void ReleaseBufferForAvFrame(void* opaque, uint8_t* buffer); 44 static void ReleaseBufferForAvFrame(void* opaque, uint8_t* buffer);
41 45
42 // AllocateBufferForAvFrame deposits the packet size here, because there's 46 // The allocator used by avcodec_decode_audio4 to provide context for
43 // no good evidence of it after avcodec_decode_audio4 completes. 47 // AllocateBufferForAvFrame. This is set only during the call to
44 uint64_t packet_size_; 48 // avcodec_decode_audio4.
49 PayloadAllocator* allocator_;
kulakowski 2016/04/27 02:16:30 Are PayloadAllocators some global-ish things? Or o
dalesat 2016/04/27 15:40:14 PayloadAllocator implementations come in two forms
45 50
46 // This is used to verify that an allocated buffer is being used as expected 51 // Used to supply PTS for end-of-stream.
47 // by ffmpeg avcodec_decode_audio4. AllocateBufferForAvFrame sets it. 52 int64_t next_pts_ = Packet::kUnknownPts;
48 // void* packet_buffer_; 53
54 // TODO(dalesat): For investigation purposes only...remove one day.
kulakowski 2016/04/27 02:16:30 Does this mean all three of the following members?
dalesat 2016/04/27 15:40:14 Yes. Changed the comment.
55 bool first_frame_ = true;
56 AVColorSpace colorspace_;
57 Extent coded_size_;
49 }; 58 };
50 59
51 } // namespace media 60 } // namespace media
52 } // namespace mojo 61 } // namespace mojo
53 62
54 #endif // SERVICES_MEDIA_FRAMEWORK_FFMPEG_FFMPEG_VIDEO_DECODER_H_ 63 #endif // SERVICES_MEDIA_FRAMEWORK_FFMPEG_FFMPEG_VIDEO_DECODER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698