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
gpu / ipc / service / gpu_memory_buffer_factory_native_pixmap.h [blame]
// Copyright 2014 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef GPU_IPC_SERVICE_GPU_MEMORY_BUFFER_FACTORY_NATIVE_PIXMAP_H_
#define GPU_IPC_SERVICE_GPU_MEMORY_BUFFER_FACTORY_NATIVE_PIXMAP_H_
#include <vulkan/vulkan_core.h>
#include <unordered_map>
#include <utility>
#include "base/hash/hash.h"
#include "base/synchronization/lock.h"
#include "gpu/ipc/service/gpu_ipc_service_export.h"
#include "gpu/ipc/service/gpu_memory_buffer_factory.h"
#include "ui/gfx/native_pixmap.h"
namespace gpu {
class VulkanDeviceQueue;
class GPU_IPC_SERVICE_EXPORT GpuMemoryBufferFactoryNativePixmap
: public GpuMemoryBufferFactory {
public:
GpuMemoryBufferFactoryNativePixmap();
explicit GpuMemoryBufferFactoryNativePixmap(
viz::VulkanContextProvider* vulkan_context_provider);
GpuMemoryBufferFactoryNativePixmap(
const GpuMemoryBufferFactoryNativePixmap&) = delete;
GpuMemoryBufferFactoryNativePixmap& operator=(
const GpuMemoryBufferFactoryNativePixmap&) = delete;
~GpuMemoryBufferFactoryNativePixmap() override;
// Overridden from GpuMemoryBufferFactory:
gfx::GpuMemoryBufferHandle CreateGpuMemoryBuffer(
gfx::GpuMemoryBufferId id,
const gfx::Size& size,
const gfx::Size& framebuffer_size,
gfx::BufferFormat format,
gfx::BufferUsage usage,
int client_id,
SurfaceHandle surface_handle) override;
void CreateGpuMemoryBufferAsync(
gfx::GpuMemoryBufferId id,
const gfx::Size& size,
gfx::BufferFormat format,
gfx::BufferUsage usage,
int client_id,
SurfaceHandle surface_handle,
CreateGpuMemoryBufferAsyncCallback callback) override;
void DestroyGpuMemoryBuffer(gfx::GpuMemoryBufferId id,
int client_id) override;
bool FillSharedMemoryRegionWithBufferContents(
gfx::GpuMemoryBufferHandle buffer_handle,
base::UnsafeSharedMemoryRegion shared_memory) override;
private:
using NativePixmapMapKey = std::pair<int, int>;
using NativePixmapMapKeyHash = base::IntPairHash<NativePixmapMapKey>;
using NativePixmapMap = std::unordered_map<NativePixmapMapKey,
scoped_refptr<gfx::NativePixmap>,
NativePixmapMapKeyHash>;
static void OnNativePixmapCreated(
gfx::GpuMemoryBufferId id,
const gfx::Size& size,
gfx::BufferFormat format,
gfx::BufferUsage usage,
int client_id,
CreateGpuMemoryBufferAsyncCallback callback,
base::WeakPtr<GpuMemoryBufferFactoryNativePixmap> weak_ptr,
scoped_refptr<gfx::NativePixmap> pixmap);
gfx::GpuMemoryBufferHandle CreateGpuMemoryBufferFromNativePixmap(
gfx::GpuMemoryBufferId id,
const gfx::Size& size,
gfx::BufferFormat format,
gfx::BufferUsage usage,
int client_id,
scoped_refptr<gfx::NativePixmap> pixmap);
VulkanDeviceQueue* GetVulkanDeviceQueue();
scoped_refptr<viz::VulkanContextProvider> vulkan_context_provider_;
NativePixmapMap native_pixmaps_;
base::Lock native_pixmaps_lock_;
base::WeakPtrFactory<GpuMemoryBufferFactoryNativePixmap> weak_factory_{this};
};
} // namespace gpu
#endif // GPU_IPC_SERVICE_GPU_MEMORY_BUFFER_FACTORY_NATIVE_PIXMAP_H_