mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:30:27 +00:00
4ac9bef80d
- Bug 936092, initial DnD support for e10s, r=enndeakin,karlt (3cde556cf) - Bug 1152066 - Remove ugly dynamic loading code now that we can assume this symbol exists. r=roc (04813dd18) - Bug 966395 - Correctly propagate the input language's direction on OSX. r=masayuki/mrbkap (14a21fa0c) - Bug 1158791 - Try harder to avoid Gtk-Critical errors in xpcshell tests. r=karlt (f6cec3b99) - Bug 1153922 - Add a SandboxOptions option for creating the sandbox in a fresh JS::Zone. r=mrbkap (f99b17726) - Bug 968520 - Always use fallible allocator with nsTArray_base::ShrinkCapacity. r=froydnj (b7cf63063) - Bug 1160027 - Move ResourceQueue implementation from header file - r=cpearce (5fabd8c8f) - Bug 1119277 - Remove the process CPU priority parameter and simplify all the associated code. r=khuey, r=dhylands (32d2b0df2) - Goanna -> Gecko (2b16bec4c) - Bug 892371 - Adjust oom_score_adj values for foreground processes according to an LRU policy. r=dhylands, r=khuey (61cdfc3db) - Bug 892371 - Add mochitests covering LRU priority adjustments for both foreground and background processes. r=khuey (46676e34f) - Bug 1164297 - tweaks to logging modules of MediaDecoderStateMachine to remove accessing to env vars. r=cpearce. (e9dc910da) - Bug 1150539: log getUserMedia constraints used in MediaManager:5. r=jesup (161853b66) - Bug 1139027 - Permit running of camera mochitests on B2G desktop. r=mikeh (8bb265db2) - Bug 1145403 - Don't open MediaManager on shutdown. r=jesup (9338eef82) - Bug 1046245 - enumerateDevices w/non-blocking e10s, nsICryptoHMAC, clear cookies, lambdas. r=keeler, florian, billm, jesup (ce9d684a0) - remove StopWebRtcLoc() to be readded in Bug 1219339 - Part2 (7a0c901fc) - Bug 1046245 - IO on STS thread + cleanup BackgroundChild on shutdown r=jesup (e85dd7716) - Bug 579517 follow-up: Remove NSPR types that crept in (35aee15a6) - Bug 1152443 - Fix broken validation which prevented reading of enumerate_devices.txt. r=jesup (4e135355b) - Bug 1143562 - use /data/b2g/mozilla/gmp as the gmp storage folder on B2G. r=cpearce. (ddc07f09a) - Bug 1143562. Part2 - only init |mStorageBaseDir| in the chrome process. r=cpearce (3039a4f44) - remove specific hack, this code is going away anyway (34aed4d6b) - Bug 1057908 - GeckoMediaPluginService needs to be proxied from Content processes to parent process. Part 0 - Make mozIGeckoMediaPluginService::GetPluginVersionForAPI return whether we even have the plugin. r=cpearce. (e6ac61630) - Bug 1057908 - GeckoMediaPluginService needs to be proxied from Content processes to parent process. Part 1 - split GeckoMediaPluginService into a part for chrome and a part for both content and chrome. r=jwwang. (09f8c4a83) - Bug 1057908 - GeckoMediaPluginService needs to be proxied from Content processes to parent process. Part 2 - support asynchronous GMP API getters. r=jwwang,rjesup. (e33266976) - Bug 1143532 - Include pid in the log messages of GMPParent. r=edwin (8486ebc50) - Bug 1057908 - GeckoMediaPluginService needs to be proxied from Content processes to parent process. Part 3 - split the GMP IPDL actors in 2 parts (and use opens to open the second in non-e10s). r=billm. (d17fa36ff) - Bug 1057908 - GeckoMediaPluginService needs to be proxied from Content processes to parent process. Part 4 - make GetNodeId asynchronous. r=jwwang. (db7a21e4a) - Bug 1150049 - tidy up nsImageBoxFrame::Init a little bit; r=dholbert (41c258a71) - Bug 1150266 - fix IPDL thinko for never-inline method declarations; r=bent (445d3420b) - Bug 1150207 - Convert a focus() call to use SpecialPowers to avoid out-of-order focusing behaviour. r=mwargers (4d134848c) - Bug 1148641 - Guard against null parameters to SendSetTargetAPZCNotification. r=botond (8c5f4bb6d) - Bug 1096172 - Fix position reporting of bad charrefs in RCDATA. r=hsivonen. (77100d26d) - Bug 1149971 Part 2: Cet rid of kCurrentProcessId as it makes lots of static initializers. r=dvander (3efaefdba) - remove android widgets (0c2565418) - Bug 1129991 - Remove QuotaManager::SetCurrentWindow(); r=bent (7ccabf88c) - Bug 1133748 - Fix ipdl code for bridged protocols that are also opened. r=billm. (402751d09) - Bug 1057908 - GeckoMediaPluginService needs to be proxied from Content processes to parent process. Part 5 - use bridging for GMP in e10s. r=billm. (e45a87c5f) - Bug 1057908 followup: Add missing 'override' annotation on GMPServiceParent::ActorDestroy method decl. rs=ehsan (48f53b28a) - Bug 1057908 - GeckoMediaPluginService needs to be proxied from Content processes to parent process. Add nsServiceManagerUtils.h include to WMFDecoderModule.cpp. (67cddb4da) - kill android widgets better (bec243c8d)
204 lines
4.7 KiB
C++
204 lines
4.7 KiB
C++
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* 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/. */
|
|
|
|
#include "GMPVideoDecoderChild.h"
|
|
#include "GMPVideoi420FrameImpl.h"
|
|
#include "GMPContentChild.h"
|
|
#include <stdio.h>
|
|
#include "mozilla/unused.h"
|
|
#include "GMPVideoEncodedFrameImpl.h"
|
|
|
|
namespace mozilla {
|
|
namespace gmp {
|
|
|
|
GMPVideoDecoderChild::GMPVideoDecoderChild(GMPContentChild* aPlugin)
|
|
: GMPSharedMemManager(aPlugin),
|
|
mPlugin(aPlugin),
|
|
mVideoDecoder(nullptr),
|
|
mVideoHost(this)
|
|
{
|
|
MOZ_ASSERT(mPlugin);
|
|
}
|
|
|
|
GMPVideoDecoderChild::~GMPVideoDecoderChild()
|
|
{
|
|
}
|
|
|
|
void
|
|
GMPVideoDecoderChild::Init(GMPVideoDecoder* aDecoder)
|
|
{
|
|
MOZ_ASSERT(aDecoder, "Cannot initialize video decoder child without a video decoder!");
|
|
mVideoDecoder = aDecoder;
|
|
}
|
|
|
|
GMPVideoHostImpl&
|
|
GMPVideoDecoderChild::Host()
|
|
{
|
|
return mVideoHost;
|
|
}
|
|
|
|
void
|
|
GMPVideoDecoderChild::Decoded(GMPVideoi420Frame* aDecodedFrame)
|
|
{
|
|
MOZ_ASSERT(mPlugin->GMPMessageLoop() == MessageLoop::current());
|
|
|
|
if (!aDecodedFrame) {
|
|
MOZ_CRASH("Not given a decoded frame!");
|
|
}
|
|
|
|
auto df = static_cast<GMPVideoi420FrameImpl*>(aDecodedFrame);
|
|
|
|
GMPVideoi420FrameData frameData;
|
|
df->InitFrameData(frameData);
|
|
SendDecoded(frameData);
|
|
|
|
aDecodedFrame->Destroy();
|
|
}
|
|
|
|
void
|
|
GMPVideoDecoderChild::ReceivedDecodedReferenceFrame(const uint64_t aPictureId)
|
|
{
|
|
MOZ_ASSERT(mPlugin->GMPMessageLoop() == MessageLoop::current());
|
|
|
|
SendReceivedDecodedReferenceFrame(aPictureId);
|
|
}
|
|
|
|
void
|
|
GMPVideoDecoderChild::ReceivedDecodedFrame(const uint64_t aPictureId)
|
|
{
|
|
MOZ_ASSERT(mPlugin->GMPMessageLoop() == MessageLoop::current());
|
|
|
|
SendReceivedDecodedFrame(aPictureId);
|
|
}
|
|
|
|
void
|
|
GMPVideoDecoderChild::InputDataExhausted()
|
|
{
|
|
MOZ_ASSERT(mPlugin->GMPMessageLoop() == MessageLoop::current());
|
|
|
|
SendInputDataExhausted();
|
|
}
|
|
|
|
void
|
|
GMPVideoDecoderChild::DrainComplete()
|
|
{
|
|
MOZ_ASSERT(mPlugin->GMPMessageLoop() == MessageLoop::current());
|
|
|
|
SendDrainComplete();
|
|
}
|
|
|
|
void
|
|
GMPVideoDecoderChild::ResetComplete()
|
|
{
|
|
MOZ_ASSERT(mPlugin->GMPMessageLoop() == MessageLoop::current());
|
|
|
|
SendResetComplete();
|
|
}
|
|
|
|
void
|
|
GMPVideoDecoderChild::Error(GMPErr aError)
|
|
{
|
|
MOZ_ASSERT(mPlugin->GMPMessageLoop() == MessageLoop::current());
|
|
|
|
SendError(aError);
|
|
}
|
|
|
|
bool
|
|
GMPVideoDecoderChild::RecvInitDecode(const GMPVideoCodec& aCodecSettings,
|
|
InfallibleTArray<uint8_t>&& aCodecSpecific,
|
|
const int32_t& aCoreCount)
|
|
{
|
|
if (!mVideoDecoder) {
|
|
return false;
|
|
}
|
|
|
|
// Ignore any return code. It is OK for this to fail without killing the process.
|
|
mVideoDecoder->InitDecode(aCodecSettings,
|
|
aCodecSpecific.Elements(),
|
|
aCodecSpecific.Length(),
|
|
this,
|
|
aCoreCount);
|
|
return true;
|
|
}
|
|
|
|
bool
|
|
GMPVideoDecoderChild::RecvDecode(const GMPVideoEncodedFrameData& aInputFrame,
|
|
const bool& aMissingFrames,
|
|
InfallibleTArray<uint8_t>&& aCodecSpecificInfo,
|
|
const int64_t& aRenderTimeMs)
|
|
{
|
|
if (!mVideoDecoder) {
|
|
return false;
|
|
}
|
|
|
|
auto f = new GMPVideoEncodedFrameImpl(aInputFrame, &mVideoHost);
|
|
|
|
// Ignore any return code. It is OK for this to fail without killing the process.
|
|
mVideoDecoder->Decode(f,
|
|
aMissingFrames,
|
|
aCodecSpecificInfo.Elements(),
|
|
aCodecSpecificInfo.Length(),
|
|
aRenderTimeMs);
|
|
|
|
return true;
|
|
}
|
|
|
|
bool
|
|
GMPVideoDecoderChild::RecvChildShmemForPool(Shmem&& aFrameBuffer)
|
|
{
|
|
if (aFrameBuffer.IsWritable()) {
|
|
mVideoHost.SharedMemMgr()->MgrDeallocShmem(GMPSharedMem::kGMPFrameData,
|
|
aFrameBuffer);
|
|
}
|
|
return true;
|
|
}
|
|
|
|
bool
|
|
GMPVideoDecoderChild::RecvReset()
|
|
{
|
|
if (!mVideoDecoder) {
|
|
return false;
|
|
}
|
|
|
|
// Ignore any return code. It is OK for this to fail without killing the process.
|
|
mVideoDecoder->Reset();
|
|
|
|
return true;
|
|
}
|
|
|
|
bool
|
|
GMPVideoDecoderChild::RecvDrain()
|
|
{
|
|
if (!mVideoDecoder) {
|
|
return false;
|
|
}
|
|
|
|
// Ignore any return code. It is OK for this to fail without killing the process.
|
|
mVideoDecoder->Drain();
|
|
|
|
return true;
|
|
}
|
|
|
|
bool
|
|
GMPVideoDecoderChild::RecvDecodingComplete()
|
|
{
|
|
if (mVideoDecoder) {
|
|
// Ignore any return code. It is OK for this to fail without killing the process.
|
|
mVideoDecoder->DecodingComplete();
|
|
mVideoDecoder = nullptr;
|
|
}
|
|
|
|
mVideoHost.DoneWithAPI();
|
|
|
|
mPlugin = nullptr;
|
|
|
|
unused << Send__delete__(this);
|
|
|
|
return true;
|
|
}
|
|
|
|
} // namespace gmp
|
|
} // namespace mozilla
|