Linear PCM WebCodecs Registration

W3C Group Draft Note,

More details about this document
This version:
https://www.w3.org/TR/2024/DNOTE-webcodecs-pcm-codec-registration-20240206/
Latest published version:
https://www.w3.org/TR/webcodecs-pcm-codec-registration/
Editor's Draft:
https://w3c.github.io/webcodecs/pcm_codec_registration.html
Previous Versions:
History:
https://www.w3.org/standards/history/webcodecs-pcm-codec-registration/
Feedback:
GitHub
Editors:
Paul Adenot (Mozilla)
Bernard Aboba (Microsoft Corporation)
Former Editor:
Chris Cunningham (Google Inc.)
Participate:
Git Repository.
File an issue.
Version History:
https://github.com/w3c/webcodecs/commits

Abstract

This registration is entered into the [webcodecs-codec-registry]. It describes, for Linear PCM, the (1) fully qualified codec strings, (2) the codec-specific EncodedAudioChunk [[internal data]] bytes, (3) the AudioDecoderConfig.description, and (4) the values of EncodedAudioChunk [[type]].

Linear PCM is the raw audio format used in WebCodecs and does not require decoding. The motivation for registering the Linear PCM codec is to enable passthrough "decoding" of PCM content as an architectural simpliciation for WebCodecs applications.

The registration is not intended to include any information on whether a codec format is encumbered by intellectual property claims. Implementers and authors are advised to seek appropriate legal counsel in this matter if they intend to implement or use a specific codec format.

This registration is non-normative.

Status of this document

This section describes the status of this document at the time of its publication. A list of current W3C publications and the latest revision of this technical report can be found in the W3C technical reports index at https://www.w3.org/TR/.

Feedback and comments on this specification are welcome. GitHub Issues are preferred for discussion on this specification. Alternatively, you can send comments to the Media Working Group’s mailing-list, public-media-wg@w3.org (archives). This draft highlights some of the pending issues that are still to be discussed in the working group. No decision has been taken on the outcome of these issues including whether they are valid.

This document was published by the Media Working Group as a Group Draft Note using the Note track.

Group Draft Notes are not endorsed by W3C nor its Members.

This is a draft document and may be updated, replaced or obsoleted by other documents at any time. It is inappropriate to cite this document as other than work in progress.

The W3C Patent Policy does not carry any licensing requirements or commitments on this document.

This document is governed by the 03 November 2023 W3C Process Document.

1. Fully qualified codec strings

This codec’s string begins with the prefix "pcm-", followed by a suffix that indicates the sample format. The complete list of strings and associated formats is as follows.

NOTE: [WEBCODECS] does not define a 24-bit AudioSampleFormat. 24-bit samples are permitted within an EncodedAudioChunk, but such samples will be "decoded" in AudioData objects as either s32 of f32. Please see WebCodecs § 9.3.2 Magnitude of the audio samples for additional details.

2. EncodedAudioChunk data

Linear pulse code modulation (linear PCM) describes a format where the audio values are sampled at a regular interval, and where the quantization levels between two successive values are linearly uniform.

EncodedAudioChunk [[internal data]] is expected to be a sequence of bytes of arbitrary length, with a sample occuring every N bits, where N is defined by the codec string. For multichannel PCM, samples from different channels are interleaved.

3. AudioDecoderConfig description

The description is expected to be omitted from the AudioDecoderConfig.

4. EncodedAudioChunk type

The [[type]] for an EncodedAudioChunk containing Linear PCM is always "key".

5. Privacy Considerations

Please refer to the section Privacy Considerations in [WEBCODECS].

6. Security Considerations

Please refer to the section Security Considerations in [WEBCODECS].

Conformance

Document conventions

Conformance requirements are expressed with a combination of descriptive assertions and RFC 2119 terminology. The key words “MUST”, “MUST NOT”, “REQUIRED”, “SHALL”, “SHALL NOT”, “SHOULD”, “SHOULD NOT”, “RECOMMENDED”, “MAY”, and “OPTIONAL” in the normative parts of this document are to be interpreted as described in RFC 2119. However, for readability, these words do not appear in all uppercase letters in this specification.

All of the text of this specification is normative except sections explicitly marked as non-normative, examples, and notes. [RFC2119]

Examples in this specification are introduced with the words “for example” or are set apart from the normative text with class="example", like this:

This is an example of an informative example.

Informative notes begin with the word “Note” and are set apart from the normative text with class="note", like this:

Note, this is an informative note.

Index

Terms defined by reference

References

Normative References

[CSP3]
Mike West; Antonio Sartori. Content Security Policy Level 3. 23 January 2024. WD. URL: https://www.w3.org/TR/CSP3/
[RFC2119]
S. Bradner. Key words for use in RFCs to Indicate Requirement Levels. March 1997. Best Current Practice. URL: https://datatracker.ietf.org/doc/html/rfc2119
[WEBCODECS]
Paul Adenot; Bernard Aboba; Eugene Zemtsov. WebCodecs. 8 January 2024. WD. URL: https://www.w3.org/TR/webcodecs/
[WEBIDL]
Edgar Chen; Timothy Gu. Web IDL Standard. Living Standard. URL: https://webidl.spec.whatwg.org/

Informative References

[WEBCODECS-CODEC-REGISTRY]
Chris Cunningham; Paul Adenot; Bernard Aboba. WebCodecs Codec Registry. 10 October 2022. NOTE. URL: https://www.w3.org/TR/webcodecs-codec-registry/