Open Bug 1651753 Opened 4 years ago Updated 3 years ago

Janky WebRender scrolling on reallifecomics.com with Renderer thread swamped in draw_alpha_batch_container

Categories

(Core :: Graphics: WebRender, defect, P3)

defect

Tracking

()

People

(Reporter: bholley, Unassigned)

References

(Blocks 1 open bug)

Details

I noticed this on my pixel 2 last night, and just reproduced on my MBP (External display, discrete Radeon GPU).

STR:

The HUD profiler shows high CPU time on the renderer thread. I captured a profile and it looks like this:

https://share.firefox.dev/3gIDpnw

The selected segment comes from finding the janky segments in the marker chart on the compositor thread and the zooming to that. Switching over to the renderer thread for that interval, we see a bunch of time in the GL driver under glBufferData. I don't believe this is a mac driver quirk though, because I saw the same thing on Android (though I haven't profiled it on that device).

Looks like another glyph bounds batching disaster. I'll make sure to test against this one because the glyphs are spaced very close together, so we'll need to be very accurate with the bounds to avoid breaking batches

See Also: → 1650167, 1645665
Blocks: wr-perf
Severity: -- → S3
Priority: -- → P3

This was certainly helped by bug 1645665, but is still quite bad. Looking closer at the page, I think a lot of the glyphs do in fact overlap, which means that approach cannot fix them.

To improve this further we could increase the size of the texture arrays and/or be more aggressive about eviction, both to reduce the chances of fragmentation. We could also look in to binding multiple textures in the shader. And I believe Glen was also considering caching entire runs of rasterized glyphs together, which would help.

Blocks: wr-batching-perf
No longer blocks: wr-perf
You need to log in before you can comment on or make changes to this bug.