Reland "Call native codec factories from Android ones."
This is a reland of commit 937a59268e2ae56a58f648fba827444f7beb4466 Check if codec requested in createEncoder/Decoder is supported and return null if not. Original change's description: > Call native codec factories from Android ones. > > Android video codec factories are expected to be synchronised with the native ones in terms on supported codecs. But before this change there were differences: > > 1. Native decoder factory keeps AV1 support behind RTC_DAV1D_IN_INTERNAL_DECODER_FACTORY while Android decoder factory advertises AV1 unconditionally; > > 2. Native encoder factory advertises AV1 if RTC_USE_LIBAOM_AV1_ENCODER is enabled while Android encoder factory never advertises AV1. > > This CL synchronises the codecs set in Android factories with that of native factories by calling native factories from Android ones. > > Bug: webrtc:13573, b/257272020 > Change-Id: I99d801eda0c5f3400bac222b9b08d719f1a6ed72 > Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/282240 > Reviewed-by: Rasmus Brandt <brandtr@webrtc.org> > Commit-Queue: Sergey Silkin <ssilkin@webrtc.org> > Reviewed-by: Xavier Lepaul <xalep@webrtc.org> > Cr-Commit-Position: refs/heads/main@{#38583} Bug: webrtc:13573, b/257272020 Change-Id: Ida7bb9a2954b836a07ad560de29c1f8088264b77 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/282802 Reviewed-by: Xavier Lepaul <xalep@webrtc.org> Commit-Queue: Sergey Silkin <ssilkin@webrtc.org> Cr-Commit-Position: refs/heads/main@{#38607}
This commit is contained in:
committed by
WebRTC LUCI CQ
parent
dd7dc25a30
commit
c97651cbb4
@ -885,9 +885,20 @@ if (current_os == "linux" || is_android) {
|
||||
rtc_library("swcodecs_jni") {
|
||||
visibility = [ "*" ]
|
||||
allow_poison = [ "software_video_codecs" ]
|
||||
sources = [
|
||||
"src/jni/software_video_decoder_factory.cc",
|
||||
"src/jni/software_video_encoder_factory.cc",
|
||||
]
|
||||
deps = [
|
||||
":base_jni",
|
||||
":generated_swcodecs_jni",
|
||||
":libvpx_vp8_jni",
|
||||
":libvpx_vp9_jni",
|
||||
":native_api_jni",
|
||||
":video_jni",
|
||||
"../../api/video_codecs:builtin_video_decoder_factory",
|
||||
"../../api/video_codecs:builtin_video_encoder_factory",
|
||||
"../../api/video_codecs:video_codecs_api",
|
||||
]
|
||||
}
|
||||
|
||||
@ -1353,6 +1364,16 @@ if (current_os == "linux" || is_android) {
|
||||
jni_generator_include = "//sdk/android/src/jni/jni_generator_helper.h"
|
||||
}
|
||||
|
||||
generate_jni("generated_swcodecs_jni") {
|
||||
sources = [
|
||||
"api/org/webrtc/SoftwareVideoDecoderFactory.java",
|
||||
"api/org/webrtc/SoftwareVideoEncoderFactory.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",
|
||||
@ -1471,6 +1492,8 @@ if (is_android) {
|
||||
"instrumentationtests/src/org/webrtc/RtcCertificatePemTest.java",
|
||||
"instrumentationtests/src/org/webrtc/RtpSenderTest.java",
|
||||
"instrumentationtests/src/org/webrtc/RtpTransceiverTest.java",
|
||||
"instrumentationtests/src/org/webrtc/SoftwareVideoDecoderFactoryTest.java",
|
||||
"instrumentationtests/src/org/webrtc/SoftwareVideoEncoderFactoryTest.java",
|
||||
"instrumentationtests/src/org/webrtc/SurfaceTextureHelperTest.java",
|
||||
"instrumentationtests/src/org/webrtc/SurfaceViewRendererOnMeasureTest.java",
|
||||
"instrumentationtests/src/org/webrtc/TestConstants.java",
|
||||
|
||||
Reference in New Issue
Block a user