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

Unified Diff: ppapi/proxy/ppb_video_decoder_proxy.h

Issue 7545014: Implement PPAPI VideoDecode out-of-process support (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: . Created 9 years, 5 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
Index: ppapi/proxy/ppb_video_decoder_proxy.h
diff --git a/ppapi/proxy/ppb_video_decoder_proxy.h b/ppapi/proxy/ppb_video_decoder_proxy.h
new file mode 100644
index 0000000000000000000000000000000000000000..9de3f3f1c87f73010dcc3d66061aa42c3872f8f2
--- /dev/null
+++ b/ppapi/proxy/ppb_video_decoder_proxy.h
@@ -0,0 +1,81 @@
+// Copyright (c) 2011 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 PPAPI_PROXY_PPB_VIDEO_DECODER_PROXY_H_
+#define PPAPI_PROXY_PPB_VIDEO_DECODER_PROXY_H_
+
+#include "ppapi/c/pp_instance.h"
+#include "ppapi/cpp/completion_callback.h"
+#include "ppapi/proxy/interface_proxy.h"
+#include "ppapi/proxy/plugin_resource.h"
+#include "ppapi/proxy/proxy_non_thread_safe_ref_count.h"
+#include "ppapi/shared_impl/video_decoder_impl.h"
+#include "ppapi/thunk/ppb_video_decoder_api.h"
+
+namespace pp {
+namespace proxy {
+
+class PPB_VideoDecoder_Proxy : public InterfaceProxy {
+ public:
+ PPB_VideoDecoder_Proxy(Dispatcher* dispatcher, const void* target_interface);
+ virtual ~PPB_VideoDecoder_Proxy();
+
+ static const Info* GetInfo();
+
+ // Creates a VideoDecoder object in the plugin process.
+ static PP_Resource CreateProxyResource(PP_Instance instance,
+ PP_Resource context3d_id, const PP_VideoConfigElement* config);
+
+ // InterfaceProxy implementation.
+ virtual bool OnMessageReceived(const IPC::Message& msg);
+
+ const PPB_VideoDecoder_Dev* ppb_video_decoder_target() const {
+ return static_cast<const PPB_VideoDecoder_Dev*>(target_interface());
+ }
+
+ private:
+ // Message handlers in the renderer process to receive messages from the
+ // plugin process.
+ void OnMsgCreate(PP_Instance instance, const HostResource& context3d_id,
+ const std::vector<PP_VideoConfigElement>& config,
+ HostResource* result);
+ void OnMsgDecode(
+ const HostResource& decoder,
+ const HostResource& buffer, int32 id, int32 size);
+ void OnMsgAssignPictureBuffers(
+ const HostResource& decoder,
+ const std::vector<PP_PictureBuffer_Dev>& buffers);
+ void OnMsgReusePictureBuffer(
+ const HostResource& decoder,
+ int32 picture_buffer_id);
+ void OnMsgFlush(const HostResource& decoder);
+ void OnMsgReset(const HostResource& decoder);
+ void OnMsgDestroy(const HostResource& decoder);
+
+ // Send a message from the renderer process to the plugin process to tell it
+ // to run its callback.
+ void SendMsgEndOfBitstreamACKToPlugin(
+ int32_t result, const HostResource& decoder, int32 id);
+ void SendMsgFlushACKToPlugin(
+ int32_t result, const HostResource& decoder);
+ void SendMsgResetACKToPlugin(
+ int32_t result, const HostResource& decoder);
+
+ // Message handlers in the plugin process to receive messages from the
+ // renderer process.
+ void OnMsgEndOfBitstreamACK(const HostResource& decoder,
+ int32_t id, int32_t pp_error);
Ami GONE FROM CHROMIUM 2011/08/03 20:25:53 elsewhere these are called "result" and I think th
vrk (LEFT CHROMIUM) 2011/08/03 22:05:22 Done.
+ void OnMsgFlushACK(const HostResource& decoder, int32_t pp_error);
+ void OnMsgResetACK(const HostResource& decoder, int32_t pp_error);
+
+ CompletionCallbackFactory<PPB_VideoDecoder_Proxy,
+ ProxyNonThreadSafeRefCount> callback_factory_;
+
+ DISALLOW_COPY_AND_ASSIGN(PPB_VideoDecoder_Proxy);
+};
+
+} // namespace proxy
+} // namespace pp
+
+#endif // PPAPI_PROXY_PPB_VIDEO_DECODER_PROXY_H_

Powered by Google App Engine
This is Rietveld 408576698