Closed
Bug 635373
Opened 14 years ago
Closed 14 years ago
Small artifacts appear then disappear with hardware acceleration
Categories
(Core :: Graphics, defect)
Tracking
()
RESOLVED
FIXED
mozilla2.0
Tracking | Status | |
---|---|---|
blocking2.0 | --- | .x+ |
People
(Reporter: zpao, Assigned: roc)
References
()
Details
Attachments
(10 files, 2 obsolete files)
(deleted),
text/html
|
Details | |
(deleted),
text/html
|
Details | |
(deleted),
patch
|
roc
:
review-
|
Details | Diff | Splinter Review |
(deleted),
text/html
|
Details | |
(deleted),
patch
|
Details | Diff | Splinter Review | |
(deleted),
patch
|
bas.schouten
:
review+
beltzner
:
approval2.0-
|
Details | Diff | Splinter Review |
(deleted),
patch
|
dbaron
:
review+
joe
:
superreview+
|
Details | Diff | Splinter Review |
(deleted),
patch
|
cjones
:
review+
beltzner
:
approval2.0+
|
Details | Diff | Splinter Review |
(deleted),
patch
|
mattwoodrow
:
review+
beltzner
:
approval2.0-
|
Details | Diff | Splinter Review |
(deleted),
patch
|
bas.schouten
:
review+
|
Details | Diff | Splinter Review |
+++ This bug was initially created as a clone of Bug #634784 +++
Just like bug 634784, I was using the demo at http://shakenandstirredweb.com/playground/blur/. This time just small black artifacts, not the big black areas from before.
You can see them in action in the video I attached previously: attachment #512978 [details].
Demoting to blocking? since I'm not sure how bad this really is.
Still OS X, still same graphics card situation as before.
Comment 1•14 years ago
|
||
Same for me (but I'm on Win 7 x32).
Updated•14 years ago
|
OS: Mac OS X → All
Comment 2•14 years ago
|
||
Matt Woodrow wrote:
> I think these are due to scaling the texture and rounding causing sampling to
> read from the opposite side of the texture. We fixed this on container layers
> by disabling wrapping, but on thebes layers the texture boundary can be in the
> middle of a physical texture. I'm not sure how we can fix this other than
> disabling the texture rotation code, which probably shouldn't be done for this
> release.
I'm not sure why wrapping would cause black pixels though. Also this happens on Windows which isn't using the texture rotation.
Comment 3•14 years ago
|
||
This is cross-platform. For now, I'm going to give this to Rob; me or Matt or Jeff or Bas could easily take it on, though.
This is ugly, but I wouldn't pull an RC off the wire for it, so it softblocks. This probably doesn't require beta coverage either.
Assignee: nobody → roc
blocking2.0: ? → final+
Whiteboard: [softblocker]
Comment 4•14 years ago
|
||
> I'm not sure why wrapping would cause black pixels though. Also this happens on
> Windows which isn't using the texture rotation.
Bug 622585 included a fix for a similar looking problem by disabling texture wrapping. We were occasionally sampling from outside the texture bounds when scaled and getting pixel data from the opposite side of the texture.
Since this happens on platforms without texture rotation, I take my conclusion back
Assignee | ||
Comment 5•14 years ago
|
||
Hover over the browser window to trigger rotation.
The testcase passes with BasicLayers and fails with D3D9 and D3D10, but only when the <article> layer is using component alpha. Interestingly it passes with OpenGL and component alpha!
The testcase seems to show that the artifacts appear at the boundaries of our text drawing that are inside the rectangular bounds of the layer, which is weird since the layer system doesn't really know about that. The only thing I can think of is that the visible region contains two rectangles, which don't fill the whole bounding rectangle of the ThebesLayer, and that's triggering it somehow.
Assignee | ||
Comment 6•14 years ago
|
||
This testcase shows that if we don't use a component alpha layer, the bug does not occur, even if the visible region isn't filling its bounding rectangle.
Assignee | ||
Comment 7•14 years ago
|
||
This seems to fix it for D3D9. I have to confess I don't fully understand what the problem it fixes is.
We're not doing any GPU-based antialiasing, right? So the same set of pixels should be updated on each pass of the component alpha rendering, and we shouldn't be getting burned by partial coverage. So I still don't know what's actually causing those artifacts, or in particular why they only appear in the interior of the texture rect. There's clearly nothing wrong with the texture data itself, since the artifacts are completely dependent on the current transform.
Is it possible that the blend modes we're setting are actually affecting which pixels are being updated by the primitive? Or some other hidden state is affecting that? Help me, Obi-Bas!
Attachment #513926 -
Flags: review?(bas.schouten)
Assignee | ||
Comment 8•14 years ago
|
||
Hmm. I suppose that when we resample due to a transform we could be sampling pixels outside the visible region but inside the texture bounds, so clamping to texture bounds doesn't help. For RGBA textures those pixels would normally be transparent so they won't hurt (much), but we probably still shouldn't do that. For component-alpha textures, we only fill the buffers with white and black in the visible region, so when we sample outside that region we mix some transparent black with both the on-white and on-black values, which will definitely cause problems.
I don't know why this isn't affecting GL.
If this analysis is correct, then I think the correct solution is to apply the patch in comment #7 but for all layer modes (opaque, RGBA, component-alpha), so that whenever the effective transform is going to cause resampling, the entire mTextureRect is valid and we don't risk sampling pixels in a dubious state.
Assignee | ||
Comment 9•14 years ago
|
||
Note that the simplified testcase exposes some other issues that we should fix ASAP, possibly even for Firefox 4 since they're technically regressions. Namely, we render subpixel-AA text to a buffer and then transform the buffer. That is bogus! If we know a layer buffer is going to be transformed (by something other than an integer translation) we need to disable subpixel AA for everything that renders into that buffer. And conveniently, that means the buffer will not need component alpha! I need to file a new bug on this.
Comment 10•14 years ago
|
||
(In reply to comment #5)
> Created attachment 513923 [details]
> Simple testcase
>
> Hover over the browser window to trigger rotation.
>
> The testcase passes with BasicLayers and fails with D3D9 and D3D10, but only
> when the <article> layer is using component alpha. Interestingly it passes with
> OpenGL and component alpha!
>
> The testcase seems to show that the artifacts appear at the boundaries of our
> text drawing that are inside the rectangular bounds of the layer, which is
> weird since the layer system doesn't really know about that. The only thing I
> can think of is that the visible region contains two rectangles, which don't
> fill the whole bounding rectangle of the ThebesLayer, and that's triggering it
> somehow.
WFM. Latest nightly; Win7 x32; graph. card is hd3850; d2d, dw are on.
Comment 11•14 years ago
|
||
(In reply to comment #8)
> Hmm. I suppose that when we resample due to a transform we could be sampling
> pixels outside the visible region but inside the texture bounds, so clamping to
> texture bounds doesn't help. For RGBA textures those pixels would normally be
> transparent so they won't hurt (much), but we probably still shouldn't do that.
> For component-alpha textures, we only fill the buffers with white and black in
> the visible region, so when we sample outside that region we mix some
> transparent black with both the on-white and on-black values, which will
> definitely cause problems.
This was going to be my theory, the fix I'm suggesting is slightly different, we should take the visible region, but extend each rect in the region by a certain amount of pixels (bounded by the texture rect of course). The amount of pixels depends on the level of scaling in the transforms (i.e. how far away pixels can be sampled).
I should note there is some cases where if we simply take the bounds of the visible region as visible region as the visible region layout will not draw the correct content there. See bug 593860.
Comment 12•14 years ago
|
||
Comment on attachment 513926 [details] [diff] [review]
D3D9 fix?
This should be okay if we only do it for component alpha surfaces.
Attachment #513926 -
Flags: review?(bas.schouten) → review+
Assignee | ||
Comment 13•14 years ago
|
||
(In reply to comment #11)
> This was going to be my theory, the fix I'm suggesting is slightly different,
> we should take the visible region, but extend each rect in the region by a
> certain amount of pixels (bounded by the texture rect of course). The amount of
> pixels depends on the level of scaling in the transforms (i.e. how far away
> pixels can be sampled).
We could do that, but it adds complexity, and maybe that complexity is not needed in practice. I suspect it would only matter if we have a transformed object where the visible region is much smaller than its bounds (e.g. two very disconnected pieces).
> I should note there is some cases where if we simply take the bounds of the
> visible region as visible region as the visible region layout will not draw the
> correct content there. See bug 593860.
My patch won't cause problems like that because I extend the visible region before we compute the drawRegion, so we'll actually fill and draw the full bounds.
Assignee | ||
Comment 14•14 years ago
|
||
I think we need to do this for all texture types. Also, this version of the patch avoids modifying mVisibleRegion, which is a good thing since the visible region should be entirely under layout's control.
Attachment #513926 -
Attachment is obsolete: true
Attachment #514069 -
Flags: review?(bas.schouten)
Assignee | ||
Updated•14 years ago
|
Whiteboard: [softblocker] → [softblocker][needs review]
Assignee | ||
Comment 15•14 years ago
|
||
This static testcase shows the bug occurring in a ThebesLayer that is marked opaqueContent.
Assignee | ||
Comment 16•14 years ago
|
||
Comment on attachment 514069 [details] [diff] [review]
better fix for D3D9 and D3D10
This patch isn't correct because for opaque ThebesLayers, we can't rely on layout drawing opaque stuff outside the visible region (the opaque flag only guarantees opaque drawing in the visible region), so we'll draw bad stuff or nothing at all there (perhaps leaving it black or garbage).
When we need to draw in the bounds of the visible region, we should also convert opaque ThebesLayers to RGBA format to avoid this problem.
Attachment #514069 -
Flags: review?(bas.schouten) → review-
Assignee | ||
Comment 17•14 years ago
|
||
These tests test compositing of a transformed, resampled ThebesLayer with complex visible region. There is one test for each of opaque, RGBA and component alpha ThebesLayers.
Assignee | ||
Comment 18•14 years ago
|
||
These patches pass those tests. BasicLayers also passes. OpenGL does not, there are some visual artifacts if you zoom in.
Attachment #514129 -
Flags: review?(bas.schouten)
Comment 19•14 years ago
|
||
Comment on attachment 514129 [details] [diff] [review]
D3D9 and D3D10 fix
>diff --git a/gfx/layers/d3d10/ThebesLayerD3D10.cpp b/gfx/layers/d3d10/ThebesLayerD3D10.cpp
>--- a/gfx/layers/d3d10/ThebesLayerD3D10.cpp
>+++ b/gfx/layers/d3d10/ThebesLayerD3D10.cpp
> ThebesLayerD3D10::Validate(ReadbackProcessor *aReadback)
> {
> if (mVisibleRegion.IsEmpty()) {
> return;
> }
>
>+ nsIntRect newTextureRect = mVisibleRegion.GetBounds();
>+
> SurfaceMode mode = GetSurfaceMode();
> if (mode == SURFACE_COMPONENT_ALPHA &&
> (!mParent || !mParent->SupportsComponentAlphaChildren())) {
> mode = SURFACE_SINGLE_CHANNEL_ALPHA;
> }
Nit: I'd like some whitespace here.
>+ // If we have a transform that requires resampling of our texture, then
>+ // we need to make sure we don't sample pixels that haven't been drawn.
>+ // We clamp sample coordinates to the texture rect, but when the visible region
>+ // doesn't fill the entire texture rect we need to make sure we draw all the
>+ // pixels in the texture rect anyway in case they get sampled.
>+ nsIntRegion neededRegion = mVisibleRegion;
>+ if (neededRegion.GetBounds() != newTextureRect ||
>+ neededRegion.GetNumRects() > 1) {
>+ gfxMatrix transform2d;
>+ if (!GetEffectiveTransform().Is2D(&transform2d) ||
>diff --git a/gfx/layers/d3d9/ThebesLayerD3D9.cpp b/gfx/layers/d3d9/ThebesLayerD3D9.cpp
>--- a/gfx/layers/d3d9/ThebesLayerD3D9.cpp
>+++ b/gfx/layers/d3d9/ThebesLayerD3D9.cpp
>@@ -203,21 +203,44 @@ ThebesLayerD3D9::RenderVisibleRegion()
>
> void
> ThebesLayerD3D9::RenderThebesLayer(ReadbackProcessor* aReadback)
> {
> if (mVisibleRegion.IsEmpty()) {
> return;
> }
>
>+ nsIntRect newTextureRect = mVisibleRegion.GetBounds();
>+
> SurfaceMode mode = GetSurfaceMode();
> if (mode == SURFACE_COMPONENT_ALPHA &&
> (!mParent || !mParent->SupportsComponentAlphaChildren())) {
> mode = SURFACE_SINGLE_CHANNEL_ALPHA;
> }
Nit: And here.
>+ // If we have a transform that requires resampling of our texture, then
>+ // we need to make sure we don't sample pixels that haven't been drawn.
>+ // We clamp sample coordinates to the texture rect, but when the visible region
>+ // doesn't fill the entire texture rect we need to make sure we draw all the
>+ // pixels in the texture rect anyway in case they get sampled.
>+ nsIntRegion neededRegion = mVisibleRegion;
>+ if (neededRegion.GetBounds() != newTextureRect ||
>+ neededRegion.GetNumRects() > 1) {
>+ gfxMatrix transform2d;
>+ if (!GetEffectiveTransform().Is2D(&transform2d) ||
>+ transform2d.HasNonIntegerTranslation()) {
>+ neededRegion = newTextureRect;
>+ if (mode == SURFACE_OPAQUE) {
>+ // We're going to paint outside the visible region, but layout hasn't
>+ // promised that it will paint opaquely there, so we'll have to
>+ // treat this layer as transparent.
>+ mode = SURFACE_SINGLE_CHANNEL_ALPHA;
>+ }
>+ }
>+ }
>+
Attachment #514129 -
Flags: review?(bas.schouten) → review+
Assignee | ||
Comment 20•14 years ago
|
||
(In reply to comment #19)
> Nit: I'd like some whitespace here.
Hmm, where exactly? There is whitespace there :-)
Assignee | ||
Comment 21•14 years ago
|
||
This doesn't completely fix GL. With these patches, the first test fails because the antialiasing along the edges of the visible region that are inside its bounding rect is slightly different in the test and reference. It's possible there's nothing we can do about that. Visually it looks fine.
Attachment #514156 -
Flags: review?(matt.woodrow+bugzilla)
Comment 22•14 years ago
|
||
Comment on attachment 514156 [details] [diff] [review]
GL fix
>
>+static const int ALLOW_REPEAT = 0x01;
>+
> // BindAndDrawQuadWithTextureRect can work with either GL_REPEAT (preferred)
> // or GL_CLAMP_TO_EDGE textures. We select based on whether REPEAT is
> // valid for non-power-of-two textures -- if we have NPOT support we use it,
> // otherwise we stick with CLAMP_TO_EDGE and decompose.
> static already_AddRefed<TextureImage>
> CreateClampOrRepeatTextureImage(GLContext *aGl,
> const nsIntSize& aSize,
>- TextureImage::ContentType aContentType)
>+ TextureImage::ContentType aContentType,
>+ PRUint32 aFlags)
Probably should update the comment here.
>
>- if (visibleBounds.Size() <= mBufferRect.Size()) {
>+ if (neededBounds.Size() <= mBufferRect.Size() &&
>+ mTexImage &&
>+ (mTexImage->GetWrapMode() == LOCAL_GL_CLAMP_TO_EDGE || mEnableRotationOptimization)) {
> NS_ASSERTION(curXRes == aXResolution && curYRes == aYResolution,
> "resolution changes must clear the buffer!");
> // The current buffer is big enough to hold the visible area.
This one too, this condition isn't overly clear what it's testing.
> gfxMatrix transform2d;
> gfxSize scale(1.0, 1.0);
>+ float paintXRes = 1.0;
>+ float paintYRes = 1.0;
>+ bool willResample;
> if (transform.Is2D(&transform2d)) {
> scale = transform2d.ScaleFactors(PR_TRUE);
>+ paintXRes = gfxUtils::ClampToScaleFactor(scale.width);
>+ paintYRes = gfxUtils::ClampToScaleFactor(scale.height);
>+ transform2d.Scale(1.0/paintXRes, 1.0/paintYRes);
>+ willResample = transform2d.HasNonIntegerTranslation();
>+ } else {
>+ willResample = true;
> }
In the case where the translation is only a scale and integer translation, and paint*Res matches scale willResample could probably be false too. I doubt this will ever matter in practice, simplicity is probably better.
Attachment #514156 -
Flags: review?(matt.woodrow+bugzilla) → review+
Assignee | ||
Updated•14 years ago
|
Whiteboard: [softblocker][needs review] → [softblocker][needs landing]
Assignee | ||
Comment 23•14 years ago
|
||
Attachment #514449 -
Flags: superreview?(joe)
Attachment #514449 -
Flags: review?(dbaron)
Comment 24•14 years ago
|
||
Comment on attachment 514449 [details] [diff] [review]
Add layersOpenGL to the reftest harness
r=dbaron
(though I think all of the null-checking of gWindowUtils can go...)
Attachment #514449 -
Flags: review?(dbaron) → review+
Updated•14 years ago
|
Attachment #514449 -
Flags: superreview?(joe) → superreview+
Assignee | ||
Comment 25•14 years ago
|
||
A fix for BasicLayers is needed as well; the problems are less visible but show up with the reftests. Working on it.
Updated•14 years ago
|
tracking-fennec: --- → ?
Assignee | ||
Comment 26•14 years ago
|
||
Attachment #514973 -
Flags: review?(jones.chris.g)
Assignee | ||
Comment 27•14 years ago
|
||
I updated this quite a lot on top of the BasicLayers fix.
Attachment #514156 -
Attachment is obsolete: true
Attachment #514974 -
Flags: review?(matt.woodrow+bugzilla)
Comment on attachment 514973 [details] [diff] [review]
BasicLayers fix
I like this patch more than the previous one.
>+ NS_ASSERTION(!(aFlags & PAINT_WILL_RESAMPLE) || destBufferRect == neededRegion.GetBounds(),
>+ "If we're resampling, we need to validate the entire buffer");
>
I'd appreciate an
|assert(BufferSizeOkFor(ScaledSize(destBufferRect.Size() ...))| here.
>+ enum {
>+ PAINT_WILL_RESAMPLE = 0x01
>+ };
I'd prefer a name more like PAINT_ALLOW_RESAMPLE or SUPPORT_RESAMPLE
or ASSUME_RESAMPLE, because in the shadow-layer case the buffer might
or might not be resampled.
> /**
> * Start a drawing operation. This returns a PaintState describing what
> * needs to be drawn to bring the buffer up to date in the visible region.
> * This queries aLayer to get the currently valid and visible regions.
> * The returned mContext may be null if mRegionToDraw is empty.
> * Otherwise it must not be null.
> * mRegionToInvalidate will contain mRegionToDraw.
>+ * @param aFlags when PAINT_WILL_RESAMPLE is passed, this indicates that
"passing PAINT_WILL_RESAMPLE indicates .."
> BasicThebesLayerBuffer(BasicThebesLayer* aLayer)
> : Base(ContainsVisibleBounds)
> , mLayer(aLayer)
>- {}
>+ {
>+ }
?
>+ PRUint32 flags = 0;
>+ gfxMatrix transform;
>+ if (!GetEffectiveTransform().Is2D(&transform) ||
>+ transform.HasNonIntegerTranslation()) {
>+ flags |= ThebesLayerBuffer::PAINT_WILL_RESAMPLE;
>+ }
We also need this flag for shadowable layers with shadows.
MustRetainContent() already exists and makes enough sense here, so I'd
be fine with reusing it.
r=me with the shadow-layer fix. Yeah, it's broken already, but no need to
make it worse. ;)
Attachment #514973 -
Flags: review?(jones.chris.g) → review+
Assignee | ||
Comment 29•14 years ago
|
||
(In reply to comment #28)
> >+ NS_ASSERTION(!(aFlags & PAINT_WILL_RESAMPLE) || destBufferRect == neededRegion.GetBounds(),
> >+ "If we're resampling, we need to validate the entire buffer");
> >
>
> I'd appreciate an
> |assert(BufferSizeOkFor(ScaledSize(destBufferRect.Size() ...))| here.
Will do.
> >+ enum {
> >+ PAINT_WILL_RESAMPLE = 0x01
> >+ };
>
> I'd prefer a name more like PAINT_ALLOW_RESAMPLE or SUPPORT_RESAMPLE
> or ASSUME_RESAMPLE, because in the shadow-layer case the buffer might
> or might not be resampled.
Sure.
> > BasicThebesLayerBuffer(BasicThebesLayer* aLayer)
> > : Base(ContainsVisibleBounds)
> > , mLayer(aLayer)
> >- {}
> >+ {
> >+ }
>
> ?
Will remove.
> >+ PRUint32 flags = 0;
> >+ gfxMatrix transform;
> >+ if (!GetEffectiveTransform().Is2D(&transform) ||
> >+ transform.HasNonIntegerTranslation()) {
> >+ flags |= ThebesLayerBuffer::PAINT_WILL_RESAMPLE;
> >+ }
>
> We also need this flag for shadowable layers with shadows.
> MustRetainContent() already exists and makes enough sense here, so I'd
> be fine with reusing it.
OK. This means we'll disable rotation for shadowlayers as soon as this lands. I hope that's OK!
Assignee | ||
Comment 30•14 years ago
|
||
Tragically, my new reftests fail on BasicLayers and GL layers because of small, not visually relevant differences. I'll probably just mark them as failing and go ahead.
Oops, I wasn't CC'd here :/.
(In reply to comment #29)
> OK. This means we'll disable rotation for shadowlayers as soon as this lands. I
> hope that's OK!
Yep. For a variety of reasons, fennec basically never ends up using rotation.
Updated•14 years ago
|
Attachment #514974 -
Flags: review?(matt.woodrow+bugzilla) → review+
Assignee | ||
Comment 32•14 years ago
|
||
Comment on attachment 514129 [details] [diff] [review]
D3D9 and D3D10 fix
Fixes visible artifacts with CSS transforms
Attachment #514129 -
Flags: approval2.0?
Assignee | ||
Comment 33•14 years ago
|
||
Comment on attachment 514973 [details] [diff] [review]
BasicLayers fix
Fixes visible artifacts with CSS transforms
Attachment #514973 -
Flags: approval2.0?
Assignee | ||
Comment 34•14 years ago
|
||
Comment on attachment 514974 [details] [diff] [review]
Updated GL patch
Fixes visible artifacts with CSS transforms
Attachment #514974 -
Flags: approval2.0?
Assignee | ||
Comment 35•14 years ago
|
||
The BasicLayers fix may also be a hardblocker for Fennec.
Comment 36•14 years ago
|
||
I don't think we want to take this at this time; the current state is not great, but livable. We'll fix this in Firefox 5.
If the BasicLayers fix is a hard blocker for Fennec, they should mark as such.
Updated•14 years ago
|
Attachment #514129 -
Flags: approval2.0? → approval2.0-
Updated•14 years ago
|
Attachment #514973 -
Flags: approval2.0? → approval2.0-
Updated•14 years ago
|
Attachment #514974 -
Flags: approval2.0? → approval2.0-
Comment 37•14 years ago
|
||
This should hard block Fennec because of bug 634397. We need the displayport to draw correctly so we can make invalidate only a portion of it and make it fast.
Comment 38•14 years ago
|
||
(In reply to comment #35)
> The BasicLayers fix may also be a hardblocker for Fennec.
Fennec does want to block on this, but first, I'd like to know if there are technical issues or risks with landing this for FF4?
Comment 39•14 years ago
|
||
If I understand correctly, it should also block Fennec because we spend a lot of time rendering stuff at non-identity resolutions, unlike Firefox.
Assignee | ||
Comment 41•14 years ago
|
||
There is some risk because we're changing core ThebesLayer code. However, the code is tested by reftests and this is a bad bug, not just for Fennec but for any pages using CSS transforms on desktop Firefox.
Assignee | ||
Comment 42•14 years ago
|
||
Comment on attachment 514973 [details] [diff] [review]
BasicLayers fix
Renominating based on Fennec needs.
Attachment #514973 -
Flags: approval2.0- → approval2.0?
Comment 43•14 years ago
|
||
Comment on attachment 514973 [details] [diff] [review]
BasicLayers fix
a=beltzner
Attachment #514973 -
Flags: approval2.0? → approval2.0+
Assignee | ||
Comment 44•14 years ago
|
||
Updated•14 years ago
|
Status: NEW → RESOLVED
Closed: 14 years ago
Resolution: --- → FIXED
Whiteboard: [softblocker][needs landing] → [softblocker]
Target Milestone: --- → mozilla2.0
Comment 45•14 years ago
|
||
Landing of this bug and bug 632423 caused Windows reftest failures such as <http://tinderbox.mozilla.org/showlog.cgi?log=Firefox/1299024306.1299027792.9789.gz>.
I landed the following two changesets to deal with the failures:
http://hg.mozilla.org/mozilla-central/rev/f0a5657c643c
http://hg.mozilla.org/mozilla-central/rev/3436b367b4a4
Assignee | ||
Comment 46•14 years ago
|
||
This is not fully fixed. There are D3D and GL patches to land (post-FF4).
Status: RESOLVED → REOPENED
Resolution: FIXED → ---
Comment 47•14 years ago
|
||
Clearing blocking-fennec because the remaining patches do not block Fennec 4.
tracking-fennec: 2.0+ → ---
Updated•14 years ago
|
Whiteboard: [softblocker] → [softblocker][approved-patches-landed]
Comment 48•14 years ago
|
||
** PRODUCT DRIVERS PLEASE NOTE **
This bug is one of 7 automatically changed from blocking2.0:final+ to blocking2.0:.x during the endgame of Firefox 4 for the following reasons:
- it was marked as a soft blocking issue without a requirement for beta coverage
blocking2.0: final+ → .x+
(In reply to comment #29)
None of these comments were addressed. I'll fix PAINT_WILL_RESAMPLE for shadow layers in bug 635035. (It's the only actual bug.)
Comment 50•14 years ago
|
||
I just landed what was in this bug, roc may have had a different patch in his queue.
Assignee | ||
Comment 51•14 years ago
|
||
sorry!
Assignee | ||
Comment 53•14 years ago
|
||
My tests fail on OpenGL and D3D9 because in the test files we draw the #d ThebesLayer as two quads, so the GPU makes a binary decision about which pixels to touch on the inside edges of the quads (the inside of the 'L'). In the reference files, we draw the #d ThebesLayer as a single quad with an L-shaped image in it, so the inside edge is antialiased by the bilinear filter when the ThebesLayer is resampled.
I don't know how to fix this. We can't ignore these edge pixels because they're exactly where we want to test for artifacts. I can improve the situation by noting when this bug fix is active --- i.e., because we're resampling we're ensuring the entire texture is filled with valid pixels --- and in that case, drawing the entire texture as one quad so our interior edges are antialised by resampling. However, for D3D9 at least, we still have off-by-one errors along the edge ... it seems that resampling and compositing an edge between rgb(200,200,200) and rgba(0,0,0,0) over a white background can give slightly different results to resampling an edge between rgb(200,200,200) and rgb(255,255,255).
Assignee | ||
Comment 54•14 years ago
|
||
OK, I got the tests passing with D3D9 by making the reference use a background image so that there are transparent pixels in its transformed ThebesLayer along the inside of the 'L'.
Assignee | ||
Comment 55•14 years ago
|
||
This is needed for the tests to pass with D3D9.
You could argue that this is sacrificing some performance for a barely-perceptible improvement in quality, but I think it doesn't really matter and it helps for testing.
Attachment #522336 -
Flags: review?(bas.schouten)
Comment 56•14 years ago
|
||
Comment on attachment 522336 [details] [diff] [review]
draw layer in a single quad when resampling
I think this is fine perf wise. I doubt we're going to be fillrate bound very often.
However this still leaves the outer edges non-anti-aliased right? Of course we knew this when we did layers this way, but we're okay with that?
Attachment #522336 -
Flags: review?(bas.schouten) → review+
Assignee | ||
Comment 57•14 years ago
|
||
(In reply to comment #56)
> I think this is fine perf wise. I doubt we're going to be fillrate bound very
> often.
>
> However this still leaves the outer edges non-anti-aliased right? Of course we
> knew this when we did layers this way, but we're okay with that?
Yes, that's right. I think that's OK for now.
Updated•14 years ago
|
Whiteboard: [softblocker][approved-patches-landed] → [softblocker][approved-patches-landed][not-ready-for-cedar]
Assignee | ||
Comment 58•14 years ago
|
||
http://hg.mozilla.org/mozilla-central/rev/e36b387929f0
http://hg.mozilla.org/mozilla-central/rev/4096a34495a5
http://hg.mozilla.org/mozilla-central/rev/c686a9fb1b50
http://hg.mozilla.org/mozilla-central/rev/844579d34200
http://hg.mozilla.org/mozilla-central/rev/bec3f251f53a
Status: REOPENED → RESOLVED
Closed: 14 years ago → 14 years ago
Flags: in-testsuite+
Resolution: --- → FIXED
Whiteboard: [softblocker][approved-patches-landed][not-ready-for-cedar]
Comment 59•14 years ago
|
||
Comment on attachment 514128 [details] [diff] [review]
tests
>+#d {
>+ position:absolute;
>+ top:200px;
>+ left:200px;
>+ font-size:30px;
>+ transform:rotate(30deg);
>+ -moz-transform:rotate(30deg);
>+ background:white;
>+}
What's up with the tabs?
Assignee | ||
Comment 60•14 years ago
|
||
Sorry.
Comment 61•13 years ago
|
||
Interestingly, I get an unexpected pass in a xvfb:
REFTEST TEST-UNEXPECTED-PASS | file:///tmp/build/layout/reftests/bugs/635373-3.html | image comparison (==)
Should I file a separate bug?
Comment 62•13 years ago
|
||
Corresponding image:

Updated•9 years ago
|
Keywords: testcase-wanted
You need to log in
before you can comment on or make changes to this bug.
Description
•