summaryrefslogtreecommitdiffstats
path: root/dom/media/platforms/agnostic/AOMDecoder.cpp
diff options
context:
space:
mode:
authortrav90 <travawine@palemoon.org>2018-10-17 05:54:22 -0500
committertrav90 <travawine@palemoon.org>2018-10-17 05:54:22 -0500
commit0cc51bc106250988cc3b89cb5d743a5af52cd35a (patch)
tree68a1e4544f48012be2cebdc36e888cdbfd0fddec /dom/media/platforms/agnostic/AOMDecoder.cpp
parent1036d1fa0b1fe0f1a7136ffe111f577aa35de21e (diff)
downloadUXP-0cc51bc106250988cc3b89cb5d743a5af52cd35a.tar
UXP-0cc51bc106250988cc3b89cb5d743a5af52cd35a.tar.gz
UXP-0cc51bc106250988cc3b89cb5d743a5af52cd35a.tar.lz
UXP-0cc51bc106250988cc3b89cb5d743a5af52cd35a.tar.xz
UXP-0cc51bc106250988cc3b89cb5d743a5af52cd35a.zip
Add av1 to MediaSource.isTypeSupported
When av1 video playback is enabled, declare it as supported in the webm container in MediaSource.IsTypeSupported. Also support special mime types of the form video/webm; codecs=vp9.experimental.<git-commit-id> so test sites can verify playback support of particular encodings while the av1 bitstream is under development.
Diffstat (limited to 'dom/media/platforms/agnostic/AOMDecoder.cpp')
-rw-r--r--dom/media/platforms/agnostic/AOMDecoder.cpp13
1 files changed, 13 insertions, 0 deletions
diff --git a/dom/media/platforms/agnostic/AOMDecoder.cpp b/dom/media/platforms/agnostic/AOMDecoder.cpp
index 3ab5004e3..d1b45cf7f 100644
--- a/dom/media/platforms/agnostic/AOMDecoder.cpp
+++ b/dom/media/platforms/agnostic/AOMDecoder.cpp
@@ -212,6 +212,19 @@ AOMDecoder::IsAV1(const nsACString& aMimeType)
/* static */
bool
+AOMDecoder::IsSupportedCodec(const nsAString& aCodecType)
+{
+ // While AV1 is under development, we describe support
+ // for a specific aom commit hash so sites can check
+ // compatibility.
+ auto version = NS_ConvertASCIItoUTF16("av1.experimental.");
+ version.AppendLiteral("4d668d7feb1f8abd809d1bca0418570a7f142a36");
+ return aCodecType.EqualsLiteral("av1") ||
+ aCodecType.Equals(version);
+}
+
+/* static */
+bool
AOMDecoder::IsKeyframe(Span<const uint8_t> aBuffer) {
aom_codec_stream_info_t info;
PodZero(&info);