Firefox/Shutdown Decoders: Difference between revisions
Joshwalker (talk | contribs) (→Team) |
|||
Line 141: | Line 141: | ||
* [https://bugzil.la/1295844 Bug 1295844 - Test suspended videos with webm files] | * [https://bugzil.la/1295844 Bug 1295844 - Test suspended videos with webm files] | ||
** done | ** done | ||
== Logged bugs ( blocking [https://bugzilla.mozilla.org/show_bug.cgi?id= 1276556 ] ) == | |||
<bugzilla> | |||
{ | |||
"blocks":[1276556], | |||
"include_fields": "id, priority, component, assigned_to, summary, status, target_milestone" | |||
} | |||
</bugzilla> | |||
=Team= | =Team= | ||
Revision as of 16:14, 30 September 2016
Overview
Suspending video element's video decoder, when the video element is in background tabs or is invisible even in the foreground tab, is a Firefox feature that reduces CPU/GPU & memory usage.
The mechanism is that, when a video element is invisible, we replace its original video decoder with blank video decoder which only produces white frames with right resolution and right time information. The original video decoder is released and the black video decoder is light so that we reduce CPU/GPU & memory usage.
The drawback is that, while the suspended-video-element is switched back to be visible again, we should resume its original video decoder. The resuming operation must be asynchronous and might be time-consuming which depends on the resolution of the video file and whether it contains audio tracks or not.
In the prototype (Phase 0), we have enabled this feature on the Firefox Nightly channel for any video element. We also add telemetry to collect needed information, especially on the resuming time. Currently (Phase 1), we are going to enable this feature on the Firefox Release channel for videos that is able to be resumed quickly and the criteria is 1) videos without audio track or 2) videos with both audio and video tracks but with low resolution (480P for now). In the future (Phase 2), our goal is to enable this feature on all videos without observable latency while resuming.
The following is a step-by-step description of suspending decoder working flow.
- At the very beginning of the decoding framework, the raw media data is sent to demuxer.
- Demuxer helps to separate a combined signal, e.g., a streaming can be separated into audio data and video data by demuxer. After that, audio and video data are sent to audio and video decoder separately.
- In data decoding period, audio decoder keeps working as normal because a user may be listening to the music. But, Firefox uses a blank video decoder to replace current video decoder if the video element is invisible.
Key Documents
- Code: https://hg.mozilla.org/integration/mozilla-inbound/file/tip/dom/media
- Issues: Meta Bug - Bug 1276556 [META] Tracking enable of background tab video decoder suspend
- Product/UX Trello Board: NA
Other Resources
Install
Stable Release
Stay tuned.
Developer Release
The developer release is updated each time code is committed to Mozilla-central in HG.
Reporting Issues
If you find a bug or have a suggestion, please submit it on Bugzilla: https://goo.gl/coRinl
Known Issues
Decoder resuming latency
While the suspended-video-element is switched back to be visible again, we should resume its original video decoder. The resuming operation must be asynchronous since we don't want to block the main thread and might be time-consuming which depends on the resolution of the video file and whether it contains audio tracks or not.
Currently, we have no way to boost the resuming time, however, we have telemetries for collecting the needed time of different resolutions on different platforms.
Related telemetries:
Related bugs:
Video element as content source
The situation is about the video element itself is used as a content source and its decoder might be suspended at the same time. This issue could be split into two cases:
- Case 1: The decoder is suspended AFTER the {cpatureStream(), drawImage(), createImageBitmap()} is called.
- Case 2: The decoder is suspended BEFORE the {cpatureStream(), drawImage(), createImageBitmap()} is called.
Case 1 is relatively easy, we could mark the video element as being a content source while {cpatureStream(), drawImage(), createImageBitmap()} is invoked and then its decoder should never be suspended.
Case 2 is rather complicated. The critical issue is that resuming decoder is an async operation with latency. So, while {cpatureStream(), drawImage(), createImageBitmap()} is invoked on an already-suspended-video, there must be several "blank" frames been leaked, even though we resume the decoder immediately. To completely solve this problem, we must make "resuming decoder" a blocking operation, however, it might block the main thread; otherwise, we leak the blank frames.
Related bugs:
- Bug 1284389 - Don't suspend video elements captured via mozCaptureStream()
- Bug 1295921 - Don't suspend video decoder for elements as sources to drawImage() and createImageBitmap()
Planning
Goals
- Help users to reduce device resource usage (CPU & Memory)
- Finish tasks across videos
- No impact on current user flow
Feature Plan
- Phase 0: Shutdown decoders when video element is invisible
- Phase 1: Using a blank video decoder to replace video decoder instead of shutdown decoders directly. In this phase, the mechanism is applied to 1) Low-resolution video (480P) and 2) Video film without audio track
- Phase 2: We're going to enhance the mechanism and make sure it can apply to all video files.
Success
- Effective cross-discipline teams solving problems across platforms
- Validation of key assumptions through telemetrics
- video decode suspend in the hands of all our users
Schedule
Product Milestones
Engineering
Shutdown_Decoders [status: Green]
Current Goals:
- Ship disabling video decoders for ads
- Silent, looping videos where user doesn't really care the exact point
Next Milestone:
Milestones
Optimizations
- Bug 1282710 - Suspend and resume foreground video decoders according to visibility events
- done.
- Bug 1282012 - Seek to nearest keyframe when resuming videos with no audio
- Bug 1294657 - Seek to nearest keyframe when resuming videos with no audio - with audio track but muted
- pending, excluded from phase 1.
- Bug 1294658 - Seek to nearest keyframe when resuming videos with no audio - with audio track but might be silent
- pending, excluded from phase 1.
- Bug 1294656 - Seek to nearest keyframe when resuming videos with no audio - no audio track
- done.
- Bug 1294657 - Seek to nearest keyframe when resuming videos with no audio - with audio track but muted
- Bug 1274919 - Resume suspended video decoders on tab mouse hover.
- under review.
- Bug 1284389 - Don't suspend video elements captured via mozCaptureStream()
- WIP.
- Bug 1295921 - Don't suspend video decoder for elements as sources to drawImage() and createImageBitmap()
- WIP.
- Resume video when keyboard is used to change tags - Needs Bug
- For example, if it's possible to detect the direction of cycling and videos are within, say, 5 tabs of the current tab, then start decoding again.
- Need to hook into the tab navigation/change code and alert media elements, like bug 1274919
Telemetry
- Amount of time hidden - measure of user value (Bucket results by resolution; i.e. are 720p videos hidden less often?)
- Bug 1285419 - Telemetry to support background video decoder suspend: Hidden play time
- VIDEO_HIDDEN_PLAY_TIME_MS
- Bug 1287987 - Telemetry to support background video decoder suspend: Percentage hidden/total play time, keyed by audio presence and height ranges
- VIDEO_HIDDEN_PLAY_TIME_PERCENTAGE
- Bug 1293145 - Telemetry to support background video decoder suspend: Percentage video-decode-suspended/total play time
- VIDEO_INFERRED_DECODE_SUSPEND_PERCENTAGE
- Recovery time - measure of user cost (separate for noisy vs silent videos) (Bucket results by resolution; i.e. do 720p videos take longer to recover?)
- Key frame spacing - distribution allows better tuning
Mochitests
- Bug 1284177 - Add tests for video suspend in background
- done
- Bug 1294358 - Add test for suspended videos still fire 'ended' event
- done
- Bug 1295844 - Test suspended videos with webm files
- done
Logged bugs ( blocking 1276556 )
29 Total; 0 Open (0%); 26 Resolved (89.66%); 3 Verified (10.34%);
Team
Product owner:
Eng: Alastor, Daniel, Gerald, JW, Kaku,
Program Management: Blake, Josh
UX: Mark, Morpheus
QA: SoftVision and William
Communications
IRC:
Email:
VidyoRoom: