Skip to content

Commit

Permalink
Merge branch 'feature/media-pipeline' into feature/media-info
Browse files Browse the repository at this point in the history
  • Loading branch information
jlacivita committed Mar 18, 2024
2 parents cc2c231 + 84257b5 commit 384f55e
Show file tree
Hide file tree
Showing 23 changed files with 1,051 additions and 32 deletions.
104 changes: 103 additions & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,10 +1,112 @@
# [0.14.0-next.8](https://github.com/rdkcentral/firebolt-apis/compare/v0.14.0-next.7...v0.14.0-next.8) (2023-06-27)
# [0.16.0-next.3](https://github.com/rdkcentral/firebolt-apis/compare/v0.16.0-next.2...v0.16.0-next.3) (2023-08-14)


### Bug Fixes

* Update package.json to point to release 2.0.4 of `firebolt-openrpc` ([9e3cf55](https://github.com/rdkcentral/firebolt-apis/commit/9e3cf55d465d3b429ebcba0167e888eb7d7f0588))

# [0.16.0-next.2](https://github.com/rdkcentral/firebolt-apis/compare/v0.16.0-next.1...v0.16.0-next.2) (2023-08-10)


### Bug Fixes

* Unit test cases for setting null value ([#159](https://github.com/rdkcentral/firebolt-apis/issues/159)) ([7e011e2](https://github.com/rdkcentral/firebolt-apis/commit/7e011e2937842902c6b111646492b33a057b23c8))
* Update firebolt-openrpc, fix tests ([9480984](https://github.com/rdkcentral/firebolt-apis/commit/948098490595ffa374df08f3f44157d70beb7990))
* Update firebolt-openrpc, fix tests ([312b5ec](https://github.com/rdkcentral/firebolt-apis/commit/312b5ec627e9b494ac455475efe7851bed70c34e))

# [0.16.0-next.1](https://github.com/rdkcentral/firebolt-apis/compare/v0.15.0...v0.16.0-next.1) (2023-08-07)


### Features

* Added manage apis for windlowColor and windowOpacity ([#157](https://github.com/rdkcentral/firebolt-apis/issues/157)) ([f508358](https://github.com/rdkcentral/firebolt-apis/commit/f508358aeb2f58bb3893bbfaf09e2340fcadac8f))

# [0.15.0](https://github.com/rdkcentral/firebolt-apis/compare/v0.14.0...v0.15.0) (2023-07-31)


### Bug Fixes

* CHANGELOGs for 0.15 ([#152](https://github.com/rdkcentral/firebolt-apis/issues/152)) ([667f7a4](https://github.com/rdkcentral/firebolt-apis/commit/667f7a4620b3726a48e9071af6f5a9cfaf1c3ec8))
* CI weirdness ([b72990f](https://github.com/rdkcentral/firebolt-apis/commit/b72990f5363b5ce37aa09e80a2b2daffc209216a))
* Rename Advisory "Committee" to "Board" ([#135](https://github.com/rdkcentral/firebolt-apis/issues/135)) ([ef410c4](https://github.com/rdkcentral/firebolt-apis/commit/ef410c43bbb32414c3aa1d11b43093565cc90edf))
* Update package-lock.json ([767fc65](https://github.com/rdkcentral/firebolt-apis/commit/767fc658b5ac2020f5d6eca82c8734baf0200fd8))
* Updating package.json ([dd438b7](https://github.com/rdkcentral/firebolt-apis/commit/dd438b77c18c4565fd91a88e3394e5ce7c2cecff))
* Upgrade to `firebolt-js/openrpc` version 2.0.3 ([c0a2647](https://github.com/rdkcentral/firebolt-apis/commit/c0a26475dba5059f9fc6ceb11bcb103bb355cceb))
* window fix from firebolt-openrpc 2.0.3-next.1 ([8c06dd1](https://github.com/rdkcentral/firebolt-apis/commit/8c06dd1432822719f5634e2877b36efdf02a4809))


### Features

* Added support to set and get null in ClosedCaptions style fields ([#150](https://github.com/rdkcentral/firebolt-apis/issues/150)) ([9c511e4](https://github.com/rdkcentral/firebolt-apis/commit/9c511e4fddebcdf5dfc04e9e8e31f98ab7eef680))
* Added windowColor and windowOpacity to closedCaptions style ([#145](https://github.com/rdkcentral/firebolt-apis/issues/145)) ([f65b901](https://github.com/rdkcentral/firebolt-apis/commit/f65b9019bda22400df9b9634c332e720db38118d))
* Audio Description and Preferred Audio Languages Settings ([#45](https://github.com/rdkcentral/firebolt-apis/issues/45)) ([58f6ea1](https://github.com/rdkcentral/firebolt-apis/commit/58f6ea1dde7a819883eb3da24f879b6a9ecc9a41))

# [0.15.0-next.4](https://github.com/rdkcentral/firebolt-apis/compare/v0.15.0-next.3...v0.15.0-next.4) (2023-07-31)


### Bug Fixes

* CHANGELOGs for 0.15 ([#152](https://github.com/rdkcentral/firebolt-apis/issues/152)) ([667f7a4](https://github.com/rdkcentral/firebolt-apis/commit/667f7a4620b3726a48e9071af6f5a9cfaf1c3ec8))
* Update package-lock.json ([767fc65](https://github.com/rdkcentral/firebolt-apis/commit/767fc658b5ac2020f5d6eca82c8734baf0200fd8))

# [0.15.0-next.3](https://github.com/rdkcentral/firebolt-apis/compare/v0.15.0-next.2...v0.15.0-next.3) (2023-07-31)


### Features

* Audio Description and Preferred Audio Languages Settings ([#45](https://github.com/rdkcentral/firebolt-apis/issues/45)) ([58f6ea1](https://github.com/rdkcentral/firebolt-apis/commit/58f6ea1dde7a819883eb3da24f879b6a9ecc9a41))

# [0.15.0-next.2](https://github.com/rdkcentral/firebolt-apis/compare/v0.15.0-next.1...v0.15.0-next.2) (2023-07-28)


### Bug Fixes

* CI weirdness ([b72990f](https://github.com/rdkcentral/firebolt-apis/commit/b72990f5363b5ce37aa09e80a2b2daffc209216a))
* Updating package.json ([dd438b7](https://github.com/rdkcentral/firebolt-apis/commit/dd438b77c18c4565fd91a88e3394e5ce7c2cecff))

# [0.15.0-next.1](https://github.com/rdkcentral/firebolt-apis/compare/v0.14.0...v0.15.0-next.1) (2023-07-27)


### Bug Fixes

* Rename Advisory "Committee" to "Board" ([#135](https://github.com/rdkcentral/firebolt-apis/issues/135)) ([ef410c4](https://github.com/rdkcentral/firebolt-apis/commit/ef410c43bbb32414c3aa1d11b43093565cc90edf))
* window fix from firebolt-openrpc 2.0.3-next.1 ([8c06dd1](https://github.com/rdkcentral/firebolt-apis/commit/8c06dd1432822719f5634e2877b36efdf02a4809))


### Features

* Added support to set and get null in ClosedCaptions style fields ([#150](https://github.com/rdkcentral/firebolt-apis/issues/150)) ([9c511e4](https://github.com/rdkcentral/firebolt-apis/commit/9c511e4fddebcdf5dfc04e9e8e31f98ab7eef680))
* Added windowColor and windowOpacity to closedCaptions style ([#145](https://github.com/rdkcentral/firebolt-apis/issues/145)) ([f65b901](https://github.com/rdkcentral/firebolt-apis/commit/f65b9019bda22400df9b9634c332e720db38118d))

# [0.14.0-next.10](https://github.com/rdkcentral/firebolt-apis/compare/v0.14.0-next.8...v0.14.0-next.11) (2023-07-26)

### Features

* Added support to set and get null in ClosedCaptions style fields ([#150](https://github.com/rdkcentral/firebolt-apis/issues/150)) ([9c511e4](https://github.com/rdkcentral/firebolt-apis/commit/9c511e4fddebcdf5dfc04e9e8e31f98ab7eef680))
* Added windowColor and windowOpacity to closedCaptions style ([#145](https://github.com/rdkcentral/firebolt-apis/issues/145)) ([f65b901](https://github.com/rdkcentral/firebolt-apis/commit/f65b9019bda22400df9b9634c332e720db38118d))

### Bug Fixes

* window fix from firebolt-openrpc 2.0.3-next.1 ([8c06dd1](https://github.com/rdkcentral/firebolt-apis/commit/8c06dd1432822719f5634e2877b36efdf02a4809))
* Rename Advisory "Committee" to "Board" ([#135](https://github.com/rdkcentral/firebolt-apis/issues/135)) ([ef410c4](https://github.com/rdkcentral/firebolt-apis/commit/ef410c43bbb32414c3aa1d11b43093565cc90edf))

# [0.14.0](https://github.com/rdkcentral/firebolt-apis/compare/v0.13.0...v0.14.0) (2023-06-22)

* Add Capabilities ToC to github.io docs ([0d23136](https://github.com/rdkcentral/firebolt-apis/commit/0d23136bfa4976686795158bdfe179430598af9e))
* **Advertising:** put resetAdvertisingIdentifier back in manage sdk ([ce92ae7](https://github.com/rdkcentral/firebolt-apis/commit/ce92ae7bfff58fa1d3e4bee78c88d5edf0266473))
* event links in capability toc ([31a8a85](https://github.com/rdkcentral/firebolt-apis/commit/31a8a85c0749ebfa872f2a158975697396ebdf8c))
* **governance:** Add governance process docs ([a80ab53](https://github.com/rdkcentral/firebolt-apis/commit/a80ab53c5cdd914b5acbce1effbdb464475bed63))
* Move to `firebolt-openrpc` 2.0.2 ([52fe2a7](https://github.com/rdkcentral/firebolt-apis/commit/52fe2a78b17f1e36ec854fedd52d136cfa60b4e2))
* package-lock.json ([dd8025c](https://github.com/rdkcentral/firebolt-apis/commit/dd8025c637a5ae58ce2e0355b995d55feeab9713))
* Update path in publish docs ([9881383](https://github.com/rdkcentral/firebolt-apis/commit/98813833a074a6e25b012d2aac376377d8c5d5a9))


### Features

* Add an event when apps call signIn or signOut ([#133](https://github.com/rdkcentral/firebolt-apis/issues/133)) ([8ba2515](https://github.com/rdkcentral/firebolt-apis/commit/8ba2515948c433ccc38662f223f5fb399cf34841))
* Allow granted in capability.info and capability.granted to be null ([#134](https://github.com/rdkcentral/firebolt-apis/issues/134)) ([c5c31ee](https://github.com/rdkcentral/firebolt-apis/commit/c5c31ee3c744ec018a57232d2e7b1caf41158ed6))
* Change voice guidance limits to 0.5 and 2 ([#137](https://github.com/rdkcentral/firebolt-apis/issues/137)) ([b8f1944](https://github.com/rdkcentral/firebolt-apis/commit/b8f19449efd808639599b162aba61c08ec089c41))

# [0.14.0-next.7](https://github.com/rdkcentral/firebolt-apis/compare/v0.14.0-next.6...v0.14.0-next.7) (2023-06-22)


Expand Down
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@firebolt-js/sdks",
"version": "0.14.0-next.8",
"version": "0.16.0-next.3",
"description": "The Firebolt JS SDK",
"type": "module",
"bin": {
Expand Down
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
267 changes: 267 additions & 0 deletions requirements/specifications/media/media-pipeline.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,267 @@
# Media Pipeline Requirements

Document Status: Working Draft

See [Firebolt Requirements Governance](./governance.md) for more info.

**NOTE**: Update this link based on your directory depth ^^

| Contributor | Organization |
| -------------- | -------------- |
| Lucien Kennedy-Lamb | Sky |
| Bijal Shah | Sky |
| Yuri Pasquali | Sky |
| Stuart Pett | Sky |
| Wouter Meek | Comcast |
| Jeremy LaCivita | Comcast |
| Kevin Pearson | Comcast |
| Phillip Stroffolino | Comcast |

## 1. Overview

Playback of audio/video media is a first-class concern for Firebolt. As
such, Firebolt must provide a consistent, secure Media Pipeline API for
sending audio and video streams from an app container out to a decoder
and CDM for content decryption, decoding, and rasterization.

Additionally, Firebolt browsers must leverage the same Media Pipeline
implementation as native apps, so that content plays back the same in
both environments and can have resources managed in the same way.

This is achieved with the open source [Rialto Media
Pipeline](https://github.com/rdkcentral/rialto) API and implementation:

![Diagram Description automatically
generated](../../../../requirements/images/specifications/media/media-pipeline/media/image1.png)

## 2. Table of Contents
- [1. Overview](#1-overview)
- [2. Table of Contents](#2-table-of-contents)
- [3. Media Pipeline](#3-media-pipeline)
- [3.1. Media Pipeline Commands](#31-media-pipeline-commands)
- [3.2. MediaPipeline Notifications](#32-mediapipeline-notifications)
- [3.3. Media Pipeline Management](#33-media-pipeline-management)
- [4. W3C Media APIs](#4-w3c-media-apis)
- [4.1. MediaSource](#41-mediasource)
- [4.2. MediaElement](#42-mediaelement)
- [5. Supported Media](#5-supported-media)
- [5.1. Container formats](#51-container-formats)
- [5.2. Video codecs](#52-video-codecs)
- [5.3. Audio codecs](#53-audio-codecs)
- [6. Supported Decryption](#6-supported-decryption)
- [6.1. DRM Key Systems](#61-drm-key-systems)
- [6.2. Decryption Schemes](#62-decryption-schemes)

## 3. Media Pipeline

The Firebolt Media Pipeline consists of an API for passing audio & video
streams *out* of individual app containers *into* managed media sessions
that support decryption, decoding, and rasterization. Additionally there
is an API for sending notifications out of the decoder and into the app
container.

The goal of this abstraction is to decouple individual Firebolt Apps and
containers from the underlying implementations of these features.
Additionally, this abstraction allows for the same component to manage
media sessions in a consistent manner regardless of implementation.

To ensure consistency, all native containers, including browsers, that
run on Firebolt platforms **MUST** use Rialto as the only pipeline to
Media decoders and CDMs.

The Media Pipeline API uses a client-server model to allow Firebolt
devices to manage media pipeline resources and visibility. This enables
multiple media pipeline sessions to be running at once, even though they
will not all have access to the underlying decoder. Command messages are
passed using an efficient binary RPC protocol. Media data is passed
using memory shared by only the app container and its respective Rialto
session server.

![Timeline Description automatically
generated](../../../requirements/images/specifications/media/media-pipeline/media/image2.png)

### 3.1. Media Pipeline Commands

Media Pipeline commands go from the app to the Rialto Media Pipeline
server.

This section describes the use cases that the Rialto API solves. For
actual API semantics, please refer to the Rialto Github repository.

The MediaPipeline API **MUST** support pushing data into the Pipeline,
in response to a notification that more data is needed.

The MediaPipeline API **MUST** support informing the Pipeline that it
has reached the end of a stream and no more data is available.

The MediaPipeline API **MUST** support initializing (aka loading) a new
Media session, typically done before starting a new stream.

The MediaPipeline API **MUST** support attaching one video and one audio
source buffer.

The MediaPipeline API **MUST** support removing source buffers.

The MediaPipeline API **MUST** support pausing and playing.

The MediaPipeline API **MUST** support stopping playback, such that it
cannot be resumed without reinitializing.

The MediaPipeline API **MUST** support setting the playback rate.

The MediaPipeline API **MUST** support setting the current playback
position.

The MediaPipeline API **MUST** support setting the video location and
dimensions.

The MediaPipeline API **MUST** support dynamic audio decode switching to
support Netflix use cases.

### 3.2. MediaPipeline Notifications

Media Pipeline notifications come from the Rialto Media Pipeline server
to the app.

This section describes the use cases that the Rialto API solves. For
actual API semantics, please refer to the Rialto Github repository.

The MediaPipeline API **MUST** support notifying the app when more audio
or video data is needed in order for playback to continue without error.

The MediaPipeline API **MUST** support notifying the app when a need for
more audio or video data is no longer relevant, e.g. due to switching
buffers or stopping.

The MediaPipeline API **MUST** support notifying the app of the current
Media duration.

The MediaPipeline API **MUST** support notifying the app of the current
Media position.

The MediaPipeline API **MUST** support notifying the app of the current
native dimensions of the current Media.

The MediaPipeline API **MUST** support notifying the app of the current
buffer state, e.g. buffered, idle, error.

The MediaPipeline API **MUST** support notifying the app of the current
playback state, e.g. playing, paused, seeking, stopped.

The MediaPipeline API **MUST** support notifying the app whether the
current media contains video and/or audio data.

The MediaPipeline API **MUST** support notifying the app when frames of
video or samples of audio are dropped due to performance.

The MediaPipeline API **MUST** support notifying the app when EIA/CEA
608/708 closed caption data is extracted and ready for presentation.

### 3.3. Media Pipeline Management

Rialto also exposes a management API for deciding which Rialto session
is active and visible. The Firebolt Execution Environment, typically
Ripple interacts with this API as apps move in and out of focus.

![Diagram Description automatically
generated](../../../requirements/images/specifications/media/media-pipeline/media/image3.png)

**TODO**: add decode pool requirements, e.g. minimum decoders for a
Firebolt platform, etc. \-- This needs to be written out.

**TODO**: add colloquial description of API surface in Rialto Server
Manager. We need this written out for the management api.

## 4. W3C Media APIs

The Media Source API enables the entire functional scope of the W3C
MediaSource and MediaElement APIs, (e.g. MediaSource.addSourceBuffer,
video.src, video.play(), etc.)

Firebolt browsers will use Rialto to implement `MediaElement` and
`MediaSource` APIs.

### 4.1. MediaSource

Browser MediaSource APIs **MUST** be powered by Rialto. Higher level
concerns such as source buffer management, etc., are outside the scope
of this document.

When using MediaSource APIs, demuxing is the concern of the app, not the
browser.

![Graphical user interface, application, Teams Description automatically
generated](../../../requirements/images/specifications/media/media-pipeline/media/image4.png)

### 4.2. MediaElement

Browser Media Element implementations **MUST** support progressive
download and demuxing of the following media container formats:

- Progressive MPEG4 video

- Progressive MP3 audio

Demuxed segments **MUST** be sent to Rialto for decoding.

MediaElement implementations **MUST** not support additional formats,
e.g. HLS or DASH. These formats should be parsed and fetched by a player
implemented on top of MSE.

Legacy support for direct playback of HLS is outside the scope of this
document.

![Graphical user interface, application Description automatically
generated](../../../requirements/images/specifications/media/media-pipeline/media/image5.png)

## 5. Supported Media

The Rialto Media Pipeline supports the following media types.

### 5.1. Container formats

The Media Pipeline **MUST** support the following container formats:

- Demuxed MP4 audio and video streams, via MSE

- MPEG 1 for audio-only playback (progressively fetched upstream)

### 5.2. Video codecs

The Media Pipeline **MUST** support the following video codecs:

- AVC

- HEVC

- VP9

- H.264

### 5.3. Audio codecs

The Media Pipeline **MUST** support the following audio codecs:

- HE-AAC

- AAC-LC

- HE-AACv2

- MPEG-1 Audio Layer III (for audio-only media)

## 6. Supported Decryption

The Rialto Media Pipeline supports the following media decryption types.

### 6.1. DRM Key Systems

- Widevine

- PlayReady

- *I know there\'s **legacy use cases**\... do we call them out?*

### 6.2. Decryption Schemes

- CMAF CBCS decryption
Loading

0 comments on commit 384f55e

Please sign in to comment.