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