1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
|
// Copyright 2014 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CONTENT_RENDERER_PEPPER_VIDEO_DECODER_SHIM_H_
#define CONTENT_RENDERER_PEPPER_VIDEO_DECODER_SHIM_H_
#include <stdint.h>
#include <memory>
#include <vector>
#include "base/containers/hash_tables.h"
#include "base/containers/queue.h"
#include "base/macros.h"
#include "base/memory/weak_ptr.h"
#include "gpu/command_buffer/common/mailbox.h"
#include "media/base/video_decoder_config.h"
#include "media/video/video_decode_accelerator.h"
#include "ppapi/c/pp_codecs.h"
namespace base {
class SingleThreadTaskRunner;
}
namespace ui {
class ContextProviderCommandBuffer;
}
namespace content {
class PepperVideoDecoderHost;
// This class is a shim to wrap a media::VideoDecoder so that it can be used
// by PepperVideoDecoderHost in place of a media::VideoDecodeAccelerator.
// This class should be constructed, used, and destructed on the main (render)
// thread.
class VideoDecoderShim : public media::VideoDecodeAccelerator {
public:
VideoDecoderShim(PepperVideoDecoderHost* host, uint32_t texture_pool_size);
~VideoDecoderShim() override;
// media::VideoDecodeAccelerator implementation.
bool Initialize(const Config& config, Client* client) override;
void Decode(const media::BitstreamBuffer& bitstream_buffer) override;
void AssignPictureBuffers(
const std::vector<media::PictureBuffer>& buffers) override;
void ReusePictureBuffer(int32_t picture_buffer_id) override;
void Flush() override;
void Reset() override;
void Destroy() override;
private:
enum State {
UNINITIALIZED,
DECODING,
FLUSHING,
RESETTING,
};
struct PendingDecode;
struct PendingFrame;
class DecoderImpl;
class YUVConverter;
void OnInitializeFailed();
void OnDecodeComplete(int32_t result, uint32_t decode_id);
void OnOutputComplete(std::unique_ptr<PendingFrame> frame);
void SendPictures();
void OnResetComplete();
void NotifyCompletedDecodes();
void DismissTexture(uint32_t texture_id);
void DeleteTexture(uint32_t texture_id);
// Call this whenever we change GL state that the plugin relies on, such as
// creating picture textures.
void FlushCommandBuffer();
std::unique_ptr<DecoderImpl> decoder_impl_;
State state_;
PepperVideoDecoderHost* host_;
scoped_refptr<base::SingleThreadTaskRunner> media_task_runner_;
scoped_refptr<ui::ContextProviderCommandBuffer> context_provider_;
// The current decoded frame size.
gfx::Size texture_size_;
// Map that takes the plugin's GL texture id to the renderer's GL texture id.
using TextureIdMap = base::hash_map<uint32_t, uint32_t>;
TextureIdMap texture_id_map_;
// Available textures (these are plugin ids.)
using TextureIdSet = base::hash_set<uint32_t>;
TextureIdSet available_textures_;
// Track textures that are no longer needed (these are plugin ids.)
TextureIdSet textures_to_dismiss_;
// Mailboxes for pending texture requests, to write to plugin's textures.
std::vector<gpu::Mailbox> pending_texture_mailboxes_;
// Queue of completed decode ids, for notifying the host.
using CompletedDecodeQueue = base::queue<uint32_t>;
CompletedDecodeQueue completed_decodes_;
// Queue of decoded frames that await rgb->yuv conversion.
using PendingFrameQueue = base::queue<std::unique_ptr<PendingFrame>>;
PendingFrameQueue pending_frames_;
// The optimal number of textures to allocate for decoder_impl_.
uint32_t texture_pool_size_;
uint32_t num_pending_decodes_;
std::unique_ptr<YUVConverter> yuv_converter_;
base::WeakPtrFactory<VideoDecoderShim> weak_ptr_factory_;
DISALLOW_COPY_AND_ASSIGN(VideoDecoderShim);
};
} // namespace content
#endif // CONTENT_RENDERER_PEPPER_VIDEO_DECODER_SHIM_H_
|