MediaCodecVideoEncoder.smali
.class public Lorg/webrtc/ali/MediaCodecVideoEncoder;
.super Ljava/lang/Object;
.source "MediaCodecVideoEncoder.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lorg/webrtc/ali/MediaCodecVideoEncoder$OutputBufferInfo;,
Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;,
Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecVideoEncoderErrorCallback;,
Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;,
Lorg/webrtc/ali/MediaCodecVideoEncoder$H264Profile;,
Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;,
Lorg/webrtc/ali/MediaCodecVideoEncoder$VideoCodecType;
}
.end annotation
# static fields
.field private static final BITRATE_ADJUSTMENT_FPS:I = 0x1e
.field private static final BITRATE_CORRECTION_MAX_SCALE:D = 4.0
.field private static final BITRATE_CORRECTION_SEC:D = 3.0
.field private static final BITRATE_CORRECTION_STEPS:I = 0x14
.field private static final COLOR_QCOM_FORMATYUV420PackedSemiPlanar32m:I = 0x7fa30c04
.field private static final DEQUEUE_TIMEOUT:I = 0x0
.field private static final H264_HW_EXCEPTION_MODELS:[Ljava/lang/String;
.field private static final H264_MIME_TYPE:Ljava/lang/String; = "video/avc"
.field private static final MAXIMUM_INITIAL_FPS:I = 0x1e
.field private static final MEDIA_CODEC_RELEASE_TIMEOUT_MS:I = 0x1388
.field private static final QCOM_VP8_KEY_FRAME_INTERVAL_ANDROID_L_MS:J = 0x3a98L
.field private static final QCOM_VP8_KEY_FRAME_INTERVAL_ANDROID_M_MS:J = 0x4e20L
.field private static final QCOM_VP8_KEY_FRAME_INTERVAL_ANDROID_N_MS:J = 0x3a98L
.field private static final TAG:Ljava/lang/String; = "MediaCodecVideoEncoder"
.field private static final VIDEO_AVCLevel3:I = 0x100
.field private static final VIDEO_AVCProfileHigh:I = 0x8
.field private static final VIDEO_ControlRateConstant:I = 0x2
.field private static final VP8_MIME_TYPE:Ljava/lang/String; = "video/x-vnd.on2.vp8"
.field private static final VP9_MIME_TYPE:Ljava/lang/String; = "video/x-vnd.on2.vp9"
.field private static codecErrors:I
.field private static errorCallback:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecVideoEncoderErrorCallback;
.field private static final exynosH264HighProfileHwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.field private static final exynosH264HwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.field private static final exynosVp8HwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.field private static final exynosVp9HwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.field private static final h264HighProfileHwList:[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.field private static final h264HwList:[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.field private static hwEncoderDisabledTypes:Ljava/util/Set;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Set<",
"Ljava/lang/String;",
">;"
}
.end annotation
.end field
.field private static final intelVp8HwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.field private static final qcomH264HwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.field private static final qcomVp8HwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.field private static final qcomVp9HwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.field private static runningInstance:Lorg/webrtc/ali/MediaCodecVideoEncoder;
.field private static final supportedColorList:[I
.field private static final supportedSurfaceColorList:[I
.field private static final vp9HwList:[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
# instance fields
.field private bitrateAccumulator:D
.field private bitrateAccumulatorMax:D
.field private bitrateAdjustmentScaleExp:I
.field private bitrateAdjustmentType:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
.field private bitrateObservationTimeMs:D
.field private colorFormat:I
.field private configData:Ljava/nio/ByteBuffer;
.field private drawer:Lorg/webrtc/ali/GlRectDrawer;
.field private eglBase:Lorg/webrtc/ali/EglBase14;
.field private forcedKeyFrameMs:J
.field private height:I
.field private inputSurface:Landroid/view/Surface;
.field private lastKeyFrameMs:J
.field private mediaCodec:Landroid/media/MediaCodec;
.field private mediaCodecThread:Ljava/lang/Thread;
.field private outputBuffers:[Ljava/nio/ByteBuffer;
.field private profile:I
.field private targetBitrateBps:I
.field private targetFps:I
.field private type:Lorg/webrtc/ali/MediaCodecVideoEncoder$VideoCodecType;
.field private width:I
# direct methods
.method static constructor <clinit>()V
.registers 10
.line 63
const/4 v0, 0x0
sput-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->runningInstance:Lorg/webrtc/ali/MediaCodecVideoEncoder;
.line 64
sput-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->errorCallback:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecVideoEncoderErrorCallback;
.line 65
const/4 v0, 0x0
sput v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->codecErrors:I
.line 67
new-instance v1, Ljava/util/HashSet;
invoke-direct {v1}, Ljava/util/HashSet;-><init>()V
sput-object v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->hwEncoderDisabledTypes:Ljava/util/Set;
.line 137
new-instance v1, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
sget-object v2, Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;->NO_ADJUSTMENT:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
const/16 v3, 0x13
const-string v4, "OMX.qcom."
invoke-direct {v1, v4, v3, v2}, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;-><init>(Ljava/lang/String;ILorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;)V
sput-object v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->qcomVp8HwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.line 139
new-instance v1, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
sget-object v2, Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;->DYNAMIC_ADJUSTMENT:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
const/16 v5, 0x17
const-string v6, "OMX.Exynos."
invoke-direct {v1, v6, v5, v2}, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;-><init>(Ljava/lang/String;ILorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;)V
sput-object v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->exynosVp8HwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.line 141
new-instance v1, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
sget-object v2, Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;->NO_ADJUSTMENT:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
const/16 v7, 0x15
const-string v8, "OMX.Intel."
invoke-direct {v1, v8, v7, v2}, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;-><init>(Ljava/lang/String;ILorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;)V
sput-object v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->intelVp8HwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.line 154
new-instance v1, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
sget-object v2, Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;->NO_ADJUSTMENT:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
const/16 v8, 0x18
invoke-direct {v1, v4, v8, v2}, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;-><init>(Ljava/lang/String;ILorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;)V
sput-object v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->qcomVp9HwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.line 156
new-instance v1, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
sget-object v2, Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;->FRAMERATE_ADJUSTMENT:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
invoke-direct {v1, v6, v8, v2}, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;-><init>(Ljava/lang/String;ILorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;)V
sput-object v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->exynosVp9HwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.line 158
const/4 v2, 0x2
new-array v8, v2, [Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
sget-object v9, Lorg/webrtc/ali/MediaCodecVideoEncoder;->qcomVp9HwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
aput-object v9, v8, v0
const/4 v9, 0x1
aput-object v1, v8, v9
sput-object v8, Lorg/webrtc/ali/MediaCodecVideoEncoder;->vp9HwList:[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.line 162
new-instance v1, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
sget-object v8, Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;->NO_ADJUSTMENT:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
invoke-direct {v1, v4, v3, v8}, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;-><init>(Ljava/lang/String;ILorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;)V
sput-object v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->qcomH264HwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.line 164
new-instance v1, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
sget-object v3, Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;->FRAMERATE_ADJUSTMENT:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
invoke-direct {v1, v6, v7, v3}, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;-><init>(Ljava/lang/String;ILorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;)V
sput-object v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->exynosH264HwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.line 166
new-array v2, v2, [Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
sget-object v3, Lorg/webrtc/ali/MediaCodecVideoEncoder;->qcomH264HwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
aput-object v3, v2, v0
aput-object v1, v2, v9
sput-object v2, Lorg/webrtc/ali/MediaCodecVideoEncoder;->h264HwList:[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.line 170
new-instance v1, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
sget-object v2, Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;->FRAMERATE_ADJUSTMENT:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
invoke-direct {v1, v6, v5, v2}, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;-><init>(Ljava/lang/String;ILorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;)V
sput-object v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->exynosH264HighProfileHwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.line 173
new-array v2, v9, [Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
aput-object v1, v2, v0
sput-object v2, Lorg/webrtc/ali/MediaCodecVideoEncoder;->h264HighProfileHwList:[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.line 179
const-string v1, "SAMSUNG-SGH-I337"
const-string v2, "Nexus 7"
const-string v3, "Nexus 4"
filled-new-array {v1, v2, v3}, [Ljava/lang/String;
move-result-object v1
sput-object v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->H264_HW_EXCEPTION_MODELS:[Ljava/lang/String;
.line 189
const/4 v1, 0x4
new-array v1, v1, [I
fill-array-data v1, :array_a0
sput-object v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->supportedColorList:[I
.line 193
new-array v1, v9, [I
const v2, 0x7f000789
aput v2, v1, v0
sput-object v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->supportedSurfaceColorList:[I
return-void
nop
:array_a0
.array-data 4
0x13
0x15
0x7fa30c00
0x7fa30c04
.end array-data
.end method
.method public constructor <init>()V
.registers 2
.line 36
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 198
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;->NO_ADJUSTMENT:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
iput-object v0, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAdjustmentType:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
.line 212
const/4 v0, 0x0
iput-object v0, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->configData:Ljava/nio/ByteBuffer;
return-void
.end method
.method static synthetic access$000(Lorg/webrtc/ali/MediaCodecVideoEncoder;)Landroid/media/MediaCodec;
.registers 2
.param p0, "x0" # Lorg/webrtc/ali/MediaCodecVideoEncoder;
.line 36
iget-object v0, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodec:Landroid/media/MediaCodec;
return-object v0
.end method
.method private checkOnMediaCodecThread()V
.registers 6
.line 390
iget-object v0, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodecThread:Ljava/lang/Thread;
invoke-virtual {v0}, Ljava/lang/Thread;->getId()J
move-result-wide v0
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/Thread;->getId()J
move-result-wide v2
cmp-long v4, v0, v2
if-nez v4, :cond_13
.line 394
return-void
.line 391
:cond_13
new-instance v0, Ljava/lang/RuntimeException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "MediaCodecVideoEncoder previously operated on "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v2, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodecThread:Ljava/lang/Thread;
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string v2, " but is now called on "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 392
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method static createByCodecName(Ljava/lang/String;)Landroid/media/MediaCodec;
.registers 3
.param p0, "codecName" # Ljava/lang/String;
.line 412
:try_start_0
invoke-static {p0}, Landroid/media/MediaCodec;->createByCodecName(Ljava/lang/String;)Landroid/media/MediaCodec;
move-result-object v0
:try_end_4
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_4} :catch_5
return-object v0
.line 413
:catch_5
move-exception v0
.line 414
.local v0, "e":Ljava/lang/Exception;
const/4 v1, 0x0
return-object v1
.end method
.method public static disableH264HwCodec()V
.registers 2
.line 239
const-string v0, "MediaCodecVideoEncoder"
const-string v1, "H.264 encoding is disabled by application."
invoke-static {v0, v1}, Lorg/webrtc/ali/Logging;->w(Ljava/lang/String;Ljava/lang/String;)V
.line 240
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->hwEncoderDisabledTypes:Ljava/util/Set;
const-string v1, "video/avc"
invoke-interface {v0, v1}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
.line 241
return-void
.end method
.method public static disableVp8HwCodec()V
.registers 2
.line 229
const-string v0, "MediaCodecVideoEncoder"
const-string v1, "VP8 encoding is disabled by application."
invoke-static {v0, v1}, Lorg/webrtc/ali/Logging;->w(Ljava/lang/String;Ljava/lang/String;)V
.line 230
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->hwEncoderDisabledTypes:Ljava/util/Set;
const-string v1, "video/x-vnd.on2.vp8"
invoke-interface {v0, v1}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
.line 231
return-void
.end method
.method public static disableVp9HwCodec()V
.registers 2
.line 234
const-string v0, "MediaCodecVideoEncoder"
const-string v1, "VP9 encoding is disabled by application."
invoke-static {v0, v1}, Lorg/webrtc/ali/Logging;->w(Ljava/lang/String;Ljava/lang/String;)V
.line 235
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->hwEncoderDisabledTypes:Ljava/util/Set;
const-string v1, "video/x-vnd.on2.vp9"
invoke-interface {v0, v1}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
.line 236
return-void
.end method
.method private static findHwEncoder(Ljava/lang/String;[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;[I)Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
.registers 20
.param p0, "mime" # Ljava/lang/String;
.param p1, "supportedHwCodecProperties" # [Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.param p2, "colorList" # [I
.line 304
move-object/from16 v1, p0
move-object/from16 v2, p1
move-object/from16 v3, p2
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/4 v4, 0x0
const/16 v5, 0x13
if-ge v0, v5, :cond_e
.line 305
return-object v4
.line 309
:cond_e
const-string v0, "video/avc"
invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
const-string v5, "MediaCodecVideoEncoder"
if-eqz v0, :cond_42
.line 310
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->H264_HW_EXCEPTION_MODELS:[Ljava/lang/String;
invoke-static {v0}, Ljava/util/Arrays;->asList([Ljava/lang/Object;)Ljava/util/List;
move-result-object v0
.line 311
.local v0, "exceptionModels":Ljava/util/List;, "Ljava/util/List<Ljava/lang/String;>;"
sget-object v6, Landroid/os/Build;->MODEL:Ljava/lang/String;
invoke-interface {v0, v6}, Ljava/util/List;->contains(Ljava/lang/Object;)Z
move-result v6
if-eqz v6, :cond_42
.line 312
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
const-string v7, "Model: "
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v7, Landroid/os/Build;->MODEL:Ljava/lang/String;
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v7, " has black listed H.264 encoder."
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
invoke-static {v5, v6}, Lorg/webrtc/ali/Logging;->w(Ljava/lang/String;Ljava/lang/String;)V
.line 313
return-object v4
.line 317
.end local v0 # "exceptionModels":Ljava/util/List;, "Ljava/util/List<Ljava/lang/String;>;"
:cond_42
const/4 v0, 0x0
move v6, v0
.local v6, "i":I
:goto_44
invoke-static {}, Landroid/media/MediaCodecList;->getCodecCount()I
move-result v0
if-ge v6, v0, :cond_187
.line 318
const/4 v7, 0x0
.line 320
.local v7, "info":Landroid/media/MediaCodecInfo;
:try_start_4b
invoke-static {v6}, Landroid/media/MediaCodecList;->getCodecInfoAt(I)Landroid/media/MediaCodecInfo;
move-result-object v0
:try_end_4f
.catch Ljava/lang/IllegalArgumentException; {:try_start_4b .. :try_end_4f} :catch_51
move-object v7, v0
.line 323
goto :goto_59
.line 321
:catch_51
move-exception v0
move-object v8, v0
move-object v0, v8
.line 322
.local v0, "e":Ljava/lang/IllegalArgumentException;
const-string v8, "Cannot retrieve encoder codec info"
invoke-static {v5, v8, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 324
.end local v0 # "e":Ljava/lang/IllegalArgumentException;
:goto_59
if-eqz v7, :cond_182
invoke-virtual {v7}, Landroid/media/MediaCodecInfo;->isEncoder()Z
move-result v0
if-nez v0, :cond_63
.line 325
goto/16 :goto_182
.line 327
:cond_63
const/4 v0, 0x0
.line 328
.local v0, "name":Ljava/lang/String;
invoke-virtual {v7}, Landroid/media/MediaCodecInfo;->getSupportedTypes()[Ljava/lang/String;
move-result-object v8
array-length v9, v8
const/4 v11, 0x0
:goto_6a
if-ge v11, v9, :cond_7d
aget-object v12, v8, v11
.line 329
.local v12, "mimeType":Ljava/lang/String;
invoke-virtual {v12, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v13
if-eqz v13, :cond_7a
.line 330
invoke-virtual {v7}, Landroid/media/MediaCodecInfo;->getName()Ljava/lang/String;
move-result-object v0
.line 331
move-object v8, v0
goto :goto_7e
.line 328
.end local v12 # "mimeType":Ljava/lang/String;
:cond_7a
add-int/lit8 v11, v11, 0x1
goto :goto_6a
:cond_7d
move-object v8, v0
.line 334
.end local v0 # "name":Ljava/lang/String;
.local v8, "name":Ljava/lang/String;
:goto_7e
if-nez v8, :cond_82
.line 335
goto/16 :goto_182
.line 337
:cond_82
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v9, "Found candidate encoder "
invoke-virtual {v0, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v5, v0}, Lorg/webrtc/ali/Logging;->v(Ljava/lang/String;Ljava/lang/String;)V
.line 340
const/4 v0, 0x0
.line 341
.local v0, "supportedCodec":Z
sget-object v9, Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;->NO_ADJUSTMENT:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
.line 342
.local v9, "bitrateAdjustmentType":Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
array-length v11, v2
const/4 v12, 0x0
:goto_9b
if-ge v12, v11, :cond_f5
aget-object v13, v2, v12
.line 343
.local v13, "codecProperties":Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
iget-object v14, v13, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;->codecPrefix:Ljava/lang/String;
invoke-virtual {v8, v14}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v14
if-eqz v14, :cond_f2
.line 344
sget v14, Landroid/os/Build$VERSION;->SDK_INT:I
iget v15, v13, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;->minSdk:I
const-string v10, "Codec "
if-ge v14, v15, :cond_cc
.line 345
new-instance v14, Ljava/lang/StringBuilder;
invoke-direct {v14}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v14, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v14, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v10, " is disabled due to SDK version "
invoke-virtual {v14, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget v10, Landroid/os/Build$VERSION;->SDK_INT:I
invoke-virtual {v14, v10}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v14}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v10
invoke-static {v5, v10}, Lorg/webrtc/ali/Logging;->w(Ljava/lang/String;Ljava/lang/String;)V
.line 347
goto :goto_f2
.line 349
:cond_cc
iget-object v11, v13, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;->bitrateAdjustmentType:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
sget-object v12, Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;->NO_ADJUSTMENT:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
if-eq v11, v12, :cond_ee
.line 350
iget-object v9, v13, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;->bitrateAdjustmentType:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
.line 351
new-instance v11, Ljava/lang/StringBuilder;
invoke-direct {v11}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v11, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v11, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v10, " requires bitrate adjustment: "
invoke-virtual {v11, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v11, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v11}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v10
invoke-static {v5, v10}, Lorg/webrtc/ali/Logging;->w(Ljava/lang/String;Ljava/lang/String;)V
.line 354
:cond_ee
const/4 v0, 0x1
.line 355
move-object v10, v9
move v9, v0
goto :goto_f7
.line 342
.end local v13 # "codecProperties":Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
:cond_f2
:goto_f2
add-int/lit8 v12, v12, 0x1
goto :goto_9b
:cond_f5
move-object v10, v9
move v9, v0
.line 358
.end local v0 # "supportedCodec":Z
.local v9, "supportedCodec":Z
.local v10, "bitrateAdjustmentType":Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
:goto_f7
if-nez v9, :cond_fb
.line 359
goto/16 :goto_182
.line 365
:cond_fb
:try_start_fb
invoke-virtual {v7, v1}, Landroid/media/MediaCodecInfo;->getCapabilitiesForType(Ljava/lang/String;)Landroid/media/MediaCodecInfo$CodecCapabilities;
move-result-object v0
:try_end_ff
.catch Ljava/lang/IllegalArgumentException; {:try_start_fb .. :try_end_ff} :catch_179
.line 369
.local v0, "capabilities":Landroid/media/MediaCodecInfo$CodecCapabilities;
nop
.line 370
iget-object v11, v0, Landroid/media/MediaCodecInfo$CodecCapabilities;->colorFormats:[I
array-length v12, v11
const/4 v13, 0x0
:goto_104
if-ge v13, v12, :cond_124
aget v14, v11, v13
.line 371
.local v14, "colorFormat":I
new-instance v15, Ljava/lang/StringBuilder;
invoke-direct {v15}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, " Color: 0x"
invoke-virtual {v15, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-static {v14}, Ljava/lang/Integer;->toHexString(I)Ljava/lang/String;
move-result-object v4
invoke-virtual {v15, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v15}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-static {v5, v4}, Lorg/webrtc/ali/Logging;->v(Ljava/lang/String;Ljava/lang/String;)V
.line 370
.end local v14 # "colorFormat":I
add-int/lit8 v13, v13, 0x1
const/4 v4, 0x0
goto :goto_104
.line 374
:cond_124
array-length v4, v3
const/4 v11, 0x0
:goto_126
if-ge v11, v4, :cond_176
aget v12, v3, v11
.line 375
.local v12, "supportedColorFormat":I
iget-object v13, v0, Landroid/media/MediaCodecInfo$CodecCapabilities;->colorFormats:[I
array-length v14, v13
const/4 v15, 0x0
:goto_12e
if-ge v15, v14, :cond_171
move-object/from16 v16, v0
.end local v0 # "capabilities":Landroid/media/MediaCodecInfo$CodecCapabilities;
.local v16, "capabilities":Landroid/media/MediaCodecInfo$CodecCapabilities;
aget v0, v13, v15
.line 376
.local v0, "codecColorFormat":I
if-ne v0, v12, :cond_16c
.line 378
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v11, "Found target encoder for mime "
invoke-virtual {v4, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v11, " : "
invoke-virtual {v4, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v11, ". Color: 0x"
invoke-virtual {v4, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 379
invoke-static {v0}, Ljava/lang/Integer;->toHexString(I)Ljava/lang/String;
move-result-object v11
invoke-virtual {v4, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v11, ". Bitrate adjustment: "
invoke-virtual {v4, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
.line 378
invoke-static {v5, v4}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 381
new-instance v4, Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
invoke-direct {v4, v8, v0, v10}, Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;-><init>(Ljava/lang/String;ILorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;)V
return-object v4
.line 375
.end local v0 # "codecColorFormat":I
:cond_16c
add-int/lit8 v15, v15, 0x1
move-object/from16 v0, v16
goto :goto_12e
.end local v16 # "capabilities":Landroid/media/MediaCodecInfo$CodecCapabilities;
.local v0, "capabilities":Landroid/media/MediaCodecInfo$CodecCapabilities;
:cond_171
move-object/from16 v16, v0
.line 374
.end local v0 # "capabilities":Landroid/media/MediaCodecInfo$CodecCapabilities;
.end local v12 # "supportedColorFormat":I
.restart local v16 # "capabilities":Landroid/media/MediaCodecInfo$CodecCapabilities;
add-int/lit8 v11, v11, 0x1
goto :goto_126
.end local v16 # "capabilities":Landroid/media/MediaCodecInfo$CodecCapabilities;
.restart local v0 # "capabilities":Landroid/media/MediaCodecInfo$CodecCapabilities;
:cond_176
move-object/from16 v16, v0
.end local v0 # "capabilities":Landroid/media/MediaCodecInfo$CodecCapabilities;
.restart local v16 # "capabilities":Landroid/media/MediaCodecInfo$CodecCapabilities;
goto :goto_182
.line 366
.end local v16 # "capabilities":Landroid/media/MediaCodecInfo$CodecCapabilities;
:catch_179
move-exception v0
move-object v4, v0
move-object v0, v4
.line 367
.local v0, "e":Ljava/lang/IllegalArgumentException;
const-string v4, "Cannot retrieve encoder capabilities"
invoke-static {v5, v4, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 368
nop
.line 317
.end local v0 # "e":Ljava/lang/IllegalArgumentException;
.end local v7 # "info":Landroid/media/MediaCodecInfo;
.end local v8 # "name":Ljava/lang/String;
.end local v9 # "supportedCodec":Z
.end local v10 # "bitrateAdjustmentType":Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
:cond_182
:goto_182
add-int/lit8 v6, v6, 0x1
const/4 v4, 0x0
goto/16 :goto_44
.line 386
.end local v6 # "i":I
:cond_187
const/4 v4, 0x0
return-object v4
.end method
.method private getBitrateScale(I)D
.registers 6
.param p1, "bitrateAdjustmentScaleExp" # I
.line 822
int-to-double v0, p1
const-wide/high16 v2, 0x4034000000000000L # 20.0
invoke-static {v0, v1}, Ljava/lang/Double;->isNaN(D)Z
div-double/2addr v0, v2
const-wide/high16 v2, 0x4010000000000000L # 4.0
invoke-static {v2, v3, v0, v1}, Ljava/lang/Math;->pow(DD)D
move-result-wide v0
return-wide v0
.end method
.method public static isH264HighProfileHwSupported()Z
.registers 3
.line 268
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->hwEncoderDisabledTypes:Ljava/util/Set;
const-string v1, "video/avc"
invoke-interface {v0, v1}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_16
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->h264HighProfileHwList:[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
sget-object v2, Lorg/webrtc/ali/MediaCodecVideoEncoder;->supportedColorList:[I
.line 269
invoke-static {v1, v0, v2}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->findHwEncoder(Ljava/lang/String;[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;[I)Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
move-result-object v0
if-eqz v0, :cond_16
const/4 v0, 0x1
goto :goto_17
:cond_16
const/4 v0, 0x0
.line 268
:goto_17
return v0
.end method
.method public static isH264HwSupported()Z
.registers 3
.line 263
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->hwEncoderDisabledTypes:Ljava/util/Set;
const-string v1, "video/avc"
invoke-interface {v0, v1}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_16
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->h264HwList:[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
sget-object v2, Lorg/webrtc/ali/MediaCodecVideoEncoder;->supportedColorList:[I
.line 264
invoke-static {v1, v0, v2}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->findHwEncoder(Ljava/lang/String;[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;[I)Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
move-result-object v0
if-eqz v0, :cond_16
const/4 v0, 0x1
goto :goto_17
:cond_16
const/4 v0, 0x0
.line 263
:goto_17
return v0
.end method
.method public static isH264HwSupportedUsingTextures()Z
.registers 3
.line 283
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->hwEncoderDisabledTypes:Ljava/util/Set;
const-string v1, "video/avc"
invoke-interface {v0, v1}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_16
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->h264HwList:[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
sget-object v2, Lorg/webrtc/ali/MediaCodecVideoEncoder;->supportedSurfaceColorList:[I
.line 284
invoke-static {v1, v0, v2}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->findHwEncoder(Ljava/lang/String;[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;[I)Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
move-result-object v0
if-eqz v0, :cond_16
const/4 v0, 0x1
goto :goto_17
:cond_16
const/4 v0, 0x0
.line 283
:goto_17
return v0
.end method
.method public static isVp8HwSupported()Z
.registers 3
.line 245
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->hwEncoderDisabledTypes:Ljava/util/Set;
const-string v1, "video/x-vnd.on2.vp8"
invoke-interface {v0, v1}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_18
.line 246
invoke-static {}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->vp8HwList()[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
move-result-object v0
sget-object v2, Lorg/webrtc/ali/MediaCodecVideoEncoder;->supportedColorList:[I
invoke-static {v1, v0, v2}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->findHwEncoder(Ljava/lang/String;[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;[I)Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
move-result-object v0
if-eqz v0, :cond_18
const/4 v0, 0x1
goto :goto_19
:cond_18
const/4 v0, 0x0
.line 245
:goto_19
return v0
.end method
.method public static isVp8HwSupportedUsingTextures()Z
.registers 3
.line 273
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->hwEncoderDisabledTypes:Ljava/util/Set;
const-string v1, "video/x-vnd.on2.vp8"
invoke-interface {v0, v1}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_18
.line 274
invoke-static {}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->vp8HwList()[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
move-result-object v0
sget-object v2, Lorg/webrtc/ali/MediaCodecVideoEncoder;->supportedSurfaceColorList:[I
invoke-static {v1, v0, v2}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->findHwEncoder(Ljava/lang/String;[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;[I)Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
move-result-object v0
if-eqz v0, :cond_18
const/4 v0, 0x1
goto :goto_19
:cond_18
const/4 v0, 0x0
.line 273
:goto_19
return v0
.end method
.method public static isVp9HwSupported()Z
.registers 3
.line 258
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->hwEncoderDisabledTypes:Ljava/util/Set;
const-string v1, "video/x-vnd.on2.vp9"
invoke-interface {v0, v1}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_16
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->vp9HwList:[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
sget-object v2, Lorg/webrtc/ali/MediaCodecVideoEncoder;->supportedColorList:[I
.line 259
invoke-static {v1, v0, v2}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->findHwEncoder(Ljava/lang/String;[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;[I)Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
move-result-object v0
if-eqz v0, :cond_16
const/4 v0, 0x1
goto :goto_17
:cond_16
const/4 v0, 0x0
.line 258
:goto_17
return v0
.end method
.method public static isVp9HwSupportedUsingTextures()Z
.registers 3
.line 278
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->hwEncoderDisabledTypes:Ljava/util/Set;
const-string v1, "video/x-vnd.on2.vp9"
invoke-interface {v0, v1}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_16
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->vp9HwList:[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
sget-object v2, Lorg/webrtc/ali/MediaCodecVideoEncoder;->supportedSurfaceColorList:[I
.line 279
invoke-static {v1, v0, v2}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->findHwEncoder(Ljava/lang/String;[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;[I)Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
move-result-object v0
if-eqz v0, :cond_16
const/4 v0, 0x1
goto :goto_17
:cond_16
const/4 v0, 0x0
.line 278
:goto_17
return v0
.end method
.method public static printStackTrace()V
.registers 6
.line 397
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->runningInstance:Lorg/webrtc/ali/MediaCodecVideoEncoder;
if-eqz v0, :cond_26
iget-object v0, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodecThread:Ljava/lang/Thread;
if-eqz v0, :cond_26
.line 398
invoke-virtual {v0}, Ljava/lang/Thread;->getStackTrace()[Ljava/lang/StackTraceElement;
move-result-object v0
.line 399
.local v0, "mediaCodecStackTraces":[Ljava/lang/StackTraceElement;
array-length v1, v0
if-lez v1, :cond_26
.line 400
const-string v1, "MediaCodecVideoEncoder"
const-string v2, "MediaCodecVideoEncoder stacks trace:"
invoke-static {v1, v2}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 401
array-length v2, v0
const/4 v3, 0x0
:goto_18
if-ge v3, v2, :cond_26
aget-object v4, v0, v3
.line 402
.local v4, "stackTrace":Ljava/lang/StackTraceElement;
invoke-virtual {v4}, Ljava/lang/StackTraceElement;->toString()Ljava/lang/String;
move-result-object v5
invoke-static {v1, v5}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 401
.end local v4 # "stackTrace":Ljava/lang/StackTraceElement;
add-int/lit8 v3, v3, 0x1
goto :goto_18
.line 406
.end local v0 # "mediaCodecStackTraces":[Ljava/lang/StackTraceElement;
:cond_26
return-void
.end method
.method private reportEncodedFrame(I)V
.registers 17
.param p1, "size" # I
.line 827
move-object v0, p0
iget v1, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->targetFps:I
if-eqz v1, :cond_fa
iget-object v1, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAdjustmentType:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
sget-object v2, Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;->DYNAMIC_ADJUSTMENT:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
if-eq v1, v2, :cond_f
move/from16 v6, p1
goto/16 :goto_fc
.line 832
:cond_f
iget v1, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->targetBitrateBps:I
int-to-double v1, v1
const-wide/high16 v3, 0x4020000000000000L # 8.0
iget v5, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->targetFps:I
int-to-double v6, v5
invoke-static {v6, v7}, Ljava/lang/Double;->isNaN(D)Z
mul-double v6, v6, v3
invoke-static {v1, v2}, Ljava/lang/Double;->isNaN(D)Z
div-double/2addr v1, v6
.line 833
.local v1, "expectedBytesPerFrame":D
iget-wide v3, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAccumulator:D
move/from16 v6, p1
int-to-double v7, v6
invoke-static {v7, v8}, Ljava/lang/Double;->isNaN(D)Z
sub-double/2addr v7, v1
add-double/2addr v3, v7
iput-wide v3, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAccumulator:D
.line 834
iget-wide v7, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateObservationTimeMs:D
const-wide v9, 0x408f400000000000L # 1000.0
int-to-double v11, v5
invoke-static {v11, v12}, Ljava/lang/Double;->isNaN(D)Z
div-double/2addr v9, v11
add-double/2addr v7, v9
iput-wide v7, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateObservationTimeMs:D
.line 838
const-wide/high16 v7, 0x4008000000000000L # 3.0
iget-wide v9, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAccumulatorMax:D
mul-double v9, v9, v7
.line 839
.local v9, "bitrateAccumulatorCap":D
invoke-static {v3, v4, v9, v10}, Ljava/lang/Math;->min(DD)D
move-result-wide v3
iput-wide v3, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAccumulator:D
.line 840
neg-double v7, v9
invoke-static {v3, v4, v7, v8}, Ljava/lang/Math;->max(DD)D
move-result-wide v3
iput-wide v3, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAccumulator:D
.line 844
iget-wide v3, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateObservationTimeMs:D
const-wide v7, 0x40a7700000000000L # 3000.0
cmpl-double v5, v3, v7
if-lez v5, :cond_f9
.line 845
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "Acc: "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-wide v4, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAccumulator:D
double-to-int v4, v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v4, ". Max: "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-wide v4, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAccumulatorMax:D
double-to-int v4, v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v4, ". ExpScale: "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v4, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAdjustmentScaleExp:I
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
const-string v4, "MediaCodecVideoEncoder"
invoke-static {v4, v3}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 847
const/4 v3, 0x0
.line 848
.local v3, "bitrateAdjustmentScaleChanged":Z
iget-wide v7, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAccumulator:D
iget-wide v11, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAccumulatorMax:D
const-wide/high16 v13, 0x3fe0000000000000L # 0.5
cmpl-double v5, v7, v11
if-lez v5, :cond_9e
.line 850
div-double/2addr v7, v11
add-double/2addr v7, v13
double-to-int v5, v7
.line 851
.local v5, "bitrateAdjustmentInc":I
iget v7, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAdjustmentScaleExp:I
sub-int/2addr v7, v5
iput v7, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAdjustmentScaleExp:I
.line 852
iput-wide v11, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAccumulator:D
.line 853
const/4 v3, 0x1
.end local v5 # "bitrateAdjustmentInc":I
goto :goto_b3
.line 854
:cond_9e
neg-double v13, v11
cmpg-double v5, v7, v13
if-gez v5, :cond_b3
.line 856
neg-double v7, v7
div-double/2addr v7, v11
const-wide/high16 v13, 0x3fe0000000000000L # 0.5
add-double/2addr v7, v13
double-to-int v5, v7
.line 857
.restart local v5 # "bitrateAdjustmentInc":I
iget v7, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAdjustmentScaleExp:I
add-int/2addr v7, v5
iput v7, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAdjustmentScaleExp:I
.line 858
neg-double v7, v11
iput-wide v7, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAccumulator:D
.line 859
const/4 v3, 0x1
goto :goto_b4
.line 854
.end local v5 # "bitrateAdjustmentInc":I
:cond_b3
:goto_b3
nop
.line 861
:goto_b4
if-eqz v3, :cond_f5
.line 862
iget v5, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAdjustmentScaleExp:I
const/16 v7, 0x14
invoke-static {v5, v7}, Ljava/lang/Math;->min(II)I
move-result v5
iput v5, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAdjustmentScaleExp:I
.line 863
const/16 v7, -0x14
invoke-static {v5, v7}, Ljava/lang/Math;->max(II)I
move-result v5
iput v5, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAdjustmentScaleExp:I
.line 864
new-instance v5, Ljava/lang/StringBuilder;
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
const-string v7, "Adjusting bitrate scale to "
invoke-virtual {v5, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v7, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAdjustmentScaleExp:I
invoke-virtual {v5, v7}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v7, ". Value: "
invoke-virtual {v5, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v7, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAdjustmentScaleExp:I
.line 865
invoke-direct {p0, v7}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->getBitrateScale(I)D
move-result-wide v7
invoke-virtual {v5, v7, v8}, Ljava/lang/StringBuilder;->append(D)Ljava/lang/StringBuilder;
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
.line 864
invoke-static {v4, v5}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 866
iget v4, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->targetBitrateBps:I
div-int/lit16 v4, v4, 0x3e8
iget v5, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->targetFps:I
invoke-direct {p0, v4, v5}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->setRates(II)Z
.line 868
:cond_f5
const-wide/16 v4, 0x0
iput-wide v4, v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateObservationTimeMs:D
.line 870
.end local v3 # "bitrateAdjustmentScaleChanged":Z
:cond_f9
return-void
.line 827
.end local v1 # "expectedBytesPerFrame":D
.end local v9 # "bitrateAccumulatorCap":D
:cond_fa
move/from16 v6, p1
.line 828
:goto_fc
return-void
.end method
.method public static setErrorCallback(Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecVideoEncoderErrorCallback;)V
.registers 3
.param p0, "errorCallback" # Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecVideoEncoderErrorCallback;
.line 222
const-string v0, "MediaCodecVideoEncoder"
const-string v1, "Set error callback"
invoke-static {v0, v1}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 223
sput-object p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->errorCallback:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecVideoEncoderErrorCallback;
.line 224
return-void
.end method
.method private setRates(II)Z
.registers 11
.param p1, "kbps" # I
.param p2, "frameRate" # I
.line 683
invoke-direct {p0}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->checkOnMediaCodecThread()V
.line 685
mul-int/lit16 v0, p1, 0x3e8
.line 686
.local v0, "codecBitrateBps":I
iget-object v1, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAdjustmentType:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
sget-object v2, Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;->DYNAMIC_ADJUSTMENT:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
if-ne v1, v2, :cond_29
.line 687
int-to-double v1, v0
const-wide/high16 v3, 0x4020000000000000L # 8.0
invoke-static {v1, v2}, Ljava/lang/Double;->isNaN(D)Z
div-double/2addr v1, v3
iput-wide v1, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAccumulatorMax:D
.line 688
iget v1, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->targetBitrateBps:I
if-lez v1, :cond_29
if-ge v0, v1, :cond_29
.line 690
iget-wide v2, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAccumulator:D
int-to-double v4, v0
invoke-static {v4, v5}, Ljava/lang/Double;->isNaN(D)Z
mul-double v2, v2, v4
int-to-double v4, v1
invoke-static {v4, v5}, Ljava/lang/Double;->isNaN(D)Z
div-double/2addr v2, v4
iput-wide v2, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAccumulator:D
.line 693
:cond_29
iput v0, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->targetBitrateBps:I
.line 694
iput p2, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->targetFps:I
.line 697
iget-object v1, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAdjustmentType:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
sget-object v2, Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;->FRAMERATE_ADJUSTMENT:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
const-string v3, " kbps. Fps: "
const-string v4, "setRates: "
const-string v5, "MediaCodecVideoEncoder"
if-ne v1, v2, :cond_68
iget v1, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->targetFps:I
if-lez v1, :cond_68
.line 698
iget v2, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->targetBitrateBps:I
mul-int/lit8 v2, v2, 0x1e
div-int v0, v2, v1
.line 699
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v2, " -> "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
div-int/lit16 v2, v0, 0x3e8
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v2, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->targetFps:I
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v5, v1}, Lorg/webrtc/ali/Logging;->v(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_bc
.line 701
:cond_68
iget-object v1, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAdjustmentType:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
sget-object v2, Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;->DYNAMIC_ADJUSTMENT:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
if-ne v1, v2, :cond_a2
.line 702
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v2, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->targetFps:I
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v2, ". ExpScale: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v2, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAdjustmentScaleExp:I
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v5, v1}, Lorg/webrtc/ali/Logging;->v(Ljava/lang/String;Ljava/lang/String;)V
.line 704
iget v1, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAdjustmentScaleExp:I
if-eqz v1, :cond_bc
.line 705
int-to-double v2, v0
invoke-direct {p0, v1}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->getBitrateScale(I)D
move-result-wide v6
invoke-static {v2, v3}, Ljava/lang/Double;->isNaN(D)Z
mul-double v2, v2, v6
double-to-int v0, v2
goto :goto_bc
.line 708
:cond_a2
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v2, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->targetFps:I
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v5, v1}, Lorg/webrtc/ali/Logging;->v(Ljava/lang/String;Ljava/lang/String;)V
.line 712
:cond_bc
:goto_bc
:try_start_bc
new-instance v1, Landroid/os/Bundle;
invoke-direct {v1}, Landroid/os/Bundle;-><init>()V
.line 713
.local v1, "params":Landroid/os/Bundle;
const-string v2, "video-bitrate"
invoke-virtual {v1, v2, v0}, Landroid/os/Bundle;->putInt(Ljava/lang/String;I)V
.line 714
iget-object v2, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodec:Landroid/media/MediaCodec;
invoke-virtual {v2, v1}, Landroid/media/MediaCodec;->setParameters(Landroid/os/Bundle;)V
:try_end_cb
.catch Ljava/lang/IllegalStateException; {:try_start_bc .. :try_end_cb} :catch_cd
.line 715
const/4 v2, 0x1
return v2
.line 716
.end local v1 # "params":Landroid/os/Bundle;
:catch_cd
move-exception v1
.line 717
.local v1, "e":Ljava/lang/IllegalStateException;
const-string v2, "setRates failed"
invoke-static {v5, v2, v1}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 718
const/4 v2, 0x0
return v2
.end method
.method public static vp8HwEncoderProperties()Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
.registers 3
.line 250
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->hwEncoderDisabledTypes:Ljava/util/Set;
const-string v1, "video/x-vnd.on2.vp8"
invoke-interface {v0, v1}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_c
.line 251
const/4 v0, 0x0
return-object v0
.line 253
:cond_c
invoke-static {}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->vp8HwList()[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
move-result-object v0
sget-object v2, Lorg/webrtc/ali/MediaCodecVideoEncoder;->supportedColorList:[I
invoke-static {v1, v0, v2}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->findHwEncoder(Ljava/lang/String;[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;[I)Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
move-result-object v0
return-object v0
.end method
.method private static vp8HwList()[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
.registers 3
.line 144
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
.line 145
.local v0, "supported_codecs":Ljava/util/ArrayList;, "Ljava/util/ArrayList<Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;>;"
sget-object v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->qcomVp8HwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
invoke-virtual {v0, v1}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
.line 146
sget-object v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->exynosVp8HwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
invoke-virtual {v0, v1}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
.line 147
const-string v1, "WebRTC-IntelVP8"
invoke-static {v1}, Lorg/webrtc/ali/PeerConnectionFactory;->fieldTrialsFindFullName(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
const-string v2, "Enabled"
invoke-virtual {v1, v2}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v1
if-eqz v1, :cond_22
.line 148
sget-object v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->intelVp8HwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
invoke-virtual {v0, v1}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
.line 150
:cond_22
invoke-virtual {v0}, Ljava/util/ArrayList;->size()I
move-result v1
new-array v1, v1, [Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
invoke-virtual {v0, v1}, Ljava/util/ArrayList;->toArray([Ljava/lang/Object;)[Ljava/lang/Object;
move-result-object v1
check-cast v1, [Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
return-object v1
.end method
# virtual methods
.method checkKeyFrameRequired(ZJ)V
.registers 12
.param p1, "requestedKeyFrame" # Z
.param p2, "presentationTimestampUs" # J
.line 544
const-wide/16 v0, 0x1f4
add-long/2addr v0, p2
const-wide/16 v2, 0x3e8
div-long/2addr v0, v2
.line 545
.local v0, "presentationTimestampMs":J
iget-wide v2, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->lastKeyFrameMs:J
const-wide/16 v4, 0x0
cmp-long v6, v2, v4
if-gez v6, :cond_10
.line 546
iput-wide v0, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->lastKeyFrameMs:J
.line 548
:cond_10
const/4 v2, 0x0
.line 549
.local v2, "forcedKeyFrame":Z
if-nez p1, :cond_21
iget-wide v6, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->forcedKeyFrameMs:J
cmp-long v3, v6, v4
if-lez v3, :cond_21
iget-wide v3, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->lastKeyFrameMs:J
add-long/2addr v3, v6
cmp-long v5, v0, v3
if-lez v5, :cond_21
.line 551
const/4 v2, 0x1
.line 553
:cond_21
if-nez p1, :cond_25
if-eqz v2, :cond_46
.line 558
:cond_25
const-string v3, "MediaCodecVideoEncoder"
if-eqz p1, :cond_2f
.line 559
const-string v4, "Sync frame request"
invoke-static {v3, v4}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_34
.line 561
:cond_2f
const-string v4, "Sync frame forced"
invoke-static {v3, v4}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 563
:goto_34
new-instance v3, Landroid/os/Bundle;
invoke-direct {v3}, Landroid/os/Bundle;-><init>()V
.line 564
.local v3, "b":Landroid/os/Bundle;
const/4 v4, 0x0
const-string v5, "request-sync"
invoke-virtual {v3, v5, v4}, Landroid/os/Bundle;->putInt(Ljava/lang/String;I)V
.line 565
iget-object v4, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodec:Landroid/media/MediaCodec;
invoke-virtual {v4, v3}, Landroid/media/MediaCodec;->setParameters(Landroid/os/Bundle;)V
.line 566
iput-wide v0, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->lastKeyFrameMs:J
.line 568
.end local v3 # "b":Landroid/os/Bundle;
:cond_46
return-void
.end method
.method dequeueInputBuffer()I
.registers 4
.line 725
invoke-direct {p0}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->checkOnMediaCodecThread()V
.line 727
:try_start_3
iget-object v0, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodec:Landroid/media/MediaCodec;
const-wide/16 v1, 0x0
invoke-virtual {v0, v1, v2}, Landroid/media/MediaCodec;->dequeueInputBuffer(J)I
move-result v0
:try_end_b
.catch Ljava/lang/IllegalStateException; {:try_start_3 .. :try_end_b} :catch_c
return v0
.line 728
:catch_c
move-exception v0
.line 729
.local v0, "e":Ljava/lang/IllegalStateException;
const-string v1, "MediaCodecVideoEncoder"
const-string v2, "dequeueIntputBuffer failed"
invoke-static {v1, v2, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 730
const/4 v1, -0x2
return v1
.end method
.method dequeueOutputBuffer()Lorg/webrtc/ali/MediaCodecVideoEncoder$OutputBufferInfo;
.registers 14
.line 753
const-string v0, "MediaCodecVideoEncoder"
invoke-direct {p0}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->checkOnMediaCodecThread()V
.line 755
:try_start_5
new-instance v1, Landroid/media/MediaCodec$BufferInfo;
invoke-direct {v1}, Landroid/media/MediaCodec$BufferInfo;-><init>()V
.line 756
.local v1, "info":Landroid/media/MediaCodec$BufferInfo;
iget-object v2, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodec:Landroid/media/MediaCodec;
const-wide/16 v3, 0x0
invoke-virtual {v2, v1, v3, v4}, Landroid/media/MediaCodec;->dequeueOutputBuffer(Landroid/media/MediaCodec$BufferInfo;J)I
move-result v2
.line 758
.local v2, "result":I
const/4 v5, 0x1
const/4 v6, 0x0
if-ltz v2, :cond_a9
.line 759
iget v7, v1, Landroid/media/MediaCodec$BufferInfo;->flags:I
and-int/lit8 v7, v7, 0x2
if-eqz v7, :cond_1e
const/4 v7, 0x1
goto :goto_1f
:cond_1e
const/4 v7, 0x0
.line 760
.local v7, "isConfigFrame":Z
:goto_1f
if-eqz v7, :cond_a9
.line 761
new-instance v8, Ljava/lang/StringBuilder;
invoke-direct {v8}, Ljava/lang/StringBuilder;-><init>()V
const-string v9, "Config frame generated. Offset: "
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v9, v1, Landroid/media/MediaCodec$BufferInfo;->offset:I
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v9, ". Size: "
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v9, v1, Landroid/media/MediaCodec$BufferInfo;->size:I
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v8
invoke-static {v0, v8}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 762
iget v8, v1, Landroid/media/MediaCodec$BufferInfo;->size:I
invoke-static {v8}, Ljava/nio/ByteBuffer;->allocateDirect(I)Ljava/nio/ByteBuffer;
move-result-object v8
iput-object v8, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->configData:Ljava/nio/ByteBuffer;
.line 763
iget-object v8, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->outputBuffers:[Ljava/nio/ByteBuffer;
aget-object v8, v8, v2
iget v9, v1, Landroid/media/MediaCodec$BufferInfo;->offset:I
invoke-virtual {v8, v9}, Ljava/nio/ByteBuffer;->position(I)Ljava/nio/Buffer;
.line 764
iget-object v8, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->outputBuffers:[Ljava/nio/ByteBuffer;
aget-object v8, v8, v2
iget v9, v1, Landroid/media/MediaCodec$BufferInfo;->offset:I
iget v10, v1, Landroid/media/MediaCodec$BufferInfo;->size:I
add-int/2addr v9, v10
invoke-virtual {v8, v9}, Ljava/nio/ByteBuffer;->limit(I)Ljava/nio/Buffer;
.line 765
iget-object v8, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->configData:Ljava/nio/ByteBuffer;
iget-object v9, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->outputBuffers:[Ljava/nio/ByteBuffer;
aget-object v9, v9, v2
invoke-virtual {v8, v9}, Ljava/nio/ByteBuffer;->put(Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;
.line 767
const-string v8, ""
.line 768
.local v8, "spsData":Ljava/lang/String;
const/4 v9, 0x0
.local v9, "i":I
:goto_6a
iget v10, v1, Landroid/media/MediaCodec$BufferInfo;->size:I
const/16 v11, 0x8
if-ge v10, v11, :cond_72
iget v11, v1, Landroid/media/MediaCodec$BufferInfo;->size:I
:cond_72
if-ge v9, v11, :cond_98
.line 769
new-instance v10, Ljava/lang/StringBuilder;
invoke-direct {v10}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v10, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v11, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->configData:Ljava/nio/ByteBuffer;
invoke-virtual {v11, v9}, Ljava/nio/ByteBuffer;->get(I)B
move-result v11
and-int/lit16 v11, v11, 0xff
invoke-static {v11}, Ljava/lang/Integer;->toHexString(I)Ljava/lang/String;
move-result-object v11
invoke-virtual {v10, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v11, " "
invoke-virtual {v10, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v10}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v10
move-object v8, v10
.line 768
add-int/lit8 v9, v9, 0x1
goto :goto_6a
.line 771
.end local v9 # "i":I
:cond_98
invoke-static {v0, v8}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 773
iget-object v9, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodec:Landroid/media/MediaCodec;
invoke-virtual {v9, v2, v6}, Landroid/media/MediaCodec;->releaseOutputBuffer(IZ)V
.line 775
iget-object v9, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodec:Landroid/media/MediaCodec;
invoke-virtual {v9, v1, v3, v4}, Landroid/media/MediaCodec;->dequeueOutputBuffer(Landroid/media/MediaCodec$BufferInfo;J)I
move-result v3
move v2, v3
move v8, v2
goto :goto_aa
.line 778
.end local v7 # "isConfigFrame":Z
.end local v8 # "spsData":Ljava/lang/String;
:cond_a9
move v8, v2
.end local v2 # "result":I
.local v8, "result":I
:goto_aa
if-ltz v8, :cond_145
.line 782
iget-object v2, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->outputBuffers:[Ljava/nio/ByteBuffer;
aget-object v2, v2, v8
invoke-virtual {v2}, Ljava/nio/ByteBuffer;->duplicate()Ljava/nio/ByteBuffer;
move-result-object v2
move-object v9, v2
.line 783
.local v9, "outputBuffer":Ljava/nio/ByteBuffer;
iget v2, v1, Landroid/media/MediaCodec$BufferInfo;->offset:I
invoke-virtual {v9, v2}, Ljava/nio/ByteBuffer;->position(I)Ljava/nio/Buffer;
.line 784
iget v2, v1, Landroid/media/MediaCodec$BufferInfo;->offset:I
iget v3, v1, Landroid/media/MediaCodec$BufferInfo;->size:I
add-int/2addr v2, v3
invoke-virtual {v9, v2}, Ljava/nio/ByteBuffer;->limit(I)Ljava/nio/Buffer;
.line 785
iget v2, v1, Landroid/media/MediaCodec$BufferInfo;->size:I
invoke-direct {p0, v2}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->reportEncodedFrame(I)V
.line 788
iget v2, v1, Landroid/media/MediaCodec$BufferInfo;->flags:I
and-int/2addr v2, v5
if-eqz v2, :cond_cd
goto :goto_ce
:cond_cd
const/4 v5, 0x0
:goto_ce
move v10, v5
.line 789
.local v10, "isKeyFrame":Z
if-eqz v10, :cond_d6
.line 790
const-string v2, "Sync frame generated"
invoke-static {v0, v2}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 792
:cond_d6
if-eqz v10, :cond_136
iget-object v2, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->type:Lorg/webrtc/ali/MediaCodecVideoEncoder$VideoCodecType;
sget-object v3, Lorg/webrtc/ali/MediaCodecVideoEncoder$VideoCodecType;->VIDEO_CODEC_H264:Lorg/webrtc/ali/MediaCodecVideoEncoder$VideoCodecType;
if-ne v2, v3, :cond_136
.line 793
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Appending config frame of size "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v3, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->configData:Ljava/nio/ByteBuffer;
invoke-virtual {v3}, Ljava/nio/ByteBuffer;->capacity()I
move-result v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v3, " to output buffer with offset "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v3, v1, Landroid/media/MediaCodec$BufferInfo;->offset:I
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v3, ", size "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v3, v1, Landroid/media/MediaCodec$BufferInfo;->size:I
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v0, v2}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 796
iget-object v2, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->configData:Ljava/nio/ByteBuffer;
invoke-virtual {v2}, Ljava/nio/ByteBuffer;->capacity()I
move-result v2
iget v3, v1, Landroid/media/MediaCodec$BufferInfo;->size:I
add-int/2addr v2, v3
invoke-static {v2}, Ljava/nio/ByteBuffer;->allocateDirect(I)Ljava/nio/ByteBuffer;
move-result-object v2
move-object v11, v2
.line 797
.local v11, "keyFrameBuffer":Ljava/nio/ByteBuffer;
iget-object v2, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->configData:Ljava/nio/ByteBuffer;
invoke-virtual {v2}, Ljava/nio/ByteBuffer;->rewind()Ljava/nio/Buffer;
.line 798
iget-object v2, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->configData:Ljava/nio/ByteBuffer;
invoke-virtual {v11, v2}, Ljava/nio/ByteBuffer;->put(Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;
.line 799
invoke-virtual {v11, v9}, Ljava/nio/ByteBuffer;->put(Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;
.line 800
invoke-virtual {v11, v6}, Ljava/nio/ByteBuffer;->position(I)Ljava/nio/Buffer;
.line 801
new-instance v12, Lorg/webrtc/ali/MediaCodecVideoEncoder$OutputBufferInfo;
iget-wide v6, v1, Landroid/media/MediaCodec$BufferInfo;->presentationTimeUs:J
move-object v2, v12
move v3, v8
move-object v4, v11
move v5, v10
invoke-direct/range {v2 .. v7}, Lorg/webrtc/ali/MediaCodecVideoEncoder$OutputBufferInfo;-><init>(ILjava/nio/ByteBuffer;ZJ)V
return-object v12
.line 803
.end local v11 # "keyFrameBuffer":Ljava/nio/ByteBuffer;
:cond_136
new-instance v11, Lorg/webrtc/ali/MediaCodecVideoEncoder$OutputBufferInfo;
.line 804
invoke-virtual {v9}, Ljava/nio/ByteBuffer;->slice()Ljava/nio/ByteBuffer;
move-result-object v4
iget-wide v6, v1, Landroid/media/MediaCodec$BufferInfo;->presentationTimeUs:J
move-object v2, v11
move v3, v8
move v5, v10
invoke-direct/range {v2 .. v7}, Lorg/webrtc/ali/MediaCodecVideoEncoder$OutputBufferInfo;-><init>(ILjava/nio/ByteBuffer;ZJ)V
.line 803
return-object v11
.line 806
.end local v9 # "outputBuffer":Ljava/nio/ByteBuffer;
.end local v10 # "isKeyFrame":Z
:cond_145
const/4 v2, -0x3
if-ne v8, v2, :cond_155
.line 807
iget-object v2, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodec:Landroid/media/MediaCodec;
invoke-virtual {v2}, Landroid/media/MediaCodec;->getOutputBuffers()[Ljava/nio/ByteBuffer;
move-result-object v2
iput-object v2, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->outputBuffers:[Ljava/nio/ByteBuffer;
.line 808
invoke-virtual {p0}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->dequeueOutputBuffer()Lorg/webrtc/ali/MediaCodecVideoEncoder$OutputBufferInfo;
move-result-object v0
return-object v0
.line 809
:cond_155
const/4 v2, -0x2
if-ne v8, v2, :cond_15d
.line 810
invoke-virtual {p0}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->dequeueOutputBuffer()Lorg/webrtc/ali/MediaCodecVideoEncoder$OutputBufferInfo;
move-result-object v0
return-object v0
.line 811
:cond_15d
const/4 v2, -0x1
if-ne v8, v2, :cond_162
.line 812
const/4 v0, 0x0
return-object v0
.line 814
:cond_162
new-instance v2, Ljava/lang/RuntimeException;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "dequeueOutputBuffer: "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v8}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-direct {v2, v3}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw v2
:try_end_179
.catch Ljava/lang/IllegalStateException; {:try_start_5 .. :try_end_179} :catch_179
.line 815
.end local v1 # "info":Landroid/media/MediaCodec$BufferInfo;
.end local v8 # "result":I
:catch_179
move-exception v1
.line 816
.local v1, "e":Ljava/lang/IllegalStateException;
const-string v2, "dequeueOutputBuffer failed"
invoke-static {v0, v2, v1}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 817
new-instance v0, Lorg/webrtc/ali/MediaCodecVideoEncoder$OutputBufferInfo;
const/4 v4, -0x1
const/4 v5, 0x0
const/4 v6, 0x0
const-wide/16 v7, -0x1
move-object v3, v0
invoke-direct/range {v3 .. v8}, Lorg/webrtc/ali/MediaCodecVideoEncoder$OutputBufferInfo;-><init>(ILjava/nio/ByteBuffer;ZJ)V
return-object v0
.end method
.method encodeBuffer(ZIIJ)Z
.registers 13
.param p1, "isKeyframe" # Z
.param p2, "inputBuffer" # I
.param p3, "size" # I
.param p4, "presentationTimestampUs" # J
.line 572
invoke-direct {p0}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->checkOnMediaCodecThread()V
.line 574
:try_start_3
invoke-virtual {p0, p1, p4, p5}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->checkKeyFrameRequired(ZJ)V
.line 575
iget-object v0, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodec:Landroid/media/MediaCodec;
const/4 v2, 0x0
const/4 v6, 0x0
move v1, p2
move v3, p3
move-wide v4, p4
invoke-virtual/range {v0 .. v6}, Landroid/media/MediaCodec;->queueInputBuffer(IIIJI)V
:try_end_10
.catch Ljava/lang/IllegalStateException; {:try_start_3 .. :try_end_10} :catch_12
.line 576
const/4 v0, 0x1
return v0
.line 577
:catch_12
move-exception v0
.line 578
.local v0, "e":Ljava/lang/IllegalStateException;
const-string v1, "MediaCodecVideoEncoder"
const-string v2, "encodeBuffer failed"
invoke-static {v1, v2, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 579
const/4 v1, 0x0
return v1
.end method
.method encodeTexture(ZI[FJ)Z
.registers 16
.param p1, "isKeyframe" # Z
.param p2, "oesTextureId" # I
.param p3, "transformationMatrix" # [F
.param p4, "presentationTimestampUs" # J
.line 585
invoke-direct {p0}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->checkOnMediaCodecThread()V
.line 587
:try_start_3
invoke-virtual {p0, p1, p4, p5}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->checkKeyFrameRequired(ZJ)V
.line 588
iget-object v0, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->eglBase:Lorg/webrtc/ali/EglBase14;
invoke-virtual {v0}, Lorg/webrtc/ali/EglBase14;->makeCurrent()V
.line 591
const/16 v0, 0x4000
invoke-static {v0}, Landroid/opengl/GLES20;->glClear(I)V
.line 592
iget-object v1, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->drawer:Lorg/webrtc/ali/GlRectDrawer;
iget v4, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->width:I
iget v5, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->height:I
const/4 v6, 0x0
const/4 v7, 0x0
iget v8, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->width:I
iget v9, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->height:I
move v2, p2
move-object v3, p3
invoke-virtual/range {v1 .. v9}, Lorg/webrtc/ali/GlRectDrawer;->drawOes(I[FIIIIII)V
.line 593
iget-object v0, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->eglBase:Lorg/webrtc/ali/EglBase14;
sget-object v1, Ljava/util/concurrent/TimeUnit;->MICROSECONDS:Ljava/util/concurrent/TimeUnit;
invoke-virtual {v1, p4, p5}, Ljava/util/concurrent/TimeUnit;->toNanos(J)J
move-result-wide v1
invoke-virtual {v0, v1, v2}, Lorg/webrtc/ali/EglBase14;->swapBuffers(J)V
:try_end_2c
.catch Ljava/lang/RuntimeException; {:try_start_3 .. :try_end_2c} :catch_2e
.line 594
const/4 v0, 0x1
return v0
.line 595
:catch_2e
move-exception v0
.line 596
.local v0, "e":Ljava/lang/RuntimeException;
const-string v1, "MediaCodecVideoEncoder"
const-string v2, "encodeTexture failed"
invoke-static {v1, v2, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 597
const/4 v1, 0x0
return v1
.end method
.method getInputBuffers()[Ljava/nio/ByteBuffer;
.registers 4
.line 538
iget-object v0, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodec:Landroid/media/MediaCodec;
invoke-virtual {v0}, Landroid/media/MediaCodec;->getInputBuffers()[Ljava/nio/ByteBuffer;
move-result-object v0
.line 539
.local v0, "inputBuffers":[Ljava/nio/ByteBuffer;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Input buffers: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
array-length v2, v0
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
const-string v2, "MediaCodecVideoEncoder"
invoke-static {v2, v1}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 540
return-object v0
.end method
.method initEncode(Lorg/webrtc/ali/MediaCodecVideoEncoder$VideoCodecType;IIIIILorg/webrtc/ali/EglBase14$Context;)Z
.registers 27
.param p1, "type" # Lorg/webrtc/ali/MediaCodecVideoEncoder$VideoCodecType;
.param p2, "profile" # I
.param p3, "width" # I
.param p4, "height" # I
.param p5, "kbps" # I
.param p6, "fps" # I
.param p7, "sharedContext" # Lorg/webrtc/ali/EglBase14$Context;
.line 420
move-object/from16 v1, p0
move-object/from16 v2, p1
move/from16 v3, p2
move/from16 v4, p3
move/from16 v5, p4
move/from16 v6, p5
move/from16 v0, p6
move-object/from16 v7, p7
if-eqz v7, :cond_14
const/4 v10, 0x1
goto :goto_15
:cond_14
const/4 v10, 0x0
.line 421
.local v10, "useSurface":Z
:goto_15
new-instance v11, Ljava/lang/StringBuilder;
invoke-direct {v11}, Ljava/lang/StringBuilder;-><init>()V
const-string v12, "Java initEncode: "
invoke-virtual {v11, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v11, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string v12, ". Profile: "
invoke-virtual {v11, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v11, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v12, " : "
invoke-virtual {v11, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v11, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v12, " x "
invoke-virtual {v11, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v11, v5}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v12, ". @ "
invoke-virtual {v11, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v11, v6}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v12, " kbps. Fps: "
invoke-virtual {v11, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v11, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v12, ". Encode from texture : "
invoke-virtual {v11, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v11, v10}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
invoke-virtual {v11}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v11
const-string v12, "MediaCodecVideoEncoder"
invoke-static {v12, v11}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 425
iput v3, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->profile:I
.line 426
iput v4, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->width:I
.line 427
iput v5, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->height:I
.line 428
iget-object v11, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodecThread:Ljava/lang/Thread;
if-nez v11, :cond_24d
.line 431
const/4 v11, 0x0
.line 432
.local v11, "properties":Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
const/4 v13, 0x0
.line 433
.local v13, "mime":Ljava/lang/String;
const/4 v14, 0x0
.line 434
.local v14, "keyFrameIntervalSec":I
const/4 v15, 0x0
.line 435
.local v15, "configureH264HighProfile":Z
sget-object v8, Lorg/webrtc/ali/MediaCodecVideoEncoder$VideoCodecType;->VIDEO_CODEC_VP8:Lorg/webrtc/ali/MediaCodecVideoEncoder$VideoCodecType;
if-ne v2, v8, :cond_88
.line 436
const-string v13, "video/x-vnd.on2.vp8"
.line 437
nop
.line 438
invoke-static {}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->vp8HwList()[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
move-result-object v8
if-eqz v10, :cond_79
sget-object v16, Lorg/webrtc/ali/MediaCodecVideoEncoder;->supportedSurfaceColorList:[I
goto :goto_7b
:cond_79
sget-object v16, Lorg/webrtc/ali/MediaCodecVideoEncoder;->supportedColorList:[I
:goto_7b
move-object/from16 v9, v16
.line 437
move-object/from16 v16, v11
.end local v11 # "properties":Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
.local v16, "properties":Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
const-string v11, "video/x-vnd.on2.vp8"
invoke-static {v11, v8, v9}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->findHwEncoder(Ljava/lang/String;[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;[I)Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
move-result-object v11
.line 439
.end local v16 # "properties":Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
.restart local v11 # "properties":Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
const/16 v14, 0x64
goto :goto_e3
.line 440
:cond_88
move-object/from16 v16, v11
.end local v11 # "properties":Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
.restart local v16 # "properties":Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
sget-object v8, Lorg/webrtc/ali/MediaCodecVideoEncoder$VideoCodecType;->VIDEO_CODEC_VP9:Lorg/webrtc/ali/MediaCodecVideoEncoder$VideoCodecType;
if-ne v2, v8, :cond_a2
.line 441
const-string v13, "video/x-vnd.on2.vp9"
.line 442
sget-object v8, Lorg/webrtc/ali/MediaCodecVideoEncoder;->vp9HwList:[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
if-eqz v10, :cond_97
sget-object v9, Lorg/webrtc/ali/MediaCodecVideoEncoder;->supportedSurfaceColorList:[I
goto :goto_99
:cond_97
sget-object v9, Lorg/webrtc/ali/MediaCodecVideoEncoder;->supportedColorList:[I
:goto_99
const-string v11, "video/x-vnd.on2.vp9"
invoke-static {v11, v8, v9}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->findHwEncoder(Ljava/lang/String;[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;[I)Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
move-result-object v11
.line 444
.end local v16 # "properties":Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
.restart local v11 # "properties":Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
const/16 v14, 0x64
goto :goto_e3
.line 445
.end local v11 # "properties":Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
.restart local v16 # "properties":Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
:cond_a2
sget-object v8, Lorg/webrtc/ali/MediaCodecVideoEncoder$VideoCodecType;->VIDEO_CODEC_H264:Lorg/webrtc/ali/MediaCodecVideoEncoder$VideoCodecType;
if-ne v2, v8, :cond_e1
.line 446
const-string v13, "video/avc"
.line 447
sget-object v8, Lorg/webrtc/ali/MediaCodecVideoEncoder;->h264HwList:[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
if-eqz v10, :cond_af
sget-object v9, Lorg/webrtc/ali/MediaCodecVideoEncoder;->supportedSurfaceColorList:[I
goto :goto_b1
:cond_af
sget-object v9, Lorg/webrtc/ali/MediaCodecVideoEncoder;->supportedColorList:[I
:goto_b1
const-string v11, "video/avc"
invoke-static {v11, v8, v9}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->findHwEncoder(Ljava/lang/String;[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;[I)Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
move-result-object v8
.line 449
.end local v16 # "properties":Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
.local v8, "properties":Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
sget-object v9, Lorg/webrtc/ali/MediaCodecVideoEncoder$H264Profile;->CONSTRAINED_HIGH:Lorg/webrtc/ali/MediaCodecVideoEncoder$H264Profile;
invoke-virtual {v9}, Lorg/webrtc/ali/MediaCodecVideoEncoder$H264Profile;->getValue()I
move-result v9
if-ne v3, v9, :cond_dd
.line 450
sget-object v9, Lorg/webrtc/ali/MediaCodecVideoEncoder;->h264HighProfileHwList:[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
if-eqz v10, :cond_c6
sget-object v16, Lorg/webrtc/ali/MediaCodecVideoEncoder;->supportedSurfaceColorList:[I
goto :goto_c8
:cond_c6
sget-object v16, Lorg/webrtc/ali/MediaCodecVideoEncoder;->supportedColorList:[I
:goto_c8
move-object/from16 v3, v16
invoke-static {v11, v9, v3}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->findHwEncoder(Ljava/lang/String;[Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;[I)Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
move-result-object v3
.line 452
.local v3, "h264HighProfileProperties":Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
if-eqz v3, :cond_d8
.line 453
const-string v9, "High profile H.264 encoder supported."
invoke-static {v12, v9}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 454
const/4 v9, 0x1
move v15, v9
.end local v15 # "configureH264HighProfile":Z
.local v9, "configureH264HighProfile":Z
goto :goto_dd
.line 456
.end local v9 # "configureH264HighProfile":Z
.restart local v15 # "configureH264HighProfile":Z
:cond_d8
const-string v9, "High profile H.264 encoder requested, but not supported. Use baseline."
invoke-static {v12, v9}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 459
.end local v3 # "h264HighProfileProperties":Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
:cond_dd
:goto_dd
const/16 v14, 0x14
move-object v11, v8
goto :goto_e3
.line 445
.end local v8 # "properties":Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
.restart local v16 # "properties":Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
:cond_e1
move-object/from16 v11, v16
.line 461
.end local v16 # "properties":Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
.restart local v11 # "properties":Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
:goto_e3
if-eqz v11, :cond_236
.line 464
sput-object v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->runningInstance:Lorg/webrtc/ali/MediaCodecVideoEncoder;
.line 465
iget v3, v11, Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;->colorFormat:I
iput v3, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->colorFormat:I
.line 466
iget-object v3, v11, Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;->bitrateAdjustmentType:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
iput-object v3, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAdjustmentType:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
.line 467
sget-object v8, Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;->FRAMERATE_ADJUSTMENT:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
if-ne v3, v8, :cond_f7
.line 468
const/16 v0, 0x1e
move v3, v0
.end local p6 # "fps":I
.local v0, "fps":I
goto :goto_fe
.line 470
.end local v0 # "fps":I
.restart local p6 # "fps":I
:cond_f7
const/16 v3, 0x1e
invoke-static {v0, v3}, Ljava/lang/Math;->min(II)I
move-result v0
move v3, v0
.line 473
.end local p6 # "fps":I
.local v3, "fps":I
:goto_fe
const-wide/16 v8, 0x0
iput-wide v8, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->forcedKeyFrameMs:J
.line 474
const-wide/16 v8, -0x1
iput-wide v8, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->lastKeyFrameMs:J
.line 475
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder$VideoCodecType;->VIDEO_CODEC_VP8:Lorg/webrtc/ali/MediaCodecVideoEncoder$VideoCodecType;
if-ne v2, v0, :cond_13f
iget-object v0, v11, Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;->codecName:Ljava/lang/String;
sget-object v8, Lorg/webrtc/ali/MediaCodecVideoEncoder;->qcomVp8HwProperties:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;
iget-object v8, v8, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecProperties;->codecPrefix:Ljava/lang/String;
.line 476
invoke-virtual {v0, v8}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_13c
.line 477
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v8, 0x15
move/from16 v16, v10
.end local v10 # "useSurface":Z
.local v16, "useSurface":Z
const-wide/16 v9, 0x3a98
if-eq v0, v8, :cond_139
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v8, 0x16
if-ne v0, v8, :cond_127
goto :goto_139
.line 480
:cond_127
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v8, 0x17
if-ne v0, v8, :cond_132
.line 481
const-wide/16 v8, 0x4e20
iput-wide v8, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->forcedKeyFrameMs:J
goto :goto_141
.line 482
:cond_132
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
if-le v0, v8, :cond_141
.line 483
iput-wide v9, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->forcedKeyFrameMs:J
goto :goto_141
.line 479
:cond_139
:goto_139
iput-wide v9, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->forcedKeyFrameMs:J
goto :goto_141
.line 476
.end local v16 # "useSurface":Z
.restart local v10 # "useSurface":Z
:cond_13c
move/from16 v16, v10
.end local v10 # "useSurface":Z
.restart local v16 # "useSurface":Z
goto :goto_141
.line 475
.end local v16 # "useSurface":Z
.restart local v10 # "useSurface":Z
:cond_13f
move/from16 v16, v10
.line 487
.end local v10 # "useSurface":Z
.restart local v16 # "useSurface":Z
:cond_141
:goto_141
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v8, "Color format: "
invoke-virtual {v0, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v8, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->colorFormat:I
invoke-virtual {v0, v8}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v8, ". Bitrate adjustment: "
invoke-virtual {v0, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v8, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAdjustmentType:Lorg/webrtc/ali/MediaCodecVideoEncoder$BitrateAdjustmentType;
invoke-virtual {v0, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string v8, ". Key frame interval: "
invoke-virtual {v0, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-wide v8, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->forcedKeyFrameMs:J
invoke-virtual {v0, v8, v9}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
const-string v8, " . Initial fps: "
invoke-virtual {v0, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v12, v0}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 489
mul-int/lit16 v0, v6, 0x3e8
iput v0, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->targetBitrateBps:I
.line 490
iput v3, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->targetFps:I
.line 491
int-to-double v8, v0
const-wide/high16 v17, 0x4020000000000000L # 8.0
invoke-static {v8, v9}, Ljava/lang/Double;->isNaN(D)Z
div-double v8, v8, v17
iput-wide v8, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAccumulatorMax:D
.line 492
const-wide/16 v8, 0x0
iput-wide v8, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAccumulator:D
.line 493
iput-wide v8, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateObservationTimeMs:D
.line 494
const/4 v8, 0x0
iput v8, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->bitrateAdjustmentScaleExp:I
.line 496
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v0
iput-object v0, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodecThread:Ljava/lang/Thread;
.line 498
:try_start_192
invoke-static {v13, v4, v5}, Landroid/media/MediaFormat;->createVideoFormat(Ljava/lang/String;II)Landroid/media/MediaFormat;
move-result-object v0
.line 499
.local v0, "format":Landroid/media/MediaFormat;
const-string v8, "bitrate"
iget v9, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->targetBitrateBps:I
invoke-virtual {v0, v8, v9}, Landroid/media/MediaFormat;->setInteger(Ljava/lang/String;I)V
.line 500
const-string v8, "bitrate-mode"
const/4 v9, 0x2
invoke-virtual {v0, v8, v9}, Landroid/media/MediaFormat;->setInteger(Ljava/lang/String;I)V
.line 501
const-string v8, "color-format"
iget v9, v11, Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;->colorFormat:I
invoke-virtual {v0, v8, v9}, Landroid/media/MediaFormat;->setInteger(Ljava/lang/String;I)V
.line 502
const-string v8, "frame-rate"
iget v9, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->targetFps:I
invoke-virtual {v0, v8, v9}, Landroid/media/MediaFormat;->setInteger(Ljava/lang/String;I)V
.line 503
const-string v8, "i-frame-interval"
invoke-virtual {v0, v8, v14}, Landroid/media/MediaFormat;->setInteger(Ljava/lang/String;I)V
.line 508
new-instance v8, Ljava/lang/StringBuilder;
invoke-direct {v8}, Ljava/lang/StringBuilder;-><init>()V
const-string v9, " Format: "
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v8, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v8
invoke-static {v12, v8}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 509
iget-object v8, v11, Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;->codecName:Ljava/lang/String;
invoke-static {v8}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->createByCodecName(Ljava/lang/String;)Landroid/media/MediaCodec;
move-result-object v8
iput-object v8, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodec:Landroid/media/MediaCodec;
.line 510
iput-object v2, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->type:Lorg/webrtc/ali/MediaCodecVideoEncoder$VideoCodecType;
.line 511
if-nez v8, :cond_1e0
.line 512
const-string v8, "Can not create media encoder"
invoke-static {v12, v8}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V
.line 513
invoke-virtual/range {p0 .. p0}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->release()V
.line 514
const/4 v8, 0x0
return v8
.line 516
:cond_1e0
const/4 v9, 0x0
const/4 v10, 0x1
invoke-virtual {v8, v0, v9, v9, v10}, Landroid/media/MediaCodec;->configure(Landroid/media/MediaFormat;Landroid/view/Surface;Landroid/media/MediaCrypto;I)V
.line 518
if-eqz v16, :cond_204
.line 519
new-instance v8, Lorg/webrtc/ali/EglBase14;
sget-object v9, Lorg/webrtc/ali/EglBase;->CONFIG_RECORDABLE:[I
invoke-direct {v8, v7, v9}, Lorg/webrtc/ali/EglBase14;-><init>(Lorg/webrtc/ali/EglBase14$Context;[I)V
iput-object v8, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->eglBase:Lorg/webrtc/ali/EglBase14;
.line 521
iget-object v8, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodec:Landroid/media/MediaCodec;
invoke-virtual {v8}, Landroid/media/MediaCodec;->createInputSurface()Landroid/view/Surface;
move-result-object v8
iput-object v8, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->inputSurface:Landroid/view/Surface;
.line 522
iget-object v9, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->eglBase:Lorg/webrtc/ali/EglBase14;
invoke-virtual {v9, v8}, Lorg/webrtc/ali/EglBase14;->createSurface(Landroid/view/Surface;)V
.line 523
new-instance v8, Lorg/webrtc/ali/GlRectDrawer;
invoke-direct {v8}, Lorg/webrtc/ali/GlRectDrawer;-><init>()V
iput-object v8, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->drawer:Lorg/webrtc/ali/GlRectDrawer;
.line 525
:cond_204
iget-object v8, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodec:Landroid/media/MediaCodec;
invoke-virtual {v8}, Landroid/media/MediaCodec;->start()V
.line 526
iget-object v8, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodec:Landroid/media/MediaCodec;
invoke-virtual {v8}, Landroid/media/MediaCodec;->getOutputBuffers()[Ljava/nio/ByteBuffer;
move-result-object v8
iput-object v8, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->outputBuffers:[Ljava/nio/ByteBuffer;
.line 527
new-instance v8, Ljava/lang/StringBuilder;
invoke-direct {v8}, Ljava/lang/StringBuilder;-><init>()V
const-string v9, "Output buffers: "
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v9, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder;->outputBuffers:[Ljava/nio/ByteBuffer;
array-length v9, v9
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v8
invoke-static {v12, v8}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
:try_end_228
.catch Ljava/lang/IllegalStateException; {:try_start_192 .. :try_end_228} :catch_22b
.line 533
.end local v0 # "format":Landroid/media/MediaFormat;
nop
.line 534
const/4 v0, 0x1
return v0
.line 529
:catch_22b
move-exception v0
.line 530
.local v0, "e":Ljava/lang/IllegalStateException;
const-string v8, "initEncode failed"
invoke-static {v12, v8, v0}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 531
invoke-virtual/range {p0 .. p0}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->release()V
.line 532
const/4 v8, 0x0
return v8
.line 462
.end local v0 # "e":Ljava/lang/IllegalStateException;
.end local v3 # "fps":I
.end local v16 # "useSurface":Z
.restart local v10 # "useSurface":Z
.restart local p6 # "fps":I
:cond_236
new-instance v3, Ljava/lang/RuntimeException;
new-instance v8, Ljava/lang/StringBuilder;
invoke-direct {v8}, Ljava/lang/StringBuilder;-><init>()V
const-string v9, "Can not find HW encoder for "
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v8, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v8
invoke-direct {v3, v8}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw v3
.line 429
.end local v11 # "properties":Lorg/webrtc/ali/MediaCodecVideoEncoder$EncoderProperties;
.end local v13 # "mime":Ljava/lang/String;
.end local v14 # "keyFrameIntervalSec":I
.end local v15 # "configureH264HighProfile":Z
:cond_24d
new-instance v3, Ljava/lang/RuntimeException;
const-string v8, "Forgot to release()?"
invoke-direct {v3, v8}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw v3
.end method
.method release()V
.registers 10
.line 602
const-string v0, "MediaCodecVideoEncoder"
const-string v1, "Java releaseEncoder"
invoke-static {v0, v1}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 603
invoke-direct {p0}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->checkOnMediaCodecThread()V
.line 608
new-instance v1, Lorg/webrtc/ali/MediaCodecVideoEncoder$1CaughtException;
invoke-direct {v1, p0}, Lorg/webrtc/ali/MediaCodecVideoEncoder$1CaughtException;-><init>(Lorg/webrtc/ali/MediaCodecVideoEncoder;)V
.line 609
.local v1, "caughtException":Lorg/webrtc/ali/MediaCodecVideoEncoder$1CaughtException;
const/4 v2, 0x0
.line 611
.local v2, "stopHung":Z
iget-object v3, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodec:Landroid/media/MediaCodec;
const/4 v4, 0x1
const/4 v5, 0x0
if-eqz v3, :cond_38
.line 614
new-instance v3, Ljava/util/concurrent/CountDownLatch;
invoke-direct {v3, v4}, Ljava/util/concurrent/CountDownLatch;-><init>(I)V
.line 616
.local v3, "releaseDone":Ljava/util/concurrent/CountDownLatch;
new-instance v6, Lorg/webrtc/ali/MediaCodecVideoEncoder$1;
invoke-direct {v6, p0, v1, v3}, Lorg/webrtc/ali/MediaCodecVideoEncoder$1;-><init>(Lorg/webrtc/ali/MediaCodecVideoEncoder;Lorg/webrtc/ali/MediaCodecVideoEncoder$1CaughtException;Ljava/util/concurrent/CountDownLatch;)V
.line 636
.local v6, "runMediaCodecRelease":Ljava/lang/Runnable;
new-instance v7, Ljava/lang/Thread;
invoke-direct {v7, v6}, Ljava/lang/Thread;-><init>(Ljava/lang/Runnable;)V
invoke-virtual {v7}, Ljava/lang/Thread;->start()V
.line 638
const-wide/16 v7, 0x1388
invoke-static {v3, v7, v8}, Lorg/webrtc/ali/ThreadUtils;->awaitUninterruptibly(Ljava/util/concurrent/CountDownLatch;J)Z
move-result v7
if-nez v7, :cond_36
.line 639
const-string v7, "Media encoder release timeout"
invoke-static {v0, v7}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V
.line 640
const/4 v2, 0x1
.line 643
:cond_36
iput-object v5, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodec:Landroid/media/MediaCodec;
.line 646
.end local v3 # "releaseDone":Ljava/util/concurrent/CountDownLatch;
.end local v6 # "runMediaCodecRelease":Ljava/lang/Runnable;
:cond_38
iput-object v5, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodecThread:Ljava/lang/Thread;
.line 647
iget-object v3, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->drawer:Lorg/webrtc/ali/GlRectDrawer;
if-eqz v3, :cond_43
.line 648
invoke-virtual {v3}, Lorg/webrtc/ali/GlRectDrawer;->release()V
.line 649
iput-object v5, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->drawer:Lorg/webrtc/ali/GlRectDrawer;
.line 651
:cond_43
iget-object v3, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->eglBase:Lorg/webrtc/ali/EglBase14;
if-eqz v3, :cond_4c
.line 652
invoke-virtual {v3}, Lorg/webrtc/ali/EglBase14;->release()V
.line 653
iput-object v5, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->eglBase:Lorg/webrtc/ali/EglBase14;
.line 655
:cond_4c
iget-object v3, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->inputSurface:Landroid/view/Surface;
if-eqz v3, :cond_55
.line 656
invoke-virtual {v3}, Landroid/view/Surface;->release()V
.line 657
iput-object v5, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->inputSurface:Landroid/view/Surface;
.line 659
:cond_55
sput-object v5, Lorg/webrtc/ali/MediaCodecVideoEncoder;->runningInstance:Lorg/webrtc/ali/MediaCodecVideoEncoder;
.line 661
if-eqz v2, :cond_87
.line 662
sget v3, Lorg/webrtc/ali/MediaCodecVideoEncoder;->codecErrors:I
add-int/2addr v3, v4
sput v3, Lorg/webrtc/ali/MediaCodecVideoEncoder;->codecErrors:I
.line 663
sget-object v3, Lorg/webrtc/ali/MediaCodecVideoEncoder;->errorCallback:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecVideoEncoderErrorCallback;
if-eqz v3, :cond_7f
.line 664
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "Invoke codec error callback. Errors: "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget v4, Lorg/webrtc/ali/MediaCodecVideoEncoder;->codecErrors:I
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v0, v3}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V
.line 665
sget-object v0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->errorCallback:Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecVideoEncoderErrorCallback;
sget v3, Lorg/webrtc/ali/MediaCodecVideoEncoder;->codecErrors:I
invoke-interface {v0, v3}, Lorg/webrtc/ali/MediaCodecVideoEncoder$MediaCodecVideoEncoderErrorCallback;->onMediaCodecVideoEncoderCriticalError(I)V
.line 667
:cond_7f
new-instance v0, Ljava/lang/RuntimeException;
const-string v3, "Media encoder release timeout."
invoke-direct {v0, v3}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw v0
.line 672
:cond_87
iget-object v3, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder$1CaughtException;->e:Ljava/lang/Exception;
if-nez v3, :cond_91
.line 679
const-string v3, "Java releaseEncoder done"
invoke-static {v0, v3}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 680
return-void
.line 673
:cond_91
new-instance v0, Ljava/lang/RuntimeException;
iget-object v3, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder$1CaughtException;->e:Ljava/lang/Exception;
invoke-direct {v0, v3}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/Throwable;)V
.line 674
.local v0, "runtimeException":Ljava/lang/RuntimeException;
iget-object v3, v1, Lorg/webrtc/ali/MediaCodecVideoEncoder$1CaughtException;->e:Ljava/lang/Exception;
.line 675
invoke-virtual {v3}, Ljava/lang/Exception;->getStackTrace()[Ljava/lang/StackTraceElement;
move-result-object v3
invoke-virtual {v0}, Ljava/lang/RuntimeException;->getStackTrace()[Ljava/lang/StackTraceElement;
move-result-object v4
.line 674
invoke-static {v3, v4}, Lorg/webrtc/ali/ThreadUtils;->concatStackTraces([Ljava/lang/StackTraceElement;[Ljava/lang/StackTraceElement;)[Ljava/lang/StackTraceElement;
move-result-object v3
invoke-virtual {v0, v3}, Ljava/lang/RuntimeException;->setStackTrace([Ljava/lang/StackTraceElement;)V
.line 676
throw v0
.end method
.method releaseOutputBuffer(I)Z
.registers 6
.param p1, "index" # I
.line 875
invoke-direct {p0}, Lorg/webrtc/ali/MediaCodecVideoEncoder;->checkOnMediaCodecThread()V
.line 877
const/4 v0, 0x0
:try_start_4
iget-object v1, p0, Lorg/webrtc/ali/MediaCodecVideoEncoder;->mediaCodec:Landroid/media/MediaCodec;
invoke-virtual {v1, p1, v0}, Landroid/media/MediaCodec;->releaseOutputBuffer(IZ)V
:try_end_9
.catch Ljava/lang/IllegalStateException; {:try_start_4 .. :try_end_9} :catch_b
.line 878
const/4 v0, 0x1
return v0
.line 879
:catch_b
move-exception v1
.line 880
.local v1, "e":Ljava/lang/IllegalStateException;
const-string v2, "MediaCodecVideoEncoder"
const-string v3, "releaseOutputBuffer failed"
invoke-static {v2, v3, v1}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 881
return v0
.end method