diff --git a/examples/androidapp/res/values/arrays.xml b/examples/androidapp/res/values/arrays.xml
index 4a2948c875..e0e6ccbdc2 100644
--- a/examples/androidapp/res/values/arrays.xml
+++ b/examples/androidapp/res/values/arrays.xml
@@ -34,7 +34,6 @@
- VP9
- H264 Baseline
- H264 High
- - AV1
diff --git a/examples/androidapp/src/org/appspot/apprtc/PeerConnectionClient.java b/examples/androidapp/src/org/appspot/apprtc/PeerConnectionClient.java
index 31e6e9722b..0776ccba60 100644
--- a/examples/androidapp/src/org/appspot/apprtc/PeerConnectionClient.java
+++ b/examples/androidapp/src/org/appspot/apprtc/PeerConnectionClient.java
@@ -95,8 +95,6 @@ public class PeerConnectionClient {
private static final String VIDEO_CODEC_H264 = "H264";
private static final String VIDEO_CODEC_H264_BASELINE = "H264 Baseline";
private static final String VIDEO_CODEC_H264_HIGH = "H264 High";
- private static final String VIDEO_CODEC_AV1 = "AV1";
- private static final String VIDEO_CODEC_AV1_SDP_CODEC_NAME = "AV1X";
private static final String AUDIO_CODEC_OPUS = "opus";
private static final String AUDIO_CODEC_ISAC = "ISAC";
private static final String VIDEO_CODEC_PARAM_START_BITRATE = "x-google-start-bitrate";
@@ -988,8 +986,6 @@ public class PeerConnectionClient {
return VIDEO_CODEC_VP8;
case VIDEO_CODEC_VP9:
return VIDEO_CODEC_VP9;
- case VIDEO_CODEC_AV1:
- return VIDEO_CODEC_AV1_SDP_CODEC_NAME;
case VIDEO_CODEC_H264_HIGH:
case VIDEO_CODEC_H264_BASELINE:
return VIDEO_CODEC_H264;
diff --git a/sdk/android/BUILD.gn b/sdk/android/BUILD.gn
index 0094c8ea39..9b6a5dcdb1 100644
--- a/sdk/android/BUILD.gn
+++ b/sdk/android/BUILD.gn
@@ -43,7 +43,6 @@ if (is_android) {
":filevideo_java",
":hwcodecs_java",
":java_audio_device_module_java",
- ":libaom_av1_java",
":libjingle_peerconnection_java",
":libjingle_peerconnection_metrics_default_java",
":libvpx_vp8_java",
@@ -501,20 +500,6 @@ if (is_android) {
]
}
- rtc_android_library("libaom_av1_java") {
- visibility = [ "*" ]
- sources = [
- "api/org/webrtc/LibaomAv1Decoder.java",
- "api/org/webrtc/LibaomAv1Encoder.java",
- ]
- deps = [
- ":base_java",
- ":video_api_java",
- ":video_java",
- "//rtc_base:base_java",
- ]
- }
-
rtc_android_library("swcodecs_java") {
visibility = [ "*" ]
sources = [
@@ -524,7 +509,6 @@ if (is_android) {
deps = [
":base_java",
- ":libaom_av1_java",
":libvpx_vp8_java",
":libvpx_vp9_java",
":video_api_java",
@@ -841,24 +825,10 @@ if (current_os == "linux" || is_android) {
]
}
- rtc_library("libaom_av1_jni") {
- visibility = [ "*" ]
- allow_poison = [ "software_video_codecs" ]
- sources = [ "src/jni/av1_codec.cc" ]
- deps = [
- ":base_jni",
- ":generated_libaom_av1_jni",
- ":video_jni",
- "../../modules/video_coding/codecs/av1:libaom_av1_decoder",
- "../../modules/video_coding/codecs/av1:libaom_av1_encoder",
- ]
- }
-
rtc_library("swcodecs_jni") {
visibility = [ "*" ]
allow_poison = [ "software_video_codecs" ]
deps = [
- ":libaom_av1_jni",
":libvpx_vp8_jni",
":libvpx_vp9_jni",
]
@@ -1294,16 +1264,6 @@ if (current_os == "linux" || is_android) {
jni_generator_include = "//sdk/android/src/jni/jni_generator_helper.h"
}
- generate_jni("generated_libaom_av1_jni") {
- sources = [
- "api/org/webrtc/LibaomAv1Decoder.java",
- "api/org/webrtc/LibaomAv1Encoder.java",
- ]
-
- namespace = "webrtc::jni"
- jni_generator_include = "//sdk/android/src/jni/jni_generator_helper.h"
- }
-
generate_jni("generated_peerconnection_jni") {
sources = [
"api/org/webrtc/AddIceObserver.java",
diff --git a/sdk/android/api/org/webrtc/HardwareVideoEncoderFactory.java b/sdk/android/api/org/webrtc/HardwareVideoEncoderFactory.java
index 17ba76ab30..8fe8b36909 100644
--- a/sdk/android/api/org/webrtc/HardwareVideoEncoderFactory.java
+++ b/sdk/android/api/org/webrtc/HardwareVideoEncoderFactory.java
@@ -137,9 +137,9 @@ public class HardwareVideoEncoderFactory implements VideoEncoderFactory {
List supportedCodecInfos = new ArrayList();
// Generate a list of supported codecs in order of preference:
- // VP8, VP9, H264 (high profile), H264 (baseline profile) and AV1.
- for (VideoCodecMimeType type : new VideoCodecMimeType[] {VideoCodecMimeType.VP8,
- VideoCodecMimeType.VP9, VideoCodecMimeType.H264, VideoCodecMimeType.AV1}) {
+ // VP8, VP9, H264 (high profile), and H264 (baseline profile).
+ for (VideoCodecMimeType type : new VideoCodecMimeType[] {
+ VideoCodecMimeType.VP8, VideoCodecMimeType.VP9, VideoCodecMimeType.H264}) {
MediaCodecInfo codec = findCodecForType(type);
if (codec != null) {
String name = type.name();
@@ -202,8 +202,6 @@ public class HardwareVideoEncoderFactory implements VideoEncoderFactory {
return isHardwareSupportedInCurrentSdkVp9(info);
case H264:
return isHardwareSupportedInCurrentSdkH264(info);
- case AV1:
- return false;
}
return false;
}
@@ -250,7 +248,6 @@ public class HardwareVideoEncoderFactory implements VideoEncoderFactory {
switch (type) {
case VP8: // Fallthrough intended.
case VP9:
- case AV1:
return 100;
case H264:
return 20;
diff --git a/sdk/android/api/org/webrtc/LibaomAv1Decoder.java b/sdk/android/api/org/webrtc/LibaomAv1Decoder.java
deleted file mode 100644
index 609203fe3f..0000000000
--- a/sdk/android/api/org/webrtc/LibaomAv1Decoder.java
+++ /dev/null
@@ -1,22 +0,0 @@
-/*
- * Copyright (c) 2021 The WebRTC project authors. All Rights Reserved.
- *
- * Use of this source code is governed by a BSD-style license
- * that can be found in the LICENSE file in the root of the source
- * tree. An additional intellectual property rights grant can be found
- * in the file PATENTS. All contributing project authors may
- * be found in the AUTHORS file in the root of the source tree.
- */
-
-package org.webrtc;
-
-public class LibaomAv1Decoder extends WrappedNativeVideoDecoder {
- @Override
- public long createNativeVideoDecoder() {
- return nativeCreateDecoder();
- }
-
- static native long nativeCreateDecoder();
-
- static native boolean nativeIsSupported();
-}
diff --git a/sdk/android/api/org/webrtc/LibaomAv1Encoder.java b/sdk/android/api/org/webrtc/LibaomAv1Encoder.java
deleted file mode 100644
index 26648c589e..0000000000
--- a/sdk/android/api/org/webrtc/LibaomAv1Encoder.java
+++ /dev/null
@@ -1,27 +0,0 @@
-/*
- * Copyright (c) 2021 The WebRTC project authors. All Rights Reserved.
- *
- * Use of this source code is governed by a BSD-style license
- * that can be found in the LICENSE file in the root of the source
- * tree. An additional intellectual property rights grant can be found
- * in the file PATENTS. All contributing project authors may
- * be found in the AUTHORS file in the root of the source tree.
- */
-
-package org.webrtc;
-
-public class LibaomAv1Encoder extends WrappedNativeVideoEncoder {
- @Override
- public long createNativeVideoEncoder() {
- return nativeCreateEncoder();
- }
-
- static native long nativeCreateEncoder();
-
- @Override
- public boolean isHardwareEncoder() {
- return false;
- }
-
- static native boolean nativeIsSupported();
-}
diff --git a/sdk/android/api/org/webrtc/SoftwareVideoDecoderFactory.java b/sdk/android/api/org/webrtc/SoftwareVideoDecoderFactory.java
index da11e87ec3..7abe3505a6 100644
--- a/sdk/android/api/org/webrtc/SoftwareVideoDecoderFactory.java
+++ b/sdk/android/api/org/webrtc/SoftwareVideoDecoderFactory.java
@@ -32,9 +32,6 @@ public class SoftwareVideoDecoderFactory implements VideoDecoderFactory {
if (codecType.getName().equalsIgnoreCase("VP9") && LibvpxVp9Decoder.nativeIsSupported()) {
return new LibvpxVp9Decoder();
}
- if (codecType.getName().equalsIgnoreCase("AV1") && LibaomAv1Decoder.nativeIsSupported()) {
- return new LibaomAv1Decoder();
- }
return null;
}
@@ -51,9 +48,6 @@ public class SoftwareVideoDecoderFactory implements VideoDecoderFactory {
if (LibvpxVp9Decoder.nativeIsSupported()) {
codecs.add(new VideoCodecInfo("VP9", new HashMap<>()));
}
- if (LibaomAv1Decoder.nativeIsSupported()) {
- codecs.add(new VideoCodecInfo("AV1", new HashMap<>()));
- }
return codecs.toArray(new VideoCodecInfo[codecs.size()]);
}
diff --git a/sdk/android/api/org/webrtc/SoftwareVideoEncoderFactory.java b/sdk/android/api/org/webrtc/SoftwareVideoEncoderFactory.java
index 528adab98c..ed70d228ef 100644
--- a/sdk/android/api/org/webrtc/SoftwareVideoEncoderFactory.java
+++ b/sdk/android/api/org/webrtc/SoftwareVideoEncoderFactory.java
@@ -25,9 +25,6 @@ public class SoftwareVideoEncoderFactory implements VideoEncoderFactory {
if (info.name.equalsIgnoreCase("VP9") && LibvpxVp9Encoder.nativeIsSupported()) {
return new LibvpxVp9Encoder();
}
- if (info.name.equalsIgnoreCase("AV1") && LibaomAv1Encoder.nativeIsSupported()) {
- return new LibaomAv1Encoder();
- }
return null;
}
@@ -44,9 +41,6 @@ public class SoftwareVideoEncoderFactory implements VideoEncoderFactory {
if (LibvpxVp9Encoder.nativeIsSupported()) {
codecs.add(new VideoCodecInfo("VP9", new HashMap<>()));
}
- if (LibaomAv1Encoder.nativeIsSupported()) {
- codecs.add(new VideoCodecInfo("AV1", new HashMap<>()));
- }
return codecs.toArray(new VideoCodecInfo[codecs.size()]);
}
diff --git a/sdk/android/api/org/webrtc/VideoEncoder.java b/sdk/android/api/org/webrtc/VideoEncoder.java
index 460428192d..cb8eb81767 100644
--- a/sdk/android/api/org/webrtc/VideoEncoder.java
+++ b/sdk/android/api/org/webrtc/VideoEncoder.java
@@ -86,8 +86,6 @@ public interface VideoEncoder {
public class CodecSpecificInfoH264 extends CodecSpecificInfo {}
- public class CodecSpecificInfoAV1 extends CodecSpecificInfo {}
-
/**
* Represents bitrate allocated for an encoder to produce frames. Bitrate can be divided between
* spatial and temporal layers.
diff --git a/sdk/android/instrumentationtests/src/org/webrtc/DefaultVideoEncoderFactoryTest.java b/sdk/android/instrumentationtests/src/org/webrtc/DefaultVideoEncoderFactoryTest.java
index 8ffacbe788..69b0129c36 100644
--- a/sdk/android/instrumentationtests/src/org/webrtc/DefaultVideoEncoderFactoryTest.java
+++ b/sdk/android/instrumentationtests/src/org/webrtc/DefaultVideoEncoderFactoryTest.java
@@ -70,14 +70,13 @@ public class DefaultVideoEncoderFactoryTest {
VideoEncoderFactory hwFactory = new CustomHardwareVideoEncoderFactory(true, true);
DefaultVideoEncoderFactory dvef = new DefaultVideoEncoderFactory(hwFactory);
VideoCodecInfo[] videoCodecs = dvef.getSupportedCodecs();
- assertEquals(5, videoCodecs.length);
+ assertEquals(4, videoCodecs.length);
assertEquals("VP8", videoCodecs[0].name);
assertEquals("VP9", videoCodecs[1].name);
- assertEquals("AV1", videoCodecs[2].name);
+ assertEquals("H264", videoCodecs[2].name);
+ assertEquals("42e01f", videoCodecs[2].params.get("profile-level-id"));
assertEquals("H264", videoCodecs[3].name);
- assertEquals("42e01f", videoCodecs[3].params.get("profile-level-id"));
- assertEquals("H264", videoCodecs[4].name);
- assertEquals("640c1f", videoCodecs[4].params.get("profile-level-id"));
+ assertEquals("640c1f", videoCodecs[3].params.get("profile-level-id"));
}
@SmallTest
@@ -86,12 +85,11 @@ public class DefaultVideoEncoderFactoryTest {
VideoEncoderFactory hwFactory = new CustomHardwareVideoEncoderFactory(true, false);
DefaultVideoEncoderFactory dvef = new DefaultVideoEncoderFactory(hwFactory);
VideoCodecInfo[] videoCodecs = dvef.getSupportedCodecs();
- assertEquals(4, videoCodecs.length);
+ assertEquals(3, videoCodecs.length);
assertEquals("VP8", videoCodecs[0].name);
assertEquals("VP9", videoCodecs[1].name);
- assertEquals("AV1", videoCodecs[2].name);
- assertEquals("H264", videoCodecs[3].name);
- assertEquals("42e01f", videoCodecs[3].params.get("profile-level-id"));
+ assertEquals("H264", videoCodecs[2].name);
+ assertEquals("42e01f", videoCodecs[2].params.get("profile-level-id"));
}
@SmallTest
@@ -100,13 +98,12 @@ public class DefaultVideoEncoderFactoryTest {
VideoEncoderFactory hwFactory = new CustomHardwareVideoEncoderFactory(false, true);
DefaultVideoEncoderFactory dvef = new DefaultVideoEncoderFactory(hwFactory);
VideoCodecInfo[] videoCodecs = dvef.getSupportedCodecs();
- assertEquals(5, videoCodecs.length);
+ assertEquals(4, videoCodecs.length);
assertEquals("VP8", videoCodecs[0].name);
assertEquals("VP9", videoCodecs[1].name);
- assertEquals("AV1", videoCodecs[2].name);
+ assertEquals("H264", videoCodecs[2].name);
+ assertEquals("42e01f", videoCodecs[2].params.get("profile-level-id"));
assertEquals("H264", videoCodecs[3].name);
- assertEquals("42e01f", videoCodecs[3].params.get("profile-level-id"));
- assertEquals("H264", videoCodecs[4].name);
- assertEquals("640c1f", videoCodecs[4].params.get("profile-level-id"));
+ assertEquals("640c1f", videoCodecs[3].params.get("profile-level-id"));
}
}
diff --git a/sdk/android/src/java/org/webrtc/HardwareVideoEncoder.java b/sdk/android/src/java/org/webrtc/HardwareVideoEncoder.java
index f116fefc83..f6d98bd14f 100644
--- a/sdk/android/src/java/org/webrtc/HardwareVideoEncoder.java
+++ b/sdk/android/src/java/org/webrtc/HardwareVideoEncoder.java
@@ -169,7 +169,7 @@ class HardwareVideoEncoder implements VideoEncoder {
* intervals, and bitrateAdjuster.
*
* @param codecName the hardware codec implementation to use
- * @param codecType the type of the given video codec (eg. VP8, VP9, H264 or AV1)
+ * @param codecType the type of the given video codec (eg. VP8, VP9, or H264)
* @param surfaceColorFormat color format for surface mode or null if not available
* @param yuvColorFormat color format for bytebuffer mode
* @param keyFrameIntervalSec interval in seconds between key frames; used to initialize the codec
diff --git a/sdk/android/src/java/org/webrtc/MediaCodecUtils.java b/sdk/android/src/java/org/webrtc/MediaCodecUtils.java
index b634fb34f5..cd43098015 100644
--- a/sdk/android/src/java/org/webrtc/MediaCodecUtils.java
+++ b/sdk/android/src/java/org/webrtc/MediaCodecUtils.java
@@ -91,7 +91,6 @@ class MediaCodecUtils {
switch (type) {
case VP8:
case VP9:
- case AV1:
return new HashMap();
case H264:
return H264Utils.getDefaultH264Params(highProfile);
diff --git a/sdk/android/src/java/org/webrtc/MediaCodecVideoDecoderFactory.java b/sdk/android/src/java/org/webrtc/MediaCodecVideoDecoderFactory.java
index bd446fb741..036aca5822 100644
--- a/sdk/android/src/java/org/webrtc/MediaCodecVideoDecoderFactory.java
+++ b/sdk/android/src/java/org/webrtc/MediaCodecVideoDecoderFactory.java
@@ -64,8 +64,8 @@ class MediaCodecVideoDecoderFactory implements VideoDecoderFactory {
List supportedCodecInfos = new ArrayList();
// Generate a list of supported codecs in order of preference:
// VP8, VP9, H264 (high profile), and H264 (baseline profile).
- for (VideoCodecMimeType type : new VideoCodecMimeType[] {VideoCodecMimeType.VP8,
- VideoCodecMimeType.VP9, VideoCodecMimeType.H264, VideoCodecMimeType.AV1}) {
+ for (VideoCodecMimeType type : new VideoCodecMimeType[] {
+ VideoCodecMimeType.VP8, VideoCodecMimeType.VP9, VideoCodecMimeType.H264}) {
MediaCodecInfo codec = findCodecForType(type);
if (codec != null) {
String name = type.name();
diff --git a/sdk/android/src/java/org/webrtc/VideoCodecMimeType.java b/sdk/android/src/java/org/webrtc/VideoCodecMimeType.java
index 26a030919d..f27a9176cf 100644
--- a/sdk/android/src/java/org/webrtc/VideoCodecMimeType.java
+++ b/sdk/android/src/java/org/webrtc/VideoCodecMimeType.java
@@ -14,8 +14,7 @@ package org.webrtc;
enum VideoCodecMimeType {
VP8("video/x-vnd.on2.vp8"),
VP9("video/x-vnd.on2.vp9"),
- H264("video/avc"),
- AV1("video/av01");
+ H264("video/avc");
private final String mimeType;
diff --git a/sdk/android/src/jni/av1_codec.cc b/sdk/android/src/jni/av1_codec.cc
deleted file mode 100644
index 02070f7901..0000000000
--- a/sdk/android/src/jni/av1_codec.cc
+++ /dev/null
@@ -1,39 +0,0 @@
-/*
- * Copyright 2021 The WebRTC project authors. All Rights Reserved.
- *
- * Use of this source code is governed by a BSD-style license
- * that can be found in the LICENSE file in the root of the source
- * tree. An additional intellectual property rights grant can be found
- * in the file PATENTS. All contributing project authors may
- * be found in the AUTHORS file in the root of the source tree.
- */
-
-#include
-
-#include "modules/video_coding/codecs/av1/libaom_av1_decoder.h"
-#include "modules/video_coding/codecs/av1/libaom_av1_encoder.h"
-#include "sdk/android/generated_libaom_av1_jni/LibaomAv1Decoder_jni.h"
-#include "sdk/android/generated_libaom_av1_jni/LibaomAv1Encoder_jni.h"
-#include "sdk/android/src/jni/jni_helpers.h"
-
-namespace webrtc {
-namespace jni {
-
-static jlong JNI_LibaomAv1Encoder_CreateEncoder(JNIEnv* jni) {
- return jlongFromPointer(webrtc::CreateLibaomAv1Encoder().release());
-}
-
-static jboolean JNI_LibaomAv1Encoder_IsSupported(JNIEnv* jni) {
- return webrtc::kIsLibaomAv1EncoderSupported;
-}
-
-static jlong JNI_LibaomAv1Decoder_CreateDecoder(JNIEnv* jni) {
- return jlongFromPointer(webrtc::CreateLibaomAv1Decoder().release());
-}
-
-static jboolean JNI_LibaomAv1Decoder_IsSupported(JNIEnv* jni) {
- return webrtc::kIsLibaomAv1DecoderSupported;
-}
-
-} // namespace jni
-} // namespace webrtc
diff --git a/sdk/android/src/jni/video_codec_info.cc b/sdk/android/src/jni/video_codec_info.cc
index 8c86b7c376..a218a1d23f 100644
--- a/sdk/android/src/jni/video_codec_info.cc
+++ b/sdk/android/src/jni/video_codec_info.cc
@@ -19,33 +19,18 @@ namespace jni {
SdpVideoFormat VideoCodecInfoToSdpVideoFormat(JNIEnv* jni,
const JavaRef& j_info) {
- std::string codecName =
- JavaToNativeString(jni, Java_VideoCodecInfo_getName(jni, j_info));
- std::string sdpCodecName;
- if (codecName == "AV1") {
- // TODO(yyaroshevich): Undo mapping once AV1 sdp name is standardized
- sdpCodecName = "AV1X";
- } else {
- sdpCodecName = codecName;
- }
return SdpVideoFormat(
- sdpCodecName,
+ JavaToNativeString(jni, Java_VideoCodecInfo_getName(jni, j_info)),
JavaToNativeStringMap(jni, Java_VideoCodecInfo_getParams(jni, j_info)));
}
ScopedJavaLocalRef SdpVideoFormatToVideoCodecInfo(
JNIEnv* jni,
const SdpVideoFormat& format) {
- std::string codecName;
- if (format.name == "AV1X" || format.name == "AV1") {
- codecName = "AV1";
- } else {
- codecName = format.name;
- }
ScopedJavaLocalRef j_params =
NativeToJavaStringMap(jni, format.parameters);
return Java_VideoCodecInfo_Constructor(
- jni, NativeToJavaString(jni, codecName), j_params);
+ jni, NativeToJavaString(jni, format.name), j_params);
}
} // namespace jni