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
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#ifndef gfx_layers_ipc_VideoBridgeParent_h_
#define gfx_layers_ipc_VideoBridgeParent_h_
#include "mozilla/Monitor.h"
#include "mozilla/layers/ISurfaceAllocator.h"
#include "mozilla/layers/PVideoBridgeParent.h"
namespace mozilla::layers {
enum class VideoBridgeSource : uint8_t;
class CompositorThreadHolder;
class VideoBridgeParent final : public PVideoBridgeParent,
public HostIPCAllocator,
public mozilla::ipc::IShmemAllocator {
public:
NS_INLINE_DECL_REFCOUNTING_INHERITED(VideoBridgeParent, HostIPCAllocator)
static RefPtr<VideoBridgeParent> GetSingleton(
const Maybe<VideoBridgeSource>& aSource);
static void Open(Endpoint<PVideoBridgeParent>&& aEndpoint,
VideoBridgeSource aSource);
static void Shutdown();
static void UnregisterExternalImages();
already_AddRefed<TextureHost> LookupTextureAsync(
const dom::ContentParentId& aContentId, uint64_t aSerial);
already_AddRefed<TextureHost> LookupTexture(
const dom::ContentParentId& aContentId, uint64_t aSerial);
// PVideoBridgeParent
void ActorDestroy(ActorDestroyReason aWhy) override;
PTextureParent* AllocPTextureParent(const SurfaceDescriptor& aSharedData,
ReadLockDescriptor& aReadLock,
const LayersBackend& aLayersBackend,
const TextureFlags& aFlags,
const dom::ContentParentId& aContentId,
const uint64_t& aSerial);
bool DeallocPTextureParent(PTextureParent* actor);
// HostIPCAllocator
base::ProcessId GetChildProcessId() override { return OtherPid(); }
void NotifyNotUsed(PTextureParent* aTexture,
uint64_t aTransactionId) override;
void SendAsyncMessage(
const nsTArray<AsyncParentMessageData>& aMessage) override;
// ISurfaceAllocator
IShmemAllocator* AsShmemAllocator() override { return this; }
bool IsSameProcess() const override;
bool IPCOpen() const override { return !mClosed; }
// IShmemAllocator
bool AllocShmem(size_t aSize, mozilla::ipc::Shmem* aShmem) override;
bool AllocUnsafeShmem(size_t aSize, mozilla::ipc::Shmem* aShmem) override;
bool DeallocShmem(mozilla::ipc::Shmem& aShmem) override;
private:
~VideoBridgeParent();
explicit VideoBridgeParent(VideoBridgeSource aSource);
void Bind(Endpoint<PVideoBridgeParent>&& aEndpoint);
static void ShutdownInternal();
void DoUnregisterExternalImages();
Monitor mMonitor;
RefPtr<CompositorThreadHolder> mCompositorThreadHolder
MOZ_GUARDED_BY(mMonitor);
std::map<uint64_t, PTextureParent*> mTextureMap MOZ_GUARDED_BY(mMonitor);
bool mClosed;
};
} // namespace mozilla::layers
#endif // gfx_layers_ipc_VideoBridgeParent_h_
|