RESOLVED FIXED 217943
TextureMapperLayer::paintWithIntermediateSurface: Reduce BitmapTextures by unifying replicaSurface and mainSurface
https://bugs.webkit.org/show_bug.cgi?id=217943
Summary TextureMapperLayer::paintWithIntermediateSurface: Reduce BitmapTextures by un...
Fujii Hironori
Reported 2020-10-19 23:23:59 PDT
TextureMapperLayer::paintWithIntermediateSurface: Reduce BitmapTextures by unifying replicaSurface and mainSurface TextureMapperLayer::paintWithIntermediateSurface is using two BitmapTextures for replicaSurface and mainSurface. But, IIUC, a single BitmapTexture suffices.
Attachments
Patch (5.83 KB, patch)
2020-10-19 23:30 PDT, Fujii Hironori
no flags
Patch (5.86 KB, patch)
2020-10-27 23:28 PDT, Fujii Hironori
no flags
Fujii Hironori
Comment 1 2020-10-19 23:30:14 PDT
Noam Rosenthal
Comment 2 2020-10-20 00:02:49 PDT
Comment on attachment 411841 [details] Patch IIRC the second surface is necessary. Since the replica might have a different opacity/transform/mask than the main surface, it needs to blend separately, and it also needs a different size surface due to the different transform. This patch would result in the main surface clipping the reflection, and blending it incorrectly. I'm sure some of the tests in compositing/reflection would catch this, not sure if they're skipped for GTK/WPE
Fujii Hironori
Comment 3 2020-10-20 00:11:54 PDT
I'm testing with GTK port which runs all compositing/reflection 30 test cases. I observers no regressions.
Noam Rosenthal
Comment 4 2020-10-20 00:15:07 PDT
(In reply to Fujii Hironori from comment #3) > I'm testing with GTK port which runs all compositing/reflection 30 test > cases. I observers no regressions. OK then. Will let current Texmap people review :)
Radar WebKit Bug Importer
Comment 5 2020-10-26 23:24:17 PDT
Miguel Gomez
Comment 6 2020-10-27 03:45:53 PDT
I'm not an expert in this replica code, but I've been looking into how it works and what this patch does. * From what I see, TextureMapperLayer::paintWithIntermediateSurface() paints the replicaLayer first into a surface with opacity 1 and its own transformation. * If the original opacity is 1 it already paints the surface content into the frambuffer with the original opacity. * Then it paints the main layer with opacity 1 into a new surface. * If the original opacity is not 1 (which would mean that the replica surface has already been painted), the main surface is painted into the replica surface with opacity 1, and then the result is painted to the framebuffer with the real opacity. From this code I see that both the main layer and the replica layer are painted with the same opacity. The rect received to paint is the same for both layers, and its size includes the size for both layers: if the original layer is 200x200 and the reflection is below, the passed rect will be 200x400. The transformation is different for those layers, but the replica one just performs the move&flip for the reflection. I've been checking the CSS doc and I don't see how a replica layer can have more transformations than those (can't be scaled or rotated or anything else, am I wrong?), which means that it should fit into the target rect. So, taking into account all those things, this patch seems to have the same behavior than the existent code: * The allocated surface is has the size of the passed rect, which is enough to paint both layers. * The replica layer is painted into the surface with opacity 1 * The main layer is painted into the same surface with opacity 1 * The result is painted into the framebuffer with the original opacity So, unless I'm missing some use cases that I don't know about, I think that this patch should be ok.
Noam Rosenthal
Comment 7 2020-10-27 04:00:51 PDT
(In reply to Miguel Gomez from comment #6) > I'm not an expert in this replica code, but I've been looking into how it > works and what this patch does. > > * From what I see, TextureMapperLayer::paintWithIntermediateSurface() paints > the replicaLayer first into a surface with opacity 1 and its own > transformation. > > * If the original opacity is 1 it already paints the surface content into > the frambuffer with the original opacity. > > * Then it paints the main layer with opacity 1 into a new surface. > > * If the original opacity is not 1 (which would mean that the replica > surface has already been painted), the main surface is painted into the > replica surface with opacity 1, and then the result is painted to the > framebuffer with the real opacity. > > From this code I see that both the main layer and the replica layer are > painted with the same opacity. > The rect received to paint is the same for both layers, and its size > includes the size for both layers: if the original layer is 200x200 and the > reflection is below, the passed rect will be 200x400. > The transformation is different for those layers, but the replica one just > performs the move&flip for the reflection. I've been checking the CSS doc > and I don't see how a replica layer can have more transformations than those > (can't be scaled or rotated or anything else, am I wrong?), which means that > it should fit into the target rect. > > So, taking into account all those things, this patch seems to have the same > behavior than the existent code: > > * The allocated surface is has the size of the passed rect, which is enough > to paint both layers. > * The replica layer is painted into the surface with opacity 1 > * The main layer is painted into the same surface with opacity 1 > * The result is painted into the framebuffer with the original opacity > > So, unless I'm missing some use cases that I don't know about, I think that > this patch should be ok. I wrote the original replica code and I believe the additional surface was originally needed because of something to do with the surface sizes, which was since changed. btw CSS reflections have never been fully standardized and are not supported by Firefox :( TextureMapper can probably become much simpler if it didn't support those.
Fujii Hironori
Comment 8 2020-10-27 20:19:23 PDT
Thank you for the review, Miguel and Noam.
Fujii Hironori
Comment 9 2020-10-27 23:23:07 PDT
Comment on attachment 411841 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=411841&action=review > Source/WebCore/platform/graphics/texmap/TextureMapperLayer.cpp:451 > paintOptions.backdropLayer = nullptr; I moved paintOptions to the local scope of if. I can remove this line. > Source/WebCore/platform/graphics/texmap/TextureMapperLayer.cpp:-458 > - surface = surface->applyFilters(options.textureMapper, m_currentFilters); I shouldn't remove this applyFilters. The subsequent applyMask is using it. As far as I tested, the combination of reflection and mask doesn't work as expected in TextureMapper. I'll add a test case in a new bug.
Fujii Hironori
Comment 10 2020-10-27 23:28:03 PDT
Fujii Hironori
Comment 11 2020-10-28 13:01:44 PDT
Comment on attachment 412508 [details] Patch Clearing flags on attachment: 412508 Committed r269116: <https://trac.webkit.org/changeset/269116>
Fujii Hironori
Comment 12 2020-10-28 13:01:47 PDT
All reviewed patches have been landed. Closing bug.
Note You need to log in before you can comment on or make changes to this bug.