Closed Bug 927625 Opened 11 years ago Closed 7 years ago

requestAnimationFrame-based WebGL animation periodically stutters in Firefox.

Categories

(Firefox :: General, defect)

x86
Windows 7
defect
Not set
normal

Tracking

()

RESOLVED FIXED

People

(Reporter: jujjyl, Unassigned)

References

(Blocks 1 open bug)

Details

(Whiteboard: [games] webgl-perf)

Attachments

(1 file)

397.46 KB, application/x-gzip
Details
Visit either of these links: 

https://dl.dropboxusercontent.com/u/40949268/emcc/Pong/Pong.html
https://dl.dropboxusercontent.com/u/40949268/emcc/VSyncTest/VSyncTest.html

Both pages are Emscripten-based applications that use requestAnimationFrame() as the mechanism to update animation. In the first link, the update function does a time-independent fixed update of the ball at 6 pixels per frame. In the second link, a vertical bar traces through the screen at a fixed rate that can be controlled with left&right keyboard buttons.

The profiler at the bottom of the screen shows how much time is spent in the update function requestAnimationFrame() calls. The bottom bright green/yellow/red part of the graph represents the time spent in the requestAnimationFrame() function itself (which is typically very small < 1msec), whereas the darker green/yellow/red part stacked on top of the bright part shows the time spent between two subsequent requestAnimationFrame() calls. Each column of pixels represents a single call to requestAnimationFrame().

In all tested browsers (Chrome 30, FF24, IE11 Release Preview, Opera 17) on my Windows laptop, the profiler graph at the bottom shows good frametimes of around ~16 msecs, so it looks like requestAnimationFrame() is called at good intervals to reach the 60fps vsync target of my laptop.

On Firefox however, visually estimating the motion of the white ball and the vertical bar looks good at times, but at other times the motion is jumpy, or stuttering. In Chrome, IE11 Release Preview and Opera the motion does not exhibit this kind of jumpiness but is much smoother.

I am not sure whether this is attributable to tearing in the lack of vsync - in the second link it looks like the vsync tear artifact, i.e. the horizontal "cut" line dividing the previous and current frame does not seem to be present. Does Firefox enforce vsync on when requestAnimationFrame is used?

Expected: the animation in both examples should be pleasingly smooth, since the application requires only ~1msec to update, which should be plenty of time to hit the 60fps vsync animation rate.
Version: 24 Branch → Trunk
Tested with latest, looks like it behaves similar to Firefox 24.
Bug https://bugzilla.mozilla.org/show_bug.cgi?id=707884 is related, this might be a duplicate(?) if it turns out to be vsync after all.
Whiteboard: [games]
Blocks: gecko-games
Whiteboard: [games] → [games] webgl-perf
Playing this recently released game on Facebook https://apps.prod.facebook.com/264099533962255/, its tutorials in the beginning have several camera panning and zooming events. I'm running on a beefy desktop PC with

Haswell-based Core i7 5960x with 16 logical cores
32GB of RAM
Asus GeForce GTX 980 Ti DC3OC
Windows 10 Home

The zooming and panning sequences stutter quite a bit. Looking at Process Explorer, the game is running well within 60fps, with headroom for the CPU to be idle. The stutters aren't due to JS pauses, but short 1-2 frame glitches which are most visibly present when the camera pans or zooms.
Attached file Pong.tar.gz
Since having reported this originally, Dropbox has stopped allowing hotlinking to pages, so here is a new WebAssembly-compiled build of the Pong sample.
Running latest Firefox Nightly 32-bit and 64-bit on the Pong example gives much smoother vsync scheduling than originally, so this one looks like fixed.
Status: NEW → RESOLVED
Closed: 7 years ago
Resolution: --- → FIXED
You need to log in before you can comment on or make changes to this bug.

Attachment

General

Creator:
Created:
Updated:
Size: