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

Side by Side Diff: media/renderers/mock_gpu_video_accelerator_factories.cc

Issue 1133563010: Add a GpuMemoryBuffer pool that creates hardware backed VideoFrames. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Address reveman@'s nits. Created 5 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 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 #include "media/renderers/mock_gpu_video_accelerator_factories.h" 5 #include "media/renderers/mock_gpu_video_accelerator_factories.h"
6 6
7 #include "ui/gfx/gpu_memory_buffer.h"
8
7 namespace media { 9 namespace media {
8 10
11 namespace {
12
13 class GpuMemoryBufferImpl : public gfx::GpuMemoryBuffer {
14 public:
15 GpuMemoryBufferImpl(const gfx::Size& size) : size_(size) {
16 bytes_.resize(size_.GetArea());
17 }
18
19 // Overridden from gfx::GpuMemoryBuffer:
20 bool Map(void** data) override {
21 data[0] = &bytes_[0];
22 return true;
23 }
24 void Unmap() override{};
25 bool IsMapped() const override {
26 NOTREACHED();
27 return false;
28 }
29 Format GetFormat() const override { return gfx::GpuMemoryBuffer::R_8; }
30 void GetStride(int* stride) const override { stride[0] = size_.width(); }
31 gfx::GpuMemoryBufferHandle GetHandle() const override {
32 NOTREACHED();
33 return gfx::GpuMemoryBufferHandle();
34 }
35 ClientBuffer AsClientBuffer() override {
36 return reinterpret_cast<ClientBuffer>(this);
37 }
38
39 private:
40 std::vector<unsigned char> bytes_;
41 const gfx::Size size_;
42 };
43
44 } // unnamed namespace
45
9 MockGpuVideoAcceleratorFactories::MockGpuVideoAcceleratorFactories() {} 46 MockGpuVideoAcceleratorFactories::MockGpuVideoAcceleratorFactories() {}
10 47
11 MockGpuVideoAcceleratorFactories::~MockGpuVideoAcceleratorFactories() {} 48 MockGpuVideoAcceleratorFactories::~MockGpuVideoAcceleratorFactories() {}
12 49
50 scoped_ptr<gfx::GpuMemoryBuffer>
51 MockGpuVideoAcceleratorFactories::AllocateGpuMemoryBuffer(
52 const gfx::Size& size,
53 gfx::GpuMemoryBuffer::Format format,
54 gfx::GpuMemoryBuffer::Usage usage) {
55 DCHECK_EQ(gfx::GpuMemoryBuffer::R_8, format);
56 return make_scoped_ptr<gfx::GpuMemoryBuffer>(new GpuMemoryBufferImpl(size));
57 }
58
13 scoped_ptr<base::SharedMemory> 59 scoped_ptr<base::SharedMemory>
14 MockGpuVideoAcceleratorFactories::CreateSharedMemory(size_t size) { 60 MockGpuVideoAcceleratorFactories::CreateSharedMemory(size_t size) {
15 return nullptr; 61 return nullptr;
16 } 62 }
17 63
18 scoped_ptr<VideoDecodeAccelerator> 64 scoped_ptr<VideoDecodeAccelerator>
19 MockGpuVideoAcceleratorFactories::CreateVideoDecodeAccelerator() { 65 MockGpuVideoAcceleratorFactories::CreateVideoDecodeAccelerator() {
20 return scoped_ptr<VideoDecodeAccelerator>(DoCreateVideoDecodeAccelerator()); 66 return scoped_ptr<VideoDecodeAccelerator>(DoCreateVideoDecodeAccelerator());
21 } 67 }
22 68
23 scoped_ptr<VideoEncodeAccelerator> 69 scoped_ptr<VideoEncodeAccelerator>
24 MockGpuVideoAcceleratorFactories::CreateVideoEncodeAccelerator() { 70 MockGpuVideoAcceleratorFactories::CreateVideoEncodeAccelerator() {
25 return scoped_ptr<VideoEncodeAccelerator>(DoCreateVideoEncodeAccelerator()); 71 return scoped_ptr<VideoEncodeAccelerator>(DoCreateVideoEncodeAccelerator());
26 } 72 }
27 73
28 } // namespace media 74 } // namespace media
OLDNEW
« no previous file with comments | « media/renderers/mock_gpu_video_accelerator_factories.h ('k') | media/renderers/video_renderer_impl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698