summaryrefslogtreecommitdiffstats
path: root/content/gpu/gpu_video_service.cc
diff options
context:
space:
mode:
Diffstat (limited to 'content/gpu/gpu_video_service.cc')
-rw-r--r--content/gpu/gpu_video_service.cc82
1 files changed, 82 insertions, 0 deletions
diff --git a/content/gpu/gpu_video_service.cc b/content/gpu/gpu_video_service.cc
new file mode 100644
index 0000000..355aabc
--- /dev/null
+++ b/content/gpu/gpu_video_service.cc
@@ -0,0 +1,82 @@
+// 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.
+
+#include "content/common/gpu_messages.h"
+#include "content/gpu/gpu_channel.h"
+#include "content/gpu/gpu_video_decoder.h"
+#include "content/gpu/gpu_video_service.h"
+
+struct GpuVideoService::GpuVideoDecoderInfo {
+ scoped_refptr<GpuVideoDecoder> decoder;
+ GpuChannel* channel;
+};
+
+
+GpuVideoService::GpuVideoService() {
+ // TODO(jiesun): move this time consuming stuff out of here.
+ IntializeGpuVideoService();
+}
+
+GpuVideoService::~GpuVideoService() {
+ // TODO(jiesun): move this time consuming stuff out of here.
+ UnintializeGpuVideoService();
+}
+
+// static
+GpuVideoService* GpuVideoService::GetInstance() {
+ return Singleton<GpuVideoService>::get();
+}
+
+void GpuVideoService::OnChannelConnected(int32 peer_pid) {
+ LOG(ERROR) << "GpuVideoService::OnChannelConnected";
+}
+
+void GpuVideoService::OnChannelError() {
+ LOG(ERROR) << "GpuVideoService::OnChannelError";
+}
+
+bool GpuVideoService::OnMessageReceived(const IPC::Message& msg) {
+#if 0
+ IPC_BEGIN_MESSAGE_MAP(GpuVideoService, msg)
+ IPC_MESSAGE_UNHANDLED_ERROR()
+ IPC_END_MESSAGE_MAP()
+#endif
+ return false;
+}
+
+bool GpuVideoService::IntializeGpuVideoService() {
+ return true;
+}
+
+bool GpuVideoService::UnintializeGpuVideoService() {
+ return true;
+}
+
+bool GpuVideoService::CreateVideoDecoder(
+ GpuChannel* channel,
+ MessageRouter* router,
+ int32 decoder_host_id,
+ int32 decoder_id,
+ gpu::gles2::GLES2Decoder* gles2_decoder) {
+ GpuVideoDecoderInfo decoder_info;
+ decoder_info.decoder = new GpuVideoDecoder(MessageLoop::current(),
+ decoder_host_id,
+ channel,
+ channel->renderer_process(),
+ gles2_decoder);
+ decoder_info.channel = channel;
+ decoder_map_[decoder_id] = decoder_info;
+ router->AddRoute(decoder_id, decoder_info.decoder);
+
+ channel->Send(new GpuVideoDecoderHostMsg_CreateVideoDecoderDone(
+ decoder_host_id, decoder_id));
+ return true;
+}
+
+void GpuVideoService::DestroyVideoDecoder(
+ MessageRouter* router,
+ int32 decoder_id) {
+ router->RemoveRoute(decoder_id);
+ decoder_map_.erase(decoder_id);
+}