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

Unified Diff: chrome/renderer/pepper_plugin_delegate_impl.cc

Issue 3087009: add pepper video decoder glue and delegate (Closed) Base URL: http://src.chromium.org/git/chromium.git
Patch Set: reload Created 10 years, 4 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/renderer/pepper_plugin_delegate_impl.h ('k') | webkit/glue/plugins/pepper_plugin_delegate.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/renderer/pepper_plugin_delegate_impl.cc
diff --git a/chrome/renderer/pepper_plugin_delegate_impl.cc b/chrome/renderer/pepper_plugin_delegate_impl.cc
index df9d49c63fd4c49500d464593b1b638dda4c9fb4..7baab68c32b4768753422f1348fd67a75aec2e41 100644
--- a/chrome/renderer/pepper_plugin_delegate_impl.cc
+++ b/chrome/renderer/pepper_plugin_delegate_impl.cc
@@ -157,6 +157,91 @@ void PlatformAudioImpl::ShutDown() {
client_ = NULL;
}
+// Implements the VideoDecoder.
+class PlatformVideoDecoderImpl
+ : public pepper::PluginDelegate::PlatformVideoDecoder {
+ public:
+ PlatformVideoDecoderImpl()
+ : input_buffer_size_(0),
+ next_dib_id_(0),
+ dib_(NULL) {
+ memset(&flush_callback_, 0, sizeof(flush_callback_));
+ }
+
+ virtual bool Init(const PP_VideoDecoderConfig& decoder_config) {
+ decoder_config_ = decoder_config;
+ input_buffer_size_ = 1024 << 4;
+
+ // Allocate the transport DIB.
+ TransportDIB* dib = TransportDIB::Create(input_buffer_size_,
+ next_dib_id_++);
+ if (!dib)
+ return false;
+
+ // TODO(wjia): Create video decoder in GPU process.
+
+ return true;
+ }
+
+ virtual bool Decode(PP_VideoCompressedDataBuffer& input_buffer) {
+ // TODO(wjia): Implement me!
+ NOTIMPLEMENTED();
+
+ input_buffers_.push(&input_buffer);
+
+ // Copy input data to dib_ and send it to GPU video decoder.
+
+ return false;
+ }
+
+ virtual int32_t Flush(PP_CompletionCallback& callback) {
+ // TODO(wjia): Implement me!
+ NOTIMPLEMENTED();
+
+ // Do nothing if there is a flush pending.
+ if (flush_callback_.func)
+ return PP_ERROR_BADARGUMENT;
+
+ flush_callback_ = callback;
+
+ // Call GPU video decoder to flush.
+
+ return PP_ERROR_WOULDBLOCK;
+ }
+
+ virtual bool ReturnUncompressedDataBuffer(
+ PP_VideoUncompressedDataBuffer& buffer) {
+ // TODO(wjia): Implement me!
+ NOTIMPLEMENTED();
+
+ // Deliver the buffer to GPU video decoder.
+
+ return false;
+ }
+
+ void OnFlushDone() {
+ if (!flush_callback_.func)
+ return;
+
+ flush_callback_.func(flush_callback_.user_data, PP_OK);
+ flush_callback_.func = NULL;
+ }
+
+ virtual intptr_t GetSharedMemoryHandle() const {
+ return reinterpret_cast<intptr_t>(dib_.get());
+ }
+
+ private:
+ size_t input_buffer_size_;
+ int next_dib_id_;
+ scoped_ptr<TransportDIB> dib_;
+ PP_VideoDecoderConfig decoder_config_;
+ std::queue<PP_VideoCompressedDataBuffer*> input_buffers_;
+ PP_CompletionCallback flush_callback_;
+
+ DISALLOW_COPY_AND_ASSIGN(PlatformVideoDecoderImpl);
+};
+
} // namespace
PepperPluginDelegateImpl::PepperPluginDelegateImpl(RenderView* render_view)
@@ -248,6 +333,17 @@ PepperPluginDelegateImpl::CreateImage2D(int width, int height) {
return new PlatformImage2DImpl(width, height, dib);
}
+pepper::PluginDelegate::PlatformVideoDecoder*
+PepperPluginDelegateImpl::CreateVideoDecoder(
+ const PP_VideoDecoderConfig& decoder_config) {
+ scoped_ptr<PlatformVideoDecoderImpl> decoder(new PlatformVideoDecoderImpl());
+
+ if (!decoder->Init(decoder_config))
+ return NULL;
+
+ return decoder.release();
+}
+
void PepperPluginDelegateImpl::DidChangeNumberOfFindResults(int identifier,
int total,
bool final_result) {
« no previous file with comments | « chrome/renderer/pepper_plugin_delegate_impl.h ('k') | webkit/glue/plugins/pepper_plugin_delegate.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698