mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:30:27 +00:00
8f529f64f5
- Bug 932865 - Add ThreadHangStats for collecting background hang telemetry; r=vladan (2f08a076b)
- Bug 932865 - Add way for telemetry to iterate over active threads; r=froydnj (535615d3d)
- Bug 1128768: Part 3 - Update BHR to allow for hang annotations; r=vladan (0b880a667)
- Bug 935092 - Add ThreadStackHelper to get a thread's pesudo-stack; r=BenWa (1422cfe4d)
- Bug 942488 - Don't report pseudo-stacks without SPS profiler. r=nchen (e160a7a08)
- Bug 946817 - Don't assert mPseudoStack on B2G. r=BenWa (9f846df3b)
- Bug 951431 - Don't get stacks during profiler runs on Linux; r=BenWa (15036e907)
- Bug 978262 - Ignore duplicate frames when getting BHR stack. r=froydnj (964721b1b)
- Bug 985155 - Add signal trampoline on ARM Linux to work around kernel bug. r=snorp (cb8a7846c)
- Bug 995730 - Convert xpcom/threads/ to Gecko style. r=froydnj (fe150404e)
- Bug 1013326 - Distinguish chrome and content scripts in pseudostack; r=snorp (81273c977)
- Bug 1023461 - Remove temporary stack buffer in ThreadStackHelper; r=snorp (cf5a717c2)
- Bug 1023461 - Record filename and line number for chrome JS entries; r=snorp (10c89808f)
- Bug 1022456 - Fix modelines in xpcom/{base,glue,io,string,threads}/. (48dbc0416)
- Bug 1016441 - Switch to using real-time signal in ThreadStackHelper; (2c5f818be)
- Bug 1016629 - b. Use RAII class to assign mStackToFill; r=snorp (769eae130)
- Bug 1016629 - c. Add define for ThreadStackHelper pseudostack support; r=snorp (67def0d2f)
- Bug 1016629 - d. Add and implement GetNativeStack method in ThreadStackHelper; r=snorp r=jseward (46c52f2be)
- Bug 1016629 - e. Implement platform-specific code for filling in context; r=snorp r=jseward (e6a66858b)
- Bug 1016629 - g. Avoid ASan flag when copying stack; r=snorp (0159628b5)
- Bug 1045176 - Unbreak build on non-SPS platforms after bug 1016629. (f1d60d838)
- Bug 1047123 - ThreadStackHelper should use UniquePtr<uint8_t[]>, not ScopedDeleteArray. r=jchen (0e4af313c)
- Bug 1049161 - Fix ThreadStackHelper thread handle permissions on Windows; r=snorp (c05172b1c)
- Bug 1050185 - Make ThreadStackHelper::FillThreadContext Valgrind-friendly. r=nchen (368725774)
- Bug 1050440 - Remove repeated js::RunScript frames in ThreadStackHelper (2a79600b3)
- Bug 1046841 - Fix more style violations in previously touched .cpp files in xpcom/. r=froydnj (02afe2493)
- Bug 1069694 - Remove or move around functions in OldDebugAPI. r=shu (177197302)
- Bug 1069694 - Remove OldDebugAPI from the browser. r=shu (b8c917d42)
- Bug 1100911 - For MacOS builds running on Valgrind, make ThreadStackHelper::GetStack be a no-op. r=nchen. (d99c02e16)
- Bug 1091758 - Report full paths for most chrome scripts; r=snorp (2b72e7878)
- Bug 1109291 - Include better paths for hanging chrome scripts in profile extensions directory; r=snorp r=bsmedberg (1997b9532)
- Bug 1113416 - Don't read stack labels inside hang monitor sighandler; r=nfroyd r=snorp (9688f6069)
- bug 1146027 - more final r=froydnj (7b0f295e5)
- Bug 1164090 - Check for Windows path separator in BHR file name; r=snorp (f014b4d78)
- Bug 1169034 - include <cstdlib> in ThreadStackHelper.cpp to declare correct overload for std::abs; r=jseward (874d4447e)
- Bug 1182996 - Fix and add missing namespace comments. rs=ehsan (054fc00b2)
- Bug 932865 - Collect thread hang stats in BackgroundHangMonitor; (ac80c8e9f)
- minor anticipated fixes to get it compiling (2bd701d15)
196 lines
5.5 KiB
C++
196 lines
5.5 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 "BasicLayersImpl.h"
|
|
#include <new> // for operator new
|
|
#include "Layers.h" // for Layer, etc
|
|
#include "basic/BasicImplData.h" // for BasicImplData
|
|
#include "mozilla/Assertions.h" // for MOZ_ASSERT, etc
|
|
#include "mozilla/DebugOnly.h" // for DebugOnly
|
|
#include "mozilla/layers/CompositorTypes.h"
|
|
#include "mozilla/layers/ISurfaceAllocator.h"
|
|
#include "AutoMaskData.h"
|
|
|
|
namespace mozilla {
|
|
namespace layers {
|
|
|
|
using namespace mozilla::gfx;
|
|
|
|
bool
|
|
GetMaskData(Layer* aMaskLayer,
|
|
const Point& aDeviceOffset,
|
|
AutoMoz2DMaskData* aMaskData)
|
|
{
|
|
if (aMaskLayer) {
|
|
RefPtr<SourceSurface> surface =
|
|
static_cast<BasicImplData*>(aMaskLayer->ImplData())->GetAsSourceSurface();
|
|
if (surface) {
|
|
Matrix transform;
|
|
Matrix4x4 effectiveTransform = aMaskLayer->GetEffectiveTransform();
|
|
DebugOnly<bool> maskIs2D = effectiveTransform.CanDraw2D(&transform);
|
|
NS_ASSERTION(maskIs2D, "How did we end up with a 3D transform here?!");
|
|
transform.PostTranslate(-aDeviceOffset.x, -aDeviceOffset.y);
|
|
aMaskData->Construct(transform, surface);
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
void
|
|
PaintWithMask(gfxContext* aContext, float aOpacity, Layer* aMaskLayer)
|
|
{
|
|
AutoMoz2DMaskData mask;
|
|
if (GetMaskData(aMaskLayer, Point(), &mask)) {
|
|
if (aOpacity < 1.0) {
|
|
aContext->PushGroup(gfxContentType::COLOR_ALPHA);
|
|
aContext->Paint(aOpacity);
|
|
aContext->PopGroupToSource();
|
|
}
|
|
aContext->SetMatrix(ThebesMatrix(mask.GetTransform()));
|
|
aContext->Mask(mask.GetSurface());
|
|
return;
|
|
}
|
|
|
|
// if there is no mask, just paint normally
|
|
aContext->Paint(aOpacity);
|
|
}
|
|
|
|
void
|
|
FillRectWithMask(DrawTarget* aDT,
|
|
const Rect& aRect,
|
|
const Color& aColor,
|
|
const DrawOptions& aOptions,
|
|
SourceSurface* aMaskSource,
|
|
const Matrix* aMaskTransform)
|
|
{
|
|
if (aMaskSource && aMaskTransform) {
|
|
aDT->PushClipRect(aRect);
|
|
Matrix oldTransform = aDT->GetTransform();
|
|
|
|
aDT->SetTransform(*aMaskTransform);
|
|
aDT->MaskSurface(ColorPattern(aColor), aMaskSource, Point(), aOptions);
|
|
aDT->SetTransform(oldTransform);
|
|
aDT->PopClip();
|
|
return;
|
|
}
|
|
|
|
aDT->FillRect(aRect, ColorPattern(aColor), aOptions);
|
|
}
|
|
void
|
|
FillRectWithMask(DrawTarget* aDT,
|
|
const gfx::Point& aDeviceOffset,
|
|
const Rect& aRect,
|
|
const Color& aColor,
|
|
const DrawOptions& aOptions,
|
|
Layer* aMaskLayer)
|
|
{
|
|
AutoMoz2DMaskData mask;
|
|
if (GetMaskData(aMaskLayer, aDeviceOffset, &mask)) {
|
|
const Matrix& maskTransform = mask.GetTransform();
|
|
FillRectWithMask(aDT, aRect, aColor, aOptions, mask.GetSurface(), &maskTransform);
|
|
return;
|
|
}
|
|
|
|
FillRectWithMask(aDT, aRect, aColor, aOptions);
|
|
}
|
|
|
|
void
|
|
FillRectWithMask(DrawTarget* aDT,
|
|
const Rect& aRect,
|
|
SourceSurface* aSurface,
|
|
Filter aFilter,
|
|
const DrawOptions& aOptions,
|
|
ExtendMode aExtendMode,
|
|
SourceSurface* aMaskSource,
|
|
const Matrix* aMaskTransform,
|
|
const Matrix* aSurfaceTransform)
|
|
{
|
|
if (aMaskSource && aMaskTransform) {
|
|
aDT->PushClipRect(aRect);
|
|
Matrix oldTransform = aDT->GetTransform();
|
|
|
|
Matrix inverseMask = *aMaskTransform;
|
|
inverseMask.Invert();
|
|
|
|
Matrix transform = oldTransform * inverseMask;
|
|
if (aSurfaceTransform) {
|
|
transform = (*aSurfaceTransform) * transform;
|
|
}
|
|
|
|
SurfacePattern source(aSurface, aExtendMode, transform, aFilter);
|
|
|
|
aDT->SetTransform(*aMaskTransform);
|
|
aDT->MaskSurface(source, aMaskSource, Point(0, 0), aOptions);
|
|
aDT->SetTransform(oldTransform);
|
|
aDT->PopClip();
|
|
return;
|
|
}
|
|
|
|
aDT->FillRect(aRect,
|
|
SurfacePattern(aSurface, aExtendMode,
|
|
aSurfaceTransform ? (*aSurfaceTransform) : Matrix(),
|
|
aFilter), aOptions);
|
|
}
|
|
|
|
void
|
|
FillRectWithMask(DrawTarget* aDT,
|
|
const gfx::Point& aDeviceOffset,
|
|
const Rect& aRect,
|
|
SourceSurface* aSurface,
|
|
Filter aFilter,
|
|
const DrawOptions& aOptions,
|
|
Layer* aMaskLayer)
|
|
{
|
|
AutoMoz2DMaskData mask;
|
|
if (GetMaskData(aMaskLayer, aDeviceOffset, &mask)) {
|
|
const Matrix& maskTransform = mask.GetTransform();
|
|
FillRectWithMask(aDT, aRect, aSurface, aFilter, aOptions, ExtendMode::CLAMP,
|
|
mask.GetSurface(), &maskTransform);
|
|
return;
|
|
}
|
|
|
|
FillRectWithMask(aDT, aRect, aSurface, aFilter, aOptions, ExtendMode::CLAMP);
|
|
}
|
|
|
|
BasicImplData*
|
|
ToData(Layer* aLayer)
|
|
{
|
|
return static_cast<BasicImplData*>(aLayer->ImplData());
|
|
}
|
|
|
|
gfx::CompositionOp
|
|
GetEffectiveOperator(Layer* aLayer)
|
|
{
|
|
CompositionOp op = aLayer->GetEffectiveMixBlendMode();
|
|
|
|
if (op != CompositionOp::OP_OVER) {
|
|
return op;
|
|
}
|
|
|
|
return ToData(aLayer)->GetOperator();
|
|
}
|
|
|
|
ShadowableLayer*
|
|
ToShadowable(Layer* aLayer)
|
|
{
|
|
return aLayer->AsShadowableLayer();
|
|
}
|
|
|
|
bool
|
|
ShouldShadow(Layer* aLayer)
|
|
{
|
|
if (!ToShadowable(aLayer)) {
|
|
MOZ_ASSERT(aLayer->GetType() == Layer::TYPE_READBACK,
|
|
"Only expect not to shadow ReadbackLayers");
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
|
|
} // namespace layers
|
|
} // namespace mozilla
|