[whatwg] <video> and acceleration

Benjamin M. Schwartz bmschwar at fas.harvard.edu
Fri Mar 27 21:57:35 PDT 2009


-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1

Dear What,

Short: <video> won't work on slow devices.  Help!

Long:
The <video> tag has great potential to be useful on low-powered computers
and computing devices, where current internet video streaming solutions
(such as Adobe's Flash) are too computationally expensive.  My personal
experience is with OLPC XO-1*, on which Flash (and Gnash) are terribly
slow for any purpose, but Theora+Vorbis playback is quite smooth at
reasonable resolutions and bitrates.

The <video> standard allows arbitrary manipulations of the video stream
within the HTML renderer.  To permit this, the initial implementations
(such as the one in Firefox 3.5) will perform all video decoding
operations on the CPU, including the tremendously expensive YUV->RGB
conversion and scaling.  This is viable only for moderate resolutions and
extremely fast processors.

Recognizing this, the Firefox developers expect that the decoding process
will eventually be accelerated.  However, an accelerated implementation of
the <video> spec inevitably requires a 3D GPU, in order to permit
transparent video, blended overlays, and arbitrary rotations.

Pure software playback of video looks like a slideshow on the XO, or any
device with similar CPU power, achieving 1 or 2 fps.  However, these
devices typically have a 2D graphics chip that provides "video overlay"
acceleration: 1-bit alpha, YUV->RGB, and simple scaling, all in
special-purpose hardware.**  Using the overlay (via XVideo on Linux)
allows smooth, full-speed playback.

THE QUESTION:
What is the recommended way to handle the <video> tag on such hardware?

There are two obvious solutions:
0. Implement the spec, and just let it be really slow.
1. Attempt to approximate the correct behavior, given the limitations of
the hardware.  Make the video appear where it's supposed to appear, and
use the 1-bit alpha (dithered?) to blend static items over it.  Ignore
transparency of the video.  Ignore rotations, etc.
2. Ignore the HTML context.  Show the video "in manners more suitable to
the user (e.g. full-screen or in an independent resizable window)".

Which is preferable?  Is it worth specifying a preferred behavior?

Thanks for your input,
Ben Schwartz

*: Contrary to popular belief, OLPC is not dead.  Over 500,000 XOs have
been delivered, and another 500,000 are on backorder, being manufactured
at full capacity.  They all have Theora and Gecko installed.

**: Anyone who has owned a desktop PC without a 3D accelerator likely has
experienced this system.
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v2.0.9 (GNU/Linux)

iEYEARECAAYFAknNrj4ACgkQUJT6e6HFtqSLVwCgkrJP1mCMsFugNW91/7rRfzcl
KtkAn3t2rkLR+pZHDsoG1b6/bTp3Yctu
=MTxx
-----END PGP SIGNATURE-----


More information about the whatwg mailing list